@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
@@ -1,23 +1,33 @@
1
1
  import type React from 'react';
2
2
  import type { CSSProperties, HTMLAttributes, Key, ReactNode } from 'react';
3
+ import type { CheckboxProps } from "../Checkbox";
3
4
  import type { EmptyProps } from "../Empty";
5
+ import type { DataIndex as InternalDataIndex } from './internal/kernel/interface';
4
6
  export type TableSize = 'large' | 'small';
5
7
  export type TableVariant = 'fill' | 'stroke';
6
8
  export type TableAlign = 'left' | 'center' | 'right';
7
9
  export type TableSortOrder = 'ascend' | 'descend' | null;
8
- export type TableAction = 'paginate' | 'sort';
10
+ export type TableAction = 'paginate' | 'sort' | 'filter';
9
11
  export type TableLayout = 'auto' | 'fixed';
10
12
  export type TableDirection = 'ltr' | 'rtl';
13
+ /** Default record shape — matches `rc-table`'s `DefaultRecordType`. */
14
+ export type TableRecord = Record<string, any>;
15
+ /**
16
+ * Path used to derive a value from a record. Re-exported from the kernel so the
17
+ * public API supports the same shapes as `rc-table` (string / number / array /
18
+ * recursive deep paths) instead of the previous narrower union.
19
+ */
20
+ export type TableDataIndex<T extends TableRecord = TableRecord> = InternalDataIndex<T>;
11
21
  export interface TablePaginationConfig {
12
22
  current?: number;
13
23
  defaultCurrent?: number;
14
24
  pageSize?: number;
15
25
  defaultPageSize?: number;
16
26
  }
