@lemon-fe/kits 1.0.0-52 → 1.0.0-54

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (61) hide show
  1. package/es/components/DataGrid/hooks.d.ts +13 -1
  2. package/es/components/DataGrid/hooks.js +13 -3
  3. package/es/components/DataGrid/index.d.ts +2 -3
  4. package/es/components/DataGrid/index.js +12 -17
  5. package/es/components/DataGrid/renderer/CellIndexRenderer.js +1 -1
  6. package/es/components/DataGrid/typings.d.ts +1 -1
  7. package/es/components/DurationPicker/index.d.ts +5 -5
  8. package/es/components/DurationPicker/index.js +18 -15
  9. package/es/components/Popup/index.js +1 -0
  10. package/es/index.d.ts +1 -0
  11. package/package.json +1 -1
  12. package/es/components/DataGrid/modules/client-side-row-model/clientSideRowModel/clientSideNodeManager.d.ts +0 -35
  13. package/es/components/DataGrid/modules/client-side-row-model/clientSideRowModel/clientSideNodeManager.js +0 -378
  14. package/es/components/DataGrid/modules/client-side-row-model/clientSideRowModel/clientSideRowModel.d.ts +0 -99
  15. package/es/components/DataGrid/modules/client-side-row-model/clientSideRowModel/clientSideRowModel.js +0 -1160
  16. package/es/components/DataGrid/modules/client-side-row-model/clientSideRowModel/filterService.d.ts +0 -7
  17. package/es/components/DataGrid/modules/client-side-row-model/clientSideRowModel/filterService.js +0 -137
  18. package/es/components/DataGrid/modules/client-side-row-model/clientSideRowModel/filterStage.d.ts +0 -5
  19. package/es/components/DataGrid/modules/client-side-row-model/clientSideRowModel/filterStage.js +0 -60
  20. package/es/components/DataGrid/modules/client-side-row-model/clientSideRowModel/flattenStage.d.ts +0 -10
  21. package/es/components/DataGrid/modules/client-side-row-model/clientSideRowModel/flattenStage.js +0 -199
  22. package/es/components/DataGrid/modules/client-side-row-model/clientSideRowModel/immutableService.d.ts +0 -13
  23. package/es/components/DataGrid/modules/client-side-row-model/clientSideRowModel/immutableService.js +0 -175
  24. package/es/components/DataGrid/modules/client-side-row-model/clientSideRowModel/sortService.d.ts +0 -14
  25. package/es/components/DataGrid/modules/client-side-row-model/clientSideRowModel/sortService.js +0 -330
  26. package/es/components/DataGrid/modules/client-side-row-model/clientSideRowModel/sortStage.d.ts +0 -7
  27. package/es/components/DataGrid/modules/client-side-row-model/clientSideRowModel/sortStage.js +0 -75
  28. package/es/components/DataGrid/modules/client-side-row-model/clientSideRowModelModule.d.ts +0 -2
  29. package/es/components/DataGrid/modules/client-side-row-model/clientSideRowModelModule.js +0 -15
  30. package/es/components/DataGrid/modules/client-side-row-model/index.d.ts +0 -1
  31. package/es/components/DataGrid/modules/client-side-row-model/index.js +0 -1
  32. package/es/components/DataGrid/modules/server-side-row-model/index.d.ts +0 -1
  33. package/es/components/DataGrid/modules/server-side-row-model/index.js +0 -1
  34. package/es/components/DataGrid/modules/server-side-row-model/serverSideRowModel/blocks/blockUtils.d.ts +0 -47
  35. package/es/components/DataGrid/modules/server-side-row-model/serverSideRowModel/blocks/blockUtils.js +0 -444
  36. package/es/components/DataGrid/modules/server-side-row-model/serverSideRowModel/blocks/infiniteStoreBlock.d.ts +0 -92
  37. package/es/components/DataGrid/modules/server-side-row-model/serverSideRowModel/blocks/infiniteStoreBlock.js +0 -510
  38. package/es/components/DataGrid/modules/server-side-row-model/serverSideRowModel/listeners/expandListener.d.ts +0 -9
  39. package/es/components/DataGrid/modules/server-side-row-model/serverSideRowModel/listeners/expandListener.js +0 -115
  40. package/es/components/DataGrid/modules/server-side-row-model/serverSideRowModel/listeners/filterListener.d.ts +0 -9
  41. package/es/components/DataGrid/modules/server-side-row-model/serverSideRowModel/listeners/filterListener.js +0 -114
  42. package/es/components/DataGrid/modules/server-side-row-model/serverSideRowModel/listeners/listenerUtils.d.ts +0 -5
  43. package/es/components/DataGrid/modules/server-side-row-model/serverSideRowModel/listeners/listenerUtils.js +0 -68
  44. package/es/components/DataGrid/modules/server-side-row-model/serverSideRowModel/listeners/sortListener.d.ts +0 -13
  45. package/es/components/DataGrid/modules/server-side-row-model/serverSideRowModel/listeners/sortListener.js +0 -194
  46. package/es/components/DataGrid/modules/server-side-row-model/serverSideRowModel/nodeManager.d.ts +0 -7
  47. package/es/components/DataGrid/modules/server-side-row-model/serverSideRowModel/nodeManager.js +0 -63
  48. package/es/components/DataGrid/modules/server-side-row-model/serverSideRowModel/serverSideRowModel.d.ts +0 -88
  49. package/es/components/DataGrid/modules/server-side-row-model/serverSideRowModel/serverSideRowModel.js +0 -572
  50. package/es/components/DataGrid/modules/server-side-row-model/serverSideRowModel/stores/fullStore.d.ts +0 -108
  51. package/es/components/DataGrid/modules/server-side-row-model/serverSideRowModel/stores/fullStore.js +0 -876
  52. package/es/components/DataGrid/modules/server-side-row-model/serverSideRowModel/stores/infiniteStore.d.ts +0 -102
  53. package/es/components/DataGrid/modules/server-side-row-model/serverSideRowModel/stores/infiniteStore.js +0 -918
  54. package/es/components/DataGrid/modules/server-side-row-model/serverSideRowModel/stores/storeFactory.d.ts +0 -12
  55. package/es/components/DataGrid/modules/server-side-row-model/serverSideRowModel/stores/storeFactory.js +0 -141
  56. package/es/components/DataGrid/modules/server-side-row-model/serverSideRowModel/stores/storeUtils.d.ts +0 -35
  57. package/es/components/DataGrid/modules/server-side-row-model/serverSideRowModel/stores/storeUtils.js +0 -154
  58. package/es/components/DataGrid/modules/server-side-row-model/serverSideRowModel/transactionManager.d.ts +0 -23
  59. package/es/components/DataGrid/modules/server-side-row-model/serverSideRowModel/transactionManager.js +0 -210
  60. package/es/components/DataGrid/modules/server-side-row-model/serverSideRowModelModule.d.ts +0 -18
  61. package/es/components/DataGrid/modules/server-side-row-model/serverSideRowModelModule.js +0 -18
