@uxf/data-grid 10.0.7 → 11.0.0-beta.2
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/_store/reducer.d.ts +8 -0
- package/{store → _store}/reducer.js +33 -19
- package/_story-utils/data.d.ts +12 -0
- package/_story-utils/data.js +115 -0
- package/_story-utils/grid-type.d.ts +22 -0
- package/_story-utils/grid-type.js +2 -0
- package/_story-utils/loader.d.ts +2 -0
- package/_story-utils/loader.js +36 -0
- package/_story-utils/schema.d.ts +3 -0
- package/_story-utils/schema.js +53 -0
- package/{tailwindui/body-cell → body-cell}/body-cell-boolean.d.ts +1 -1
- package/{tailwindui/body-cell → body-cell}/body-cell-date.d.ts +1 -1
- package/{tailwindui/body-cell → body-cell}/body-cell-datetime.d.ts +1 -1
- package/{tailwindui/body-cell → body-cell}/body-cell-default.d.ts +1 -1
- package/{tailwindui/body-cell → body-cell}/body-cell-email.d.ts +1 -1
- package/{tailwindui/body-cell → body-cell}/body-cell-phone.d.ts +1 -1
- package/{tailwindui/body-cell → body-cell}/body-cell-to-many.d.ts +1 -1
- package/{tailwindui/body-cell → body-cell}/body-cell-to-one.d.ts +1 -1
- package/{tailwindui/body-cell → body-cell}/body-cell-url.d.ts +1 -1
- package/{tailwindui/body-cell → body-cell}/index.d.ts +1 -1
- package/data-grid.d.ts +1 -1
- package/data-grid.js +34 -120
- package/data-grid.stories.d.ts +0 -5
- package/data-grid.stories.js +14 -216
- package/export-button/export-button.d.ts +10 -0
- package/export-button/export-button.js +15 -0
- package/export-button/export-button.stories.d.ts +2 -0
- package/export-button/export-button.stories.js +18 -0
- package/export-button/index.d.ts +1 -0
- package/{tailwindui → export-button}/index.js +1 -3
- package/{tailwindui/filter-handler → filter-handler}/bool-filter.d.ts +1 -1
- package/{tailwindui/filter-handler → filter-handler}/boolean-filter.d.ts +1 -1
- package/filter-handler/index.d.ts +4 -0
- package/{tailwindui/filter-handler → filter-handler}/index.js +15 -0
- package/{tailwindui/filter-handler → filter-handler}/interval-filter.d.ts +1 -1
- package/{tailwindui/filter-handler → filter-handler}/interval-filter.js +2 -2
- package/{tailwindui/filter-handler → filter-handler}/select-filter.d.ts +1 -1
- package/{tailwindui/filter-handler → filter-handler}/text-filter.d.ts +1 -1
- package/filter-handler/types.d.ts +8 -0
- package/filter-handler/types.js +2 -0
- package/filter-list/filter-list.d.ts +11 -0
- package/{tailwindui/components → filter-list}/filter-list.js +7 -6
- package/filter-list/filter-list.stories.d.ts +2 -0
- package/filter-list/filter-list.stories.js +19 -0
- package/filter-list/index.d.ts +1 -0
- package/filter-list/index.js +17 -0
- package/filters/filters.d.ts +11 -0
- package/filters/filters.js +25 -0
- package/filters/filters.stories.d.ts +2 -0
- package/filters/filters.stories.js +19 -0
- package/filters/index.d.ts +1 -0
- package/filters/index.js +17 -0
- package/filters-button/filters-button.d.ts +11 -0
- package/{tailwindui/show.js → filters-button/filters-button.js} +15 -6
- package/filters-button/filters-button.stories.d.ts +2 -0
- package/filters-button/filters-button.stories.js +19 -0
- package/filters-button/index.d.ts +1 -0
- package/filters-button/index.js +17 -0
- package/fulltext-input/fulltext-input.d.ts +5 -0
- package/fulltext-input/fulltext-input.js +13 -0
- package/fulltext-input/fulltext-input.stories.d.ts +2 -0
- package/fulltext-input/fulltext-input.stories.js +18 -0
- package/fulltext-input/index.d.ts +1 -0
- package/fulltext-input/index.js +17 -0
- package/hidden-columns/hidden-columns.d.ts +8 -0
- package/hidden-columns/hidden-columns.js +17 -0
- package/hidden-columns/hidden-columns.stories.d.ts +2 -0
- package/hidden-columns/hidden-columns.stories.js +18 -0
- package/hidden-columns/index.d.ts +1 -0
- package/hidden-columns/index.js +17 -0
- package/hidden-columns-button/hidden-columns-button.d.ts +8 -0
- package/{tailwindui/data-grid.js → hidden-columns-button/hidden-columns-button.js} +14 -10
- package/hidden-columns-button/hidden-columns-button.stories.d.ts +2 -0
- package/hidden-columns-button/hidden-columns-button.stories.js +18 -0
- package/hidden-columns-button/index.d.ts +1 -0
- package/hidden-columns-button/index.js +17 -0
- package/linear-progress/index.d.ts +1 -0
- package/linear-progress/index.js +17 -0
- package/linear-progress/linear-progress.d.ts +5 -0
- package/{tailwindui/components → linear-progress}/linear-progress.js +4 -4
- package/package.json +1 -1
- package/pagination/index.d.ts +1 -0
- package/pagination/index.js +17 -0
- package/pagination/pagination.d.ts +8 -0
- package/pagination/pagination.js +16 -0
- package/pagination/pagination.stories.d.ts +2 -0
- package/pagination/pagination.stories.js +18 -0
- package/row-counts/index.d.ts +1 -0
- package/row-counts/index.js +17 -0
- package/row-counts/row-counts.d.ts +7 -0
- package/row-counts/row-counts.js +18 -0
- package/row-counts/row-counts.stories.d.ts +2 -0
- package/row-counts/row-counts.stories.js +15 -0
- package/rows-per-page-select/index.d.ts +1 -0
- package/rows-per-page-select/index.js +17 -0
- package/rows-per-page-select/rows-per-page-select.d.ts +3 -0
- package/{tailwindui/components/pagination-rows-per-page-select.js → rows-per-page-select/rows-per-page-select.js} +5 -5
- package/rows-per-page-select/rows-per-page-select.stories.d.ts +2 -0
- package/rows-per-page-select/rows-per-page-select.stories.js +18 -0
- package/selected-rows-toolbar/index.d.ts +1 -0
- package/selected-rows-toolbar/index.js +17 -0
- package/selected-rows-toolbar/selected-rows-toolbar.d.ts +11 -0
- package/{tailwindui/components → selected-rows-toolbar}/selected-rows-toolbar.js +9 -6
- package/selected-rows-toolbar/selected-rows-toolbar.stories.d.ts +2 -0
- package/{tailwindui/components/select-row-checkbox.js → selected-rows-toolbar/selected-rows-toolbar.stories.js} +15 -14
- package/table/components/select-row-checkbox.d.ts +3 -0
- package/table/components/select-row-checkbox.js +20 -0
- package/table/hooks/use-react-data-grid-columns.d.ts +3 -0
- package/table/hooks/use-react-data-grid-columns.js +92 -0
- package/table/index.d.ts +1 -0
- package/table/index.js +17 -0
- package/table/no-rows-fallback.d.ts +7 -0
- package/{tailwindui/components → table}/no-rows-fallback.js +4 -4
- package/table/table.d.ts +3 -0
- package/table/table.js +80 -0
- package/table/table.stories.d.ts +2 -0
- package/table/table.stories.js +20 -0
- package/table/types.d.ts +26 -0
- package/table/types.js +2 -0
- package/toolbar-control/index.d.ts +1 -0
- package/toolbar-control/index.js +17 -0
- package/toolbar-control/toolbar-control.d.ts +13 -0
- package/toolbar-control/toolbar-control.js +22 -0
- package/toolbar-control/toolbar-control.stories.d.ts +2 -0
- package/toolbar-control/toolbar-control.stories.js +20 -0
- package/toolbar-customs/index.d.ts +1 -0
- package/toolbar-customs/index.js +17 -0
- package/toolbar-customs/toolbar-customs.d.ts +10 -0
- package/{tailwindui/components → toolbar-customs}/toolbar-customs.js +2 -2
- package/toolbar-customs/toolbar-customs.stories.d.ts +2 -0
- package/toolbar-customs/toolbar-customs.stories.js +16 -0
- package/toolbar-tabs/index.d.ts +1 -0
- package/toolbar-tabs/index.js +17 -0
- package/toolbar-tabs/toolbar-tabs.d.ts +7 -0
- package/{tailwindui/components → toolbar-tabs}/toolbar-tabs.js +10 -10
- package/toolbar-tabs/toolbar-tabs.stories.d.ts +2 -0
- package/toolbar-tabs/toolbar-tabs.stories.js +18 -0
- package/types/components.d.ts +5 -160
- package/types/data-grid-props.d.ts +16 -23
- package/types/state.d.ts +7 -3
- package/types/ui-components.d.ts +7 -16
- package/use-data-grid-control/actions-factory.d.ts +14 -0
- package/use-data-grid-control/actions-factory.js +18 -0
- package/use-data-grid-control/index.d.ts +1 -0
- package/use-data-grid-control/index.js +17 -0
- package/use-data-grid-control/use-data-grid-control.d.ts +25 -0
- package/use-data-grid-control/use-data-grid-control.js +12 -0
- package/use-data-grid-fetching/index.d.ts +1 -0
- package/use-data-grid-fetching/index.js +17 -0
- package/use-data-grid-fetching/use-data-grid-fetching.d.ts +16 -0
- package/use-data-grid-fetching/use-data-grid-fetching.js +37 -0
- package/utils/classes.d.ts +1 -0
- package/utils/classes.js +4 -0
- package/utils.d.ts +4 -5
- package/utils.js +9 -60
- package/hooks/useColumns.d.ts +0 -3
- package/hooks/useColumns.js +0 -97
- package/store/reducer.d.ts +0 -5
- package/tailwindui/components/container.d.ts +0 -2
- package/tailwindui/components/container.js +0 -13
- package/tailwindui/components/filter-list.d.ts +0 -2
- package/tailwindui/components/footer.d.ts +0 -2
- package/tailwindui/components/footer.js +0 -12
- package/tailwindui/components/linear-progress.d.ts +0 -2
- package/tailwindui/components/no-rows-fallback.d.ts +0 -2
- package/tailwindui/components/pagination-counts.d.ts +0 -2
- package/tailwindui/components/pagination-counts.js +0 -18
- package/tailwindui/components/pagination-rows-per-page-select.d.ts +0 -2
- package/tailwindui/components/select-row-checkbox.d.ts +0 -2
- package/tailwindui/components/selected-rows-toolbar.d.ts +0 -2
- package/tailwindui/components/toolbar-control.d.ts +0 -2
- package/tailwindui/components/toolbar-control.js +0 -86
- package/tailwindui/components/toolbar-customs.d.ts +0 -2
- package/tailwindui/components/toolbar-tabs.d.ts +0 -2
- package/tailwindui/components/toolbar.d.ts +0 -2
- package/tailwindui/components/toolbar.js +0 -12
- package/tailwindui/data-grid.d.ts +0 -6
- package/tailwindui/filter-handler/index.d.ts +0 -2
- package/tailwindui/index.d.ts +0 -3
- package/tailwindui/show.d.ts +0 -7
- package/tailwindui/styles.css +0 -592
- package/tailwindui/ui.d.ts +0 -2
- package/tailwindui/ui.js +0 -38
- /package/{tailwindui/components → _components}/drawer.d.ts +0 -0
- /package/{tailwindui/components → _components}/drawer.js +0 -0
- /package/{store → _store}/actions.d.ts +0 -0
- /package/{store → _store}/actions.js +0 -0
- /package/{tailwindui/body-cell → body-cell}/body-cell-boolean.js +0 -0
- /package/{tailwindui/body-cell → body-cell}/body-cell-date.js +0 -0
- /package/{tailwindui/body-cell → body-cell}/body-cell-datetime.js +0 -0
- /package/{tailwindui/body-cell → body-cell}/body-cell-default.js +0 -0
- /package/{tailwindui/body-cell → body-cell}/body-cell-email.js +0 -0
- /package/{tailwindui/body-cell → body-cell}/body-cell-phone.js +0 -0
- /package/{tailwindui/body-cell → body-cell}/body-cell-to-many.js +0 -0
- /package/{tailwindui/body-cell → body-cell}/body-cell-to-one.js +0 -0
- /package/{tailwindui/body-cell → body-cell}/body-cell-url.js +0 -0
- /package/{tailwindui/body-cell → body-cell}/index.js +0 -0
- /package/{tailwindui/filter-handler → filter-handler}/bool-filter.js +0 -0
- /package/{tailwindui/filter-handler → filter-handler}/boolean-filter.js +0 -0
- /package/{tailwindui/filter-handler → filter-handler}/select-filter.js +0 -0
- /package/{tailwindui/filter-handler → filter-handler}/text-filter.js +0 -0
- /package/{tailwindui → table}/components/action-cell-base.d.ts +0 -0
- /package/{tailwindui → table}/components/action-cell-base.js +0 -0
|
@@ -23,18 +23,19 @@ var __importStar = (this && this.__importStar) || function (mod) {
|
|
|
23
23
|
return result;
|
|
24
24
|
};
|
|
25
25
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
26
|
-
exports.
|
|
27
|
-
const
|
|
26
|
+
exports.Default = void 0;
|
|
27
|
+
const json_renderer_1 = require("@uxf/example/src/components/json-renderer");
|
|
28
28
|
const react_1 = __importStar(require("react"));
|
|
29
|
-
const
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
}
|
|
36
|
-
};
|
|
37
|
-
return (react_1.default.createElement(
|
|
38
|
-
react_1.default.createElement(
|
|
39
|
-
};
|
|
40
|
-
|
|
29
|
+
const schema_1 = require("../_story-utils/schema");
|
|
30
|
+
const use_data_grid_control_1 = require("../use-data-grid-control");
|
|
31
|
+
const selected_rows_toolbar_1 = require("./selected-rows-toolbar");
|
|
32
|
+
function Default() {
|
|
33
|
+
const { state, actions } = (0, use_data_grid_control_1.useDataGridControl)({ schema: schema_1.schema });
|
|
34
|
+
(0, react_1.useEffect)(() => {
|
|
35
|
+
actions.setSelectedRows([{ id: 1 }, { id: 2 }]);
|
|
36
|
+
}, [actions]);
|
|
37
|
+
return (react_1.default.createElement(react_1.default.Fragment, null,
|
|
38
|
+
react_1.default.createElement(selected_rows_toolbar_1.SelectedRowsToolbar, { state: state, actions: actions }),
|
|
39
|
+
react_1.default.createElement(json_renderer_1.JsonRenderer, { value: state })));
|
|
40
|
+
}
|
|
41
|
+
exports.Default = Default;
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.SelectRowCheckbox = void 0;
|
|
7
|
+
const checkbox_1 = require("@uxf/ui/checkbox");
|
|
8
|
+
const react_1 = __importDefault(require("react"));
|
|
9
|
+
function SelectRowCheckbox(props) {
|
|
10
|
+
var _a;
|
|
11
|
+
const handleChange = (value, e) => {
|
|
12
|
+
if (typeof value !== "undefined") {
|
|
13
|
+
const shiftKey = (e === null || e === void 0 ? void 0 : e.nativeEvent) && e.nativeEvent instanceof MouseEvent ? e.nativeEvent.shiftKey : false;
|
|
14
|
+
props.onChange(value, shiftKey);
|
|
15
|
+
}
|
|
16
|
+
};
|
|
17
|
+
return (react_1.default.createElement("div", { className: "uxf-data-grid__select-row-checkbox-wrapper" },
|
|
18
|
+
react_1.default.createElement(checkbox_1.Checkbox, { ...props, value: (_a = props.checked) !== null && _a !== void 0 ? _a : false, onChange: handleChange })));
|
|
19
|
+
}
|
|
20
|
+
exports.SelectRowCheckbox = SelectRowCheckbox;
|
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
25
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
26
|
+
exports.useReactDataGridColumns = void 0;
|
|
27
|
+
const cx_1 = require("@uxf/core/utils/cx");
|
|
28
|
+
const is_not_nil_1 = require("@uxf/core/utils/is-not-nil");
|
|
29
|
+
const react_1 = __importStar(require("react"));
|
|
30
|
+
const react_data_grid_1 = require("react-data-grid");
|
|
31
|
+
const action_cell_base_1 = require("../components/action-cell-base");
|
|
32
|
+
function useReactDataGridColumns(props) {
|
|
33
|
+
var _a;
|
|
34
|
+
const { onReload, actionCellWidth, schema, isRowSelectable, BodyCells, getOpenUrl, onOpen, getEditUrl, onEdit, onRemove, } = props;
|
|
35
|
+
const ActionCell = (_a = props.ActionCell) !== null && _a !== void 0 ? _a : action_cell_base_1.ActionCellBase;
|
|
36
|
+
return (0, react_1.useMemo)(() => {
|
|
37
|
+
const columns = [];
|
|
38
|
+
if (isRowSelectable) {
|
|
39
|
+
columns.push(react_data_grid_1.SelectColumn);
|
|
40
|
+
}
|
|
41
|
+
for (const schemaColumn of schema.columns) {
|
|
42
|
+
columns.push({
|
|
43
|
+
key: schemaColumn.name,
|
|
44
|
+
name: schemaColumn.label,
|
|
45
|
+
headerCellClass: (0, cx_1.cx)("uxf-data-grid__cell", "uxf-data-grid__cell--header", `uxf-data-grid__cell--type-${schemaColumn.type}`, `uxf-data-grid__cell--name-${schemaColumn.name}`),
|
|
46
|
+
resizable: true,
|
|
47
|
+
sortable: schemaColumn.sort,
|
|
48
|
+
width: schemaColumn.width,
|
|
49
|
+
minWidth: schemaColumn.minWidth,
|
|
50
|
+
maxWidth: schemaColumn.maxWidth,
|
|
51
|
+
cellClass: (0, cx_1.cx)("uxf-data-grid__cell", `uxf-data-grid__cell--type-${schemaColumn.type}`, `uxf-data-grid__cell--name-${schemaColumn.name}`),
|
|
52
|
+
renderCell: (p) => {
|
|
53
|
+
var _a;
|
|
54
|
+
const columnType = schemaColumn.type;
|
|
55
|
+
const BodyCell = (_a = BodyCells === null || BodyCells === void 0 ? void 0 : BodyCells[columnType]) !== null && _a !== void 0 ? _a : BodyCells === null || BodyCells === void 0 ? void 0 : BodyCells.default;
|
|
56
|
+
if (!BodyCell) {
|
|
57
|
+
return null;
|
|
58
|
+
}
|
|
59
|
+
return (react_1.default.createElement(BodyCell, { column: {
|
|
60
|
+
name: p.column.key,
|
|
61
|
+
label: p.column.name,
|
|
62
|
+
sort: p.column.sortable,
|
|
63
|
+
type: columnType,
|
|
64
|
+
}, row: p.row, value: p.row[p.column.key], reload: () => onReload === null || onReload === void 0 ? void 0 : onReload() }));
|
|
65
|
+
},
|
|
66
|
+
});
|
|
67
|
+
}
|
|
68
|
+
columns.push({
|
|
69
|
+
key: "__action_column",
|
|
70
|
+
name: "",
|
|
71
|
+
resizable: false,
|
|
72
|
+
headerCellClass: "uxf-data-grid__action-cell",
|
|
73
|
+
cellClass: "uxf-data-grid__action-cell",
|
|
74
|
+
width: actionCellWidth,
|
|
75
|
+
renderCell: (p) => (0, is_not_nil_1.isNotNil)(ActionCell) ? (react_1.default.createElement(ActionCell, { reload: async () => onReload === null || onReload === void 0 ? void 0 : onReload(), row: p.row, getEditUrl: getEditUrl, onEdit: onEdit, getOpenUrl: getOpenUrl, onOpen: onOpen, onRemove: onRemove })) : null,
|
|
76
|
+
});
|
|
77
|
+
return columns;
|
|
78
|
+
}, [
|
|
79
|
+
ActionCell,
|
|
80
|
+
actionCellWidth,
|
|
81
|
+
schema.columns,
|
|
82
|
+
BodyCells,
|
|
83
|
+
isRowSelectable,
|
|
84
|
+
onOpen,
|
|
85
|
+
getOpenUrl,
|
|
86
|
+
onEdit,
|
|
87
|
+
getEditUrl,
|
|
88
|
+
onRemove,
|
|
89
|
+
onReload,
|
|
90
|
+
]);
|
|
91
|
+
}
|
|
92
|
+
exports.useReactDataGridColumns = useReactDataGridColumns;
|
package/table/index.d.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from "./table";
|
package/table/index.js
ADDED
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./table"), exports);
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import React, { FC } from "react";
|
|
2
|
+
export interface NoRowsFallbackProps {
|
|
3
|
+
error?: any;
|
|
4
|
+
loading: boolean;
|
|
5
|
+
}
|
|
6
|
+
export type NoRowsFallbackComponent = FC<NoRowsFallbackProps>;
|
|
7
|
+
export declare function NoRowsFallback(props: NoRowsFallbackProps): React.JSX.Element;
|
|
@@ -4,12 +4,12 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
4
4
|
};
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
6
|
exports.NoRowsFallback = void 0;
|
|
7
|
+
const cx_1 = require("@uxf/core/utils/cx");
|
|
7
8
|
const icon_1 = require("@uxf/ui/icon");
|
|
8
9
|
const react_1 = __importDefault(require("react"));
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
return (react_1.default.createElement("div", { className: (0, utils_1.cx)("uxf-data-grid__fallback", props.loading && "is-loading", props.error && "is-error") }, props.loading ? (react_1.default.createElement(react_1.default.Fragment, null, "Na\u010D\u00EDt\u00E1m...")) : props.error ? (react_1.default.createElement(react_1.default.Fragment, null,
|
|
10
|
+
function NoRowsFallback(props) {
|
|
11
|
+
return (react_1.default.createElement("div", { className: (0, cx_1.cx)("uxf-data-grid__fallback", props.loading && "is-loading", props.error && "is-error") }, props.loading ? (react_1.default.createElement(react_1.default.Fragment, null, "Na\u010D\u00EDt\u00E1m...")) : props.error ? (react_1.default.createElement(react_1.default.Fragment, null,
|
|
12
12
|
react_1.default.createElement(icon_1.Icon, { name: "warning", size: 24 }),
|
|
13
13
|
react_1.default.createElement("p", null, "Vyskytla se chyba"))) : (react_1.default.createElement(react_1.default.Fragment, null, "\u017D\u00E1dn\u00E9 z\u00E1znamy"))));
|
|
14
|
-
}
|
|
14
|
+
}
|
|
15
15
|
exports.NoRowsFallback = NoRowsFallback;
|
package/table/table.d.ts
ADDED
package/table/table.js
ADDED
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
25
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
26
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
27
|
+
};
|
|
28
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
29
|
+
exports.Table = void 0;
|
|
30
|
+
const useIsMounted_1 = require("@uxf/core/hooks/useIsMounted");
|
|
31
|
+
const react_1 = __importStar(require("react"));
|
|
32
|
+
const react_data_grid_1 = __importDefault(require("react-data-grid"));
|
|
33
|
+
const select_row_checkbox_1 = require("./components/select-row-checkbox");
|
|
34
|
+
const use_react_data_grid_columns_1 = require("./hooks/use-react-data-grid-columns");
|
|
35
|
+
const defaultKeyExtractor = (r) => r.id;
|
|
36
|
+
const DefaultNoRowsFallback = () => react_1.default.createElement("div", null, "no rows");
|
|
37
|
+
function Table(props) {
|
|
38
|
+
var _a, _b, _c, _d, _e, _f, _g;
|
|
39
|
+
const isMounted = (0, useIsMounted_1.useIsMounted)();
|
|
40
|
+
const rowHeight = (_a = props.rowHeight) !== null && _a !== void 0 ? _a : 44;
|
|
41
|
+
const headerRowHeight = (_b = props.headerRowHeight) !== null && _b !== void 0 ? _b : 36;
|
|
42
|
+
const keyExtractor = (_c = props.keyExtractor) !== null && _c !== void 0 ? _c : defaultKeyExtractor;
|
|
43
|
+
const contentHeight = typeof rowHeight === "function"
|
|
44
|
+
? props.data.reduce((prev, curr) => prev + rowHeight({ type: "ROW", row: curr }))
|
|
45
|
+
: (rowHeight + 1) * props.data.length;
|
|
46
|
+
const reactDataGridStyles = {
|
|
47
|
+
border: 0,
|
|
48
|
+
borderRadius: 4,
|
|
49
|
+
height: contentHeight + headerRowHeight + (props.data.length === 0 ? 44 : 0) + 4,
|
|
50
|
+
overflowY: "hidden",
|
|
51
|
+
};
|
|
52
|
+
const NoRowsFallback = (_d = props.NoRowsFallback) !== null && _d !== void 0 ? _d : DefaultNoRowsFallback;
|
|
53
|
+
const isLoading = !!props.isLoading;
|
|
54
|
+
const error = props.error;
|
|
55
|
+
const components = (0, react_1.useMemo)(() => ({
|
|
56
|
+
renderCheckbox: (args) => react_1.default.createElement(select_row_checkbox_1.SelectRowCheckbox, { ...args }),
|
|
57
|
+
noRowsFallback: react_1.default.createElement(NoRowsFallback, { error: error, loading: isLoading }),
|
|
58
|
+
}), [NoRowsFallback, error, isLoading]);
|
|
59
|
+
const columns = (0, use_react_data_grid_columns_1.useReactDataGridColumns)(props);
|
|
60
|
+
const onSelectRows = (value) => {
|
|
61
|
+
const selectedRows = Array.from(value).map((id) => props.data.find((row) => keyExtractor(row) === id));
|
|
62
|
+
props.actions.setSelectedRows(selectedRows);
|
|
63
|
+
};
|
|
64
|
+
const onSortColumnChange = (sortColumns) => {
|
|
65
|
+
if (sortColumns.length > 0) {
|
|
66
|
+
props.actions.sort(sortColumns[0].columnKey, sortColumns[0].direction.toLowerCase());
|
|
67
|
+
}
|
|
68
|
+
else {
|
|
69
|
+
props.actions.sortClear();
|
|
70
|
+
}
|
|
71
|
+
};
|
|
72
|
+
const sortColumns = props.state.request.sort && props.state.request.dir
|
|
73
|
+
? [{ columnKey: props.state.request.sort, direction: props.state.request.dir.toUpperCase() }]
|
|
74
|
+
: [];
|
|
75
|
+
if (!isMounted) {
|
|
76
|
+
return null;
|
|
77
|
+
}
|
|
78
|
+
return (react_1.default.createElement(react_data_grid_1.default, { style: reactDataGridStyles, className: "uxf-data-grid__table", columns: columns, rows: props.data, enableVirtualization: false, onSortColumnsChange: onSortColumnChange, sortColumns: sortColumns, rowHeight: rowHeight, headerRowHeight: headerRowHeight, rowClass: props.rowClass, rowKeyGetter: (_e = props.keyExtractor) !== null && _e !== void 0 ? _e : defaultKeyExtractor, selectedRows: new Set((_g = (_f = props.state.selectedRows) === null || _f === void 0 ? void 0 : _f.map(keyExtractor)) !== null && _g !== void 0 ? _g : []), onSelectedRowsChange: onSelectRows, renderers: components }));
|
|
79
|
+
}
|
|
80
|
+
exports.Table = Table;
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.Default = void 0;
|
|
7
|
+
const json_renderer_1 = require("@uxf/example/src/components/json-renderer");
|
|
8
|
+
const react_1 = __importDefault(require("react"));
|
|
9
|
+
const data_1 = require("../_story-utils/data");
|
|
10
|
+
const schema_1 = require("../_story-utils/schema");
|
|
11
|
+
const body_cell_1 = require("../body-cell");
|
|
12
|
+
const use_data_grid_control_1 = require("../use-data-grid-control");
|
|
13
|
+
const table_1 = require("./table");
|
|
14
|
+
function Default() {
|
|
15
|
+
const { state, actions } = (0, use_data_grid_control_1.useDataGridControl)({ schema: schema_1.schema });
|
|
16
|
+
return (react_1.default.createElement(react_1.default.Fragment, null,
|
|
17
|
+
react_1.default.createElement(table_1.Table, { state: state, actions: actions, data: data_1.data, isLoading: true, error: undefined, schema: schema_1.schema, BodyCells: body_cell_1.BodyCells, isRowSelectable: true, onOpen: console.log, onEdit: console.log, onRemove: console.log }),
|
|
18
|
+
react_1.default.createElement(json_renderer_1.JsonRenderer, { value: state })));
|
|
19
|
+
}
|
|
20
|
+
exports.Default = Default;
|
package/table/types.d.ts
ADDED
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { Nullish } from "@uxf/core/types";
|
|
2
|
+
import { DataGridProps as RDGProps } from "react-data-grid";
|
|
3
|
+
import { ActionCellComponent, BodyCellComponents, KeyExtractor, Schema } from "../types";
|
|
4
|
+
import { DataGridControl } from "../use-data-grid-control";
|
|
5
|
+
import { NoRowsFallbackComponent } from "./no-rows-fallback";
|
|
6
|
+
export interface TableProps<Row> extends DataGridControl {
|
|
7
|
+
schema: Schema<any>;
|
|
8
|
+
data: Row[];
|
|
9
|
+
isLoading?: boolean;
|
|
10
|
+
error?: any | Nullish;
|
|
11
|
+
onReload?: () => void;
|
|
12
|
+
rowHeight?: RDGProps<any>["rowHeight"];
|
|
13
|
+
headerRowHeight?: RDGProps<any>["headerRowHeight"];
|
|
14
|
+
rowClass?: (row: Row) => "success" | "warning" | "error" | "primary" | "secondary" | string | null | undefined;
|
|
15
|
+
keyExtractor?: KeyExtractor;
|
|
16
|
+
BodyCells?: BodyCellComponents<any, any>;
|
|
17
|
+
ActionCell?: ActionCellComponent<any>;
|
|
18
|
+
actionCellWidth?: number;
|
|
19
|
+
NoRowsFallback?: NoRowsFallbackComponent;
|
|
20
|
+
isRowSelectable?: boolean;
|
|
21
|
+
onOpen?: (row: Row) => void;
|
|
22
|
+
getOpenUrl?: (row: Row) => string | null | undefined;
|
|
23
|
+
onEdit?: (row: Row) => void;
|
|
24
|
+
getEditUrl?: (row: Row) => string | null | undefined;
|
|
25
|
+
onRemove?: (row: Row, reload: () => void) => void;
|
|
26
|
+
}
|
package/table/types.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from "./toolbar-control";
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./toolbar-control"), exports);
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { Nullish } from "@uxf/core/types";
|
|
2
|
+
import React from "react";
|
|
3
|
+
import { FilterHandlers } from "../filter-handler";
|
|
4
|
+
import { CsvDownloadHandler, Schema } from "../types";
|
|
5
|
+
import { DataGridControl } from "../use-data-grid-control";
|
|
6
|
+
export interface ToolbarControlProps extends DataGridControl {
|
|
7
|
+
gridName: string | undefined;
|
|
8
|
+
schema: Schema<any>;
|
|
9
|
+
filterHandlers: FilterHandlers;
|
|
10
|
+
onCsvDownload?: CsvDownloadHandler;
|
|
11
|
+
isBorderHidden?: boolean | Nullish;
|
|
12
|
+
}
|
|
13
|
+
export declare function ToolbarControl(props: ToolbarControlProps): React.JSX.Element;
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.ToolbarControl = void 0;
|
|
7
|
+
const hide_1 = require("@uxf/core/components/hide");
|
|
8
|
+
const is_not_nil_1 = require("@uxf/core/utils/is-not-nil");
|
|
9
|
+
const react_1 = __importDefault(require("react"));
|
|
10
|
+
const export_button_1 = require("../export-button");
|
|
11
|
+
const filters_button_1 = require("../filters-button");
|
|
12
|
+
const fulltext_input_1 = require("../fulltext-input");
|
|
13
|
+
const hidden_columns_button_1 = require("../hidden-columns-button");
|
|
14
|
+
function ToolbarControl(props) {
|
|
15
|
+
return (react_1.default.createElement("div", { className: "uxf-data-grid__toolbar-control" },
|
|
16
|
+
react_1.default.createElement(hide_1.Hide, { when: !props.schema.fullText },
|
|
17
|
+
react_1.default.createElement(fulltext_input_1.FulltextInput, { state: props.state, actions: props.actions })),
|
|
18
|
+
react_1.default.createElement(filters_button_1.FiltersButton, { state: props.state, actions: props.actions, gridName: props.gridName, schema: props.schema, filterHandlers: props.filterHandlers }),
|
|
19
|
+
react_1.default.createElement(hidden_columns_button_1.HiddenColumnsButton, { state: props.state, actions: props.actions, schema: props.schema }),
|
|
20
|
+
(0, is_not_nil_1.isNotNil)(props.onCsvDownload) && (react_1.default.createElement(export_button_1.ExportButton, { state: props.state, actions: props.actions, schema: props.schema, onCsvDownload: props.onCsvDownload }))));
|
|
21
|
+
}
|
|
22
|
+
exports.ToolbarControl = ToolbarControl;
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.Default = void 0;
|
|
7
|
+
const json_renderer_1 = require("@uxf/example/src/components/json-renderer");
|
|
8
|
+
const react_1 = __importDefault(require("react"));
|
|
9
|
+
const schema_1 = require("../_story-utils/schema");
|
|
10
|
+
const filter_handler_1 = require("../filter-handler");
|
|
11
|
+
const use_data_grid_control_1 = require("../use-data-grid-control");
|
|
12
|
+
const toolbar_control_1 = require("./toolbar-control");
|
|
13
|
+
function Default() {
|
|
14
|
+
const { state, actions } = (0, use_data_grid_control_1.useDataGridControl)({ schema: schema_1.schema });
|
|
15
|
+
return (react_1.default.createElement(react_1.default.Fragment, null,
|
|
16
|
+
react_1.default.createElement("div", { className: "flex flex-row" },
|
|
17
|
+
react_1.default.createElement(toolbar_control_1.ToolbarControl, { state: state, actions: actions, schema: schema_1.schema, filterHandlers: filter_handler_1.defaultFilterHandlers, gridName: "grid-name", onCsvDownload: console.log })),
|
|
18
|
+
react_1.default.createElement(json_renderer_1.JsonRenderer, { value: state })));
|
|
19
|
+
}
|
|
20
|
+
exports.Default = Default;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from "./toolbar-customs";
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./toolbar-customs"), exports);
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import React, { ReactElement } from "react";
|
|
2
|
+
export interface ToolbarCustomsProps {
|
|
3
|
+
buttons?: {
|
|
4
|
+
label: string | ReactElement;
|
|
5
|
+
onClick?: () => void;
|
|
6
|
+
href?: string;
|
|
7
|
+
variant?: "default" | "outlined" | "text";
|
|
8
|
+
}[];
|
|
9
|
+
}
|
|
10
|
+
export declare function ToolbarCustoms(props: ToolbarCustomsProps): React.JSX.Element | null;
|
|
@@ -7,12 +7,12 @@ exports.ToolbarCustoms = void 0;
|
|
|
7
7
|
const button_1 = require("@uxf/ui/button");
|
|
8
8
|
const button_list_1 = require("@uxf/ui/button-list");
|
|
9
9
|
const react_1 = __importDefault(require("react"));
|
|
10
|
-
|
|
10
|
+
function ToolbarCustoms(props) {
|
|
11
11
|
if (!props.buttons) {
|
|
12
12
|
return null;
|
|
13
13
|
}
|
|
14
14
|
return (react_1.default.createElement("div", { className: "uxf-data-grid__toolbar-customs" },
|
|
15
15
|
react_1.default.createElement("div", { className: "uxf-data-grid__toolbar-customs-mobile" }, props.buttons.length === 1 ? (react_1.default.createElement(button_1.Button, { href: props.buttons[0].href, onClick: props.buttons[0].onClick, size: "sm", variant: props.buttons[0].variant }, props.buttons[0].label)) : (react_1.default.createElement(button_list_1.ButtonList, { buttons: props.buttons, visibleButtonsCount: 1, size: "sm", openButton: { variant: "white" } }))),
|
|
16
16
|
react_1.default.createElement("div", { className: "uxf-data-grid__toolbar-customs-desktop" }, props.buttons.map((button, index) => (react_1.default.createElement(button_1.Button, { key: index, href: button.href, onClick: button.onClick, size: "sm", variant: button.variant }, button.label))))));
|
|
17
|
-
}
|
|
17
|
+
}
|
|
18
18
|
exports.ToolbarCustoms = ToolbarCustoms;
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.Default = void 0;
|
|
7
|
+
const react_1 = __importDefault(require("react"));
|
|
8
|
+
const toolbar_customs_1 = require("./toolbar-customs");
|
|
9
|
+
function Default() {
|
|
10
|
+
return (react_1.default.createElement(toolbar_customs_1.ToolbarCustoms, { buttons: [
|
|
11
|
+
{ label: "Default", href: "/", variant: "default" },
|
|
12
|
+
{ label: "Text", href: "/", variant: "text" },
|
|
13
|
+
{ label: "Outlined", href: "/", variant: "outlined" },
|
|
14
|
+
] }));
|
|
15
|
+
}
|
|
16
|
+
exports.Default = Default;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from "./toolbar-tabs";
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./toolbar-tabs"), exports);
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import { Schema } from "../types/schema";
|
|
3
|
+
import { DataGridControl } from "../use-data-grid-control";
|
|
4
|
+
export interface ToolbarTabsProps extends DataGridControl {
|
|
5
|
+
schema: Schema<any>;
|
|
6
|
+
}
|
|
7
|
+
export declare function ToolbarTabs(props: ToolbarTabsProps): React.JSX.Element;
|
|
@@ -4,33 +4,33 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
4
4
|
};
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
6
|
exports.ToolbarTabs = void 0;
|
|
7
|
+
const show_1 = require("@uxf/core/components/show");
|
|
8
|
+
const cx_1 = require("@uxf/core/utils/cx");
|
|
7
9
|
const button_1 = require("@uxf/ui/button");
|
|
8
10
|
const icon_1 = require("@uxf/ui/icon");
|
|
9
11
|
const modal_service_1 = require("@uxf/ui/modal/modal-service");
|
|
10
12
|
const react_1 = __importDefault(require("react"));
|
|
11
|
-
const utils_1 = require("../../utils");
|
|
12
|
-
const show_1 = require("../show");
|
|
13
13
|
function Tab(props) {
|
|
14
|
-
return (react_1.default.createElement("button", { className: (0,
|
|
14
|
+
return (react_1.default.createElement("button", { className: (0, cx_1.cx)("uxf-data-grid__toolbar-tab", props.isActive && "is-active"), onClick: props.onClick }, props.title));
|
|
15
15
|
}
|
|
16
|
-
|
|
16
|
+
function ToolbarTabs(props) {
|
|
17
17
|
var _a, _b, _c, _d;
|
|
18
|
-
return (react_1.default.createElement(show_1.Show, { when: (_a = props.schema.tabs) === null || _a === void 0 ? void 0 : _a.length },
|
|
18
|
+
return (react_1.default.createElement(show_1.Show, { when: !!((_a = props.schema.tabs) === null || _a === void 0 ? void 0 : _a.length) },
|
|
19
19
|
react_1.default.createElement("div", { className: "uxf-data-grid__toolbar-tabs" },
|
|
20
|
-
react_1.default.createElement("nav", { className: "uxf-data-grid__toolbar-tabs-nav uxf-data-grid__toolbar-tabs-nav--desktop", "aria-label": "Tabs" }, (_b = props.schema.tabs) === null || _b === void 0 ? void 0 : _b.map((t) => (react_1.default.createElement(Tab, { key: t.name, title: t.label, isActive: props.
|
|
20
|
+
react_1.default.createElement("nav", { className: "uxf-data-grid__toolbar-tabs-nav uxf-data-grid__toolbar-tabs-nav--desktop", "aria-label": "Tabs" }, (_b = props.schema.tabs) === null || _b === void 0 ? void 0 : _b.map((t) => (react_1.default.createElement(Tab, { key: t.name, title: t.label, isActive: props.state.request.tab === t.name, onClick: () => props.actions.changeTab(t.name) })))),
|
|
21
21
|
react_1.default.createElement("nav", { className: "uxf-data-grid__toolbar-tabs-nav uxf-data-grid__toolbar-tabs-nav--mobile" },
|
|
22
22
|
react_1.default.createElement(button_1.Button, { variant: "text", className: "uxf-data-grid__toolbar-tabs-button", size: "sm", onClick: () => {
|
|
23
23
|
var _a;
|
|
24
24
|
return (0, modal_service_1.openModal)({
|
|
25
25
|
children: (react_1.default.createElement("div", { className: "uxf-data-grid__toolbar-tabs-modal-content" }, (_a = props.schema.tabs) === null || _a === void 0 ? void 0 : _a.map((item) => (react_1.default.createElement(button_1.Button, { className: "uxf-data-grid__toolbar-tabs-modal-button", key: item.name, variant: "text", size: "xl", onClick: () => {
|
|
26
|
-
props.
|
|
26
|
+
props.actions.changeTab(item.name);
|
|
27
27
|
(0, modal_service_1.closeModal)();
|
|
28
28
|
} },
|
|
29
|
-
item.name === props.
|
|
29
|
+
item.name === props.state.request.tab && (react_1.default.createElement(icon_1.Icon, { className: "uxf-data-grid__toolbar-tabs-modal-active-tab-icon", name: "check", size: 20 })),
|
|
30
30
|
react_1.default.createElement("span", { className: "uxf-data-grid__toolbar-tabs-modal-button-text" }, item.label)))))),
|
|
31
31
|
});
|
|
32
32
|
} },
|
|
33
|
-
react_1.default.createElement("span", { className: "uxf-data-grid__toolbar-tabs-nav-text" }, (_d = (_c = props.schema.tabs) === null || _c === void 0 ? void 0 : _c.find((t) => t.name === props.
|
|
33
|
+
react_1.default.createElement("span", { className: "uxf-data-grid__toolbar-tabs-nav-text" }, (_d = (_c = props.schema.tabs) === null || _c === void 0 ? void 0 : _c.find((t) => t.name === props.state.request.tab)) === null || _d === void 0 ? void 0 : _d.label),
|
|
34
34
|
react_1.default.createElement(icon_1.Icon, { name: "caretDown", className: "uxf-data-grid__toolbar-tabs-button-icon", size: 16 }))))));
|
|
35
|
-
}
|
|
35
|
+
}
|
|
36
36
|
exports.ToolbarTabs = ToolbarTabs;
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.Default = void 0;
|
|
7
|
+
const json_renderer_1 = require("@uxf/example/src/components/json-renderer");
|
|
8
|
+
const react_1 = __importDefault(require("react"));
|
|
9
|
+
const schema_1 = require("../_story-utils/schema");
|
|
10
|
+
const use_data_grid_control_1 = require("../use-data-grid-control");
|
|
11
|
+
const toolbar_tabs_1 = require("./toolbar-tabs");
|
|
12
|
+
function Default() {
|
|
13
|
+
const { state, actions } = (0, use_data_grid_control_1.useDataGridControl)({ schema: schema_1.schema });
|
|
14
|
+
return (react_1.default.createElement(react_1.default.Fragment, null,
|
|
15
|
+
react_1.default.createElement(toolbar_tabs_1.ToolbarTabs, { state: state, actions: actions, schema: schema_1.schema }),
|
|
16
|
+
react_1.default.createElement(json_renderer_1.JsonRenderer, { value: state })));
|
|
17
|
+
}
|
|
18
|
+
exports.Default = Default;
|