17
- export interface TableCellRenderMeta<T> {
27
+ export interface TableCellRenderMeta<T extends TableRecord = TableRecord> {
18
28
  column: TableColumn<T>;
19
29
  }
20
- export interface TableHeaderRenderMeta<T> {
30
+ export interface TableHeaderRenderMeta<T extends TableRecord = TableRecord> {
21
31
  column: TableColumn<T>;
22
32
  }
23
33
  export interface TableCellContentValue {
@@ -26,7 +36,7 @@ export interface TableCellContentValue {
26
36
  leading?: ReactNode;
27
37
  trailing?: ReactNode;
28
38
  }
29
- export interface TableRenderedCell<T> {
39
+ export interface TableRenderedCell<T extends TableRecord = TableRecord> {
30
40
  children?: ReactNode;
31
41
  props?: {
32
42
  colSpan?: number;
@@ -34,16 +44,18 @@ export interface TableRenderedCell<T> {
34
44
  className?: string;
35
45
  style?: CSSProperties;
36
46
  };
47
+ /** Reserved for future record/column-aware overrides; preserves T for variance. */
48
+ __recordType?: T;
37
49
  }
38
- export interface TableColumnSorterConfig<T> {
50
+ export interface TableColumnSorterConfig<T extends TableRecord = TableRecord> {
39
51
  compare: (a: T, b: T) => number;
40
52
  /** Priority number for multi-column sort. Columns with higher values are compared first. */
41
53
  multiple: number;
42
54
  }
43
55
  export type TableGetComponentProps<T> = (data: T, index?: number) => HTMLAttributes<HTMLElement> & React.TdHTMLAttributes<HTMLElement>;
44
- export type TableRowClassName<T> = string | ((record: T, index: number, indent: number) => string);
56
+ export type TableRowClassName<T extends TableRecord = TableRecord> = string | ((record: T, index: number, indent: number) => string);
45
57
  type TableCustomizeComponent = React.ComponentType<any> | React.ForwardRefExoticComponent<any> | React.FC<any> | keyof React.JSX.IntrinsicElements;
46
- export interface TableComponents<T> {
58
+ export interface TableComponents<T extends TableRecord = TableRecord> {
47
59
  table?: TableCustomizeComponent;
48
60
  header?: {
49
61
  table?: TableCustomizeComponent;
@@ -56,10 +68,31 @@ export interface TableComponents<T> {
56
68
  row?: TableCustomizeComponent;
57
69
  cell?: TableCustomizeComponent;
58
70
  };
71
+ /** Reserved to preserve record-type variance. */
72
+ __recordType?: T;
59
73
  }
60
- export interface TableColumn<T> {
74
+ export type TableFilterValue = (Key | boolean)[];
75
+ export interface TableColumnFilterItem {
76
+ text: ReactNode;
77
+ value: Key | boolean;
78
+ children?: TableColumnFilterItem[];
79
+ }
80
+ export interface TableFilterDropdownProps<T extends TableRecord = TableRecord> {
81
+ prefixCls: string;
82
+ setSelectedKeys: (selectedKeys: TableFilterValue) => void;
83
+ selectedKeys: TableFilterValue;
84
+ /** Apply current selection and close the dropdown. */
85
+ confirm: () => void;
86
+ /** Reset selection for this column. */
87
+ clearFilters?: () => void;
88
+ filters?: TableColumnFilterItem[];
89
+ visible: boolean;
90
+ close: () => void;
91
+ column: TableColumn<T>;
92
+ }
93
+ export interface TableColumn<T extends TableRecord = TableRecord> {
61
94
  key?: Key;
62
- dataIndex?: keyof T | string | string[];
95
+ dataIndex?: TableDataIndex<T>;
63
96
  title?: ReactNode;
64
97
  width?: number | string;
65
98
  minWidth?: number;
@@ -76,6 +109,23 @@ export interface TableColumn<T> {
76
109
  sorter?: boolean | ((a: T, b: T) => number) | TableColumnSorterConfig<T>;
77
110
  sortOrder?: TableSortOrder;
78
111
  defaultSortOrder?: Exclude<TableSortOrder, null>;
112
+ filters?: TableColumnFilterItem[];
113
+ filteredValue?: TableFilterValue | null;
114
+ defaultFilteredValue?: TableFilterValue | null;
115
+ filterMultiple?: boolean;
116
+ filterMode?: 'menu' | 'tree';
117
+ filterSearch?: boolean | ((input: string, item: TableColumnFilterItem) => boolean);
118
+ filterIcon?: ReactNode | ((filtered: boolean) => ReactNode);
119
+ filterDropdown?: ReactNode | ((props: TableFilterDropdownProps<T>) => ReactNode);
120
+ filterDropdownOpen?: boolean;
121
+ defaultFilterDropdownOpen?: boolean;
122
+ /**
123
+ * Predicate used to filter rows when `filters` (built-in UI) or `filteredValue`
124
+ * (controlled) is set. Receives one filter value at a time per row; row is kept
125
+ * if the predicate returns `true` for ANY currently selected value.
126
+ */
127
+ onFilter?: (value: Key | boolean, record: T) => boolean;
128
+ onFilterDropdownOpenChange?: (open: boolean) => void;
79
129
  onCell?: TableGetComponentProps<T>;
80
130
  onHeaderCell?: TableGetComponentProps<TableColumn<T>>;
81
131
  shouldCellUpdate?: (record: T, prevRecord: T) => boolean;
@@ -83,37 +133,60 @@ export interface TableColumn<T> {
83
133
  headerClassName?: string;
84
134
  cellClassName?: string | ((value: unknown, record: T, index: number) => string);
85
135
  }
86
- export interface TableColumnGroup<T> extends Pick<TableColumn<T>, 'key' | 'title' | 'align' | 'className' | 'headerClassName' | 'fixed'> {
136
+ export interface TableColumnGroup<T extends TableRecord = TableRecord> extends Pick<TableColumn<T>, 'key' | 'title' | 'align' | 'className' | 'headerClassName' | 'fixed'> {
87
137
  children: TableColumnType<T>[];
88
138
  }
89
- export type TableColumnType<T> = TableColumn<T> | TableColumnGroup<T>;
90
- export interface TableChangeMeta<T> {
139
+ export type TableColumnType<T extends TableRecord = TableRecord> = TableColumn<T> | TableColumnGroup<T>;
140
+ export interface TableChangeMeta<T extends TableRecord = TableRecord> {
91
141
  currentDataSource: T[];
92
142
  action: TableAction;
143
+ /**
144
+ * Current pagination state after this change. Always present so consumers can
145
+ * mirror the table's state.
146
+ */
147
+ pagination?: {
148
+ current: number;
149
+ pageSize: number;
150
+ } | false;
151
+ /** Current sorter (single-column shape — `{ columnKey, order }`). */
152
+ sorter?: {
153
+ columnKey?: Key;
154
+ order?: TableSortOrder;
155
+ };
156
+ /**
157
+ * Current filter selection keyed by column key. Required for controlled-mode
158
+ * consumers who want clicks inside the built-in filter dropdown to round-trip
159
+ * back to their state — e.g. `onChange={meta => setFilteredValue(meta.filters?.network ?? [])}`.
160
+ */
161
+ filters?: Record<string, TableFilterValue | null>;
93
162
  }
94
163
  export type TableRowSelectMethod = 'all' | 'none' | 'single';
95
- export interface TableRowSelection<T> {
164
+ /**
165
+ * Properties returned from `getCheckboxProps`. Mirrors antd: any prop accepted
166
+ * by the underlying Checkbox EXCEPT `checked` / `defaultChecked` (those are
167
+ * controlled by the table) can be customized per-row.
168
+ */
169
+ export type TableCheckboxProps = Partial<Omit<CheckboxProps, 'checked' | 'defaultChecked' | 'onChange'>>;
170
+ export interface TableRowSelection<T extends TableRecord = TableRecord> {
96
171
  type?: 'checkbox' | 'radio';
97
172
  selectedRowKeys?: Key[];
98
173
  defaultSelectedRowKeys?: Key[];
99
174
  onChange?: (selectedRowKeys: Key[], selectedRows: T[], info: {
100
175
  type: TableRowSelectMethod;
101
176
  }) => void;
102
- getCheckboxProps?: (record: T) => Partial<{
103
- disabled: boolean;
104
- }>;
177
+ getCheckboxProps?: (record: T) => TableCheckboxProps;
105
178
  preserveSelectedRowKeys?: boolean;
106
179
  fixed?: boolean;
107
180
  columnWidth?: number | string;
108
181
  }
109
- export interface TableExpandIconProps<T> {
182
+ export interface TableExpandIconProps<T extends TableRecord = TableRecord> {
110
183
  prefixCls: string;
111
184
  expanded: boolean;
112
185
  record: T;
113
186
  expandable: boolean;
114
187
  onExpand: (record: T, e: React.MouseEvent<HTMLElement>) => void;
115
188
  }
116
- export interface TableExpandableConfig<T> {
189
+ export interface TableExpandableConfig<T extends TableRecord = TableRecord> {
117
190
  expandedRowKeys?: Key[];
118
191
  defaultExpandedRowKeys?: Key[];
119
192
  defaultExpandAllRows?: boolean;
@@ -137,11 +210,19 @@ export interface TableRef {
137
210
  offset?: number;
138
211
  }) => void;
139
212
  }
140
- export interface TableProps<T> extends Omit<HTMLAttributes<HTMLDivElement>, 'onChange'> {
213
+ export interface TableProps<T extends TableRecord = TableRecord> extends Omit<HTMLAttributes<HTMLDivElement>, 'onChange'> {
141
214
  prefixCls?: string;
142
215
  columns: TableColumnType<T>[];
143
216
  dataSource: T[];
144
- rowKey: keyof T | ((record: T) => Key);
217
+ /**
218
+ * Row key for tracking. Accepts:
219
+ * - `string` — a property name, including synthetic keys not statically known on `T`
220
+ * (e.g. records carrying an injected `key` field). Same shape as `rc-table`.
221
+ * - `keyof T` — type-checked property name.
222
+ * - `(record) => Key` — function form for composite or computed keys.
223
+ * Defaults to `'key'` at runtime (kernel falls back to row index if the field is absent).
224
+ */
225
+ rowKey?: string | keyof T | ((record: T) => Key);
145
226
  size?: TableSize;
146
227
  variant?: TableVariant;
147
228
  bordered?: boolean;
@@ -170,7 +251,7 @@ export interface TableProps<T> extends Omit<HTMLAttributes<HTMLDivElement>, 'onC
170
251
  summary?: (data: readonly T[]) => ReactNode;
171
252
  onChange?: (meta: TableChangeMeta<T>) => void;
172
253
  }
173
- export interface VirtualTableProps<T> extends Omit<TableProps<T>, 'scroll'> {
254
+ export interface VirtualTableProps<T extends TableRecord = TableRecord> extends Omit<TableProps<T>, 'scroll'> {
174
255
  scroll: {
175
256
  x: number;
176
257
  y: number;
@@ -1,8 +1,8 @@
1
- import type { TableColumn } from '../interface';
2
- export declare const BodyCell: ({ column, value, record, index, }: {
3
- column: TableColumn<Record<string, unknown>>;
1
+ import type { TableColumn, TableRecord } from '../interface';
2
+ export declare const BodyCell: <T extends TableRecord = TableRecord>({ column, value, record, index, }: {
3
+ column: TableColumn<T>;
4
4
  value: unknown;
5
- record: Record<string, unknown>;
5
+ record: T;
6
6
  index: number;
7
7
  }) => import("react/jsx-runtime").JSX.Element | {
8
8
  children: string | number | bigint | boolean | Iterable<import("react").ReactNode> | Promise<string | number | bigint | boolean | import("react").ReactElement<unknown, string | import("react").JSXElementConstructor<any>> | import("react").ReactPortal | Iterable<import("react").ReactNode> | null | undefined> | import("react/jsx-runtime").JSX.Element | null | undefined;
@@ -37,4 +37,4 @@ export var BodyCell = function BodyCell(_ref) {
37
37
  children: rendered
38
38
  });
39
39
  };
40
- //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImNvbXBvbmVudHMvVGFibGUvcmVuZGVyZXJzL0JvZHlDZWxsLmpzIiwiY29tcG9uZW50cy9UYWJsZS9zcmMvY29tcG9uZW50cy9UYWJsZS9yZW5kZXJlcnMvQm9keUNlbGwudHN4Il0sIm5hbWVzIjpbImpzeCIsIl9qc3giLCJGcmFnbWVudCIsIl9GcmFnbWVudCIsIkNlbGxDb250ZW50IiwiaXNDZWxsQ29udGVudFZhbHVlIiwidmFsdWUiLCJfdHlwZW9mIiwiaXNSZW5kZXJlZENlbGwiLCJvYmoiLCJwcm9wcyIsIkJvZHlDZWxsIiwiX3JlZiIsImNvbHVtbiIsInJlY29yZCIsImluZGV4IiwicmVuZGVyZWQiLCJyZW5kZXIiLCJpbm5lciIsImNoaWxkcmVuIl0sIm1hcHBpbmdzIjoiO0FBQUEsU0FBU0EsR0FBRyxJQUFJQyxJQUFJLEVBQUVDLFFBQVEsSUFBSUMsU0FBUyxRQUFRLG1CQUFtQjtBQ0N0RSxTQUFTQyxXQUFXLFFBQVEsZUFBZTtBQUUzQyxJQUFNQyxrQkFBa0IsR0FBRyxTQUFyQkEsa0JBQWtCQSxDQUFJQyxLQUFjLEVBQW9DO0VBQzVFLE9BQU8sQ0FBQyxDQUFDQSxLQUFLLElBQUlDLE9BQUEsQ0FBT0QsS0FBSyxNQUFLLFFBQVEsSUFBSSxTQUFTLElBQUtBLEtBQWlDO0FBQ2hHLENBQUM7QUFFRCxJQUFNRSxjQUFjLEdBQUcsU0FBakJBLGNBQWNBLENBQUlGLEtBQWMsRUFBeUM7RUFDN0UsSUFBSSxDQUFDQSxLQUFLLElBQUlDLE9BQUEsQ0FBT0QsS0FBSyxNQUFLLFFBQVEsRUFBRSxPQUFPLEtBQUs7RUFDckQsSUFBTUcsR0FBRyxHQUFHSCxLQUFnQztFQUM1QztFQUNBLElBQUksVUFBVSxJQUFJRyxHQUFHLEVBQUUsT0FBTyxLQUFLO0VBQ25DLE9BQU8sT0FBTyxJQUFJQSxHQUFHLElBQUlGLE9BQUEsQ0FBT0UsR0FBRyxDQUFDQyxLQUFLLE1BQUssUUFBUTtBQUN4RCxDQUFDO0FBRUQsT0FBTyxJQUFNQyxRQUFRLEdBQUcsU0FBWEEsUUFBUUEsQ0FBQUMsSUFBQSxFQVVoQjtFQUFBLElBVEhDLE1BQU0sR0FBQUQsSUFBQSxDQUFOQyxNQUFNO0lBQ05QLEtBQUssR0FBQU0sSUFBQSxDQUFMTixLQUFLO0lBQ0xRLE1BQU0sR0FBQUYsSUFBQSxDQUFORSxNQUFNO0lBQ05DLEtBQUssR0FBQUgsSUFBQSxDQUFMRyxLQUFLO0VBT0wsSUFBTUMsUUFBUSxHQUFHSCxNQUFNLENBQUNJLE1BQU0sR0FDMUJKLE1BQU0sQ0FBQ0ksTUFBTSxDQUFDWCxLQUFLLEVBQUVRLE1BQU0sRUFBRUMsS0FBSyxFQUFFO0lBQUVGLE1BQU0sRUFBTkE7RUFBTSxDQUFFLENBQUMsR0FDL0NQLEtBQUs7RUFFVCxJQUFJRSxjQUFjLENBQUNRLFFBQVEsQ0FBQyxFQUFFO0lBQzVCLElBQU1FLEtBQUssR0FBR2Isa0JBQWtCLENBQUNXLFFBQVEsQ0FBQ0csUUFBUSxDQUFDLEdBQy9DbEIsSUFBQSxDQUFDRyxXQUFXLEVBQUE7TUFBQ0UsS0FBSyxFQUFFVSxRQUFRLENBQUNHO0lBQVEsQ0FBQSxDQUFJLEdBQ3pDSCxRQUFRLENBQUNHLFFBQVE7SUFDckIsT0FBTztNQUFFQSxRQUFRLEVBQUVELEtBQUs7TUFBRVIsS0FBSyxFQUFFTSxRQUFRLENBQUNOO0lBQUssQ0FBRTtFQUNuRDtFQUVBLElBQUlMLGtCQUFrQixDQUFDVyxRQUFRLENBQUMsRUFBRTtJQUNoQyxPQUFPZixJQUFBLENBQUNHLFdBQVcsRUFBQTtNQUFDRSxLQUFLLEVBQUVVO0lBQVEsQ0FBQSxDQUFJO0VBQ3pDO0VBRUEsT0FBT2YsSUFBQSxDQUFBRSxTQUFBLEVBQUE7SUFBQWdCLFFBQUEsRUFBR0g7RUFBUSxDQUFBLENBQUk7QUFDeEIsQ0FBQyIsImZpbGUiOiJjb21wb25lbnRzL1RhYmxlL3JlbmRlcmVycy9Cb2R5Q2VsbC5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGpzeCBhcyBfanN4LCBGcmFnbWVudCBhcyBfRnJhZ21lbnQgfSBmcm9tIFwicmVhY3QvanN4LXJ1bnRpbWVcIjtcbmltcG9ydCB7IENlbGxDb250ZW50IH0gZnJvbSAnLi9DZWxsQ29udGVudCc7XG5jb25zdCBpc0NlbGxDb250ZW50VmFsdWUgPSAodmFsdWUpID0+IHtcbiAgICByZXR1cm4gISF2YWx1ZSAmJiB0eXBlb2YgdmFsdWUgPT09ICdvYmplY3QnICYmICdwcmltYXJ5JyBpbiB2YWx1ZTtcbn07XG5jb25zdCBpc1JlbmRlcmVkQ2VsbCA9ICh2YWx1ZSkgPT4ge1xuICAgIGlmICghdmFsdWUgfHwgdHlwZW9mIHZhbHVlICE9PSAnb2JqZWN0JylcbiAgICAgICAgcmV0dXJuIGZhbHNlO1xuICAgIGNvbnN0IG9iaiA9IHZhbHVlO1xuICAgIC8vIFJlYWN0IGVsZW1lbnRzIGFsc28gaGF2ZSAncHJvcHMnLCBzbyBleGNsdWRlIHRoZW0gYnkgY2hlY2tpbmcgZm9yICQkdHlwZW9mXG4gICAgaWYgKCckJHR5cGVvZicgaW4gb2JqKVxuICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgcmV0dXJuICdwcm9wcycgaW4gb2JqICYmIHR5cGVvZiBvYmoucHJvcHMgPT09ICdvYmplY3QnO1xufTtcbmV4cG9ydCBjb25zdCBCb2R5Q2VsbCA9ICh7IGNvbHVtbiwgdmFsdWUsIHJlY29yZCwgaW5kZXgsIH0pID0+IHtcbiAgICBjb25zdCByZW5kZXJlZCA9IGNvbHVtbi5yZW5kZXJcbiAgICAgICAgPyBjb2x1bW4ucmVuZGVyKHZhbHVlLCByZWNvcmQsIGluZGV4LCB7IGNvbHVtbiB9KVxuICAgICAgICA6IHZhbHVlO1xuICAgIGlmIChpc1JlbmRlcmVkQ2VsbChyZW5kZXJlZCkpIHtcbiAgICAgICAgY29uc3QgaW5uZXIgPSBpc0NlbGxDb250ZW50VmFsdWUocmVuZGVyZWQuY2hpbGRyZW4pXG4gICAgICAgICAgICA/IF9qc3goQ2VsbENvbnRlbnQsIHsgdmFsdWU6IHJlbmRlcmVkLmNoaWxkcmVuIH0pXG4gICAgICAgICAgICA6IHJlbmRlcmVkLmNoaWxkcmVuO1xuICAgICAgICByZXR1cm4geyBjaGlsZHJlbjogaW5uZXIsIHByb3BzOiByZW5kZXJlZC5wcm9wcyB9O1xuICAgIH1cbiAgICBpZiAoaXNDZWxsQ29udGVudFZhbHVlKHJlbmRlcmVkKSkge1xuICAgICAgICByZXR1cm4gX2pzeChDZWxsQ29udGVudCwgeyB2YWx1ZTogcmVuZGVyZWQgfSk7XG4gICAgfVxuICAgIHJldHVybiBfanN4KF9GcmFnbWVudCwgeyBjaGlsZHJlbjogcmVuZGVyZWQgfSk7XG59OyIsbnVsbF0sInNvdXJjZVJvb3QiOiIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9zcmMifQ==
40
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImNvbXBvbmVudHMvVGFibGUvcmVuZGVyZXJzL0JvZHlDZWxsLmpzIiwiY29tcG9uZW50cy9UYWJsZS9zcmMvY29tcG9uZW50cy9UYWJsZS9yZW5kZXJlcnMvQm9keUNlbGwudHN4Il0sIm5hbWVzIjpbImpzeCIsIl9qc3giLCJGcmFnbWVudCIsIl9GcmFnbWVudCIsIkNlbGxDb250ZW50IiwiaXNDZWxsQ29udGVudFZhbHVlIiwidmFsdWUiLCJfdHlwZW9mIiwiaXNSZW5kZXJlZENlbGwiLCJvYmoiLCJwcm9wcyIsIkJvZHlDZWxsIiwiX3JlZiIsImNvbHVtbiIsInJlY29yZCIsImluZGV4IiwicmVuZGVyZWQiLCJyZW5kZXIiLCJpbm5lciIsImNoaWxkcmVuIl0sIm1hcHBpbmdzIjoiO0FBQUEsU0FBU0EsR0FBRyxJQUFJQyxJQUFJLEVBQUVDLFFBQVEsSUFBSUMsU0FBUyxRQUFRLG1CQUFtQjtBQ0N0RSxTQUFTQyxXQUFXLFFBQVEsZUFBZTtBQUUzQyxJQUFNQyxrQkFBa0IsR0FBRyxTQUFyQkEsa0JBQWtCQSxDQUFJQyxLQUFjLEVBQW9DO0VBQzVFLE9BQU8sQ0FBQyxDQUFDQSxLQUFLLElBQUlDLE9BQUEsQ0FBT0QsS0FBSyxNQUFLLFFBQVEsSUFBSSxTQUFTLElBQUtBLEtBQWlDO0FBQ2hHLENBQUM7QUFFRCxJQUFNRSxjQUFjLEdBQUcsU0FBakJBLGNBQWNBLENBQTJCRixLQUFjLEVBQW1DO0VBQzlGLElBQUksQ0FBQ0EsS0FBSyxJQUFJQyxPQUFBLENBQU9ELEtBQUssTUFBSyxRQUFRLEVBQUUsT0FBTyxLQUFLO0VBQ3JELElBQU1HLEdBQUcsR0FBR0gsS0FBZ0M7RUFDNUM7RUFDQSxJQUFJLFVBQVUsSUFBSUcsR0FBRyxFQUFFLE9BQU8sS0FBSztFQUNuQyxPQUFPLE9BQU8sSUFBSUEsR0FBRyxJQUFJRixPQUFBLENBQU9FLEdBQUcsQ0FBQ0MsS0FBSyxNQUFLLFFBQVE7QUFDeEQsQ0FBQztBQUVELE9BQU8sSUFBTUMsUUFBUSxHQUFHLFNBQVhBLFFBQVFBLENBQUFDLElBQUEsRUFVaEI7RUFBQSxJQVRIQyxNQUFNLEdBQUFELElBQUEsQ0FBTkMsTUFBTTtJQUNOUCxLQUFLLEdBQUFNLElBQUEsQ0FBTE4sS0FBSztJQUNMUSxNQUFNLEdBQUFGLElBQUEsQ0FBTkUsTUFBTTtJQUNOQyxLQUFLLEdBQUFILElBQUEsQ0FBTEcsS0FBSztFQU9MLElBQU1DLFFBQVEsR0FBR0gsTUFBTSxDQUFDSSxNQUFNLEdBQzFCSixNQUFNLENBQUNJLE1BQU0sQ0FBQ1gsS0FBSyxFQUFFUSxNQUFNLEVBQUVDLEtBQUssRUFBRTtJQUFFRixNQUFNLEVBQU5BO0VBQU0sQ0FBRSxDQUFDLEdBQy9DUCxLQUFLO0VBRVQsSUFBSUUsY0FBYyxDQUFJUSxRQUFRLENBQUMsRUFBRTtJQUMvQixJQUFNRSxLQUFLLEdBQUdiLGtCQUFrQixDQUFDVyxRQUFRLENBQUNHLFFBQVEsQ0FBQyxHQUMvQ2xCLElBQUEsQ0FBQ0csV0FBVyxFQUFBO01BQUNFLEtBQUssRUFBRVUsUUFBUSxDQUFDRztJQUFRLENBQUEsQ0FBSSxHQUN6Q0gsUUFBUSxDQUFDRyxRQUFRO0lBQ3JCLE9BQU87TUFBRUEsUUFBUSxFQUFFRCxLQUFLO01BQUVSLEtBQUssRUFBRU0sUUFBUSxDQUFDTjtJQUFLLENBQUU7RUFDbkQ7RUFFQSxJQUFJTCxrQkFBa0IsQ0FBQ1csUUFBUSxDQUFDLEVBQUU7SUFDaEMsT0FBT2YsSUFBQSxDQUFDRyxXQUFXLEVBQUE7TUFBQ0UsS0FBSyxFQUFFVTtJQUFRLENBQUEsQ0FBSTtFQUN6QztFQUVBLE9BQU9mLElBQUEsQ0FBQUUsU0FBQSxFQUFBO0lBQUFnQixRQUFBLEVBQUdIO0VBQVEsQ0FBQSxDQUFJO0FBQ3hCLENBQUMiLCJmaWxlIjoiY29tcG9uZW50cy9UYWJsZS9yZW5kZXJlcnMvQm9keUNlbGwuanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBqc3ggYXMgX2pzeCwgRnJhZ21lbnQgYXMgX0ZyYWdtZW50IH0gZnJvbSBcInJlYWN0L2pzeC1ydW50aW1lXCI7XG5pbXBvcnQgeyBDZWxsQ29udGVudCB9IGZyb20gJy4vQ2VsbENvbnRlbnQnO1xuY29uc3QgaXNDZWxsQ29udGVudFZhbHVlID0gKHZhbHVlKSA9PiB7XG4gICAgcmV0dXJuICEhdmFsdWUgJiYgdHlwZW9mIHZhbHVlID09PSAnb2JqZWN0JyAmJiAncHJpbWFyeScgaW4gdmFsdWU7XG59O1xuY29uc3QgaXNSZW5kZXJlZENlbGwgPSAodmFsdWUpID0+IHtcbiAgICBpZiAoIXZhbHVlIHx8IHR5cGVvZiB2YWx1ZSAhPT0gJ29iamVjdCcpXG4gICAgICAgIHJldHVybiBmYWxzZTtcbiAgICBjb25zdCBvYmogPSB2YWx1ZTtcbiAgICAvLyBSZWFjdCBlbGVtZW50cyBhbHNvIGhhdmUgJ3Byb3BzJywgc28gZXhjbHVkZSB0aGVtIGJ5IGNoZWNraW5nIGZvciAkJHR5cGVvZlxuICAgIGlmICgnJCR0eXBlb2YnIGluIG9iailcbiAgICAgICAgcmV0dXJuIGZhbHNlO1xuICAgIHJldHVybiAncHJvcHMnIGluIG9iaiAmJiB0eXBlb2Ygb2JqLnByb3BzID09PSAnb2JqZWN0Jztcbn07XG5leHBvcnQgY29uc3QgQm9keUNlbGwgPSAoeyBjb2x1bW4sIHZhbHVlLCByZWNvcmQsIGluZGV4LCB9KSA9PiB7XG4gICAgY29uc3QgcmVuZGVyZWQgPSBjb2x1bW4ucmVuZGVyXG4gICAgICAgID8gY29sdW1uLnJlbmRlcih2YWx1ZSwgcmVjb3JkLCBpbmRleCwgeyBjb2x1bW4gfSlcbiAgICAgICAgOiB2YWx1ZTtcbiAgICBpZiAoaXNSZW5kZXJlZENlbGwocmVuZGVyZWQpKSB7XG4gICAgICAgIGNvbnN0IGlubmVyID0gaXNDZWxsQ29udGVudFZhbHVlKHJlbmRlcmVkLmNoaWxkcmVuKVxuICAgICAgICAgICAgPyBfanN4KENlbGxDb250ZW50LCB7IHZhbHVlOiByZW5kZXJlZC5jaGlsZHJlbiB9KVxuICAgICAgICAgICAgOiByZW5kZXJlZC5jaGlsZHJlbjtcbiAgICAgICAgcmV0dXJuIHsgY2hpbGRyZW46IGlubmVyLCBwcm9wczogcmVuZGVyZWQucHJvcHMgfTtcbiAgICB9XG4gICAgaWYgKGlzQ2VsbENvbnRlbnRWYWx1ZShyZW5kZXJlZCkpIHtcbiAgICAgICAgcmV0dXJuIF9qc3goQ2VsbENvbnRlbnQsIHsgdmFsdWU6IHJlbmRlcmVkIH0pO1xuICAgIH1cbiAgICByZXR1cm4gX2pzeChfRnJhZ21lbnQsIHsgY2hpbGRyZW46IHJlbmRlcmVkIH0pO1xufTsiLG51bGxdLCJzb3VyY2VSb290IjoiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vc3JjIn0=
@@ -1,7 +1,11 @@
1
- import type { TableColumn, TableSize, TableSortOrder } from '../interface';
2
- export declare const HeaderCell: ({ column, size, sortOrder, onSortClick, }: {
3
- column: TableColumn<Record<string, unknown>>;
1
+ import type { TableColumn, TableFilterValue, TableRecord, TableSize, TableSortOrder } from '../interface';
2
+ interface HeaderCellProps<T extends TableRecord> {
3
+ column: TableColumn<T>;
4
4
  size: TableSize;
5
5
  sortOrder?: TableSortOrder;
6
6
  onSortClick: () => void;
7
- }) => import("react/jsx-runtime").JSX.Element;
7
+ filterSelected: TableFilterValue;
8
+ onFilterChange: (next: TableFilterValue) => void;
9
+ }
10
+ export declare const HeaderCell: <T extends TableRecord = TableRecord>({ column, size, sortOrder, onSortClick, filterSelected, onFilterChange, }: HeaderCellProps<T>) => import("react/jsx-runtime").JSX.Element;
11
+ export {};
@@ -1,22 +1,32 @@
1
1
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
2
  import { SortTrigger } from '../features/SortTrigger';
3
+ import { FilterTrigger } from '../features/FilterTrigger';
3
4
  import { TABLE_DEFAULT_PREFIX } from '../constants';
4
5
  export var HeaderCell = function HeaderCell(_ref) {
5
6
  var column = _ref.column,
6
7
  size = _ref.size,
7
8
  sortOrder = _ref.sortOrder,
8
- onSortClick = _ref.onSortClick;
9
+ onSortClick = _ref.onSortClick,
10
+ filterSelected = _ref.filterSelected,
11
+ onFilterChange = _ref.onFilterChange;
12
+ var titleText = typeof column.title === 'string' || typeof column.title === 'number' ? String(column.title) : '';
13
+ var hasFilter = column.filters && column.filters.length > 0 || column.filterDropdown !== undefined;
9
14
  return _jsxs("div", {
10
15
  className: "".concat(TABLE_DEFAULT_PREFIX, "-header-cell ").concat(TABLE_DEFAULT_PREFIX, "-header-cell--").concat(size),
11
16
  children: [_jsx("span", {
12
17
  className: "".concat(TABLE_DEFAULT_PREFIX, "-header-cell__title"),
13
18
  children: column.title
14
19
  }), column.sorter ? _jsx(SortTrigger, {
15
- label: String(column.title),
20
+ label: titleText,
16
21
  order: sortOrder,
17
22
  size: size,
18
23
  onClick: onSortClick
24
+ }) : null, hasFilter ? _jsx(FilterTrigger, {
25
+ column: column,
26
+ size: size,
27
+ selectedKeys: filterSelected,
28
+ onChange: onFilterChange
19
29
  }) : null]
20
30
  });
21
31
  };
22
- //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImNvbXBvbmVudHMvVGFibGUvcmVuZGVyZXJzL0hlYWRlckNlbGwuanMiLCJjb21wb25lbnRzL1RhYmxlL3NyYy9jb21wb25lbnRzL1RhYmxlL3JlbmRlcmVycy9IZWFkZXJDZWxsLnRzeCJdLCJuYW1lcyI6WyJqc3giLCJfanN4IiwianN4cyIsIl9qc3hzIiwiU29ydFRyaWdnZXIiLCJUQUJMRV9ERUZBVUxUX1BSRUZJWCIsIkhlYWRlckNlbGwiLCJfcmVmIiwiY29sdW1uIiwic2l6ZSIsInNvcnRPcmRlciIsIm9uU29ydENsaWNrIiwiY2xhc3NOYW1lIiwiY29uY2F0IiwiY2hpbGRyZW4iLCJ0aXRsZSIsInNvcnRlciIsImxhYmVsIiwiU3RyaW5nIiwib3JkZXIiLCJvbkNsaWNrIl0sIm1hcHBpbmdzIjoiQUFBQSxTQUFTQSxHQUFHLElBQUlDLElBQUksRUFBRUMsSUFBSSxJQUFJQyxLQUFLLFFBQVEsbUJBQW1CO0FDQTlELFNBQVNDLFdBQVcsUUFBUSx5QkFBeUI7QUFDckQsU0FBU0Msb0JBQW9CLFFBQVEsY0FBYztBQUduRCxPQUFPLElBQU1DLFVBQVUsR0FBRyxTQUFiQSxVQUFVQSxDQUFBQyxJQUFBO0VBQUEsSUFDckJDLE1BQU0sR0FBQUQsSUFBQSxDQUFOQyxNQUFNO0lBQ05DLElBQUksR0FBQUYsSUFBQSxDQUFKRSxJQUFJO0lBQ0pDLFNBQVMsR0FBQUgsSUFBQSxDQUFURyxTQUFTO0lBQ1RDLFdBQVcsR0FBQUosSUFBQSxDQUFYSSxXQUFXO0VBQUEsT0FPWFIsS0FBQSxDQUFBLEtBQUEsRUFBQTtJQUFLUyxTQUFTLEtBQUFDLE1BQUEsQ0FBS1Isb0JBQW9CLG1CQUFBUSxNQUFBLENBQWdCUixvQkFBb0Isb0JBQUFRLE1BQUEsQ0FBaUJKLElBQUksQ0FBRTtJQUFBSyxRQUFBLEVBQUEsQ0FDaEdiLElBQUEsQ0FBQSxNQUFBLEVBQUE7TUFBTVcsU0FBUyxLQUFBQyxNQUFBLENBQUtSLG9CQUFvQix3QkFBcUI7TUFBQVMsUUFBQSxFQUFHTixNQUFNLENBQUNPO0lBQUssQ0FBQSxDQUFRLEVBQ25GUCxNQUFNLENBQUNRLE1BQU0sR0FBR2YsSUFBQSxDQUFDRyxXQUFXLEVBQUE7TUFBQ2EsS0FBSyxFQUFFQyxNQUFNLENBQUNWLE1BQU0sQ0FBQ08sS0FBSyxDQUFDO01BQUVJLEtBQUssRUFBRVQsU0FBUztNQUFFRCxJQUFJLEVBQUVBLElBQUk7TUFBRVcsT0FBTyxFQUFFVDtJQUFXLENBQUEsQ0FBSSxHQUFHLElBQUk7RUFBQSxDQUFBLENBQ3BIO0FBQUEsQ0FDUCIsImZpbGUiOiJjb21wb25lbnRzL1RhYmxlL3JlbmRlcmVycy9IZWFkZXJDZWxsLmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsganN4IGFzIF9qc3gsIGpzeHMgYXMgX2pzeHMgfSBmcm9tIFwicmVhY3QvanN4LXJ1bnRpbWVcIjtcbmltcG9ydCB7IFNvcnRUcmlnZ2VyIH0gZnJvbSAnLi4vZmVhdHVyZXMvU29ydFRyaWdnZXInO1xuaW1wb3J0IHsgVEFCTEVfREVGQVVMVF9QUkVGSVggfSBmcm9tICcuLi9jb25zdGFudHMnO1xuZXhwb3J0IGNvbnN0IEhlYWRlckNlbGwgPSAoeyBjb2x1bW4sIHNpemUsIHNvcnRPcmRlciwgb25Tb3J0Q2xpY2ssIH0pID0+IChfanN4cyhcImRpdlwiLCB7IGNsYXNzTmFtZTogYCR7VEFCTEVfREVGQVVMVF9QUkVGSVh9LWhlYWRlci1jZWxsICR7VEFCTEVfREVGQVVMVF9QUkVGSVh9LWhlYWRlci1jZWxsLS0ke3NpemV9YCwgY2hpbGRyZW46IFtfanN4KFwic3BhblwiLCB7IGNsYXNzTmFtZTogYCR7VEFCTEVfREVGQVVMVF9QUkVGSVh9LWhlYWRlci1jZWxsX190aXRsZWAsIGNoaWxkcmVuOiBjb2x1bW4udGl0bGUgfSksIGNvbHVtbi5zb3J0ZXIgPyBfanN4KFNvcnRUcmlnZ2VyLCB7IGxhYmVsOiBTdHJpbmcoY29sdW1uLnRpdGxlKSwgb3JkZXI6IHNvcnRPcmRlciwgc2l6ZTogc2l6ZSwgb25DbGljazogb25Tb3J0Q2xpY2sgfSkgOiBudWxsXSB9KSk7IixudWxsXSwic291cmNlUm9vdCI6Ii4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3NyYyJ9
32
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImNvbXBvbmVudHMvVGFibGUvcmVuZGVyZXJzL0hlYWRlckNlbGwuanMiLCJjb21wb25lbnRzL1RhYmxlL3NyYy9jb21wb25lbnRzL1RhYmxlL3JlbmRlcmVycy9IZWFkZXJDZWxsLnRzeCJdLCJuYW1lcyI6WyJqc3giLCJfanN4IiwianN4cyIsIl9qc3hzIiwiU29ydFRyaWdnZXIiLCJGaWx0ZXJUcmlnZ2VyIiwiVEFCTEVfREVGQVVMVF9QUkVGSVgiLCJIZWFkZXJDZWxsIiwiX3JlZiIsImNvbHVtbiIsInNpemUiLCJzb3J0T3JkZXIiLCJvblNvcnRDbGljayIsImZpbHRlclNlbGVjdGVkIiwib25GaWx0ZXJDaGFuZ2UiLCJ0aXRsZVRleHQiLCJ0aXRsZSIsIlN0cmluZyIsImhhc0ZpbHRlciIsImZpbHRlcnMiLCJsZW5ndGgiLCJmaWx0ZXJEcm9wZG93biIsInVuZGVmaW5lZCIsImNsYXNzTmFtZSIsImNvbmNhdCIsImNoaWxkcmVuIiwic29ydGVyIiwibGFiZWwiLCJvcmRlciIsIm9uQ2xpY2siLCJzZWxlY3RlZEtleXMiLCJvbkNoYW5nZSJdLCJtYXBwaW5ncyI6IkFBQUEsU0FBU0EsR0FBRyxJQUFJQyxJQUFJLEVBQUVDLElBQUksSUFBSUMsS0FBSyxRQUFRLG1CQUFtQjtBQ0E5RCxTQUFTQyxXQUFXLFFBQVEseUJBQXlCO0FBQ3JELFNBQVNDLGFBQWEsUUFBUSwyQkFBMkI7QUFDekQsU0FBU0Msb0JBQW9CLFFBQVEsY0FBYztBQWtCbkQsT0FBTyxJQUFNQyxVQUFVLEdBQUcsU0FBYkEsVUFBVUEsQ0FBQUMsSUFBQSxFQU9FO0VBQUEsSUFOdkJDLE1BQU0sR0FBQUQsSUFBQSxDQUFOQyxNQUFNO0lBQ05DLElBQUksR0FBQUYsSUFBQSxDQUFKRSxJQUFJO0lBQ0pDLFNBQVMsR0FBQUgsSUFBQSxDQUFURyxTQUFTO0lBQ1RDLFdBQVcsR0FBQUosSUFBQSxDQUFYSSxXQUFXO0lBQ1hDLGNBQWMsR0FBQUwsSUFBQSxDQUFkSyxjQUFjO0lBQ2RDLGNBQWMsR0FBQU4sSUFBQSxDQUFkTSxjQUFjO0VBRWQsSUFBTUMsU0FBUyxHQUFHLE9BQU9OLE1BQU0sQ0FBQ08sS0FBSyxLQUFLLFFBQVEsSUFBSSxPQUFPUCxNQUFNLENBQUNPLEtBQUssS0FBSyxRQUFRLEdBQ2xGQyxNQUFNLENBQUNSLE1BQU0sQ0FBQ08sS0FBSyxDQUFDLEdBQ3BCLEVBQUU7RUFFTixJQUFNRSxTQUFTLEdBQ1pULE1BQU0sQ0FBQ1UsT0FBTyxJQUFJVixNQUFNLENBQUNVLE9BQU8sQ0FBQ0MsTUFBTSxHQUFHLENBQUMsSUFDNUNYLE1BQU0sQ0FBQ1ksY0FBYyxLQUFLQyxTQUFTO0VBRXJDLE9BQ0VuQixLQUFBLENBQUEsS0FBQSxFQUFBO0lBQUtvQixTQUFTLEtBQUFDLE1BQUEsQ0FBS2xCLG9CQUFvQixtQkFBQWtCLE1BQUEsQ0FBZ0JsQixvQkFBb0Isb0JBQUFrQixNQUFBLENBQWlCZCxJQUFJLENBQUU7SUFBQWUsUUFBQSxFQUFBLENBQ2hHeEIsSUFBQSxDQUFBLE1BQUEsRUFBQTtNQUFNc0IsU0FBUyxLQUFBQyxNQUFBLENBQUtsQixvQkFBb0Isd0JBQXFCO01BQUFtQixRQUFBLEVBQUdoQixNQUFNLENBQUNPO0lBQUssQ0FBQSxDQUFRLEVBQ25GUCxNQUFNLENBQUNpQixNQUFNLEdBQ1p6QixJQUFBLENBQUNHLFdBQVcsRUFBQTtNQUNWdUIsS0FBSyxFQUFFWixTQUFTO01BQ2hCYSxLQUFLLEVBQUVqQixTQUFTO01BQ2hCRCxJQUFJLEVBQUVBLElBQUk7TUFDVm1CLE9BQU8sRUFBRWpCO0lBQVcsQ0FBQSxDQUNwQixHQUNBLElBQUksRUFDUE0sU0FBUyxHQUNSakIsSUFBQSxDQUFDSSxhQUFhLEVBQUE7TUFDWkksTUFBTSxFQUFFQSxNQUFNO01BQ2RDLElBQUksRUFBRUEsSUFBSTtNQUNWb0IsWUFBWSxFQUFFakIsY0FBYztNQUM1QmtCLFFBQVEsRUFBRWpCO0lBQWMsQ0FBQSxDQUN4QixHQUNBLElBQUk7RUFBQSxDQUFBLENBQ0o7QUFFVixDQUFDIiwiZmlsZSI6ImNvbXBvbmVudHMvVGFibGUvcmVuZGVyZXJzL0hlYWRlckNlbGwuanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBqc3ggYXMgX2pzeCwganN4cyBhcyBfanN4cyB9IGZyb20gXCJyZWFjdC9qc3gtcnVudGltZVwiO1xuaW1wb3J0IHsgU29ydFRyaWdnZXIgfSBmcm9tICcuLi9mZWF0dXJlcy9Tb3J0VHJpZ2dlcic7XG5pbXBvcnQgeyBGaWx0ZXJUcmlnZ2VyIH0gZnJvbSAnLi4vZmVhdHVyZXMvRmlsdGVyVHJpZ2dlcic7XG5pbXBvcnQgeyBUQUJMRV9ERUZBVUxUX1BSRUZJWCB9IGZyb20gJy4uL2NvbnN0YW50cyc7XG5leHBvcnQgY29uc3QgSGVhZGVyQ2VsbCA9ICh7IGNvbHVtbiwgc2l6ZSwgc29ydE9yZGVyLCBvblNvcnRDbGljaywgZmlsdGVyU2VsZWN0ZWQsIG9uRmlsdGVyQ2hhbmdlLCB9KSA9PiB7XG4gICAgY29uc3QgdGl0bGVUZXh0ID0gdHlwZW9mIGNvbHVtbi50aXRsZSA9PT0gJ3N0cmluZycgfHwgdHlwZW9mIGNvbHVtbi50aXRsZSA9PT0gJ251bWJlcidcbiAgICAgICAgPyBTdHJpbmcoY29sdW1uLnRpdGxlKVxuICAgICAgICA6ICcnO1xuICAgIGNvbnN0IGhhc0ZpbHRlciA9IChjb2x1bW4uZmlsdGVycyAmJiBjb2x1bW4uZmlsdGVycy5sZW5ndGggPiAwKSB8fFxuICAgICAgICBjb2x1bW4uZmlsdGVyRHJvcGRvd24gIT09IHVuZGVmaW5lZDtcbiAgICByZXR1cm4gKF9qc3hzKFwiZGl2XCIsIHsgY2xhc3NOYW1lOiBgJHtUQUJMRV9ERUZBVUxUX1BSRUZJWH0taGVhZGVyLWNlbGwgJHtUQUJMRV9ERUZBVUxUX1BSRUZJWH0taGVhZGVyLWNlbGwtLSR7c2l6ZX1gLCBjaGlsZHJlbjogW19qc3goXCJzcGFuXCIsIHsgY2xhc3NOYW1lOiBgJHtUQUJMRV9ERUZBVUxUX1BSRUZJWH0taGVhZGVyLWNlbGxfX3RpdGxlYCwgY2hpbGRyZW46IGNvbHVtbi50aXRsZSB9KSwgY29sdW1uLnNvcnRlciA/IChfanN4KFNvcnRUcmlnZ2VyLCB7IGxhYmVsOiB0aXRsZVRleHQsIG9yZGVyOiBzb3J0T3JkZXIsIHNpemU6IHNpemUsIG9uQ2xpY2s6IG9uU29ydENsaWNrIH0pKSA6IG51bGwsIGhhc0ZpbHRlciA/IChfanN4KEZpbHRlclRyaWdnZXIsIHsgY29sdW1uOiBjb2x1bW4sIHNpemU6IHNpemUsIHNlbGVjdGVkS2V5czogZmlsdGVyU2VsZWN0ZWQsIG9uQ2hhbmdlOiBvbkZpbHRlckNoYW5nZSB9KSkgOiBudWxsXSB9KSk7XG59OyIsbnVsbF0sInNvdXJjZVJvb3QiOiIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9zcmMifQ==
@@ -1 +1 @@
1
- .om-component-ui-table{position:relative;box-sizing:border-box;width:100%;overflow:clip;font-variant:tabular-nums;background:var(--om-bg-default,#fff);border:1px solid var(--om-border-neutral,#e3e4e4);border-radius:var(--om-radius-300,12px)}.om-component-ui-table table{width:100%;table-layout:fixed;border-collapse:separate;border-spacing:0}.om-component-ui-table-thead>tr>td,.om-component-ui-table-thead>tr>th{text-align:start;background:var(--om-bg-default-secondary,#f8f8f8);font-size:var(--om-label-md-font-size);font-family:var(--om-label-md-font-family);line-height:var(--om-label-md-line-height);letter-spacing:var(--om-label-md-letter-spacing);font-weight:var(--om-label-md-font-weight)}.om-component-ui-table-tbody>tr>td,.om-component-ui-table-thead>tr>td,.om-component-ui-table-thead>tr>th{position:relative;padding:var(--om-spacing-300,12px) var(--om-spacing-400,16px);overflow-wrap:break-word;border-bottom:1px solid var(--om-border-neutral,#e3e4e4)}.om-component-ui-table-tbody>tr>td{color:var(--om-text-default,#131313);vertical-align:middle;font-size:var(--om-body-md-font-size);font-family:var(--om-body-md-font-family);line-height:var(--om-body-md-line-height);letter-spacing:var(--om-body-md-letter-spacing);font-weight:var(--om-body-md-font-weight)}.om-component-ui-table-tbody>tr:last-child>td{border-bottom:0}.om-component-ui-table-tbody>tr:has(+.om-component-ui-table-expanded-row:last-child)>td{border-bottom:0}.om-component-ui-table-tbody>tr:hover>td{background:var(--om-bg-default-secondary,#f8f8f8)}.om-component-ui-table-body,.om-component-ui-table-content{overflow:auto}.om-component-ui-table-header{overflow:hidden}.om-component-ui-table-sticky-holder{position:sticky;z-index:3;background:var(--om-bg-default,#fff)}.om-component-ui-table-fixed-header>.om-component-ui-table-header{overflow:hidden}.om-component-ui-table-fixed-header>.om-component-ui-table-body{overflow:auto scroll}.om-component-ui-table-cell-fix-end,.om-component-ui-table-cell-fix-start{position:sticky!important;z-index:calc(2 + var(--z-offset, 0));background:var(--om-bg-default,#fff)}.om-component-ui-table-tbody>tr:hover .om-component-ui-table-cell-fix-end,.om-component-ui-table-tbody>tr:hover .om-component-ui-table-cell-fix-start,.om-component-ui-table-thead .om-component-ui-table-cell-fix-end,.om-component-ui-table-thead .om-component-ui-table-cell-fix-start{background:var(--om-bg-default-secondary,#f8f8f8)}.om-component-ui-table-cell-fix-end-shadow:after,.om-component-ui-table-cell-fix-start-shadow:after{position:absolute;top:0;bottom:-1px;width:30px;transition:box-shadow .3s;content:"";pointer-events:none}.om-component-ui-table-cell-fix-start-shadow:after{right:0;transform:translateX(100%)}.om-component-ui-table-cell-fix-start-shadow-show:after{box-shadow:inset 10px 0 8px -8px rgba(0,0,0,.08)}.om-component-ui-table-cell-fix-end-shadow:after{left:0;transform:translateX(-100%)}.om-component-ui-table-cell-fix-end-shadow-show:after{box-shadow:inset -10px 0 8px -8px rgba(0,0,0,.08)}.om-component-ui-table-expanded-row .om-component-ui-table-cell{padding:var(--om-spacing-300,12px);background:var(--om-bg-default-secondary,#f8f8f8)}.om-component-ui-table-placeholder{text-align:center}.om-component-ui-table-tbody-virtual .om-component-ui-table-row{display:flex}.om-component-ui-table-tbody-virtual .om-component-ui-table-row:hover .om-component-ui-table-cell{background:var(--om-bg-default-secondary,#f8f8f8)}.om-component-ui-table-tbody-virtual .om-component-ui-table-cell{padding:var(--om-spacing-300,12px) var(--om-spacing-400,16px);color:var(--om-text-default,#131313);overflow-wrap:break-word;border-bottom:1px solid var(--om-border-neutral,#e3e4e4);font-size:var(--om-body-md-font-size);font-family:var(--om-body-md-font-family);line-height:var(--om-body-md-line-height);letter-spacing:var(--om-body-md-letter-spacing);font-weight:var(--om-body-md-font-weight)}.om-component-ui-table-body,.om-component-ui-table-container,.om-component-ui-table-content,.om-component-ui-table-header{background:inherit}.om-component-ui-table-pagination{display:flex;justify-content:flex-end;margin-top:var(--om-spacing-600,24px)}.om-component-ui-table-small{--table-row-height:56px;--table-header-height:40px}.om-component-ui-table-small .om-component-ui-table-tbody>tr>td,.om-component-ui-table-small .om-component-ui-table-thead>tr>td,.om-component-ui-table-small .om-component-ui-table-thead>tr>th{padding:var(--om-spacing-200,8px) var(--om-spacing-300,12px)}.om-component-ui-table-large{--table-row-height:66px;--table-header-height:48px}.om-component-ui-table-fill{border:0;border-radius:0}.om-component-ui-table-fill .om-component-ui-table-thead>tr>td,.om-component-ui-table-fill .om-component-ui-table-thead>tr>th{background:transparent}.om-component-ui-table-fill .om-component-ui-table-thead .om-component-ui-table-cell-fix-end,.om-component-ui-table-fill .om-component-ui-table-thead .om-component-ui-table-cell-fix-start{background:var(--om-bg-default,#fff)}.om-component-ui-table-stroke .om-component-ui-table-thead>tr>td,.om-component-ui-table-stroke .om-component-ui-table-thead>tr>th{border-bottom:none}.om-component-ui-table-stroke .om-component-ui-table-tbody>tr>td.om-component-ui-table-cell--spacer,.om-component-ui-table-stroke .om-component-ui-table-thead>tr>td.om-component-ui-table-cell--spacer,.om-component-ui-table-stroke .om-component-ui-table-thead>tr>th.om-component-ui-table-cell--spacer{padding:0;border-bottom:none}.om-component-ui-table .om-component-ui-table-header-cell{display:inline-flex;gap:4px;align-items:center}.om-component-ui-table .om-component-ui-table-header-cell__title{color:var(--om-text-default,#131313);white-space:nowrap}.om-component-ui-table .om-component-ui-table-header-cell--large .om-component-ui-table-header-cell__title{font-size:var(--om-title-lg-font-size);font-family:var(--om-title-lg-font-family);line-height:var(--om-title-lg-line-height);letter-spacing:var(--om-title-lg-letter-spacing);font-weight:var(--om-title-lg-font-weight)}.om-component-ui-table .om-component-ui-table-header-cell--small .om-component-ui-table-header-cell__title{font-size:var(--om-title-sm-font-size);font-family:var(--om-title-sm-font-family);line-height:var(--om-title-sm-line-height);letter-spacing:var(--om-title-sm-letter-spacing);font-weight:var(--om-title-sm-strong-font-weight)}.om-component-ui-table .om-component-ui-table-sort-trigger{display:inline-flex;align-items:center;justify-content:center;padding:0;color:var(--om-icon-default,#131313);line-height:0;background:transparent;border:0;cursor:pointer}.om-component-ui-table .om-component-ui-table-sort-trigger:focus-visible{outline:2px solid var(--om-border-default,#d1d2d2);outline-offset:2px}.om-component-ui-table .om-component-ui-table-sort-trigger--large{width:16px;height:16px}.om-component-ui-table .om-component-ui-table-sort-trigger--small{width:12px;height:12px}.om-component-ui-table .om-component-ui-table-expand-trigger{display:inline-flex;align-items:center;justify-content:center;width:var(--om-spacing-400,16px);height:var(--om-spacing-400,16px);padding:0;color:var(--om-icon-default,#131313);background:transparent;border:0;cursor:pointer;transition:color .2s ease}.om-component-ui-table .om-component-ui-table-expand-trigger:focus-visible{outline:2px solid var(--om-border-default,#d1d2d2);outline-offset:2px}.om-component-ui-table .om-component-ui-table-expand-trigger:hover{color:var(--om-icon-default-secondary,#404042)}.om-component-ui-table .om-component-ui-table-expand-trigger[aria-expanded=true]{color:var(--om-icon-default,#131313)}.om-component-ui-table .om-component-ui-table-expand-trigger[aria-expanded=true]:hover{color:var(--om-icon-default-secondary,#404042)}.om-component-ui-table .om-component-ui-table-expand-trigger__icon{transition:transform .2s ease}.om-component-ui-table .om-component-ui-table-cell-content{display:inline-flex;gap:8px;align-items:center}.om-component-ui-table .om-component-ui-table-cell-content__text{display:inline-flex;flex-direction:column;gap:0}.om-component-ui-table .om-component-ui-table-expanded-row{background:var(--om-bg-default,#fff)}.om-component-ui-table .om-component-ui-table-expanded-row__content{padding:var(--om-spacing-200,8px) 0}.om-component-ui-table-wrapper{position:relative}.om-component-ui-table-wrapper--loading>.om-component-ui-table{opacity:.6;-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:none}.om-component-ui-table-loading-overlay{position:absolute;inset:0;z-index:4;display:flex;align-items:center;justify-content:center}
1
+ .om-component-ui-table{position:relative;box-sizing:border-box;width:100%;overflow:clip;font-variant:tabular-nums;background:var(--om-bg-default,#fff);border:1px solid var(--om-border-neutral,#e3e4e4);border-radius:var(--om-radius-300,12px)}.om-component-ui-table table{width:100%;table-layout:fixed;border-collapse:separate;border-spacing:0}.om-component-ui-table-thead>tr>td,.om-component-ui-table-thead>tr>th{position:relative;padding:var(--om-spacing-300,12px) var(--om-spacing-400,16px);text-align:start;overflow-wrap:break-word;background:var(--om-bg-default-secondary,#f8f8f8);border-bottom:1px solid var(--om-border-neutral,#e3e4e4);font-size:var(--om-label-md-font-size);font-family:var(--om-label-md-font-family);line-height:var(--om-label-md-line-height);letter-spacing:var(--om-label-md-letter-spacing);font-weight:var(--om-label-md-font-weight)}.om-component-ui-table-tbody>tr>td{position:relative;padding:var(--om-spacing-300,12px) var(--om-spacing-400,16px);color:var(--om-text-default,#131313);vertical-align:middle;overflow-wrap:break-word;border-bottom:1px solid var(--om-bg-default-secondary,#f8f8f8);font-size:var(--om-body-md-font-size);font-family:var(--om-body-md-font-family);line-height:var(--om-body-md-line-height);letter-spacing:var(--om-body-md-letter-spacing);font-weight:var(--om-body-md-font-weight)}.om-component-ui-table-tbody>tr:last-child>td{border-bottom:0}.om-component-ui-table-tbody>tr:has(+.om-component-ui-table-expanded-row:last-child)>td{border-bottom:0}.om-component-ui-table-tbody>tr:hover>td{background:var(--om-bg-default-secondary,#f8f8f8);cursor:pointer}.om-component-ui-table-body,.om-component-ui-table-content{overflow:auto}.om-component-ui-table-header{overflow:hidden}.om-component-ui-table-sticky-holder{position:sticky;z-index:3;background:var(--om-bg-default,#fff)}.om-component-ui-table-fixed-header>.om-component-ui-table-header{overflow:hidden}.om-component-ui-table-fixed-header>.om-component-ui-table-body{overflow:auto scroll}.om-component-ui-table-cell-fix-end,.om-component-ui-table-cell-fix-start{position:sticky!important;z-index:calc(2 + var(--z-offset, 0));background:var(--om-bg-default,#fff)}.om-component-ui-table-tbody>tr:hover .om-component-ui-table-cell-fix-end,.om-component-ui-table-tbody>tr:hover .om-component-ui-table-cell-fix-start,.om-component-ui-table-thead .om-component-ui-table-cell-fix-end,.om-component-ui-table-thead .om-component-ui-table-cell-fix-start{background:var(--om-bg-default-secondary,#f8f8f8)}.om-component-ui-table-cell-fix-end-shadow:after,.om-component-ui-table-cell-fix-start-shadow:after{position:absolute;top:0;bottom:-1px;width:30px;transition:box-shadow .3s;content:"";pointer-events:none}.om-component-ui-table-cell-fix-start-shadow:after{right:0;transform:translateX(100%)}.om-component-ui-table-cell-fix-start-shadow-show:after{box-shadow:inset 10px 0 8px -8px rgba(0,0,0,.08)}.om-component-ui-table-cell-fix-end-shadow:after{left:0;transform:translateX(-100%)}.om-component-ui-table-cell-fix-end-shadow-show:after{box-shadow:inset -10px 0 8px -8px rgba(0,0,0,.08)}.om-component-ui-table-expanded-row .om-component-ui-table-cell{padding:var(--om-spacing-300,12px);background:var(--om-bg-default-secondary,#f8f8f8)}.om-component-ui-table-placeholder{text-align:center}.om-component-ui-table-tbody-virtual .om-component-ui-table-row{display:flex}.om-component-ui-table-tbody-virtual .om-component-ui-table-row:hover .om-component-ui-table-cell{background:var(--om-bg-default-secondary,#f8f8f8);cursor:pointer}.om-component-ui-table-tbody-virtual .om-component-ui-table-cell{padding:var(--om-spacing-300,12px) var(--om-spacing-400,16px);color:var(--om-text-default,#131313);overflow-wrap:break-word;border-bottom:1px solid var(--om-bg-default-secondary,#f8f8f8);font-size:var(--om-body-md-font-size);font-family:var(--om-body-md-font-family);line-height:var(--om-body-md-line-height);letter-spacing:var(--om-body-md-letter-spacing);font-weight:var(--om-body-md-font-weight)}.om-component-ui-table-body,.om-component-ui-table-container,.om-component-ui-table-content,.om-component-ui-table-header{background:inherit}.om-component-ui-table-pagination{display:flex;justify-content:flex-end;margin-top:var(--om-spacing-600,24px)}.om-component-ui-table-small{--table-row-height:56px;--table-header-height:40px}.om-component-ui-table-small .om-component-ui-table-tbody>tr>td,.om-component-ui-table-small .om-component-ui-table-thead>tr>td,.om-component-ui-table-small .om-component-ui-table-thead>tr>th{padding:var(--om-spacing-200,8px) var(--om-spacing-300,12px)}.om-component-ui-table-large{--table-row-height:66px;--table-header-height:48px}.om-component-ui-table-fill{border:0;border-radius:0}.om-component-ui-table-fill .om-component-ui-table-thead>tr>td,.om-component-ui-table-fill .om-component-ui-table-thead>tr>th{background:transparent}.om-component-ui-table-fill .om-component-ui-table-thead .om-component-ui-table-cell-fix-end,.om-component-ui-table-fill .om-component-ui-table-thead .om-component-ui-table-cell-fix-start{background:var(--om-bg-default,#fff)}.om-component-ui-table-stroke .om-component-ui-table-thead>tr>td,.om-component-ui-table-stroke .om-component-ui-table-thead>tr>th{border-bottom:none}.om-component-ui-table-stroke .om-component-ui-table-tbody>tr>td.om-component-ui-table-cell--spacer,.om-component-ui-table-stroke .om-component-ui-table-thead>tr>td.om-component-ui-table-cell--spacer,.om-component-ui-table-stroke .om-component-ui-table-thead>tr>th.om-component-ui-table-cell--spacer{padding:0;border-bottom:none}.om-component-ui-table .om-component-ui-table-header-cell{display:inline-flex;gap:4px;align-items:center}.om-component-ui-table .om-component-ui-table-header-cell__title{color:var(--om-text-default,#131313);white-space:nowrap}.om-component-ui-table .om-component-ui-table-header-cell--large .om-component-ui-table-header-cell__title{font-size:var(--om-title-lg-font-size);font-family:var(--om-title-lg-font-family);line-height:var(--om-title-lg-line-height);letter-spacing:var(--om-title-lg-letter-spacing);font-weight:var(--om-title-lg-font-weight)}.om-component-ui-table .om-component-ui-table-header-cell--small .om-component-ui-table-header-cell__title{font-size:var(--om-title-sm-font-size);font-family:var(--om-title-sm-font-family);line-height:var(--om-title-sm-line-height);letter-spacing:var(--om-title-sm-letter-spacing);font-weight:var(--om-title-sm-strong-font-weight)}.om-component-ui-table .om-component-ui-table-sort-trigger{display:inline-flex;align-items:center;justify-content:center;padding:0;color:var(--om-icon-default,#131313);line-height:0;background:transparent;border:0;cursor:pointer}.om-component-ui-table .om-component-ui-table-sort-trigger:focus-visible{outline:2px solid var(--om-border-default,#d1d2d2);outline-offset:2px}.om-component-ui-table .om-component-ui-table-sort-trigger--large{width:16px;height:16px}.om-component-ui-table .om-component-ui-table-sort-trigger--small{width:12px;height:12px}.om-component-ui-table .om-component-ui-table-filter-trigger{display:inline-flex;align-items:center;justify-content:center;margin-left:var(--om-spacing-100,4px);padding:0;color:var(--om-icon-default,#131313);line-height:0;background:transparent;border:0;border-radius:var(--om-radius-100,4px);cursor:pointer}.om-component-ui-table .om-component-ui-table-filter-trigger:hover{background:var(--om-bg-default-secondary,#f8f8f8)}.om-component-ui-table .om-component-ui-table-filter-trigger:focus-visible{outline:2px solid var(--om-border-default,#d1d2d2);outline-offset:2px}.om-component-ui-table .om-component-ui-table-filter-trigger--active{color:var(--om-icon-brand,#073387)}.om-component-ui-table .om-component-ui-table-filter-trigger--large{width:20px;height:20px}.om-component-ui-table .om-component-ui-table-filter-trigger--small{width:16px;height:16px}.om-component-ui-table-filter-dropdown{display:flex;flex-direction:column;gap:var(--om-spacing-200,8px);min-width:200px;padding:var(--om-spacing-200,8px);background:var(--om-bg-default,#fff);border-radius:var(--om-radius-200,8px);box-shadow:0 8px 24px hsla(0,0%,7%,.12)}.om-component-ui-table-filter-dropdown__item{display:flex;gap:var(--om-spacing-200,8px);align-items:center;padding:var(--om-spacing-100,4px) var(--om-spacing-200,8px);cursor:pointer}.om-component-ui-table-filter-dropdown__item:hover{background:var(--om-bg-default-secondary,#f8f8f8)}.om-component-ui-table-filter-dropdown__footer{display:flex;gap:var(--om-spacing-200,8px);justify-content:flex-end;padding-top:var(--om-spacing-100,4px);border-top:1px solid var(--om-border-neutral,#e3e4e4)}.om-component-ui-table .om-component-ui-table-expand-trigger{display:inline-flex;align-items:center;justify-content:center;width:var(--om-spacing-400,16px);height:var(--om-spacing-400,16px);padding:0;color:var(--om-icon-default,#131313);background:transparent;border:0;cursor:pointer;transition:color .2s ease}.om-component-ui-table .om-component-ui-table-expand-trigger:focus-visible{outline:2px solid var(--om-border-default,#d1d2d2);outline-offset:2px}.om-component-ui-table .om-component-ui-table-expand-trigger:hover{color:var(--om-icon-default-secondary,#404042)}.om-component-ui-table .om-component-ui-table-expand-trigger[aria-expanded=true]{color:var(--om-icon-default,#131313)}.om-component-ui-table .om-component-ui-table-expand-trigger[aria-expanded=true]:hover{color:var(--om-icon-default-secondary,#404042)}.om-component-ui-table .om-component-ui-table-expand-trigger__icon{transition:transform .2s ease}.om-component-ui-table .om-component-ui-table-cell-content{display:inline-flex;gap:8px;align-items:center}.om-component-ui-table .om-component-ui-table-cell-content__text{display:inline-flex;flex-direction:column;gap:0}.om-component-ui-table .om-component-ui-table-expanded-row{background:var(--om-bg-default,#fff)}.om-component-ui-table .om-component-ui-table-expanded-row__content{padding:var(--om-spacing-200,8px) 0}.om-component-ui-table-wrapper{position:relative}.om-component-ui-table-wrapper--loading>.om-component-ui-table{opacity:.6;-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:none}.om-component-ui-table-loading-overlay{position:absolute;inset:0;z-index:4;display:flex;align-items:center;justify-content:center}