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