@@ -2,7 +2,19 @@
2
2
  import type { GridStore } from './typings';
3
3
  import type DataGrid from './';
4
4
  export declare function useGridStore<T>(getter: (state: GridStore) => T): T;
5
+ interface UseGrid<TData> {
6
+ /**
7
+ * @param 执行函数
8
+ */
9
+ <T>(cb: (curr: DataGrid<TData>) => T): T;
10
+ /**
11
+ * @param 执行函数
12
+ * @param isAsync 是否启用异步形式
13
+ */
14
+ (cb: (curr: DataGrid<TData>) => void, isAsync?: boolean): void;
15
+ }
5
16
  export declare function useDataGrid<TData>(): {
6
17
  ref: import("react").RefObject<DataGrid<TData>>;
7
- use: (cb: (current: DataGrid<TData>) => void) => void;
18
+ use: UseGrid<TData>;
8
19
  };
20
+ export {};
@@ -10,7 +10,7 @@ function _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Sy
10
10
 
11
11
  function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
12
12
 
13
- import { useCallback, useContext, useEffect, useMemo, useRef, useState } from 'react';
13
+ import { useContext, useEffect, useMemo, useRef, useState } from 'react';
14
14
  import shallowEqual from 'shallowequal';
15
15
  import GridStoreContext from "./context/GridStore";
