elab_components 0.0.1 → 0.0.3
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.
- package/dist/App.d.ts +0 -1
- package/dist/components/DateInputs/MultiViewCalendar/props.d.ts +2 -2
- package/dist/components/Grid/index.d.ts +2 -46
- package/dist/components/Grid/props.d.ts +1 -1
- package/dist/index.esm.js +212 -78
- package/dist/index.esm.js.map +1 -1
- package/dist/index.js +209 -75
- package/dist/index.js.map +1 -1
- package/dist/utils/gridCell.d.ts +5 -0
- package/package.json +2 -1
package/dist/App.d.ts
CHANGED
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
declare const props: () => {
|
|
2
|
-
activeRangeEnd: "
|
|
2
|
+
activeRangeEnd: "end" | "start";
|
|
3
3
|
allowReverse: import("@storybook/addon-knobs/dist/type-defs").Mutable<boolean>;
|
|
4
4
|
bottomView: "month" | "year" | "decade" | "century";
|
|
5
5
|
defaultActiveView: "month" | "year" | "decade" | "century";
|
|
6
|
-
mode: "
|
|
6
|
+
mode: "multiple" | "range" | "single";
|
|
7
7
|
topView: "month" | "year" | "decade" | "century";
|
|
8
8
|
views: number;
|
|
9
9
|
};
|
|
@@ -1,50 +1,6 @@
|
|
|
1
1
|
/** @format */
|
|
2
2
|
import { JSX } from 'react';
|
|
3
|
-
import { GridColumn, GridCell, GridProps
|
|
4
|
-
|
|
5
|
-
interface IGrid extends GridProps {
|
|
6
|
-
data: Array<any>;
|
|
7
|
-
style: any;
|
|
8
|
-
reorderable: boolean;
|
|
9
|
-
resizable: boolean;
|
|
10
|
-
sortable: {
|
|
11
|
-
mode: 'single' | 'multiple';
|
|
12
|
-
allowUnsort: boolean;
|
|
13
|
-
};
|
|
14
|
-
dataItemKey: string;
|
|
15
|
-
editField: string;
|
|
16
|
-
filterable: boolean;
|
|
17
|
-
groupable: boolean;
|
|
18
|
-
onDataStateChange?: (event: GridDataStateChangeEvent) => void;
|
|
19
|
-
onSelectionChange: (event: GridSelectionChangeEvent) => void;
|
|
20
|
-
onHeaderSelectionChange: (event: GridHeaderSelectionChangeEvent) => void;
|
|
21
|
-
columnConfigs: any;
|
|
22
|
-
detailComponent: Function;
|
|
23
|
-
expandChange: Function;
|
|
24
|
-
page: State;
|
|
25
|
-
pageSizeValue: number | string | undefined;
|
|
26
|
-
setPageSizeValue: Function;
|
|
27
|
-
setPage: Function;
|
|
28
|
-
expandedRows: number[];
|
|
29
|
-
selectedState: {
|
|
30
|
-
[id: string]: boolean | number[];
|
|
31
|
-
};
|
|
32
|
-
setSelectedState: Function;
|
|
33
|
-
columnOption: {
|
|
34
|
-
columnOptionModel: boolean;
|
|
35
|
-
columnConfigsModel: boolean;
|
|
36
|
-
runQueriesModel: boolean;
|
|
37
|
-
};
|
|
38
|
-
setColumnOption: Function;
|
|
39
|
-
apiColumnConfig: any;
|
|
40
|
-
searchKeyword: string;
|
|
41
|
-
setSearchKeyword: Function;
|
|
42
|
-
allColumnsField: Array<{
|
|
43
|
-
field: string;
|
|
44
|
-
title: string;
|
|
45
|
-
type: string;
|
|
46
|
-
}>;
|
|
47
|
-
}
|
|
48
|
-
declare const OkGrid: ({ ...props }: IGrid) => JSX.Element;
|
|
3
|
+
import { GridColumn, GridCell, GridProps } from '@progress/kendo-react-grid';
|
|
4
|
+
declare const OkGrid: ({ ...props }: any) => JSX.Element;
|
|
49
5
|
export { OkGrid, GridColumn as OkGridColumn, GridCell as OkGridCell };
|
|
50
6
|
export type { GridProps };
|
|
@@ -23,7 +23,7 @@ declare const props: () => {
|
|
|
23
23
|
reorderable: import("@storybook/addon-knobs/dist/type-defs").Mutable<boolean>;
|
|
24
24
|
resizable: import("@storybook/addon-knobs/dist/type-defs").Mutable<boolean>;
|
|
25
25
|
rowHeight: number;
|
|
26
|
-
scrollable: "none" | "
|
|
26
|
+
scrollable: "none" | "virtual" | "scrollable";
|
|
27
27
|
selectedField: string;
|
|
28
28
|
skip: number;
|
|
29
29
|
sortable: import("@storybook/addon-knobs/dist/type-defs").Mutable<boolean>;
|
package/dist/index.esm.js
CHANGED
|
@@ -1,17 +1,17 @@
|
|
|
1
|
-
import React, { useState, useMemo, useCallback
|
|
1
|
+
import React, { useState, useEffect, useMemo, useCallback } from 'react';
|
|
2
2
|
import { Button, DropDownButton, SplitButton, Toolbar, ButtonGroup } from '@progress/kendo-react-buttons';
|
|
3
3
|
import styled from 'styled-components';
|
|
4
4
|
import { Window, Dialog, DialogActionsBar } from '@progress/kendo-react-dialogs';
|
|
5
|
-
import { MultiSelect, DropDownList } from '@progress/kendo-react-dropdowns';
|
|
5
|
+
import { MultiSelect, DropDownList, ComboBox } from '@progress/kendo-react-dropdowns';
|
|
6
6
|
import { Editor } from '@progress/kendo-react-editor';
|
|
7
7
|
import { ArcGauge } from '@progress/kendo-react-gauges';
|
|
8
|
-
import { Grid, getSelectedState, GridColumn } from '@progress/kendo-react-grid';
|
|
8
|
+
import { Grid, getSelectedState, GridToolbar, GridColumn } from '@progress/kendo-react-grid';
|
|
9
9
|
import { getter, process as process$1 } from '@progress/kendo-data-query';
|
|
10
10
|
import { ExcelExport } from '@progress/kendo-react-excel-export';
|
|
11
11
|
import { Input, Checkbox, Switch, NumericTextBox, MaskedTextBox } from '@progress/kendo-react-inputs';
|
|
12
|
+
import { DatePicker, TimePicker, MultiViewCalendar, Calendar, DateInput, DateRangePicker, DateTimePicker } from '@progress/kendo-react-dateinputs';
|
|
12
13
|
import { TreeView } from '@progress/kendo-react-treeview';
|
|
13
14
|
import { Chart } from '@progress/kendo-react-charts';
|
|
14
|
-
import { TimePicker, MultiViewCalendar, Calendar, DateInput, DateRangePicker, DateTimePicker } from '@progress/kendo-react-dateinputs';
|
|
15
15
|
import { Drawer } from '@progress/kendo-react-layout';
|
|
16
16
|
export { DrawerContent as OkDrawerContent } from '@progress/kendo-react-layout';
|
|
17
17
|
|
|
@@ -42,7 +42,7 @@ function styleInject(css, ref) {
|
|
|
42
42
|
}
|
|
43
43
|
}
|
|
44
44
|
|
|
45
|
-
var css_248z = "/** @format */\r\n@import '@progress/kendo-theme-material/dist/all';\r\n\r\nbody {\r\n margin: 0;\r\n font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Roboto',\r\n 'Oxygen', 'Ubuntu', 'Cantarell', 'Fira Sans', 'Droid Sans',\r\n 'Helvetica Neue', sans-serif;\r\n -webkit-font-smoothing: antialiased;\r\n -moz-osx-font-smoothing: grayscale;\r\n}\r\n\r\ncode {\r\n font-family: source-code-pro, Menlo, Monaco, Consolas, 'Courier New',\r\n monospace;\r\n}\r\n";
|
|
45
|
+
var css_248z = "/** @format */\r\n@import '@progress/kendo-theme-material/dist/all';\r\n\r\nbody {\r\n margin: 0;\r\n font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Roboto',\r\n 'Oxygen', 'Ubuntu', 'Cantarell', 'Fira Sans', 'Droid Sans',\r\n 'Helvetica Neue', sans-serif;\r\n -webkit-font-smoothing: antialiased;\r\n -moz-osx-font-smoothing: grayscale;\r\n}\r\n\r\ncode {\r\n font-family: source-code-pro, Menlo, Monaco, Consolas, 'Courier New',\r\n monospace;\r\n}\r\n\r\n.k-grid-toolbar {\r\n border-width: none;\r\n}\r\n.k-toolbar {\r\n padding-inline: 0px;\r\n padding-block: 0px;\r\n}\r\n.k-button {\r\n text-transform: none;\r\n}\r\n\r\n.button-container {\r\n margin-left: auto;\r\n display: flex;\r\n gap: 15px;\r\n}\r\n\r\n.button-container .custom-button {\r\n background-color: transparent;\r\n border: none;\r\n box-shadow: none;\r\n cursor: pointer;\r\n}\r\n\r\n.button-container .button-content {\r\n display: flex;\r\n align-items: center;\r\n gap: 5px;\r\n}\r\n\r\n.button-container .icon {\r\n font-size: 20px;\r\n font-weight: bold;\r\n}\r\n\r\n.button-container .text {\r\n font-size: 16px;\r\n}\r\n";
|
|
46
46
|
styleInject(css_248z);
|
|
47
47
|
|
|
48
48
|
/******************************************************************************
|
|
@@ -165,23 +165,119 @@ var OkInput = function (_a) {
|
|
|
165
165
|
};
|
|
166
166
|
var templateObject_1$g;
|
|
167
167
|
|
|
168
|
+
var DefaultContext = {
|
|
169
|
+
color: undefined,
|
|
170
|
+
size: undefined,
|
|
171
|
+
className: undefined,
|
|
172
|
+
style: undefined,
|
|
173
|
+
attr: undefined
|
|
174
|
+
};
|
|
175
|
+
var IconContext = React.createContext && /*#__PURE__*/React.createContext(DefaultContext);
|
|
176
|
+
|
|
177
|
+
var _excluded = ["attr", "size", "title"];
|
|
178
|
+
function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }
|
|
179
|
+
function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } } return target; }
|
|
180
|
+
function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
|
|
181
|
+
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
182
|
+
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
183
|
+
function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
184
|
+
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : i + ""; }
|
|
185
|
+
function _toPrimitive(t, r) { if ("object" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != typeof i) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
|
|
186
|
+
function Tree2Element(tree) {
|
|
187
|
+
return tree && tree.map((node, i) => /*#__PURE__*/React.createElement(node.tag, _objectSpread({
|
|
188
|
+
key: i
|
|
189
|
+
}, node.attr), Tree2Element(node.child)));
|
|
190
|
+
}
|
|
191
|
+
function GenIcon(data) {
|
|
192
|
+
return props => /*#__PURE__*/React.createElement(IconBase, _extends({
|
|
193
|
+
attr: _objectSpread({}, data.attr)
|
|
194
|
+
}, props), Tree2Element(data.child));
|
|
195
|
+
}
|
|
196
|
+
function IconBase(props) {
|
|
197
|
+
var elem = conf => {
|
|
198
|
+
var {
|
|
199
|
+
attr,
|
|
200
|
+
size,
|
|
201
|
+
title
|
|
202
|
+
} = props,
|
|
203
|
+
svgProps = _objectWithoutProperties(props, _excluded);
|
|
204
|
+
var computedSize = size || conf.size || "1em";
|
|
205
|
+
var className;
|
|
206
|
+
if (conf.className) className = conf.className;
|
|
207
|
+
if (props.className) className = (className ? className + " " : "") + props.className;
|
|
208
|
+
return /*#__PURE__*/React.createElement("svg", _extends({
|
|
209
|
+
stroke: "currentColor",
|
|
210
|
+
fill: "currentColor",
|
|
211
|
+
strokeWidth: "0"
|
|
212
|
+
}, conf.attr, attr, svgProps, {
|
|
213
|
+
className: className,
|
|
214
|
+
style: _objectSpread(_objectSpread({
|
|
215
|
+
color: props.color || conf.color
|
|
216
|
+
}, conf.style), props.style),
|
|
217
|
+
height: computedSize,
|
|
218
|
+
width: computedSize,
|
|
219
|
+
xmlns: "http://www.w3.org/2000/svg"
|
|
220
|
+
}), title && /*#__PURE__*/React.createElement("title", null, title), props.children);
|
|
221
|
+
};
|
|
222
|
+
return IconContext !== undefined ? /*#__PURE__*/React.createElement(IconContext.Consumer, null, conf => elem(conf)) : elem(DefaultContext);
|
|
223
|
+
}
|
|
224
|
+
|
|
225
|
+
// THIS FILE IS AUTO GENERATED
|
|
226
|
+
function HiViewColumns (props) {
|
|
227
|
+
return GenIcon({"tag":"svg","attr":{"viewBox":"0 0 24 24","fill":"currentColor","aria-hidden":"true"},"child":[{"tag":"path","attr":{"d":"M15 3.75H9v16.5h6V3.75ZM16.5 20.25h3.375c1.035 0 1.875-.84 1.875-1.875V5.625c0-1.036-.84-1.875-1.875-1.875H16.5v16.5ZM4.125 3.75H7.5v16.5H4.125a1.875 1.875 0 0 1-1.875-1.875V5.625c0-1.036.84-1.875 1.875-1.875Z"},"child":[]}]})(props);
|
|
228
|
+
}
|
|
229
|
+
|
|
230
|
+
// THIS FILE IS AUTO GENERATED
|
|
231
|
+
function PiExportBold (props) {
|
|
232
|
+
return GenIcon({"tag":"svg","attr":{"viewBox":"0 0 256 256","fill":"currentColor"},"child":[{"tag":"path","attr":{"d":"M220,112v96a20,20,0,0,1-20,20H56a20,20,0,0,1-20-20V112A20,20,0,0,1,56,92H76a12,12,0,0,1,0,24H60v88H196V116H180a12,12,0,0,1,0-24h20A20,20,0,0,1,220,112ZM96.49,72.49,116,53v83a12,12,0,0,0,24,0V53l19.51,19.52a12,12,0,1,0,17-17l-40-40a12,12,0,0,0-17,0l-40,40a12,12,0,1,0,17,17Z"},"child":[]}]})(props);
|
|
233
|
+
}
|
|
234
|
+
|
|
235
|
+
// THIS FILE IS AUTO GENERATED
|
|
236
|
+
function MdFilterList (props) {
|
|
237
|
+
return GenIcon({"tag":"svg","attr":{"viewBox":"0 0 24 24"},"child":[{"tag":"path","attr":{"fill":"none","d":"M0 0h24v24H0z"},"child":[]},{"tag":"path","attr":{"d":"M10 18h4v-2h-4v2zM3 6v2h18V6H3zm3 7h12v-2H6v2z"},"child":[]}]})(props);
|
|
238
|
+
}
|
|
239
|
+
|
|
240
|
+
// THIS FILE IS AUTO GENERATED
|
|
241
|
+
function IoClose (props) {
|
|
242
|
+
return GenIcon({"tag":"svg","attr":{"viewBox":"0 0 512 512"},"child":[{"tag":"path","attr":{"d":"m289.94 256 95-95A24 24 0 0 0 351 127l-95 95-95-95a24 24 0 0 0-34 34l95 95-95 95a24 24 0 1 0 34 34l95-95 95 95a24 24 0 0 0 34-34z"},"child":[]}]})(props);
|
|
243
|
+
}
|
|
244
|
+
|
|
168
245
|
/** @format */
|
|
169
246
|
var StyledGrid = styled(Grid)(templateObject_1$f || (templateObject_1$f = __makeTemplateObject([""], [""])));
|
|
170
247
|
var OkGrid = function (_a) {
|
|
171
248
|
var props = __rest(_a, []);
|
|
172
|
-
|
|
249
|
+
console.log('props');
|
|
250
|
+
var data = props.data;
|
|
251
|
+
var _b = props[0], resizable = _b.resizable, reorderable = _b.reorderable, pageSizeValue = _b.pageSizeValue, filterable = _b.filterable; _b.sortable; var groupable = _b.groupable, skip = _b.skip, take = _b.take, dataItemKey = _b.dataItemKey, selectField = _b.selectField, columnConfigs = _b.columnConfigs; _b.setPageSizeValue; _b.setPage; var setSearchKeyword = _b.setSearchKeyword, searchKeyword = _b.searchKeyword, allColumnsField = _b.allColumnsField, advanceFilterData = _b.advanceFilterData, advanceFilterDataActive = _b.advanceFilterDataActive, size = _b.size;
|
|
252
|
+
var idGetter = getter(dataItemKey);
|
|
253
|
+
var grid = React.useRef(null);
|
|
173
254
|
var excelExport = React.useRef(null);
|
|
174
|
-
var
|
|
175
|
-
var
|
|
176
|
-
var
|
|
255
|
+
var _c = useState([]), newData = _c[0]; _c[1];
|
|
256
|
+
var _d = useState(), runQueriesFilter = _d[0]; _d[1];
|
|
257
|
+
var _e = React.useState(null), editID = _e[0]; _e[1];
|
|
258
|
+
var _f = useState(false), filterShow = _f[0], setFilterShow = _f[1];
|
|
259
|
+
var _g = React.useState({}), selectedState = _g[0], setSelectedState = _g[1];
|
|
260
|
+
var _h = useState([]), expandedRows = _h[0], setExpandedRows = _h[1];
|
|
177
261
|
var isRowExpanded = function (productID) {
|
|
178
262
|
return expandedRows.includes(productID);
|
|
179
263
|
};
|
|
180
|
-
var
|
|
264
|
+
var _j = useState([]), modifiedData = _j[0], setModifiedData = _j[1];
|
|
265
|
+
useEffect(function () {
|
|
266
|
+
var temp = data.map(function (product, index) {
|
|
267
|
+
var _a;
|
|
268
|
+
return (__assign(__assign({}, product), (_a = { expanded: isRowExpanded(product.id) }, _a['selected'] = selectedState[idGetter(product)], _a.inEdit = product.id === editID, _a['formDataIndex'] = index, _a)));
|
|
269
|
+
});
|
|
270
|
+
setModifiedData(temp);
|
|
271
|
+
}, [data, editID, idGetter, selectedState]);
|
|
272
|
+
console.log('modifiedData', modifiedData);
|
|
273
|
+
var _k = useState({
|
|
274
|
+
columnOptionModel: false,
|
|
275
|
+
columnConfigsModel: false,
|
|
276
|
+
runQueriesModel: false,
|
|
277
|
+
}), columnOption = _k[0], setColumnOption = _k[1];
|
|
181
278
|
var filteredProducts = useMemo(function () {
|
|
182
279
|
var lowerSearchTerm = searchKeyword.toLowerCase();
|
|
183
|
-
return
|
|
184
|
-
.filter(function (product) {
|
|
280
|
+
return modifiedData.filter(function (product) {
|
|
185
281
|
return Object.values(product).some(function (value) {
|
|
186
282
|
if (typeof value === 'object' && value !== null) {
|
|
187
283
|
return Object.values(value).some(function (nestedValue) {
|
|
@@ -190,14 +286,10 @@ var OkGrid = function (_a) {
|
|
|
190
286
|
}
|
|
191
287
|
return value.toString().toLowerCase().includes(lowerSearchTerm);
|
|
192
288
|
});
|
|
193
|
-
})
|
|
194
|
-
.map(function (product, index) {
|
|
195
|
-
var _a;
|
|
196
|
-
return (__assign(__assign({}, product), (_a = { expanded: isRowExpanded(product.id) }, _a['selected'] = selectedState[idGetter(product)], _a.inEdit = product.id === editID, _a['formDataIndex'] = index, _a)));
|
|
197
289
|
});
|
|
198
|
-
}, [
|
|
290
|
+
}, [modifiedData, searchKeyword, expandedRows, selectedState, editID]);
|
|
199
291
|
console.log('filteredProducts', filteredProducts);
|
|
200
|
-
var
|
|
292
|
+
var _l = React.useState({
|
|
201
293
|
take: 10,
|
|
202
294
|
skip: 0,
|
|
203
295
|
group: [],
|
|
@@ -206,9 +298,32 @@ var OkGrid = function (_a) {
|
|
|
206
298
|
logic: 'and',
|
|
207
299
|
filters: [],
|
|
208
300
|
},
|
|
209
|
-
}), dataState =
|
|
210
|
-
var
|
|
211
|
-
|
|
301
|
+
}), dataState = _l[0], setDataState = _l[1];
|
|
302
|
+
var detailComponent = function (props) {
|
|
303
|
+
var dataItem = props.dataItem;
|
|
304
|
+
return (React.createElement("section", null,
|
|
305
|
+
React.createElement("p", null,
|
|
306
|
+
React.createElement("strong", null, "In Stock:"),
|
|
307
|
+
" ",
|
|
308
|
+
dataItem.UnitsInStock,
|
|
309
|
+
" units"),
|
|
310
|
+
React.createElement("p", null,
|
|
311
|
+
React.createElement("strong", null, "On Order:"),
|
|
312
|
+
" ",
|
|
313
|
+
dataItem.UnitsOnOrder,
|
|
314
|
+
" units"),
|
|
315
|
+
React.createElement("p", null,
|
|
316
|
+
React.createElement("strong", null, "Reorder Level:"),
|
|
317
|
+
" ",
|
|
318
|
+
dataItem.ReorderLevel,
|
|
319
|
+
" units"),
|
|
320
|
+
React.createElement("p", null,
|
|
321
|
+
React.createElement("strong", null, "Discontinued:"),
|
|
322
|
+
" ",
|
|
323
|
+
dataItem.Discontinued)));
|
|
324
|
+
};
|
|
325
|
+
var _m = React.useState(columnConfigs), columns = _m[0], setColumns = _m[1];
|
|
326
|
+
var _o = React.useState(function () {
|
|
212
327
|
var savedOptions = localStorage.getItem('gridOptions');
|
|
213
328
|
return savedOptions
|
|
214
329
|
? JSON.parse(savedOptions)
|
|
@@ -217,11 +332,11 @@ var OkGrid = function (_a) {
|
|
|
217
332
|
groupable: false,
|
|
218
333
|
filterByQueries: false,
|
|
219
334
|
};
|
|
220
|
-
}), gridOptions =
|
|
221
|
-
var
|
|
335
|
+
}), gridOptions = _o[0], setGridOptions = _o[1];
|
|
336
|
+
var _p = React.useState(process$1(modifiedData, dataState)), dataResult = _p[0], setDataResult = _p[1];
|
|
222
337
|
var onDataStateChange = function (e) {
|
|
223
338
|
setDataState(e.dataState);
|
|
224
|
-
setDataResult(process$1(
|
|
339
|
+
setDataResult(process$1(modifiedData, e.dataState));
|
|
225
340
|
};
|
|
226
341
|
var onSelectionChange = React.useCallback(function (event) {
|
|
227
342
|
var newSelectedState = getSelectedState({
|
|
@@ -250,16 +365,6 @@ var OkGrid = function (_a) {
|
|
|
250
365
|
var onItemChange = function (event) {
|
|
251
366
|
// const editedItemID = event.dataItem;
|
|
252
367
|
};
|
|
253
|
-
useEffect(function () {
|
|
254
|
-
setDataState(function (item) {
|
|
255
|
-
return __assign(__assign({}, item), { filter: runQueriesFilter });
|
|
256
|
-
});
|
|
257
|
-
}, [data, runQueriesFilter]);
|
|
258
|
-
useEffect(function () {
|
|
259
|
-
setDataResult(process$1(data, dataState));
|
|
260
|
-
}, [data, dataState]);
|
|
261
|
-
console.log(gridOptions);
|
|
262
|
-
console.log('dataResult', dataResult);
|
|
263
368
|
var onFilterChange = function (e) {
|
|
264
369
|
setSearchKeyword(e.target.value);
|
|
265
370
|
};
|
|
@@ -268,61 +373,94 @@ var OkGrid = function (_a) {
|
|
|
268
373
|
excelExport.current.save(newData);
|
|
269
374
|
}
|
|
270
375
|
};
|
|
271
|
-
var
|
|
272
|
-
var
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
};
|
|
280
|
-
setNewData(__spreadArray([newDataItem], newData, true));
|
|
376
|
+
var handleExpandChange = function (event) {
|
|
377
|
+
var dataItem = event.dataItem;
|
|
378
|
+
var productID = dataItem.id;
|
|
379
|
+
setExpandedRows(function (prevExpandedRows) {
|
|
380
|
+
return prevExpandedRows.includes(productID)
|
|
381
|
+
? prevExpandedRows.filter(function (id) { return id !== productID; })
|
|
382
|
+
: __spreadArray(__spreadArray([], prevExpandedRows, true), [productID], false);
|
|
383
|
+
});
|
|
281
384
|
};
|
|
385
|
+
useEffect(function () {
|
|
386
|
+
setDataState(function (item) {
|
|
387
|
+
return __assign(__assign({}, item), { filter: runQueriesFilter });
|
|
388
|
+
});
|
|
389
|
+
}, [runQueriesFilter]);
|
|
390
|
+
useEffect(function () {
|
|
391
|
+
setDataResult(process$1(modifiedData, dataState));
|
|
392
|
+
}, [modifiedData, dataState]);
|
|
282
393
|
return (React.createElement("div", { style: {
|
|
283
394
|
display: 'flex',
|
|
284
395
|
flexDirection: 'column',
|
|
285
|
-
gap: 25,
|
|
286
396
|
marginTop: '25px',
|
|
287
|
-
marginLeft: '10px',
|
|
288
|
-
marginRight: '10px',
|
|
289
397
|
} },
|
|
290
|
-
|
|
291
|
-
|
|
398
|
+
React.createElement("div", { style: {
|
|
399
|
+
display: 'flex',
|
|
400
|
+
justifyContent: 'space-between',
|
|
401
|
+
alignItems: 'center',
|
|
402
|
+
marginBottom: '5px',
|
|
403
|
+
} },
|
|
404
|
+
React.createElement(OkInput, { style: {
|
|
405
|
+
width: '300px',
|
|
406
|
+
}, value: searchKeyword, onChange: function (e) { return onFilterChange(e); }, placeholder: "Search..." }),
|
|
407
|
+
React.createElement("div", { className: "button-container" },
|
|
408
|
+
React.createElement(OkButton, { onClick: function () {
|
|
409
|
+
return setColumnOption(function (prevState) { return (__assign(__assign({}, prevState), { columnOptionModel: true })); });
|
|
410
|
+
}, type: "button", className: "custom-button" },
|
|
411
|
+
React.createElement("span", { className: "button-content" },
|
|
412
|
+
React.createElement(HiViewColumns, { className: "icon" }),
|
|
413
|
+
React.createElement("span", { className: "text" }, "Column Option"))),
|
|
414
|
+
React.createElement(OkButton, { type: "button", className: "custom-button", onClick: function () { return setFilterShow(!filterShow); } },
|
|
415
|
+
React.createElement("span", { className: "button-content" },
|
|
416
|
+
React.createElement(MdFilterList, { className: "icon" }),
|
|
417
|
+
React.createElement("span", { className: "text" }, "Filter"))),
|
|
418
|
+
React.createElement(OkButton, { type: "button", className: "custom-button", title: "Export Excel", onClick: exportExport },
|
|
419
|
+
React.createElement("span", { className: "button-content" },
|
|
420
|
+
React.createElement(PiExportBold, { className: "icon" }),
|
|
421
|
+
React.createElement("span", { className: "text" }, "Export"))))),
|
|
422
|
+
filterShow && advanceFilterDataActive && (React.createElement(GridToolbar, null,
|
|
292
423
|
React.createElement("div", { style: {
|
|
293
424
|
display: 'flex',
|
|
294
|
-
justifyContent: 'space-between',
|
|
295
425
|
alignItems: 'center',
|
|
426
|
+
justifyContent: 'space-between',
|
|
427
|
+
width: '100%',
|
|
296
428
|
} },
|
|
297
|
-
React.createElement(
|
|
298
|
-
|
|
299
|
-
|
|
300
|
-
|
|
301
|
-
|
|
302
|
-
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
|
|
308
|
-
|
|
309
|
-
|
|
310
|
-
|
|
311
|
-
|
|
429
|
+
React.createElement("div", { style: {
|
|
430
|
+
display: 'flex',
|
|
431
|
+
gap: '20px',
|
|
432
|
+
} },
|
|
433
|
+
advanceFilterData.map(function (item, index) { return (React.createElement("div", null,
|
|
434
|
+
item.type === 'combBox' && (React.createElement(ComboBox, { data: item.data, textField: item.textField, value: item.value, onChange: item.onchange, label: item.label, filterable: item.filterable, onFilterChange: item.filterChange })),
|
|
435
|
+
item.type === 'datePicker' && (React.createElement("div", { style: { paddingTop: '1.2rem' } },
|
|
436
|
+
React.createElement(DatePicker, { value: item.value, onChange: item.onchange, placeholder: item.placeholder }))))); }),
|
|
437
|
+
React.createElement(OkButton, { type: "button", onClick: function () { return setFilterShow(false); }, themeColor: "primary", style: { marginTop: '1.2rem', padding: '0px 30px' } }, "Apply")),
|
|
438
|
+
React.createElement(OkButton, { style: {
|
|
439
|
+
backgroundColor: 'transparent',
|
|
440
|
+
border: 'none',
|
|
441
|
+
boxShadow: 'none',
|
|
442
|
+
fontSize: '24px',
|
|
443
|
+
fontWeight: 700,
|
|
444
|
+
paddingTop: '1.2rem',
|
|
445
|
+
}, type: "button", onClick: function () { return setFilterShow(false); } },
|
|
446
|
+
React.createElement(IoClose, null))))),
|
|
312
447
|
React.createElement(ExcelExport, { data: dataResult, ref: excelExport },
|
|
313
|
-
React.createElement(StyledGrid, __assign({
|
|
448
|
+
React.createElement(StyledGrid, __assign({ onDataStateChange: onDataStateChange, onItemChange: onItemChange, ref: grid, skip: skip, filterable: filterable, reorderable: reorderable, groupable: groupable, resizable: resizable, data: dataResult, dataItemKey: dataItemKey, take: take, selectField: selectField, editField: "inEdit", sortable: {
|
|
449
|
+
mode: 'single',
|
|
450
|
+
allowUnsort: true,
|
|
451
|
+
}, detail: detailComponent, size: size, expandField: "expanded", pageable: {
|
|
452
|
+
buttonCount: 4,
|
|
453
|
+
pageSizes: [2, 10, 15, 'All'],
|
|
454
|
+
pageSizeValue: pageSizeValue,
|
|
455
|
+
} }, dataState, { onHeaderSelectionChange: function (e) {
|
|
314
456
|
return onHeaderSelectionChange(e);
|
|
315
457
|
}, onSelectionChange: function (e) {
|
|
316
458
|
return onSelectionChange(e);
|
|
317
459
|
}, onColumnReorder: function (e) {
|
|
318
460
|
onColumnReorderChange(e);
|
|
319
|
-
},
|
|
320
|
-
|
|
321
|
-
},
|
|
322
|
-
buttonCount: 4,
|
|
323
|
-
pageSizes: [2, 10, 15, 'All'],
|
|
324
|
-
pageSizeValue: pageSizeValue,
|
|
325
|
-
}, filterable: filterable, editField: editField, reorderable: reorderable, groupable: groupable, resizable: resizable, style: style, data: filteredProducts, dataItemKey: dataItemKey, take: take, sortable: sortable, detail: detail, expandField: expandField }, dataState), columns.map(function (col, index) { return (React.createElement(GridColumn, { filterable: true, key: index, editable: true, field: col.field, title: col.title, format: col.format, cell: col.cell, width: col.width, headerSelectionValue: col.headerSelectionValue, editor: col.editor })); }))),
|
|
461
|
+
}, onExpandChange: function (e) {
|
|
462
|
+
handleExpandChange(e);
|
|
463
|
+
} }), columns.map(function (col, index) { return (React.createElement(GridColumn, { filterable: true, key: index, editable: true, field: col.field, title: col.title, format: col.format, cell: col.cell, width: col.width, headerSelectionValue: col.headerSelectionValue, editor: col.editor })); }))),
|
|
326
464
|
columnOption.columnOptionModel && (React.createElement(ColumnAdd, { setColumnOption: setColumnOption, setColumns: setColumns, columns: columns, allColumnsField: allColumnsField, dataResult: dataResult, setDataResult: setDataResult })),
|
|
327
465
|
columnOption.columnConfigsModel && (React.createElement(GridFeatureEnableHandler, { gridOptions: gridOptions, setGridOptions: setGridOptions, setColumnOption: setColumnOption }))));
|
|
328
466
|
};
|
|
@@ -345,7 +483,7 @@ var SortableItem = function (_a) {
|
|
|
345
483
|
}, onClick: function () { return handleRemoveColumn(col.id); } }, "X")));
|
|
346
484
|
};
|
|
347
485
|
var ColumnAdd = function (_a) {
|
|
348
|
-
|
|
486
|
+
_a.columns; var setColumns = _a.setColumns, setColumnOption = _a.setColumnOption, allColumnsField = _a.allColumnsField;
|
|
349
487
|
var _b = useState([]), selectedColumn = _b[0], setSelectedColumn = _b[1];
|
|
350
488
|
var handleAddColumn = function () {
|
|
351
489
|
setSelectedColumn(function (item) {
|
|
@@ -385,10 +523,6 @@ var ColumnAdd = function (_a) {
|
|
|
385
523
|
return !selectedColumn.some(function (col) { return col.field === allCol.field; });
|
|
386
524
|
});
|
|
387
525
|
}, [selectedColumn, allColumnsField]);
|
|
388
|
-
useEffect(function () {
|
|
389
|
-
var filteredData = columns.filter(function (item) { return item.title !== 'Actions' && item.id !== 8; });
|
|
390
|
-
setSelectedColumn(filteredData);
|
|
391
|
-
}, [columns]);
|
|
392
526
|
return (React.createElement("div", null,
|
|
393
527
|
React.createElement(Dialog, { onClose: function () {
|
|
394
528
|
return setColumnOption(function (prevState) { return (__assign(__assign({}, prevState), { columnOptionModel: false })); });
|