-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathekko.js.flow
More file actions
70 lines (53 loc) · 1.56 KB
/
ekko.js.flow
File metadata and controls
70 lines (53 loc) · 1.56 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
/* @flow */
import * as React from 'react';
export type EditorRender = (props: {
value: mixed,
onUpdate: (newValue: mixed) => mixed,
onCancel: () => mixed,
}) => React.Element<any>;
export type CellUpdater = (value: mixed, rowDate: mixed) => mixed;
export type EditorDisplay = 'popover' | 'dialog';
export type Column = {
+name: string,
+label?: string,
+getter: (rowData: mixed) => mixed,
+render?: (value: mixed) => React$Node,
+updater?: CellUpdater,
+editor?: EditorRender | 'inline',
+editorDisplay?: EditorDisplay,
+sortable?: boolean | ((value: mixed) => boolean),
};
export type CellProps = {
+value: mixed,
+render: $PropertyType<Column, 'render'>,
+updater: $PropertyType<Column, 'updater'>,
+editor: $PropertyType<Column, 'editor'>,
+editorDisplay: $PropertyType<Column, 'editorDisplay'>,
+onCellUpdate: (value: mixed, updater: CellUpdater) => mixed,
};
export type CellState = {|
isEditing: boolean,
menuPostion: { x: number, y: number } | null,
previousValue: mixed,
|};
export type RowChangeHandler = (id: string, newData: mixed) => mixed;
export type RowProps = {|
+id: string,
+onRowChange?: RowChangeHandler,
+data: mixed,
+columns: Column[],
|};
export type SortOrder = 'asc' | 'desc' | 'none';
export type GridData = { [string]: mixed };
export type GridProps = {
+data: GridData,
+onRowChange?: RowChangeHandler,
+columns: Column[],
};
export type GridState = {|
sortIndex: number,
sortOrder: SortOrder,
|};
declare module 'ekko' {
declare export class Grid extends React.Component<GridProps> {}
}