@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,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":"AAAA,IAAIA,MAAM,GAAI,IAAI,IAAI,IAAI,CAACA,MAAM,IAAK,UAAUC,CAAC,EAAEC,CAAC,EAAE;EAClD,IAAIC,CAAC,GAAG,CAAC,CAAC;EACV,KAAK,IAAIC,CAAC,IAAIH,CAAC,EAAE,IAAII,MAAM,CAACC,SAAS,CAACC,cAAc,CAACC,IAAI,CAACP,CAAC,EAAEG,CAAC,CAAC,IAAIF,CAAC,CAACO,OAAO,CAACL,CAAC,CAAC,GAAG,CAAC,EAC/ED,CAAC,CAACC,CAAC,CAAC,GAAGH,CAAC,CAACG,CAAC,CAAC;EACf,IAAIH,CAAC,IAAI,IAAI,IAAI,OAAOI,MAAM,CAACK,qBAAqB,KAAK,UAAU,EAC/D,KAAK,IAAIC,CAAC,GAAG,CAAC,EAAEP,CAAC,GAAGC,MAAM,CAACK,qBAAqB,CAACT,CAAC,CAAC,EAAEU,CAAC,GAAGP,CAAC,CAACQ,MAAM,EAAED,CAAC,EAAE,EAAE;IACpE,IAAIT,CAAC,CAACO,OAAO,CAACL,CAAC,CAACO,CAAC,CAAC,CAAC,GAAG,CAAC,IAAIN,MAAM,CAACC,SAAS,CAACO,oBAAoB,CAACL,IAAI,CAACP,CAAC,EAAEG,CAAC,CAACO,CAAC,CAAC,CAAC,EAC1ER,CAAC,CAACC,CAAC,CAACO,CAAC,CAAC,CAAC,GAAGV,CAAC,CAACG,CAAC,CAACO,CAAC,CAAC,CAAC;EACzB;EACJ,OAAOR,CAAC;AACZ,CAAC;AACD,SAASW,GAAG,IAAIC,IAAI,QAAQ,mBAAmB;ACX/C,SAASC,OAAO,QAAuD,OAAO;AAC9E,SAASC,aAAa,QAAQ,eAAe;AAC7C,OAAOC,UAAU,IAAIC,OAAO,QAAQ,2BAA2B;AAC/D,SAASC,UAAU,QAAQ,kBAAkB;AAC7C,SAASC,oBAAoB,QAAQ,mCAAmC;AACxE,SAASC,eAAe,QAAQ,yBAAyB;AACzD,SACEC,WAAW,EACXC,oBAAoB,EACpBC,kBAAkB,EAClBC,qBAAqB,QAChB,cAAc;AACrB,SAASC,oBAAoB,QAAQ,wBAAwB;AAC7D,SAASC,iBAAiB,QAAQ,qBAAqB;AACvD,SAASC,cAAc,QAAQ,kBAAkB;AACjD,SAASC,eAAe,QAAQ,mBAAmB;AA8CnD;ADrCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;ACuCA,OAAO,IAAMC,aAAa,GAAG,SAAhBA,aAAaA,CACxBC,KAAoB,EACG;EACvB,IAAAC,gBAAA,GA4BID,KAAK,CA3BPE,SAAS;IAATA,SAAS,GAAAD,gBAAA,cAAG,EAAE,GAAAA,gBAAA;IAAAE,gBAAA,GA2BZH,KAAK,CA1BPI,SAAS;IAATA,SAAS,GAAAD,gBAAA,cAAGX,oBAAoB,GAAAW,gBAAA;IAAAE,WAAA,GA0B9BL,KAAK,CAzBPM,IAAI;IAAJA,IAAI,GAAAD,WAAA,cAAGZ,kBAAkB,GAAAY,WAAA;IAAAE,cAAA,GAyBvBP,KAAK,CAxBPQ,OAAO;IAAPA,OAAO,GAAAD,cAAA,cAAGb,qBAAqB,GAAAa,cAAA;IAC/BE,OAAO,GAuBLT,KAAK,CAvBPS,OAAO;IACPC,UAAU,GAsBRV,KAAK,CAtBPU,UAAU;IACVC,MAAM,GAqBJX,KAAK,CArBPW,MAAM;IACNC,KAAK,GAoBHZ,KAAK,CApBPY,KAAK;IACLC,QAAQ,GAmBNb,KAAK,CAnBPa,QAAQ;IACAC,OAAO,GAkBbd,KAAK,CAlBPe,MAAM;IACNC,MAAM,GAiBJhB,KAAK,CAjBPgB,MAAM;IACNC,UAAU,GAgBRjB,KAAK,CAhBPiB,UAAU;IACVC,YAAY,GAeVlB,KAAK,CAfPkB,YAAY;IAAAC,cAAA,GAeVnB,KAAK,CAdPoB,OAAO;IAAPA,OAAO,GAAAD,cAAA,cAAG,KAAK,GAAAA,cAAA;IACfE,QAAQ,GAaNrB,KAAK,CAbPqB,QAAQ;IACRC,kBAAkB,GAYhBtB,KAAK,CAZPsB,kBAAkB;IAClBC,UAAU,GAWRvB,KAAK,CAXPuB,UAAU;IACVC,UAAU,GAURxB,KAAK,CAVPwB,UAAU;IACVC,KAAK,GASHzB,KAAK,CATPyB,KAAK;IACLC,YAAY,GAQV1B,KAAK,CARP0B,YAAY;IACZC,OAAO,GAOL3B,KAAK,CAPP2B,OAAO;IACPC,UAAU,GAMR5B,KAAK,CANP4B,UAAU;IACVC,WAAW,GAKT7B,KAAK,CALP6B,WAAW;IACXC,UAAU,GAIR9B,KAAK,CAJP8B,UAAU;IACVC,SAAS,GAGP/B,KAAK,CAHP+B,SAAS;IACTC,YAAY,GAEVhC,KAAK,CAFPgC,YAAY;IACTC,IAAI,GAAAjE,MAAA,CACLgC,KAAK,EA5BH,CAAA,WAAA,EAAA,WAAA,EAAA,MAAA,EAAA,SAAA,EAAA,SAAA,EAAA,YAAA,EAAA,QAAA,EAAA,OAAA,EAAA,UAAA,EAAA,QAAA,EAAA,QAAA,EAAA,YAAA,EAAA,cAAA,EAAA,SAAA,EAAA,UAAA,EAAA,oBAAA,EAAA,YAAA,EAAA,YAAA,EAAA,OAAA,EAAA,cAAA,EAAA,SAAA,EAAA,YAAA,EAAA,aAAA,EAAA,YAAA,EAAA,WAAA,EAAA,cAAA,CA4BL,CAAQ;EACT,KAAKc,OAAO;EAEZ,IAAMoB,GAAG,GAAGhD,UAAU,CAACK,WAAW,CAAC;EAEnC,IAAM4C,SAAS,GAAGlD,aAAa,CAC7B,UAACmD,MAAS,EAAEC,KAAa,EAAS;IDtE9B,IAAIC,EAAE;ICuER,OAAA,OAAO3B,MAAM,KAAK,UAAU,GACxBA,MAAM,CAACyB,MAAM,CAAC,GACd,CAAAE,EAAA,GAACF,MAAM,CAACzB,MAAM,KAAA,IAAA,IAANA,MAAM,KAAA,KAAA,CAAA,GAANA,MAAM,GAAI,KAAK,CAAS,MAAA,IAAA,IAAA2B,EAAA,KAAA,KAAA,CAAA,GAAAA,EAAA,GAAID,KAAK;EDrE/C,CCqE+C,CAChD;EAED,IAAME,QAAQ,GAAG5C,oBAAoB,CAAC;IAAEc,OAAO,EAAPA,OAAO;IAAEC,UAAU,EAAVA,UAAU;IAAEO,UAAU,EAAVA,UAAU;IAAEI,QAAQ,EAARA;EAAQ,CAAE,CAAC;EACpF,IAAMmB,SAAS,GAAG5C,iBAAiB,CAAC;IAClCsB,YAAY,EAAZA,YAAY;IACZR,UAAU,EAAVA,UAAU;IACV+B,iBAAiB,EAAEF,QAAQ,CAACE,iBAAiB;IAC7CN,SAAS,EAATA;EDtEA,CCuED,CAAC;EACF,IAAMO,MAAM,GAAG7C,cAAc,CAAC;IAAE2B,UAAU,EAAVA;EAAU,CAAE,CAAC;EAE7C,IAAMmB,eAAe,GAAG7C,eAAe,CAAI;IACzCW,OAAO,EAAPA,OAAO;IACPH,IAAI,EAAJA,IAAI;IACJE,OAAO,EAAPA,OAAO;IACPgB,UAAU,EAAVA,UAAU;IACVoB,qBAAqB,EAAEF,MAAM,CAACE,qBAAqB;IACnDC,aAAa,EAAEH,MAAM,CAACG,aAAa;IACnC3B,YAAY,EAAZA,YAAY;IACZ4B,qBAAqB,EAAEN,SAAS,CAACM,qBAAqB;IACtDC,gBAAgB,EAAEP,SAAS,CAACO,gBAAgB;IAC5CC,aAAa,EAAER,SAAS,CAACQ,aAAa;IACtCC,eAAe,EAAET,SAAS,CAACS,eAAe;IAC1CC,gBAAgB,EAAEV,SAAS,CAACU,gBAAgB;IAC5CC,gBAAgB,EAAEX,SAAS,CAACW,gBAAgB;IAC5CC,MAAM,EAAEb,QAAQ,CAACa,MAAM;IACvBC,SAAS,EAAEd,QAAQ,CAACc,SAAS;IAC7BC,OAAO,EAAEf,QAAQ,CAACe,OAAO;IACzBC,UAAU,EAAEhB,QAAQ,CAACgB,UAAU;IAC/BpB,SAAS,EAATA;EDvEA,CCwED,CAAC;EAEF,IAAMqB,wBAAwB,GAAGvE,aAAa,CAC5C,UAACmD,MAAS,EAAEC,KAAa,EAAEoB,MAAc,EAAEC,QAAiB,EAAI;IDzE5D,IAAIpB,EAAE;ICyEuD,OAC/DvD,IAAA,CAACM,oBAAoB,EAAA;MAAAsE,QAAA,EAClB,CAAArB,EAAA,GAAAd,UAAU,KAAA,IAAA,IAAVA,UAAU,KAAA,KAAA,CAAA,GAAA,KAAA,CAAA,GAAVA,UAAU,CAAEoC,iBAAiB,MAAA,IAAA,IAAAtB,EAAA,KAAA,KAAA,CAAA,GAAA,KAAA,CAAA,GAAAA,EAAA,CAAA9D,IAAA,CAAAgD,UAAA,EAAGY,MAAM,EAAEC,KAAK,EAAEoB,MAAM,EAAEC,QAAQ;IAAC,CAAA,CAC5C;ED1EzB,CC2EC,CACF;EAED;EACA,IAAMG,cAAc,GAAG5E,aAAa,CAAC,UAACyE,QAAiB,EAAEtB,MAAS,EAAI;IACpE,IAAM0B,SAAS,GAAG3B,SAAS,CAACC,MAAM,EAAE1B,UAAU,CAACjC,OAAO,CAAC2D,MAAM,CAAC,CAAC;IAC/DM,MAAM,CAACqB,cAAc,CAACL,QAAQ,EAAEtB,MAAM,EAAE0B,SAAS,CAAC;EACpD,CAAC,CAAC;EAEF,IAAME,gBAAgB,GAAoChF,OAAO,CAC/D;IAAA,OACEwC,UAAU,GACLnD,MAAA,CAAA4F,MAAA,CAAA5F,MAAA,CAAA4F,MAAA,CAAA,CAAA,CAAA,EACIzC,UAAU,CAAA,EAAA;MACb0C,eAAe,EAAExB,MAAM,CAACE,qBAAqB;MAC7CgB,iBAAiB,EAAEpC,UAAU,CAACoC,iBAAiB,GAC3CJ,wBAAwB,GACxBW,SAAS;MACbC,gBAAgB,EAAE,KAAK;MACvBC,QAAQ,EAAER;IAAc,CAAA,CACD,GACzBM,SAAS;EAAA,GACf,CAAC3C,UAAU,EAAEkB,MAAM,CAACE,qBAAqB,EAAEY,wBAAwB,EAAEK,cAAc,CAAC,CACrF;EAED,IAAMS,kBAAkB,GAAG/B,QAAQ,CAACtB,UAAU,KAAK,KAAK,GACpD;IAAEsD,OAAO,EAAE,CAAC;IAAEC,QAAQ,EAAE;EAAE,CAAE,GAC5BjC,QAAQ,CAACtB,UAAU;EAEvB,IAAMwD,cAAc,GAAcxD,UAAU,KAAK,KAAK,GACpDlC,IAAA,CAAA,KAAA,EAAA;IAAKmB,SAAS,KAAAwE,MAAA,CAAKtE,SAAS,gBAAa;IAAAuD,QAAA,EACvC5E,IAAA,CAACK,UAAU,EAAA;MACTuF,KAAK,EAAEpC,QAAQ,CAACoC,KAAK;MACrBH,QAAQ,EAAEF,kBAAkB,CAACE,QAAQ;MACrCD,OAAO,EAAED,kBAAkB,CAACC,OAAO;MACnClD,QAAQ,EAAE,SAAVA,QAAQA,CAAGuD,QAAQ,EAAEC,YAAY;QAAA,OAC/BtC,QAAQ,CAACuC,aAAa,CAAC,UAACC,iBAAiB;UAAA,OAAK1G,MAAA,CAAA4F,MAAA,CAAA5F,MAAA,CAAA4F,MAAA,CAAA,CAAA,CAAA,EACzCc,iBAAiB,CAAA,EAAA;YACpBR,OAAO,EAAEK,QAAQ;YACjBJ,QAAQ,EAAEK;UAAY,CAAA,CAAA;QAAA,CACtB,CAAC;MAAA;IAAA,CAAA;EAEL,CAAA,CACE,GACJ,IAAI;EAER,IAAMG,gBAAgB,GAAG7F,OAAO,IAAAuF,MAAA,CAC3BtE,SAAS,eACZgB,OAAO,OAAAsD,MAAA,CAAOtE,SAAS,sBAAmB,EAC1CS,QAAQ,OAAA6D,MAAA,CAAOtE,SAAS,uBAAoB,CAC7C;EAED,IAAM6E,cAAc,GAAG9F,OAAO,CAAC+C,GAAG,CAAA,CAAE,EAAEA,GAAG,CAAC5B,IAAI,CAAC,EAAE4B,GAAG,CAAC1B,OAAO,CAAC,EAAEN,SAAS,CAAC;EAEzE,IAAMgF,SAAS,GACb9D,OAAO,IAAI,CAACV,UAAU,CAAC9B,MAAM,GAAGG,IAAA,CAAA,MAAA,EAAA,CAAA,CAAA,CAAQ,GAAGA,IAAA,CAACO,eAAe,EAAA;IAACsB,KAAK,EAAEA;EAAK,CAAA,CAAI;EAE9E,OAAO;IACLR,SAAS,EAATA,SAAS;IACT4E,gBAAgB,EAAhBA,gBAAgB;IAChBC,cAAc,EAAdA,cAAc;IACd7D,OAAO,EAAPA,OAAO;IACPuB,eAAe,EAAfA,eAAe;IACfF,iBAAiB,EAAEF,QAAQ,CAACE,iBAAiB;IAC7CuB,gBAAgB,EAAhBA,gBAAgB;IAChBkB,SAAS,EAATA,SAAS;IACTC,gBAAgB,EAAElD,IAAI;IACtBmD,oBAAoB,EAAE;MACpBzE,MAAM,EAAEA,MAAuC;MAC/CW,kBAAkB,EAAlBA,kBAAkB;MAClBC,UAAU,EAAVA,UAAU;MACVE,KAAK,EAALA,KAAK;MACLC,YAAY,EAAZA,YAAY;MACZC,OAAO,EAAPA,OAAO;MACPC,UAAU,EAAVA,UAAU;MACVC,WAAW,EAAXA,WAAW;MACXC,UAAU,EAAVA,UAAU;MACVC,SAAS,EAATA,SAAS;MACTC,YAAY,EAAZA,YAAY;MACZhB,MAAM,EAANA;IDjHE,CCkHH;IACDyD,cAAc,EAAdA;EDjHA,CCkHD;AACH,CAAC","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,
|
|
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
|
-
|
|
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, }: {
|
|
@@ -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
|
-
|
|
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":
|
|
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":
|
|
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,
|
|
54
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImNvbXBvbmVudHMvVGFibGUvZmVhdHVyZXMvU2VsZWN0aW9uQ29sdW1uLmpzIiwiY29tcG9uZW50cy9UYWJsZS9zcmMvY29tcG9uZW50cy9UYWJsZS9mZWF0dXJlcy9TZWxlY3Rpb25Db2x1bW4udHN4Il0sIm5hbWVzIjpbIl9fcmVzdCIsInMiLCJlIiwidCIsInAiLCJPYmplY3QiLCJwcm90b3R5cGUiLCJoYXNPd25Qcm9wZXJ0eSIsImNhbGwiLCJpbmRleE9mIiwiZ2V0T3duUHJvcGVydHlTeW1ib2xzIiwiaSIsImxlbmd0aCIsInByb3BlcnR5SXNFbnVtZXJhYmxlIiwianN4IiwiX2pzeCIsIkNoZWNrYm94IiwiUmFkaW8iLCJTZWxlY3Rpb25Db250cm9sIiwiX3JlZiIsImNoZWNrZWQiLCJ0eXBlIiwicm93UHJvcHMiLCJvbkNoYW5nZSIsIl9hIiwiZGlzYWJsZWQiLCJfYSRhcmlhTGFiZWwiLCJhcmlhTGFiZWwiLCJyZXN0IiwiYXNzaWduIiwiU2VsZWN0aW9uSGVhZGVyQ29udHJvbCIsIl9yZWYyIiwiaW5kZXRlcm1pbmF0ZSJdLCJtYXBwaW5ncyI6IkFBQUEsSUFBSUEsTUFBTSxHQUFJLElBQUksSUFBSSxJQUFJLENBQUNBLE1BQU0sSUFBSyxVQUFVQyxDQUFDLEVBQUVDLENBQUMsRUFBRTtFQUNsRCxJQUFJQyxDQUFDLEdBQUcsQ0FBQyxDQUFDO0VBQ1YsS0FBSyxJQUFJQyxDQUFDLElBQUlILENBQUMsRUFBRSxJQUFJSSxNQUFNLENBQUNDLFNBQVMsQ0FBQ0MsY0FBYyxDQUFDQyxJQUFJLENBQUNQLENBQUMsRUFBRUcsQ0FBQyxDQUFDLElBQUlGLENBQUMsQ0FBQ08sT0FBTyxDQUFDTCxDQUFDLENBQUMsR0FBRyxDQUFDLEVBQy9FRCxDQUFDLENBQUNDLENBQUMsQ0FBQyxHQUFHSCxDQUFDLENBQUNHLENBQUMsQ0FBQztFQUNmLElBQUlILENBQUMsSUFBSSxJQUFJLElBQUksT0FBT0ksTUFBTSxDQUFDSyxxQkFBcUIsS0FBSyxVQUFVLEVBQy9E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ZmVhdHVyZXMvU2VsZWN0aW9uQ29sdW1uLmpzIiwic291cmNlc0NvbnRlbnQiOlsidmFyIF9fcmVzdCA9ICh0aGlzICYmIHRoaXMuX19yZXN0KSB8fCBmdW5jdGlvbiAocywgZSkge1xuICAgIHZhciB0ID0ge307XG4gICAgZm9yICh2YXIgcCBpbiBzKSBpZiAoT2JqZWN0LnByb3RvdHlwZS5oYXNPd25Qcm9wZXJ0eS5jYWxsKHMsIHApICYmIGUuaW5kZXhPZihwKSA8IDApXG4gICAgICAgIHRbcF0gPSBzW3BdO1xuICAgIGlmIChzICE9IG51bGwgJiYgdHlwZW9mIE9iamVjdC5nZXRPd25Qcm9wZXJ0eVN5bWJvbHMgPT09IFwiZnVuY3Rpb25cIilcbiAgICAgICAgZm9yICh2YXIgaSA9IDAsIHAgPSBPYmplY3QuZ2V0T3duUHJvcGVydHlTeW1ib2xzKHMpOyBpIDwgcC5sZW5ndGg7IGkrKykge1xuICAgICAgICAgICAgaWYgKGUuaW5kZXhPZihwW2ldKSA8IDAgJiYgT2JqZWN0LnByb3RvdHlwZS5wcm9wZXJ0eUlzRW51bWVyYWJsZS5jYWxsKHMsIHBbaV0pKVxuICAgICAgICAgICAgICAgIHRbcFtpXV0gPSBzW3BbaV1dO1xuICAgICAgICB9XG4gICAgcmV0dXJuIHQ7XG59O1xuaW1wb3J0IHsganN4IGFzIF9qc3ggfSBmcm9tIFwicmVhY3QvanN4LXJ1bnRpbWVcIjtcbmltcG9ydCB7IENoZWNrYm94IH0gZnJvbSAnLi4vLi4vQ2hlY2tib3gnO1xuaW1wb3J0IHsgUmFkaW8gfSBmcm9tICcuLi8uLi9SYWRpbyc7XG5leHBvcnQgY29uc3QgU2VsZWN0aW9uQ29udHJvbCA9ICh7IGNoZWNrZWQsIHR5cGUsIHJvd1Byb3BzLCBvbkNoYW5nZSwgfSkgPT4ge1xuICAgIGNvbnN0IF9hID0gcm93UHJvcHMgIT09IG51bGwgJiYgcm93UHJvcHMgIT09IHZvaWQgMCA/IHJvd1Byb3BzIDoge30sIHsgZGlzYWJsZWQsICdhcmlhLWxhYmVsJzogYXJpYUxhYmVsID0gJ1NlbGVjdCByb3cnIH0gPSBfYSwgcmVzdCA9IF9fcmVzdChfYSwgW1wiZGlzYWJsZWRcIiwgJ2FyaWEtbGFiZWwnXSk7XG4gICAgaWYgKHR5cGUgPT09ICdyYWRpbycpIHtcbiAgICAgICAgcmV0dXJuIChfanN4KFJhZGlvLCB7IGNoZWNrZWQ6IGNoZWNrZWQsIGRpc2FibGVkOiBkaXNhYmxlZCwgb25DaGFuZ2U6ICgpID0+IG9uQ2hhbmdlKCksIFwiYXJpYS1sYWJlbFwiOiBhcmlhTGFiZWwgfSkpO1xuICAgIH1cbiAgICByZXR1cm4gKF9qc3goQ2hlY2tib3gsIE9iamVjdC5hc3NpZ24oe30sIHJlc3QsIHsgY2hlY2tlZDogY2hlY2tlZCwgZGlzYWJsZWQ6IGRpc2FibGVkLCBvbkNoYW5nZTogKCkgPT4gb25DaGFuZ2UoKSwgXCJhcmlhLWxhYmVsXCI6IGFyaWFMYWJlbCB9KSkpO1xufTtcbmV4cG9ydCBjb25zdCBTZWxlY3Rpb25IZWFkZXJDb250cm9sID0gKHsgY2hlY2tlZCwgaW5kZXRlcm1pbmF0ZSwgb25DaGFuZ2UsIH0pID0+IChfanN4KENoZWNrYm94LCB7IGNoZWNrZWQ6IGNoZWNrZWQsIGluZGV0ZXJtaW5hdGU6IGluZGV0ZXJtaW5hdGUsIG9uQ2hhbmdlOiAoKSA9PiBvbkNoYW5nZSgpLCBcImFyaWEtbGFiZWxcIjogXCJTZWxlY3QgYWxsIHJvd3NcIiB9KSk7IixudWxsXSwic291cmNlUm9vdCI6Ii4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3NyYyJ9
|