@1money/component-ui 0.0.46 → 0.0.47
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/es/components/Table/Table.d.ts +2 -2
- package/es/components/Table/Table.js +25 -148
- package/es/components/Table/VirtualTable.d.ts +2 -2
- package/es/components/Table/VirtualTable.js +30 -143
- package/es/components/Table/core/useTableColumns.d.ts +21 -7
- package/es/components/Table/core/useTableColumns.js +65 -13
- package/es/components/Table/core/useTableDataPipeline.d.ts +13 -6
- package/es/components/Table/core/useTableDataPipeline.js +193 -27
- package/es/components/Table/core/useTableExpand.d.ts +2 -2
- package/es/components/Table/core/useTableSelection.d.ts +3 -5
- package/es/components/Table/core/useTableSelection.js +1 -1
- package/es/components/Table/core/useTableSetup.d.ts +42 -0
- package/es/components/Table/core/useTableSetup.js +175 -0
- package/es/components/Table/features/ExpandTrigger.js +2 -1
- package/es/components/Table/features/FilterTrigger.d.ts +9 -0
- package/es/components/Table/features/FilterTrigger.js +157 -0
- package/es/components/Table/features/SelectionColumn.d.ts +3 -2
- package/es/components/Table/features/SelectionColumn.js +19 -6
- package/es/components/Table/interface.d.ts +102 -21
- package/es/components/Table/renderers/BodyCell.d.ts +4 -4
- package/es/components/Table/renderers/BodyCell.js +1 -1
- package/es/components/Table/renderers/HeaderCell.d.ts +8 -4
- package/es/components/Table/renderers/HeaderCell.js +13 -3
- package/es/components/Table/style/Table.css +1 -1
- package/es/index.css +1 -1
- package/lib/components/Table/Table.d.ts +2 -2
- package/lib/components/Table/Table.js +24 -150
- package/lib/components/Table/VirtualTable.d.ts +2 -2
- package/lib/components/Table/VirtualTable.js +28 -144
- package/lib/components/Table/core/useTableColumns.d.ts +21 -7
- package/lib/components/Table/core/useTableColumns.js +65 -13
- package/lib/components/Table/core/useTableDataPipeline.d.ts +13 -6
- package/lib/components/Table/core/useTableDataPipeline.js +192 -26
- package/lib/components/Table/core/useTableExpand.d.ts +2 -2
- package/lib/components/Table/core/useTableSelection.d.ts +3 -5
- package/lib/components/Table/core/useTableSelection.js +1 -1
- package/lib/components/Table/core/useTableSetup.d.ts +42 -0
- package/lib/components/Table/core/useTableSetup.js +184 -0
- package/lib/components/Table/features/ExpandTrigger.js +2 -1
- package/lib/components/Table/features/FilterTrigger.d.ts +9 -0
- package/lib/components/Table/features/FilterTrigger.js +164 -0
- package/lib/components/Table/features/SelectionColumn.d.ts +3 -2
- package/lib/components/Table/features/SelectionColumn.js +19 -6
- package/lib/components/Table/interface.d.ts +102 -21
- package/lib/components/Table/renderers/BodyCell.d.ts +4 -4
- package/lib/components/Table/renderers/BodyCell.js +1 -1
- package/lib/components/Table/renderers/HeaderCell.d.ts +8 -4
- package/lib/components/Table/renderers/HeaderCell.js +13 -3
- package/lib/components/Table/style/Table.css +1 -1
- package/lib/index.css +1 -1
- package/package.json +1 -1
- package/scripts/mcp-server/examples.generated.json +120 -0
- package/scripts/mcp-server/index.generated.json +336 -14
|
@@ -0,0 +1,184 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _typeof = require("@babel/runtime/helpers/typeof");
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports.useTableSetup = void 0;
|
|
8
|
+
var _jsxRuntime = require("react/jsx-runtime");
|
|
9
|
+
var _react = require("react");
|
|
10
|
+
var _hooks = require("@1money/hooks");
|
|
11
|
+
var _classnames = _interopRequireWildcard(require("../../../utils/classnames"));
|
|
12
|
+
var _Pagination = require("../../Pagination");
|
|
13
|
+
var _ExpandedRowContainer = require("../renderers/ExpandedRowContainer");
|
|
14
|
+
var _EmptyState = require("../renderers/EmptyState");
|
|
15
|
+
var _constants = require("../constants");
|
|
16
|
+
var _useTableDataPipeline = require("./useTableDataPipeline");
|
|
17
|
+
var _useTableSelection = require("./useTableSelection");
|
|
18
|
+
var _useTableExpand = require("./useTableExpand");
|
|
19
|
+
var _useTableColumns = require("./useTableColumns");
|
|
20
|
+
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
|
|
21
|
+
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
|
|
22
|
+
var __rest = void 0 && (void 0).__rest || function (s, e) {
|
|
23
|
+
var t = {};
|
|
24
|
+
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];
|
|
25
|
+
if (s != null && typeof Object.getOwnPropertySymbols === "function") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
|
|
26
|
+
if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];
|
|
27
|
+
}
|
|
28
|
+
return t;
|
|
29
|
+
};
|
|
30
|
+
/**
|
|
31
|
+
* Centralises the wiring shared by `Table` and `VirtualTable`:
|
|
32
|
+
* - destructure props
|
|
33
|
+
* - resolve row key
|
|
34
|
+
* - run pipeline / selection / expand / column transforms
|
|
35
|
+
* - build kernel-ready props
|
|
36
|
+
* - split off pass-through HTML attributes so they can land on the outer wrapper
|
|
37
|
+
* div (instead of being spread untyped into the kernel via `rest as object`).
|
|
38
|
+
*/
|
|
39
|
+
var useTableSetup = exports.useTableSetup = function useTableSetup(props) {
|
|
40
|
+
var _props$className = props.className,
|
|
41
|
+
className = _props$className === void 0 ? '' : _props$className,
|
|
42
|
+
_props$prefixCls = props.prefixCls,
|
|
43
|
+
prefixCls = _props$prefixCls === void 0 ? _constants.TABLE_DEFAULT_PREFIX : _props$prefixCls,
|
|
44
|
+
_props$size = props.size,
|
|
45
|
+
size = _props$size === void 0 ? _constants.TABLE_DEFAULT_SIZE : _props$size,
|
|
46
|
+
_props$variant = props.variant,
|
|
47
|
+
variant = _props$variant === void 0 ? _constants.TABLE_DEFAULT_VARIANT : _props$variant,
|
|
48
|
+
columns = props.columns,
|
|
49
|
+
dataSource = props.dataSource,
|
|
50
|
+
rowKey = props.rowKey,
|
|
51
|
+
empty = props.empty,
|
|
52
|
+
bordered = props.bordered,
|
|
53
|
+
_scroll = props.scroll,
|
|
54
|
+
sticky = props.sticky,
|
|
55
|
+
pagination = props.pagination,
|
|
56
|
+
rowSelection = props.rowSelection,
|
|
57
|
+
_props$loading = props.loading,
|
|
58
|
+
loading = _props$loading === void 0 ? false : _props$loading,
|
|
59
|
+
onChange = props.onChange,
|
|
60
|
+
childrenColumnName = props.childrenColumnName,
|
|
61
|
+
indentSize = props.indentSize,
|
|
62
|
+
expandable = props.expandable,
|
|
63
|
+
onRow = props.onRow,
|
|
64
|
+
rowClassName = props.rowClassName,
|
|
65
|
+
summary = props.summary,
|
|
66
|
+
showHeader = props.showHeader,
|
|
67
|
+
tableLayout = props.tableLayout,
|
|
68
|
+
components = props.components,
|
|
69
|
+
direction = props.direction,
|
|
70
|
+
rowHoverable = props.rowHoverable,
|
|
71
|
+
rest = __rest(props, ["className", "prefixCls", "size", "variant", "columns", "dataSource", "rowKey", "empty", "bordered", "scroll", "sticky", "pagination", "rowSelection", "loading", "onChange", "childrenColumnName", "indentSize", "expandable", "onRow", "rowClassName", "summary", "showHeader", "tableLayout", "components", "direction", "rowHoverable"]);
|
|
72
|
+
void _scroll;
|
|
73
|
+
var cls = (0, _classnames["default"])(_constants.TABLE_BLOCK);
|
|
74
|
+
var getRowKey = (0, _hooks.useMemoizedFn)(function (record, index) {
|
|
75
|
+
var _a;
|
|
76
|
+
return typeof rowKey === 'function' ? rowKey(record) : (_a = record[rowKey !== null && rowKey !== void 0 ? rowKey : 'key']) !== null && _a !== void 0 ? _a : index;
|
|
77
|
+
});
|
|
78
|
+
var pipeline = (0, _useTableDataPipeline.useTableDataPipeline)({
|
|
79
|
+
columns: columns,
|
|
80
|
+
dataSource: dataSource,
|
|
81
|
+
pagination: pagination,
|
|
82
|
+
onChange: onChange
|
|
83
|
+
});
|
|
84
|
+
var selection = (0, _useTableSelection.useTableSelection)({
|
|
85
|
+
rowSelection: rowSelection,
|
|
86
|
+
dataSource: dataSource,
|
|
87
|
+
currentDataSource: pipeline.currentDataSource,
|
|
88
|
+
getRowKey: getRowKey
|
|
89
|
+
});
|
|
90
|
+
var expand = (0, _useTableExpand.useTableExpand)({
|
|
91
|
+
expandable: expandable
|
|
92
|
+
});
|
|
93
|
+
var renderedColumns = (0, _useTableColumns.useTableColumns)({
|
|
94
|
+
columns: columns,
|
|
95
|
+
size: size,
|
|
96
|
+
variant: variant,
|
|
97
|
+
expandable: expandable,
|
|
98
|
+
mergedExpandedRowKeys: expand.mergedExpandedRowKeys,
|
|
99
|
+
triggerExpand: expand.triggerExpand,
|
|
100
|
+
rowSelection: rowSelection,
|
|
101
|
+
mergedSelectedRowKeys: selection.mergedSelectedRowKeys,
|
|
102
|
+
checkboxPropsMap: selection.checkboxPropsMap,
|
|
103
|
+
isAllSelected: selection.isAllSelected,
|
|
104
|
+
isIndeterminate: selection.isIndeterminate,
|
|
105
|
+
triggerSelection: selection.triggerSelection,
|
|
106
|
+
triggerSelectAll: selection.triggerSelectAll,
|
|
107
|
+
sorter: pipeline.sorter,
|
|
108
|
+
setSorter: pipeline.setSorter,
|
|
109
|
+
filters: pipeline.filters,
|
|
110
|
+
setFilters: pipeline.setFilters,
|
|
111
|
+
getRowKey: getRowKey
|
|
112
|
+
});
|
|
113
|
+
var wrappedExpandedRowRender = (0, _hooks.useMemoizedFn)(function (record, index, indent, expanded) {
|
|
114
|
+
var _a;
|
|
115
|
+
return (0, _jsxRuntime.jsx)(_ExpandedRowContainer.ExpandedRowContainer, {
|
|
116
|
+
children: (_a = expandable === null || expandable === void 0 ? void 0 : expandable.expandedRowRender) === null || _a === void 0 ? void 0 : _a.call(expandable, record, index, indent, expanded)
|
|
117
|
+
});
|
|
118
|
+
});
|
|
119
|
+
// Wire kernel's onExpand (triggered by expandRowByClick) to our state.
|
|
120
|
+
var kernelOnExpand = (0, _hooks.useMemoizedFn)(function (expanded, record) {
|
|
121
|
+
var recordKey = getRowKey(record, dataSource.indexOf(record));
|
|
122
|
+
expand.onKernelExpand(expanded, record, recordKey);
|
|
123
|
+
});
|
|
124
|
+
var mergedExpandable = (0, _react.useMemo)(function () {
|
|
125
|
+
return expandable ? Object.assign(Object.assign({}, expandable), {
|
|
126
|
+
expandedRowKeys: expand.mergedExpandedRowKeys,
|
|
127
|
+
expandedRowRender: expandable.expandedRowRender ? wrappedExpandedRowRender : undefined,
|
|
128
|
+
showExpandColumn: false,
|
|
129
|
+
onExpand: kernelOnExpand
|
|
130
|
+
}) : undefined;
|
|
131
|
+
}, [expandable, expand.mergedExpandedRowKeys, wrappedExpandedRowRender, kernelOnExpand]);
|
|
132
|
+
var resolvedPagination = pipeline.pagination === false ? {
|
|
133
|
+
current: 1,
|
|
134
|
+
pageSize: 10
|
|
135
|
+
} : pipeline.pagination;
|
|
136
|
+
var paginationNode = pagination !== false ? (0, _jsxRuntime.jsx)("div", {
|
|
137
|
+
className: "".concat(prefixCls, "-pagination"),
|
|
138
|
+
children: (0, _jsxRuntime.jsx)(_Pagination.Pagination, {
|
|
139
|
+
total: pipeline.total,
|
|
140
|
+
pageSize: resolvedPagination.pageSize,
|
|
141
|
+
current: resolvedPagination.current,
|
|
142
|
+
onChange: function onChange(nextPage, nextPageSize) {
|
|
143
|
+
return pipeline.setPagination(function (currentPagination) {
|
|
144
|
+
return Object.assign(Object.assign({}, currentPagination), {
|
|
145
|
+
current: nextPage,
|
|
146
|
+
pageSize: nextPageSize
|
|
147
|
+
});
|
|
148
|
+
});
|
|
149
|
+
}
|
|
150
|
+
})
|
|
151
|
+
}) : null;
|
|
152
|
+
var wrapperClassName = (0, _classnames.joinCls)("".concat(prefixCls, "-wrapper"), loading && "".concat(prefixCls, "-wrapper--loading"), bordered && "".concat(prefixCls, "-wrapper--bordered"));
|
|
153
|
+
var tableClassName = (0, _classnames.joinCls)(cls(), cls(size), cls(variant), className);
|
|
154
|
+
var emptyText = loading && !dataSource.length ? (0, _jsxRuntime.jsx)("span", {}) : (0, _jsxRuntime.jsx)(_EmptyState.TableEmptyState, {
|
|
155
|
+
empty: empty
|
|
156
|
+
});
|
|
157
|
+
return {
|
|
158
|
+
prefixCls: prefixCls,
|
|
159
|
+
wrapperClassName: wrapperClassName,
|
|
160
|
+
tableClassName: tableClassName,
|
|
161
|
+
loading: loading,
|
|
162
|
+
renderedColumns: renderedColumns,
|
|
163
|
+
currentDataSource: pipeline.currentDataSource,
|
|
164
|
+
mergedExpandable: mergedExpandable,
|
|
165
|
+
emptyText: emptyText,
|
|
166
|
+
wrapperHtmlProps: rest,
|
|
167
|
+
forwardedKernelProps: {
|
|
168
|
+
rowKey: rowKey,
|
|
169
|
+
childrenColumnName: childrenColumnName,
|
|
170
|
+
indentSize: indentSize,
|
|
171
|
+
onRow: onRow,
|
|
172
|
+
rowClassName: rowClassName,
|
|
173
|
+
summary: summary,
|
|
174
|
+
showHeader: showHeader,
|
|
175
|
+
tableLayout: tableLayout,
|
|
176
|
+
components: components,
|
|
177
|
+
direction: direction,
|
|
178
|
+
rowHoverable: rowHoverable,
|
|
179
|
+
sticky: sticky
|
|
180
|
+
},
|
|
181
|
+
paginationNode: paginationNode
|
|
182
|
+
};
|
|
183
|
+
};
|
|
184
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["components/Table/core/useTableSetup.js","components/Table/src/components/Table/core/useTableSetup.tsx"],"names":["_jsxRuntime","require","_react","_hooks","_classnames","_interopRequireWildcard","_Pagination","_ExpandedRowContainer","_EmptyState","_constants","_useTableDataPipeline","_useTableSelection","_useTableExpand","_useTableColumns","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","__rest","s","p","prototype","indexOf","getOwnPropertySymbols","length","propertyIsEnumerable","useTableSetup","exports","props","_props$className","className","_props$prefixCls","prefixCls","TABLE_DEFAULT_PREFIX","_props$size","size","TABLE_DEFAULT_SIZE","_props$variant","variant","TABLE_DEFAULT_VARIANT","columns","dataSource","rowKey","empty","bordered","_scroll","scroll","sticky","pagination","rowSelection","_props$loading","loading","onChange","childrenColumnName","indentSize","expandable","onRow","rowClassName","summary","showHeader","tableLayout","components","direction","rowHoverable","rest","cls","classnames","TABLE_BLOCK","getRowKey","useMemoizedFn","record","index","_a","pipeline","useTableDataPipeline","selection","useTableSelection","currentDataSource","expand","useTableExpand","renderedColumns","useTableColumns","mergedExpandedRowKeys","triggerExpand","mergedSelectedRowKeys","checkboxPropsMap","isAllSelected","isIndeterminate","triggerSelection","triggerSelectAll","sorter","setSorter","filters","setFilters","wrappedExpandedRowRender","indent","expanded","_jsx","ExpandedRowContainer","children","expandedRowRender","kernelOnExpand","recordKey","onKernelExpand","mergedExpandable","useMemo","assign","expandedRowKeys","undefined","showExpandColumn","onExpand","resolvedPagination","current","pageSize","paginationNode","concat","Pagination","total","nextPage","nextPageSize","setPagination","currentPagination","wrapperClassName","joinCls","tableClassName","emptyText","TableEmptyState","wrapperHtmlProps","forwardedKernelProps"],"mappings":"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","file":"components/Table/core/useTableSetup.js","sourcesContent":["var __rest = (this && this.__rest) || function (s, e) {\n    var t = {};\n    for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\n        t[p] = s[p];\n    if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\n        for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\n            if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\n                t[p[i]] = s[p[i]];\n        }\n    return t;\n};\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nimport { useMemo } from 'react';\nimport { useMemoizedFn } from '@1money/hooks';\nimport classnames, { joinCls } from '../../../utils/classnames';\nimport { Pagination } from '../../Pagination';\nimport { ExpandedRowContainer } from '../renderers/ExpandedRowContainer';\nimport { TableEmptyState } from '../renderers/EmptyState';\nimport { TABLE_BLOCK, TABLE_DEFAULT_PREFIX, TABLE_DEFAULT_SIZE, TABLE_DEFAULT_VARIANT, } from '../constants';\nimport { useTableDataPipeline } from './useTableDataPipeline';\nimport { useTableSelection } from './useTableSelection';\nimport { useTableExpand } from './useTableExpand';\nimport { useTableColumns } from './useTableColumns';\n/**\n * Centralises the wiring shared by `Table` and `VirtualTable`:\n *  - destructure props\n *  - resolve row key\n *  - run pipeline / selection / expand / column transforms\n *  - build kernel-ready props\n *  - split off pass-through HTML attributes so they can land on the outer wrapper\n *    div (instead of being spread untyped into the kernel via `rest as object`).\n */\nexport const useTableSetup = (props) => {\n    const { className = '', prefixCls = TABLE_DEFAULT_PREFIX, size = TABLE_DEFAULT_SIZE, variant = TABLE_DEFAULT_VARIANT, columns, dataSource, rowKey, empty, bordered, scroll: _scroll, sticky, pagination, rowSelection, loading = false, onChange, childrenColumnName, indentSize, expandable, onRow, rowClassName, summary, showHeader, tableLayout, components, direction, rowHoverable } = props, rest = __rest(props, [\"className\", \"prefixCls\", \"size\", \"variant\", \"columns\", \"dataSource\", \"rowKey\", \"empty\", \"bordered\", \"scroll\", \"sticky\", \"pagination\", \"rowSelection\", \"loading\", \"onChange\", \"childrenColumnName\", \"indentSize\", \"expandable\", \"onRow\", \"rowClassName\", \"summary\", \"showHeader\", \"tableLayout\", \"components\", \"direction\", \"rowHoverable\"]);\n    void _scroll;\n    const cls = classnames(TABLE_BLOCK);\n    const getRowKey = useMemoizedFn((record, index) => {\n        var _a;\n        return typeof rowKey === 'function'\n            ? rowKey(record)\n            : (_a = record[rowKey !== null && rowKey !== void 0 ? rowKey : 'key']) !== null && _a !== void 0 ? _a : index;\n    });\n    const pipeline = useTableDataPipeline({ columns, dataSource, pagination, onChange });\n    const selection = useTableSelection({\n        rowSelection,\n        dataSource,\n        currentDataSource: pipeline.currentDataSource,\n        getRowKey,\n    });\n    const expand = useTableExpand({ expandable });\n    const renderedColumns = useTableColumns({\n        columns,\n        size,\n        variant,\n        expandable,\n        mergedExpandedRowKeys: expand.mergedExpandedRowKeys,\n        triggerExpand: expand.triggerExpand,\n        rowSelection,\n        mergedSelectedRowKeys: selection.mergedSelectedRowKeys,\n        checkboxPropsMap: selection.checkboxPropsMap,\n        isAllSelected: selection.isAllSelected,\n        isIndeterminate: selection.isIndeterminate,\n        triggerSelection: selection.triggerSelection,\n        triggerSelectAll: selection.triggerSelectAll,\n        sorter: pipeline.sorter,\n        setSorter: pipeline.setSorter,\n        filters: pipeline.filters,\n        setFilters: pipeline.setFilters,\n        getRowKey,\n    });\n    const wrappedExpandedRowRender = useMemoizedFn((record, index, indent, expanded) => {\n        var _a;\n        return (_jsx(ExpandedRowContainer, { children: (_a = expandable === null || expandable === void 0 ? void 0 : expandable.expandedRowRender) === null || _a === void 0 ? void 0 : _a.call(expandable, record, index, indent, expanded) }));\n    });\n    // Wire kernel's onExpand (triggered by expandRowByClick) to our state.\n    const kernelOnExpand = useMemoizedFn((expanded, record) => {\n        const recordKey = getRowKey(record, dataSource.indexOf(record));\n        expand.onKernelExpand(expanded, record, recordKey);\n    });\n    const mergedExpandable = useMemo(() => expandable\n        ? Object.assign(Object.assign({}, expandable), { expandedRowKeys: expand.mergedExpandedRowKeys, expandedRowRender: expandable.expandedRowRender\n                ? wrappedExpandedRowRender\n                : undefined, showExpandColumn: false, onExpand: kernelOnExpand })\n        : undefined, [expandable, expand.mergedExpandedRowKeys, wrappedExpandedRowRender, kernelOnExpand]);\n    const resolvedPagination = pipeline.pagination === false\n        ? { current: 1, pageSize: 10 }\n        : pipeline.pagination;\n    const paginationNode = pagination !== false ? (_jsx(\"div\", { className: `${prefixCls}-pagination`, children: _jsx(Pagination, { total: pipeline.total, pageSize: resolvedPagination.pageSize, current: resolvedPagination.current, onChange: (nextPage, nextPageSize) => pipeline.setPagination((currentPagination) => (Object.assign(Object.assign({}, currentPagination), { current: nextPage, pageSize: nextPageSize }))) }) })) : null;\n    const wrapperClassName = joinCls(`${prefixCls}-wrapper`, loading && `${prefixCls}-wrapper--loading`, bordered && `${prefixCls}-wrapper--bordered`);\n    const tableClassName = joinCls(cls(), cls(size), cls(variant), className);\n    const emptyText = loading && !dataSource.length ? _jsx(\"span\", {}) : _jsx(TableEmptyState, { empty: empty });\n    return {\n        prefixCls,\n        wrapperClassName,\n        tableClassName,\n        loading,\n        renderedColumns,\n        currentDataSource: pipeline.currentDataSource,\n        mergedExpandable,\n        emptyText,\n        wrapperHtmlProps: rest,\n        forwardedKernelProps: {\n            rowKey: rowKey,\n            childrenColumnName,\n            indentSize,\n            onRow,\n            rowClassName,\n            summary,\n            showHeader,\n            tableLayout,\n            components,\n            direction,\n            rowHoverable,\n            sticky,\n        },\n        paginationNode,\n    };\n};",null],"sourceRoot":"../../../../../../../../../../src"}
|
|
@@ -11,6 +11,7 @@ var ExpandTrigger = exports.ExpandTrigger = function ExpandTrigger(_ref) {
|
|
|
11
11
|
var expanded = _ref.expanded,
|
|
12
12
|
onToggle = _ref.onToggle;
|
|
13
13
|
return (0, _jsxRuntime.jsx)("button", {
|
|
14
|
+
role: 'button',
|
|
14
15
|
type: "button",
|
|
15
16
|
"aria-label": "Expand row",
|
|
16
17
|
"aria-expanded": expanded,
|
|
@@ -27,4 +28,4 @@ var ExpandTrigger = exports.ExpandTrigger = function ExpandTrigger(_ref) {
|
|
|
27
28
|
})
|
|
28
29
|
});
|
|
29
30
|
};
|
|
30
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,
|
|
31
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImNvbXBvbmVudHMvVGFibGUvZmVhdHVyZXMvRXhwYW5kVHJpZ2dlci5qcyIsImNvbXBvbmVudHMvVGFibGUvc3JjL2NvbXBvbmVudHMvVGFibGUvZmVhdHVyZXMvRXhwYW5kVHJpZ2dlci50c3giXSwibmFtZXMiOlsiX2pzeFJ1bnRpbWUiLCJyZXF1aXJlIiwiX0ljb25zIiwiX2NvbnN0YW50cyIsIkV4cGFuZFRyaWdnZXIiLCJleHBvcnRzIiwiX3JlZiIsImV4cGFuZGVkIiwib25Ub2dnbGUiLCJfanN4Iiwicm9sZSIsInR5cGUiLCJjbGFzc05hbWUiLCJjb25jYXQiLCJUQUJMRV9ERUZBVUxUX1BSRUZJWCIsIm9uQ2xpY2siLCJjaGlsZHJlbiIsIkljb25zIiwibmFtZSIsInNpemUiLCJjb2xvciIsInN0eWxlIiwidHJhbnNmb3JtIiwidW5kZWZpbmVkIl0sIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQSxJQUFBQSxXQUFBLEdBQUFDLE9BQUE7QUNBQSxJQUFBQyxNQUFBLEdBQUFELE9BQUE7QUFDQSxJQUFBRSxVQUFBLEdBQUFGLE9BQUE7QUFFTyxJQUFNRyxhQUFhLEdBQUFDLE9BQUEsQ0FBQUQsYUFBQSxHQUFHLFNBQWhCQSxhQUFhQSxDQUFBRSxJQUFBO0VBQUEsSUFDeEJDLFFBQVEsR0FBQUQsSUFBQSxDQUFSQyxRQUFRO0lBQ1JDLFFBQVEsR0FBQUYsSUFBQSxDQUFSRSxRQUFRO0VBQUEsT0FLUixJQUFBQyxlQUFBLEVBQUEsUUFBQSxFQUFBO0lBQ0VDLElBQUksRUFBQyxRQUFRO0lBQ2JDLElBQUksRUFBQyxRQUFRO0lBQUEsWUFBQSxFQUNGLFlBQVk7SUFBQSxlQUFBLEVBQ1JKLFFBQVE7SUFDdkJLLFNBQVMsS0FBQUMsTUFBQSxDQUFLQywrQkFBb0Isb0JBQWlCO0lBQ25EQyxPQUFPLEVBQUVQLFFBQVE7SUFBQVEsUUFBQSxFQUVqQixJQUFBUCxlQUFBLEVBQUNRLFlBQUssRUFBQTtNQUNKQyxJQUFJLEVBQUMsYUFBYTtNQUNsQkMsSUFBSSxFQUFFLEVBQUU7TUFDUkMsS0FBSyxFQUFDLGNBQWM7TUFDcEJSLFNBQVMsS0FBQUMsTUFBQSxDQUFLQywrQkFBb0IsMEJBQXVCO01BQ3pETyxLQUFLLEVBQUU7UUFDTEMsU0FBUyxFQUFFZixRQUFRLEdBQUcsZ0JBQWdCLEdBQUdnQjtNRG5CekM7SUNvQkQsQ0FBQTtFQUNELENBQUEsQ0FDSztBQUFBLENBQ1YiLCJmaWxlIjoiY29tcG9uZW50cy9UYWJsZS9mZWF0dXJlcy9FeHBhbmRUcmlnZ2VyLmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsganN4IGFzIF9qc3ggfSBmcm9tIFwicmVhY3QvanN4LXJ1bnRpbWVcIjtcbmltcG9ydCB7IEljb25zIH0gZnJvbSAnLi4vLi4vSWNvbnMnO1xuaW1wb3J0IHsgVEFCTEVfREVGQVVMVF9QUkVGSVggfSBmcm9tICcuLi9jb25zdGFudHMnO1xuZXhwb3J0IGNvbnN0IEV4cGFuZFRyaWdnZXIgPSAoeyBleHBhbmRlZCwgb25Ub2dnbGUsIH0pID0+IChfanN4KFwiYnV0dG9uXCIsIHsgcm9sZTogJ2J1dHRvbicsIHR5cGU6IFwiYnV0dG9uXCIsIFwiYXJpYS1sYWJlbFwiOiBcIkV4cGFuZCByb3dcIiwgXCJhcmlhLWV4cGFuZGVkXCI6IGV4cGFuZGVkLCBjbGFzc05hbWU6IGAke1RBQkxFX0RFRkFVTFRfUFJFRklYfS1leHBhbmQtdHJpZ2dlcmAsIG9uQ2xpY2s6IG9uVG9nZ2xlLCBjaGlsZHJlbjogX2pzeChJY29ucywgeyBuYW1lOiBcImNoZXZyb25Eb3duXCIsIHNpemU6IDE2LCBjb2xvcjogXCJjdXJyZW50Q29sb3JcIiwgY2xhc3NOYW1lOiBgJHtUQUJMRV9ERUZBVUxUX1BSRUZJWH0tZXhwYW5kLXRyaWdnZXJfX2ljb25gLCBzdHlsZToge1xuICAgICAgICAgICAgdHJhbnNmb3JtOiBleHBhbmRlZCA/ICdyb3RhdGUoMTgwZGVnKScgOiB1bmRlZmluZWQsXG4gICAgICAgIH0gfSkgfSkpOyIsbnVsbF0sInNvdXJjZVJvb3QiOiIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9zcmMifQ==
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { TableColumn, TableFilterValue, TableRecord } from '../interface';
|
|
2
|
+
interface FilterTriggerProps<T extends TableRecord> {
|
|
3
|
+
column: TableColumn<T>;
|
|
4
|
+
size: 'large' | 'small';
|
|
5
|
+
selectedKeys: TableFilterValue;
|
|
6
|
+
onChange: (next: TableFilterValue) => void;
|
|
7
|
+
}
|
|
8
|
+
export declare const FilterTrigger: <T extends TableRecord>({ column, size, selectedKeys, onChange, }: FilterTriggerProps<T>) => import("react/jsx-runtime").JSX.Element;
|
|
9
|
+
export {};
|
|
@@ -0,0 +1,164 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports.FilterTrigger = void 0;
|
|
8
|
+
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
|
9
|
+
var _jsxRuntime = require("react/jsx-runtime");
|
|
10
|
+
var _react = require("react");
|
|
11
|
+
var _Icons = require("../../Icons");
|
|
12
|
+
var _Dropdown = _interopRequireDefault(require("../../Dropdown"));
|
|
13
|
+
var _Checkbox = require("../../Checkbox");
|
|
14
|
+
var _Button = require("../../Button");
|
|
15
|
+
var _constants = require("../constants");
|
|
16
|
+
var FILTER_TRIGGER_ICON_SIZE = {
|
|
17
|
+
large: 16,
|
|
18
|
+
small: 12
|
|
19
|
+
};
|
|
20
|
+
var toCheckboxValue = function toCheckboxValue(value) {
|
|
21
|
+
if (typeof value === 'string' || typeof value === 'number') return value;
|
|
22
|
+
return String(value);
|
|
23
|
+
};
|
|
24
|
+
var isPrimitive = function isPrimitive(value) {
|
|
25
|
+
return typeof value === 'string' || typeof value === 'number';
|
|
26
|
+
};
|
|
27
|
+
var toCheckboxValues = function toCheckboxValues(value) {
|
|
28
|
+
return value.map(toCheckboxValue).filter(isPrimitive);
|
|
29
|
+
};
|
|
30
|
+
var fromCheckboxValues = function fromCheckboxValues(value, filters) {
|
|
31
|
+
return value.map(function (v) {
|
|
32
|
+
var match = filters.find(function (item) {
|
|
33
|
+
return String(item.value) === String(v);
|
|
34
|
+
});
|
|
35
|
+
return match ? match.value : v;
|
|
36
|
+
});
|
|
37
|
+
};
|
|
38
|
+
var FilterTrigger = exports.FilterTrigger = function FilterTrigger(_ref) {
|
|
39
|
+
var column = _ref.column,
|
|
40
|
+
size = _ref.size,
|
|
41
|
+
selectedKeys = _ref.selectedKeys,
|
|
42
|
+
onChange = _ref.onChange;
|
|
43
|
+
var _a, _b;
|
|
44
|
+
var externallyControlled = column.filterDropdownOpen !== undefined;
|
|
45
|
+
var _useState = (0, _react.useState)((_a = column.defaultFilterDropdownOpen) !== null && _a !== void 0 ? _a : false),
|
|
46
|
+
_useState2 = (0, _slicedToArray2["default"])(_useState, 2),
|
|
47
|
+
internalOpen = _useState2[0],
|
|
48
|
+
setInternalOpen = _useState2[1];
|
|
49
|
+
var open = externallyControlled ? !!column.filterDropdownOpen : internalOpen;
|
|
50
|
+
var handleOpenChange = function handleOpenChange(next) {
|
|
51
|
+
var _a;
|
|
52
|
+
if (!externallyControlled) setInternalOpen(next);
|
|
53
|
+
(_a = column.onFilterDropdownOpenChange) === null || _a === void 0 ? void 0 : _a.call(column, next);
|
|
54
|
+
};
|
|
55
|
+
// Working selection — user can pick before confirming. Sync from external state
|
|
56
|
+
// when it changes (controlled mode) or when the popover (re)opens.
|
|
57
|
+
var _useState3 = (0, _react.useState)(selectedKeys),
|
|
58
|
+
_useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
|
|
59
|
+
draft = _useState4[0],
|
|
60
|
+
setDraft = _useState4[1];
|
|
61
|
+
(0, _react.useEffect)(function () {
|
|
62
|
+
setDraft(selectedKeys);
|
|
63
|
+
}, [selectedKeys, open]);
|
|
64
|
+
var filtered = selectedKeys.length > 0;
|
|
65
|
+
var triggerIcon = typeof column.filterIcon === 'function' ? column.filterIcon(filtered) : (_b = column.filterIcon) !== null && _b !== void 0 ? _b : (0, _jsxRuntime.jsx)(_Icons.Icons, {
|
|
66
|
+
name: "filter",
|
|
67
|
+
size: FILTER_TRIGGER_ICON_SIZE[size]
|
|
68
|
+
});
|
|
69
|
+
var close = function close() {
|
|
70
|
+
return handleOpenChange(false);
|
|
71
|
+
};
|
|
72
|
+
var confirm = function confirm() {
|
|
73
|
+
onChange(draft);
|
|
74
|
+
close();
|
|
75
|
+
};
|
|
76
|
+
var clearFilters = function clearFilters() {
|
|
77
|
+
setDraft([]);
|
|
78
|
+
onChange([]);
|
|
79
|
+
close();
|
|
80
|
+
};
|
|
81
|
+
var renderDropdownContent = function renderDropdownContent() {
|
|
82
|
+
if (typeof column.filterDropdown === 'function') {
|
|
83
|
+
var props = {
|
|
84
|
+
prefixCls: _constants.TABLE_DEFAULT_PREFIX,
|
|
85
|
+
setSelectedKeys: setDraft,
|
|
86
|
+
selectedKeys: draft,
|
|
87
|
+
confirm: confirm,
|
|
88
|
+
clearFilters: clearFilters,
|
|
89
|
+
filters: column.filters,
|
|
90
|
+
visible: open,
|
|
91
|
+
close: close,
|
|
92
|
+
column: column
|
|
93
|
+
};
|
|
94
|
+
return column.filterDropdown(props);
|
|
95
|
+
}
|
|
96
|
+
if (column.filterDropdown !== undefined) {
|
|
97
|
+
return column.filterDropdown;
|
|
98
|
+
}
|
|
99
|
+
if (!column.filters || column.filters.length === 0) return null;
|
|
100
|
+
var multiple = column.filterMultiple !== false;
|
|
101
|
+
var filters = column.filters;
|
|
102
|
+
return (0, _jsxRuntime.jsxs)("div", {
|
|
103
|
+
className: "".concat(_constants.TABLE_DEFAULT_PREFIX, "-filter-dropdown"),
|
|
104
|
+
children: [multiple ? (0, _jsxRuntime.jsx)(_Checkbox.CheckboxGroup, {
|
|
105
|
+
value: toCheckboxValues(draft),
|
|
106
|
+
options: filters.map(function (item) {
|
|
107
|
+
return {
|
|
108
|
+
value: toCheckboxValue(item.value),
|
|
109
|
+
label: item.text
|
|
110
|
+
};
|
|
111
|
+
}),
|
|
112
|
+
onChange: function onChange(values) {
|
|
113
|
+
return setDraft(fromCheckboxValues(values, filters));
|
|
114
|
+
},
|
|
115
|
+
direction: "vertical"
|
|
116
|
+
}) : filters.map(function (item) {
|
|
117
|
+
var itemKey = String(item.value);
|
|
118
|
+
var isSelected = draft.some(function (v) {
|
|
119
|
+
return String(v) === itemKey;
|
|
120
|
+
});
|
|
121
|
+
return (0, _jsxRuntime.jsxs)("label", {
|
|
122
|
+
className: "".concat(_constants.TABLE_DEFAULT_PREFIX, "-filter-dropdown__item"),
|
|
123
|
+
children: [(0, _jsxRuntime.jsx)(_Checkbox.Checkbox, {
|
|
124
|
+
checked: isSelected,
|
|
125
|
+
onChange: function onChange() {
|
|
126
|
+
return setDraft(isSelected ? [] : [item.value]);
|
|
127
|
+
}
|
|
128
|
+
}), (0, _jsxRuntime.jsx)("span", {
|
|
129
|
+
children: item.text
|
|
130
|
+
})]
|
|
131
|
+
}, itemKey);
|
|
132
|
+
}), (0, _jsxRuntime.jsxs)("div", {
|
|
133
|
+
className: "".concat(_constants.TABLE_DEFAULT_PREFIX, "-filter-dropdown__footer"),
|
|
134
|
+
children: [(0, _jsxRuntime.jsx)(_Button.Button, {
|
|
135
|
+
size: "small",
|
|
136
|
+
variant: "text",
|
|
137
|
+
onClick: clearFilters,
|
|
138
|
+
children: "Reset"
|
|
139
|
+
}), (0, _jsxRuntime.jsx)(_Button.Button, {
|
|
140
|
+
size: "small",
|
|
141
|
+
color: "primary",
|
|
142
|
+
onClick: confirm,
|
|
143
|
+
children: "OK"
|
|
144
|
+
})]
|
|
145
|
+
})]
|
|
146
|
+
});
|
|
147
|
+
};
|
|
148
|
+
return (0, _jsxRuntime.jsx)(_Dropdown["default"], {
|
|
149
|
+
open: open,
|
|
150
|
+
onOpenChange: handleOpenChange,
|
|
151
|
+
trigger: "click",
|
|
152
|
+
content: renderDropdownContent(),
|
|
153
|
+
placement: "bottom-end",
|
|
154
|
+
portal: true,
|
|
155
|
+
children: (0, _jsxRuntime.jsx)("button", {
|
|
156
|
+
type: "button",
|
|
157
|
+
"aria-label": "Filter ".concat(typeof column.title === 'string' ? column.title : ''),
|
|
158
|
+
"aria-haspopup": "listbox",
|
|
159
|
+
className: "".concat(_constants.TABLE_DEFAULT_PREFIX, "-filter-trigger ").concat(_constants.TABLE_DEFAULT_PREFIX, "-filter-trigger--").concat(size).concat(filtered ? " ".concat(_constants.TABLE_DEFAULT_PREFIX, "-filter-trigger--active") : ''),
|
|
160
|
+
children: triggerIcon
|
|
161
|
+
})
|
|
162
|
+
});
|
|
163
|
+
};
|
|
164
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["components/Table/features/FilterTrigger.js","components/Table/src/components/Table/features/FilterTrigger.tsx"],"names":["_jsxRuntime","require","_react","_Icons","_Dropdown","_interopRequireDefault","_Checkbox","_Button","_constants","FILTER_TRIGGER_ICON_SIZE","large","small","toCheckboxValue","value","String","isPrimitive","toCheckboxValues","map","filter","fromCheckboxValues","filters","v","match","find","item","FilterTrigger","exports","_ref","column","size","selectedKeys","onChange","_a","_b","externallyControlled","filterDropdownOpen","undefined","_useState","useState","defaultFilterDropdownOpen","_useState2","_slicedToArray2","internalOpen","setInternalOpen","open","handleOpenChange","next","onFilterDropdownOpenChange","call","_useState3","_useState4","draft","setDraft","useEffect","filtered","length","triggerIcon","filterIcon","_jsx","Icons","name","close","confirm","clearFilters","renderDropdownContent","filterDropdown","props","prefixCls","TABLE_DEFAULT_PREFIX","setSelectedKeys","visible","multiple","filterMultiple","_jsxs","className","concat","children","CheckboxGroup","options","label","text","values","direction","itemKey","isSelected","some","Checkbox","checked","Button","variant","onClick","color","Dropdown","onOpenChange","trigger","content","placement","portal","type","title"],"mappings":"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","file":"components/Table/features/FilterTrigger.js","sourcesContent":["import { jsx as _jsx, jsxs as _jsxs } from \"react/jsx-runtime\";\nimport { useEffect, useState } from 'react';\nimport { Icons } from '../../Icons';\nimport Dropdown from '../../Dropdown';\nimport { Checkbox, CheckboxGroup } from '../../Checkbox';\nimport { Button } from '../../Button';\nimport { TABLE_DEFAULT_PREFIX } from '../constants';\nconst FILTER_TRIGGER_ICON_SIZE = {\n    large: 16,\n    small: 12,\n};\nconst toCheckboxValue = (value) => {\n    if (typeof value === 'string' || typeof value === 'number')\n        return value;\n    return String(value);\n};\nconst isPrimitive = (value) => typeof value === 'string' || typeof value === 'number';\nconst toCheckboxValues = (value) => value.map(toCheckboxValue).filter(isPrimitive);\nconst fromCheckboxValues = (value, filters) => value.map((v) => {\n    const match = filters.find((item) => String(item.value) === String(v));\n    return match ? match.value : v;\n});\nexport const FilterTrigger = ({ column, size, selectedKeys, onChange, }) => {\n    var _a, _b;\n    const externallyControlled = column.filterDropdownOpen !== undefined;\n    const [internalOpen, setInternalOpen] = useState((_a = column.defaultFilterDropdownOpen) !== null && _a !== void 0 ? _a : false);\n    const open = externallyControlled ? !!column.filterDropdownOpen : internalOpen;\n    const handleOpenChange = (next) => {\n        var _a;\n        if (!externallyControlled)\n            setInternalOpen(next);\n        (_a = column.onFilterDropdownOpenChange) === null || _a === void 0 ? void 0 : _a.call(column, next);\n    };\n    // Working selection — user can pick before confirming. Sync from external state\n    // when it changes (controlled mode) or when the popover (re)opens.\n    const [draft, setDraft] = useState(selectedKeys);\n    useEffect(() => {\n        setDraft(selectedKeys);\n    }, [selectedKeys, open]);\n    const filtered = selectedKeys.length > 0;\n    const triggerIcon = typeof column.filterIcon === 'function'\n        ? column.filterIcon(filtered)\n        : (_b = column.filterIcon) !== null && _b !== void 0 ? _b : _jsx(Icons, { name: \"filter\", size: FILTER_TRIGGER_ICON_SIZE[size] });\n    const close = () => handleOpenChange(false);\n    const confirm = () => {\n        onChange(draft);\n        close();\n    };\n    const clearFilters = () => {\n        setDraft([]);\n        onChange([]);\n        close();\n    };\n    const renderDropdownContent = () => {\n        if (typeof column.filterDropdown === 'function') {\n            const props = {\n                prefixCls: TABLE_DEFAULT_PREFIX,\n                setSelectedKeys: setDraft,\n                selectedKeys: draft,\n                confirm,\n                clearFilters,\n                filters: column.filters,\n                visible: open,\n                close,\n                column,\n            };\n            return column.filterDropdown(props);\n        }\n        if (column.filterDropdown !== undefined) {\n            return column.filterDropdown;\n        }\n        if (!column.filters || column.filters.length === 0)\n            return null;\n        const multiple = column.filterMultiple !== false;\n        const filters = column.filters;\n        return (_jsxs(\"div\", { className: `${TABLE_DEFAULT_PREFIX}-filter-dropdown`, children: [multiple ? (_jsx(CheckboxGroup, { value: toCheckboxValues(draft), options: filters.map((item) => ({\n                        value: toCheckboxValue(item.value),\n                        label: item.text,\n                    })), onChange: (values) => setDraft(fromCheckboxValues(values, filters)), direction: \"vertical\" })) : (filters.map((item) => {\n                    const itemKey = String(item.value);\n                    const isSelected = draft.some((v) => String(v) === itemKey);\n                    return (_jsxs(\"label\", { className: `${TABLE_DEFAULT_PREFIX}-filter-dropdown__item`, children: [_jsx(Checkbox, { checked: isSelected, onChange: () => setDraft(isSelected ? [] : [item.value]) }), _jsx(\"span\", { children: item.text })] }, itemKey));\n                })), _jsxs(\"div\", { className: `${TABLE_DEFAULT_PREFIX}-filter-dropdown__footer`, children: [_jsx(Button, { size: \"small\", variant: \"text\", onClick: clearFilters, children: \"Reset\" }), _jsx(Button, { size: \"small\", color: \"primary\", onClick: confirm, children: \"OK\" })] })] }));\n    };\n    return (_jsx(Dropdown, { open: open, onOpenChange: handleOpenChange, trigger: \"click\", content: renderDropdownContent(), placement: \"bottom-end\", portal: true, children: _jsx(\"button\", { type: \"button\", \"aria-label\": `Filter ${typeof column.title === 'string' ? column.title : ''}`, \"aria-haspopup\": \"listbox\", className: `${TABLE_DEFAULT_PREFIX}-filter-trigger ${TABLE_DEFAULT_PREFIX}-filter-trigger--${size}${filtered ? ` ${TABLE_DEFAULT_PREFIX}-filter-trigger--active` : ''}`, children: triggerIcon }) }));\n};",null],"sourceRoot":"../../../../../../../../../../src"}
|
|
@@ -1,7 +1,8 @@
|
|
|
1
|
-
|
|
1
|
+
import type { TableCheckboxProps } from '../interface';
|
|
2
|
+
export declare const SelectionControl: ({ checked, type, rowProps, onChange, }: {
|
|
2
3
|
checked: boolean;
|
|
3
4
|
type: "checkbox" | "radio";
|
|
4
|
-
|
|
5
|
+
rowProps?: TableCheckboxProps;
|
|
5
6
|
onChange: () => void;
|
|
6
7
|
}) => import("react/jsx-runtime").JSX.Element;
|
|
7
8
|
export declare const SelectionHeaderControl: ({ checked, indeterminate, onChange, }: {
|
|
@@ -7,11 +7,24 @@ exports.SelectionHeaderControl = exports.SelectionControl = void 0;
|
|
|
7
7
|
var _jsxRuntime = require("react/jsx-runtime");
|
|
8
8
|
var _Checkbox = require("../../Checkbox");
|
|
9
9
|
var _Radio = require("../../Radio");
|
|
10
|
+
var __rest = void 0 && (void 0).__rest || function (s, e) {
|
|
11
|
+
var t = {};
|
|
12
|
+
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];
|
|
13
|
+
if (s != null && typeof Object.getOwnPropertySymbols === "function") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
|
|
14
|
+
if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];
|
|
15
|
+
}
|
|
16
|
+
return t;
|
|
17
|
+
};
|
|
10
18
|
var SelectionControl = exports.SelectionControl = function SelectionControl(_ref) {
|
|
11
19
|
var checked = _ref.checked,
|
|
12
20
|
type = _ref.type,
|
|
13
|
-
|
|
21
|
+
rowProps = _ref.rowProps,
|
|
14
22
|
_onChange = _ref.onChange;
|
|
23
|
+
var _a = rowProps !== null && rowProps !== void 0 ? rowProps : {},
|
|
24
|
+
disabled = _a.disabled,
|
|
25
|
+
_a$ariaLabel = _a['aria-label'],
|
|
26
|
+
ariaLabel = _a$ariaLabel === void 0 ? 'Select row' : _a$ariaLabel,
|
|
27
|
+
rest = __rest(_a, ["disabled", 'aria-label']);
|
|
15
28
|
if (type === 'radio') {
|
|
16
29
|
return (0, _jsxRuntime.jsx)(_Radio.Radio, {
|
|
17
30
|
checked: checked,
|
|
@@ -19,17 +32,17 @@ var SelectionControl = exports.SelectionControl = function SelectionControl(_ref
|
|
|
19
32
|
onChange: function onChange() {
|
|
20
33
|
return _onChange();
|
|
21
34
|
},
|
|
22
|
-
"aria-label":
|
|
35
|
+
"aria-label": ariaLabel
|
|
23
36
|
});
|
|
24
37
|
}
|
|
25
|
-
return (0, _jsxRuntime.jsx)(_Checkbox.Checkbox, {
|
|
38
|
+
return (0, _jsxRuntime.jsx)(_Checkbox.Checkbox, Object.assign({}, rest, {
|
|
26
39
|
checked: checked,
|
|
27
40
|
disabled: disabled,
|
|
28
41
|
onChange: function onChange() {
|
|
29
42
|
return _onChange();
|
|
30
43
|
},
|
|
31
|
-
"aria-label":
|
|
32
|
-
});
|
|
44
|
+
"aria-label": ariaLabel
|
|
45
|
+
}));
|
|
33
46
|
};
|
|
34
47
|
var SelectionHeaderControl = exports.SelectionHeaderControl = function SelectionHeaderControl(_ref2) {
|
|
35
48
|
var checked = _ref2.checked,
|
|
@@ -44,4 +57,4 @@ var SelectionHeaderControl = exports.SelectionHeaderControl = function Selection
|
|
|
44
57
|
"aria-label": "Select all rows"
|
|
45
58
|
});
|
|
46
59
|
};
|
|
47
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,
|
|
60
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImNvbXBvbmVudHMvVGFibGUvZmVhdHVyZXMvU2VsZWN0aW9uQ29sdW1uLmpzIiwiY29tcG9uZW50cy9UYWJsZS9zcmMvY29tcG9uZW50cy9UYWJsZS9mZWF0dXJlcy9TZWxlY3Rpb25Db2x1bW4udHN4Il0sIm5hbWVzIjpbIl9qc3hSdW50aW1lIiwicmVxdWlyZSIsIl9DaGVja2JveCIsIl9SYWRpbyIsIl9fcmVzdCIsInMiLCJlIiwidCIsInAiLCJPYmplY3QiLCJwcm90b3R5cGUiLCJoYXNPd25Qcm9wZXJ0eSIsImNhbGwiLCJpbmRleE9mIiwiZ2V0T3duUHJvcGVydHlTeW1ib2xzIiwiaSIsImxlbmd0aCIsInByb3BlcnR5SXNFbnVtZXJhYmxlIiwiU2VsZWN0aW9uQ29udHJvbCIsImV4cG9ydHMiLCJfcmVmIiwiY2hlY2tlZCIsInR5cGUiLCJyb3dQcm9wcyIsIm9uQ2hhbmdlIiwiX2EiLCJkaXNhYmxlZCIsIl9hJGFyaWFMYWJlbCIsImFyaWFMYWJlbCIsInJlc3QiLCJfanN4IiwiUmFkaW8iLCJDaGVja2JveCIsImFzc2lnbiIsIlNlbGVjdGlvbkhlYWRlckNvbnRyb2wiLCJfcmVmMiIsImluZGV0ZXJtaW5hdGUiXSwibWFwcGluZ3MiOiI7Ozs7OztBQVdBLElBQUFBLFdBQUEsR0FBQUMsT0FBQTtBQ1hBLElBQUFDLFNBQUEsR0FBQUQsT0FBQTtBQUNBLElBQUFFLE1BQUEsR0FBQUYsT0FBQTtBRERBLElBQUlHLE1BQU0sR0FBSSxVQUFRLFNBQUtBLE1BQU0sSUFBSyxVQUFVQyxDQUFDLEVBQUVDLENBQUMsRUFBRTtFQUNsRCxJQUFJQyxDQUFDLEdBQUcsQ0FBQyxDQUFDO0VBQ1YsS0FBSyxJQUFJQyxDQUFDLElBQUlILENBQUMsRUFBRSxJQUFJSSxNQUFNLENBQUNDLFNBQVMsQ0FBQ0MsY0FBYyxDQUFDQyxJQUFJLENBQUNQLENBQUMsRUFBRUcsQ0FBQyxDQUFDLElBQUlGLENBQUMsQ0FBQ08sT0FBTyxDQUFDTCxDQUFDLENBQUMsR0FBRyxDQUFD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LENBQUEsQ0FBRTtJQUFBO0lBQUEsWUFBQSxFQUNmO0VBQWlCLENBQUEsQ0FDNUI7QUFBQSxDQUNIIiwiZmlsZSI6ImNvbXBvbmVudHMvVGFibGUvZmVhdHVyZXMvU2VsZWN0aW9uQ29sdW1uLmpzIiwic291cmNlc0NvbnRlbnQiOlsidmFyIF9fcmVzdCA9ICh0aGlzICYmIHRoaXMuX19yZXN0KSB8fCBmdW5jdGlvbiAocywgZSkge1xuICAgIHZhciB0ID0ge307XG4gICAgZm9yICh2YXIgcCBpbiBzKSBpZiAoT2JqZWN0LnByb3RvdHlwZS5oYXNPd25Qcm9wZXJ0eS5jYWxsKHMsIHApICYmIGUuaW5kZXhPZihwKSA8IDApXG4gICAgICAgIHRbcF0gPSBzW3BdO1xuICAgIGlmIChzICE9IG51bGwgJiYgdHlwZW9mIE9iamVjdC5nZXRPd25Qcm9wZXJ0eVN5bWJvbHMgPT09IFwiZnVuY3Rpb25cIilcbiAgICAgICAgZm9yICh2YXIgaSA9IDAsIHAgPSBPYmplY3QuZ2V0T3duUHJvcGVydHlTeW1ib2xzKHMpOyBpIDwgcC5sZW5ndGg7IGkrKykge1xuICAgICAgICAgICAgaWYgKGUuaW5kZXhPZihwW2ldKSA8IDAgJiYgT2JqZWN0LnByb3RvdHlwZS5wcm9wZXJ0eUlzRW51bWVyYWJsZS5jYWxsKHMsIHBbaV0pKVxuICAgICAgICAgICAgICAgIHRbcFtpXV0gPSBzW3BbaV1dO1xuICAgICAgICB9XG4gICAgcmV0dXJuIHQ7XG59O1xuaW1wb3J0IHsganN4IGFzIF9qc3ggfSBmcm9tIFwicmVhY3QvanN4LXJ1bnRpbWVcIjtcbmltcG9ydCB7IENoZWNrYm94IH0gZnJvbSAnLi4vLi4vQ2hlY2tib3gnO1xuaW1wb3J0IHsgUmFkaW8gfSBmcm9tICcuLi8uLi9SYWRpbyc7XG5leHBvcnQgY29uc3QgU2VsZWN0aW9uQ29udHJvbCA9ICh7IGNoZWNrZWQsIHR5cGUsIHJvd1Byb3BzLCBvbkNoYW5nZSwgfSkgPT4ge1xuICAgIGNvbnN0IF9hID0gcm93UHJvcHMgIT09IG51bGwgJiYgcm93UHJvcHMgIT09IHZvaWQgMCA/IHJvd1Byb3BzIDoge30sIHsgZGlzYWJsZWQsICdhcmlhLWxhYmVsJzogYXJpYUxhYmVsID0gJ1NlbGVjdCByb3cnIH0gPSBfYSwgcmVzdCA9IF9fcmVzdChfYSwgW1wiZGlzYWJsZWRcIiwgJ2FyaWEtbGFiZWwnXSk7XG4gICAgaWYgKHR5cGUgPT09ICdyYWRpbycpIHtcbiAgICAgICAgcmV0dXJuIChfanN4KFJhZGlvLCB7IGNoZWNrZWQ6IGNoZWNrZWQsIGRpc2FibGVkOiBkaXNhYmxlZCwgb25DaGFuZ2U6ICgpID0+IG9uQ2hhbmdlKCksIFwiYXJpYS1sYWJlbFwiOiBhcmlhTGFiZWwgfSkpO1xuICAgIH1cbiAgICByZXR1cm4gKF9qc3goQ2hlY2tib3gsIE9iamVjdC5hc3NpZ24oe30sIHJlc3QsIHsgY2hlY2tlZDogY2hlY2tlZCwgZGlzYWJsZWQ6IGRpc2FibGVkLCBvbkNoYW5nZTogKCkgPT4gb25DaGFuZ2UoKSwgXCJhcmlhLWxhYmVsXCI6IGFyaWFMYWJlbCB9KSkpO1xufTtcbmV4cG9ydCBjb25zdCBTZWxlY3Rpb25IZWFkZXJDb250cm9sID0gKHsgY2hlY2tlZCwgaW5kZXRlcm1pbmF0ZSwgb25DaGFuZ2UsIH0pID0+IChfanN4KENoZWNrYm94LCB7IGNoZWNrZWQ6IGNoZWNrZWQsIGluZGV0ZXJtaW5hdGU6IGluZGV0ZXJtaW5hdGUsIG9uQ2hhbmdlOiAoKSA9PiBvbkNoYW5nZSgpLCBcImFyaWEtbGFiZWxcIjogXCJTZWxlY3QgYWxsIHJvd3NcIiB9KSk7IixudWxsXSwic291cmNlUm9vdCI6Ii4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3NyYyJ9
|