1 | import { PureComponent, Validator, Requireable } from 'react';
|
2 | import * as PropTypes from 'prop-types';
|
3 | import { RenderedSection } from './Grid';
|
4 |
|
5 | export type OnSectionRenderedParams = RenderedSection;
|
6 |
|
7 | export type ChildProps = {
|
8 | onSectionRendered: (params: RenderedSection) => void;
|
9 | scrollToColumn: number;
|
10 | scrollToRow: number;
|
11 | };
|
12 |
|
13 |
|
14 |
|
15 | export type ArrowKeyStepperProps = {
|
16 | children: (props: ChildProps) => React.ReactNode;
|
17 | className?: string;
|
18 | columnCount: number;
|
19 | rowCount: number;
|
20 | mode?: 'edges' | 'cells';
|
21 | disabled?: boolean;
|
22 | isControlled?: boolean;
|
23 | onScrollToChange?: (params: ScrollIndices) => void;
|
24 | scrollToColumn?: number;
|
25 | scrollToRow?: number;
|
26 | |
27 |
|
28 |
|
29 |
|
30 |
|
31 |
|
32 |
|
33 | [key: string]: any;
|
34 | };
|
35 | export type ScrollIndices = {
|
36 | scrollToRow: number;
|
37 | scrollToColumn: number;
|
38 | };
|
39 |
|
40 | export type ScrollIndexes = ScrollIndices;
|
41 |
|
42 | export class ArrowKeyStepper extends PureComponent<ArrowKeyStepperProps, ScrollIndices> {
|
43 | static defaultProps: {
|
44 | disabled: false;
|
45 | isControlled: false;
|
46 | mode: 'edges';
|
47 | scrollToColumn: 0;
|
48 | scrollToRow: 0;
|
49 | };
|
50 | }
|
51 |
|
52 | export default ArrowKeyStepper;
|