16
16
  export function useGridStore(getter) {
@@ -52,7 +52,16 @@ export function useDataGrid() {
52
52
  mounted.current = false;
53
53
  };
54
54
  }, []);
55
- var use = useCallback(function (cb) {
55
+
56
+ var use = function use(cb, isAsync) {
57
+ if (!isAsync) {
58
+ if (ref.current === null || !ref.current.ready()) {
59
+ throw new Error('Grid尚未初始化,请使用异步形式');
60
+ }
61
+
62
+ return cb(ref.current);
63
+ }
64
+
56
65
  if (ref.current !== null) {
57
66
  var grid = ref.current;
58
67
 
@@ -68,7 +77,8 @@ export function useDataGrid() {
68
77
 
69
78
  delay();
70
79
  }
71
- }, []);
80
+ };
81
+
72
82
  return useMemo(function () {
73
83
  return {
74
84
  ref: ref,
@@ -46,13 +46,13 @@ export default class DataGrid<TData> extends Component<DataGridProps<TData>, Dat
46
46
  Text: React.ForwardRefExoticComponent<import("@ag-grid-community/core").ICellEditorParams<any, any> & import("./typings").TextEditorParams & React.RefAttributes<import("@ag-grid-community/react").ICellEditorReactComp>>;
47
47
  Date: React.ForwardRefExoticComponent<import("@ag-grid-community/core").ICellEditorParams<any, any> & import("./typings").DateEditorParams & React.RefAttributes<import("@ag-grid-community/react").ICellEditorReactComp>>;
48
48
  Number: React.ForwardRefExoticComponent<import("@ag-grid-community/core").ICellEditorParams<any, any> & import("./typings").NumberEditorParams & React.RefAttributes<import("@ag-grid-community/react").ICellEditorReactComp>>;
49
- Select: React.ForwardRefExoticComponent<import("@ag-grid-community/core").ICellEditorParams<any, any> & Pick<import("antd").SelectProps<any, import("antd/lib/select").BaseOptionType>, "disabled" | "options" | "virtual" | "showSearch" | "listHeight" | "allowClear" | "mode"> & {
49
+ Select: React.ForwardRefExoticComponent<import("@ag-grid-community/core").ICellEditorParams<any, any> & Pick<import("antd").SelectProps<any, import("antd/lib/select").BaseOptionType>, "disabled" | "mode" | "allowClear" | "options" | "virtual" | "showSearch" | "listHeight"> & {
50
50
  fieldNames?: {
51
51
  label: string;
52
52
  value: string;
53
53
  } | undefined;
54
54
  valueByOption?: boolean | undefined;
55
- action?: "stop" | "next" | "none" | undefined;
55
+ action?: "stop" | "none" | "next" | undefined;
56
56
  } & React.RefAttributes<import("@ag-grid-community/react").ICellEditorReactComp>>;
57
57
  Wrapper: typeof EditorWrapper;
58
58
  };
@@ -68,7 +68,6 @@ export default class DataGrid<TData> extends Component<DataGridProps<TData>, Dat
68
68
  private afterReady;
69
69
  private updateRowData;
70
70
  private getDataFromServer;
71
- private sort;
72
71
  private pagination;
73
72
  private init;
74
73
  private LoadingOverlay;
@@ -68,6 +68,7 @@ import { AgGridReact } from '@ag-grid-community/react';
68
68
  import shallowEqual from 'shallowequal';
69
69
  import { ModuleRegistry, GridApi, ColumnApi } from '@ag-grid-community/core';
70
70
  import { InfiniteRowModelModule } from '@ag-grid-community/infinite-row-model';
71
+ import { ClientSideRowModelModule } from '@ag-grid-community/client-side-row-model';
71
72
  import { get, set } from 'lodash';
72
73
  import Scheme from 'async-validator';
73
74
  import GridStoreContext from "./context/GridStore";
@@ -76,8 +77,6 @@ import { ClipboardModule } from "./modules/clipboard";
76
77
  import { MenuModule } from "./modules/menu";
77
78
  import { ColumnsToolPanelModule } from "./modules/column-tool-panel";
78
79
  import { SideBarModule } from "./modules/side-bar";
79
- import { ServerSideRowModelModule } from "./modules/server-side-row-model";
80
- import { ClientSideRowModelModule } from "./modules/client-side-row-model";
81
80
  import { Spin, Pagination, Empty } from 'antd';
82
81
  import { prefix, getColField, isColumn, withSyncRender, Store, Selection, columnTypes } from "./utils";
83
82
  import HeaderRenderer from "./renderer/HeaderRenderer";
@@ -89,7 +88,7 @@ import NumberEditor from "./cell-editors/Number";
89
88
  import SelectEditor from "./cell-editors/Select";
90
89
  import RowEditor, { RowEditorData } from "./cell-editors/Row";
91
90
  import EditorWrapper from "./cell-editors/Wrapper";
92
- ModuleRegistry.registerModules([ClientSideRowModelModule, RowGroupingModule, InfiniteRowModelModule, ClipboardModule, MenuModule, SideBarModule, ColumnsToolPanelModule, ServerSideRowModelModule], false);
91
+ ModuleRegistry.registerModules([ClientSideRowModelModule, RowGroupingModule, InfiniteRowModelModule, ClipboardModule, MenuModule, SideBarModule, ColumnsToolPanelModule], false);
93
92
  var defaultColDef = {
94
93
  resizable: true,
95
94
  width: 140,
@@ -175,8 +174,10 @@ var DataGrid = /*#__PURE__*/function (_Component) {
175
174
  _this.getDataFromServer();
176
175
  }
177
176
 
178
- api.addEventListener('sortChanged', function (evt) {
179
- _this.sort(evt);
177
+ api.addEventListener('sortChanged', function () {
178
+ if (!_this.isClientMode()) {
179
+ _this.getDataFromServer();
180
+ }
180
181
  }); // 用于同步selection
181
182
 
182
183
  api.addEventListener('rowSelected', function (_ref) {
@@ -765,7 +766,7 @@ var DataGrid = /*#__PURE__*/function (_Component) {
765
766
  }).map(function (item) {
766
767
  return {
767
768
  field: item.colId,
768
- order: item.sort === 'desc' ? 'descend' : 'ascend'
769
+ order: item.sort
769
770
  };
770
771
  })
771
772
  }).then(function (res) {
@@ -818,16 +819,6 @@ var DataGrid = /*#__PURE__*/function (_Component) {
818
819
  });
819
820
  }
820
821
  }
821
- }, {
822
- key: "sort",
823
- value: function sort(evt) {
824
- if (this.isClientMode()) {
825
- var model = this.api.getModel();
826
- model.onSortChanged(evt);
827
- } else {
828
- this.getDataFromServer();
829
- }
830
- }
831
822
  }, {
832
823
  key: "pagination",
833
824
  value: function pagination(page, pageSize) {
@@ -1092,7 +1083,11 @@ var DataGrid = /*#__PURE__*/function (_Component) {
1092
1083
  context: context,
1093
1084
  rowSelection: rowSelection !== undefined ? rowSelection.type !== 'radio' ? 'multiple' : 'single' : undefined,
1094
1085
  components: _objectSpread(_objectSpread({}, defaultComponents), componentsProp),
1095
- defaultColDef: _objectSpread(_objectSpread({}, defaultColDef), defaultColDefProp),
1086
+ defaultColDef: _objectSpread(_objectSpread({
1087
+ comparator: this.isClientMode() ? undefined : function () {
1088
+ return 0;
1089
+ }
1090
+ }, defaultColDef), defaultColDefProp),
1096
1091
  columnTypes: _objectSpread(_objectSpread({}, columnTypes), columnTypesProp)
1097
1092
  })), /*#__PURE__*/React.createElement("div", {
1098
1093
  className: prefix('bottom')
@@ -32,7 +32,7 @@ export default function CellIndexRender(props) {
32
32
  };
33
33
  }, []);
34
34
 
35
- if (index === null) {
35
+ if (index === null || node.isRowPinned()) {
36
36
  return null;
37
37
  }
38
38
 
@@ -69,7 +69,7 @@ export declare type PaginationType = {
69
69
  onChange?: (current: number, pageSize: number) => void;
70
70
  };
71
71
  export declare type SelectionType = AgGridReactProps['rowSelection'];
72
- export declare type SortOrder = 'descend' | 'ascend' | null;
72
+ export declare type SortOrder = 'desc' | 'asc';
73
73
  export declare type SortType = {
74
74
  field: string;
75
75
  order: SortOrder;
@@ -1,7 +1,7 @@
1
1
  /// <reference types="react" />
2
2
  import type { Moment } from 'moment';
3
3
  import type { RangePickerProps } from 'antd/lib/date-picker';
4
- declare type Value = {
4
+ export declare type DurationPickerValue = {
5
5
  type: string;
6
6
  option: string;
7
7
  dates?: [string, string];
@@ -19,8 +19,8 @@ interface Props extends Omit<RangePickerProps, 'value' | 'onChange'> {
19
19
  types: DateType[];
20
20
  options?: Option[];
21
21
  dateFormat?: string;
22
- value?: Value;
23
- onChange?: (value: Value) => void;
22
+ value?: DurationPickerValue;
23
+ onChange?: (value: DurationPickerValue) => void;
24
24
  }
25
- export default function DurationPicker(props: Props): JSX.Element;
26
- export {};
25
+ declare function DurationPicker(props: Props): JSX.Element;
26
+ export default DurationPicker;
@@ -68,7 +68,8 @@ var defaultOptions = [{
68
68
  return [moment().add(-29, 'days').startOf('day'), moment().endOf('day')];
69
69
  }
70
70
  }];
71
- export default function DurationPicker(props) {
71
+
72
+ function DurationPicker(props) {
72
73
  var _result$type, _result$option, _result$option2;
73
74
 
74
75
  var _props$prefixCls = props.prefixCls,
@@ -82,7 +83,7 @@ export default function DurationPicker(props) {
82
83
  onChange = props.onChange,
83
84
  restProps = _objectWithoutProperties(props, _excluded);
84
85
 
85
- var defaultValue = useMemo(function () {
86
+ var defaultDurationPickerValue = useMemo(function () {
86
87
  if (valueProp === undefined) {
87
88
  var _options$0$value, _options$;
88
89
 
@@ -98,14 +99,14 @@ export default function DurationPicker(props) {
98
99
  return valueProp;
99
100
  }, []);
100
101
 
101
- var _useState = useState(defaultValue),
102
+ var _useState = useState(defaultDurationPickerValue),
102
103
  _useState2 = _slicedToArray(_useState, 2),
103
104
  value = _useState2[0],
104
- setValue = _useState2[1];
105
+ setDurationPickerValue = _useState2[1];
105
106
 
106
107
  useEffect(function () {
107
108
  if (valueProp !== undefined) {
108
- setValue(valueProp);
109
+ setDurationPickerValue(valueProp);
109
110
  }
110
111
  }, [valueProp]);
111
112
  var result = useMemo(function () {
@@ -127,46 +128,46 @@ export default function DurationPicker(props) {
127
128
 
128
129
  var handleChangeType = function handleChangeType(item) {
129
130
  if (value.type !== item.value) {
130
- var newValue = _objectSpread(_objectSpread({}, value), {}, {
131
+ var newDurationPickerValue = _objectSpread(_objectSpread({}, value), {}, {
131
132
  type: item.value
132
133
  });
133
134
 
134
- setValue(newValue);
135
+ setDurationPickerValue(newDurationPickerValue);
135
136
 
136
137
  if (onChange) {
137
- onChange(newValue);
138
+ onChange(newDurationPickerValue);
138
139
  }
139
140
  }
140
141
  };
141
142
 
142
143
  var handleChangeOption = function handleChangeOption(item) {
143
144
  if (value.option !== item.label) {
144
- var newValue = _objectSpread(_objectSpread({}, value), {}, {
145
+ var newDurationPickerValue = _objectSpread(_objectSpread({}, value), {}, {
145
146
  dates: item.value !== null ? item.value().map(function (date) {
146
147
  return date.format(dateFormat);
147
148
  }) : undefined,
148
149
  option: item.label
149
150
  });
150
151
 
151
- setValue(newValue);
152
+ setDurationPickerValue(newDurationPickerValue);
152
153
 
153
154
  if (onChange) {
154
- onChange(newValue);
155
+ onChange(newDurationPickerValue);
155
156
  }
156
157
  }
157
158
  };
158
159
 
159
160
  var handleChangeDates = function handleChangeDates(dates) {
160
- var newValue = _objectSpread(_objectSpread({}, value), {}, {
161
+ var newDurationPickerValue = _objectSpread(_objectSpread({}, value), {}, {
161
162
  dates: dates ? dates.map(function (item) {
162
163
  return item.format(dateFormat);
163
164
  }) : undefined
164
165
  });
165
166
 
166
- setValue(newValue);
167
+ setDurationPickerValue(newDurationPickerValue);
167
168
 
168
169
  if (onChange) {
169
- onChange(newValue);
170
+ onChange(newDurationPickerValue);
170
171
  }
171
172
  };
172
173
 
@@ -201,4 +202,6 @@ export default function DurationPicker(props) {
201
202
  onChange: handleChangeDates,
202
203
  disabled: ((_result$option2 = result.option) === null || _result$option2 === void 0 ? void 0 : _result$option2.value) !== null
203
204
  }, restProps))));
204
- }
205
+ }
206
+
207
+ export default DurationPicker;
@@ -104,6 +104,7 @@ function Popup(props) {
104
104
  return;
105
105
  }
106
106
 
107
+ setValue(valueProp);
107
108
  setOpen(true);
108
109
  };
109
110
 
package/es/index.d.ts CHANGED
@@ -18,6 +18,7 @@ export type { FilterItemType } from './components/Filter/typings';
18
18
  export { default as Section } from './components/Section';
19
19
  export { default as Layout } from './components/Layout';
20
20
  export { default as DurationPicker } from './components/DurationPicker';
21
+ export type { DurationPickerValue } from './components/DurationPicker';
21
22
  export { default as ColorPicker } from './components/ColorPicker';
22
23
  export { default as Popup } from './components/Popup';
23
24
  export type { BasePopupProps } from './components/Popup';
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@lemon-fe/kits",
3
- "version": "1.0.0-52",
3
+ "version": "1.0.0-54",
4
4
  "scripts": {
5
5
  "start": "dumi dev",
6
6
  "docs:build": "dumi build",
@@ -1,35 +0,0 @@
1
- import { Beans, ColumnModel, EventService, GridOptionsWrapper, RowDataTransaction, RowNode, RowNodeTransaction, SelectionService } from "@ag-grid-community/core";
2
- export declare class ClientSideNodeManager {
3
- private static TOP_LEVEL;
4
- private readonly rootNode;
5
- private gridOptionsWrapper;
6
- private eventService;
7
- private columnModel;
8
- private selectionService;
9
- private beans;
10
- private nextId;
11
- private static ROOT_NODE_ID;
12
- private isRowMasterFunc?;
13
- private suppressParentsInRowNodes;
14
- private doingTreeData;
15
- private doingMasterDetail;
16
- private allNodesMap;
17
- constructor(rootNode: RowNode, gridOptionsWrapper: GridOptionsWrapper, eventService: EventService, columnModel: ColumnModel, selectionService: SelectionService, beans: Beans);
18
- postConstruct(): void;
19
- getCopyOfNodesMap(): {
20
- [id: string]: RowNode;
21
- };
22
- getRowNode(id: string): RowNode | undefined;
23
- setRowData(rowData: any[]): RowNode[] | undefined;
24
- updateRowData(rowDataTran: RowDataTransaction, rowNodeOrder: {
25
- [id: string]: number;
26
- } | null | undefined): RowNodeTransaction;
27
- private updateSelection;
28
- private executeAdd;
29
- private executeRemove;
30
- private executeUpdate;
31
- private lookupRowNode;
32
- private createNode;
33
- private setMasterForRow;
34
- private isExpanded;
35
- }