@economic/taco 2.0.0-alpha.173 → 2.0.0-alpha.6

Sign up to get free protection for your applications and to get access to all the features.
Files changed (164) hide show
  1. package/dist/components/Provider/Localization.d.ts +114 -1
  2. package/dist/components/Table2/Table2.d.ts +130 -0
  3. package/dist/components/Table2/components/BatchActionsMenu.d.ts +10 -0
  4. package/dist/components/Table2/components/ColumnSettingsButton.d.ts +6 -0
  5. package/dist/components/Table2/components/EditModeButton.d.ts +8 -0
  6. package/dist/components/Table2/components/RowDensityButton.d.ts +7 -0
  7. package/dist/components/Table2/components/Search.d.ts +3 -0
  8. package/dist/components/Table2/components/ShortcutsGuideButton.d.ts +7 -0
  9. package/dist/components/Table2/components/column/Base.d.ts +14 -0
  10. package/dist/components/Table2/components/column/Cell.d.ts +15 -0
  11. package/dist/components/Table2/components/column/Footer.d.ts +9 -0
  12. package/dist/components/Table2/components/column/Header.d.ts +11 -0
  13. package/dist/components/Table2/components/column/Indicator.d.ts +17 -0
  14. package/dist/components/Table2/components/column/ValidationError.d.ts +5 -0
  15. package/dist/components/Table2/components/column/utils.d.ts +3 -0
  16. package/dist/components/Table2/components/filters/FiltersButton.d.ts +7 -0
  17. package/dist/components/Table2/components/filters/components/Column.d.ts +11 -0
  18. package/dist/components/Table2/components/filters/components/ColumnFilter.d.ts +10 -0
  19. package/dist/components/Table2/components/filters/components/Comparator.d.ts +11 -0
  20. package/dist/components/Table2/components/filters/components/EmptyFilter.d.ts +13 -0
  21. package/dist/components/Table2/components/filters/components/InferredControl.d.ts +10 -0
  22. package/dist/components/Table2/components/row/Context.d.ts +24 -0
  23. package/dist/components/Table2/components/row/ExpandedRow.d.ts +6 -0
  24. package/dist/components/Table2/components/row/Row.d.ts +2 -0
  25. package/dist/components/Table2/hooks/listeners/useActiveCellStateListener.d.ts +3 -0
  26. package/dist/components/Table2/hooks/listeners/useActiveRowStateListener.d.ts +3 -0
  27. package/dist/components/Table2/hooks/listeners/useColumnOffsetStateListener.d.ts +3 -0
  28. package/dist/components/Table2/hooks/listeners/useFilterStateListener.d.ts +3 -0
  29. package/dist/components/Table2/hooks/listeners/useRowSelectionListener.d.ts +3 -0
  30. package/dist/components/Table2/hooks/listeners/useSettingsStateListener.d.ts +3 -0
  31. package/dist/components/Table2/hooks/useActiveCell.d.ts +26 -0
  32. package/dist/components/Table2/hooks/useActiveRow.d.ts +10 -0
  33. package/dist/components/Table2/hooks/useColumnDefinitions.d.ts +37 -0
  34. package/dist/components/Table2/hooks/useEditMode.d.ts +28 -0
  35. package/dist/components/Table2/hooks/useGridTemplate.d.ts +2 -0
  36. package/dist/components/Table2/hooks/useTable.d.ts +46 -0
  37. package/dist/components/Table2/hooks/useTableShortcuts.d.ts +2 -0
  38. package/dist/components/Table2/hooks/useVirtualiser.d.ts +23 -0
  39. package/dist/components/Table2/types.d.ts +148 -0
  40. package/dist/components/Table2/utilities/cell.d.ts +14 -0
  41. package/dist/components/Table2/utilities/columns.d.ts +16 -0
  42. package/dist/components/Table2/utilities/filterFn.d.ts +3 -0
  43. package/dist/components/Table3/Table3.d.ts +3 -2
  44. package/dist/components/Table3/components/columns/cell/DisplayCell.d.ts +2 -2
  45. package/dist/components/Table3/components/columns/footer/Footer.d.ts +2 -2
  46. package/dist/components/Table3/components/columns/header/Header.d.ts +3 -3
  47. package/dist/components/Table3/components/columns/header/SortIndicator.d.ts +3 -3
  48. package/dist/components/Table3/components/columns/styles.d.ts +2 -2
  49. package/dist/components/Table3/hooks/useTable.d.ts +3 -3
  50. package/dist/components/Table3/hooks/useTableDataLoader.d.ts +23 -0
  51. package/dist/components/Table3/types.d.ts +18 -19
  52. package/dist/esm/packages/taco/src/components/Provider/Localization.js +110 -0
  53. package/dist/esm/packages/taco/src/components/Provider/Localization.js.map +1 -1
  54. package/dist/esm/packages/taco/src/components/Table2/Table2.js +422 -0
  55. package/dist/esm/packages/taco/src/components/Table2/Table2.js.map +1 -0
  56. package/dist/esm/packages/taco/src/components/Table2/components/BatchActionsMenu.js +83 -0
  57. package/dist/esm/packages/taco/src/components/Table2/components/BatchActionsMenu.js.map +1 -0
  58. package/dist/esm/packages/taco/src/components/Table2/components/ColumnSettingsButton.js +116 -0
  59. package/dist/esm/packages/taco/src/components/Table2/components/ColumnSettingsButton.js.map +1 -0
  60. package/dist/esm/packages/taco/src/components/Table2/components/EditModeButton.js +81 -0
  61. package/dist/esm/packages/taco/src/components/Table2/components/EditModeButton.js.map +1 -0
  62. package/dist/esm/packages/taco/src/components/Table2/components/RowDensityButton.js +47 -0
  63. package/dist/esm/packages/taco/src/components/Table2/components/RowDensityButton.js.map +1 -0
  64. package/dist/esm/packages/taco/src/components/Table2/components/Search.js +62 -0
  65. package/dist/esm/packages/taco/src/components/Table2/components/Search.js.map +1 -0
  66. package/dist/esm/packages/taco/src/components/Table2/components/column/Base.js +32 -0
  67. package/dist/esm/packages/taco/src/components/Table2/components/column/Base.js.map +1 -0
  68. package/dist/esm/packages/taco/src/components/Table2/components/column/Cell.js +600 -0
  69. package/dist/esm/packages/taco/src/components/Table2/components/column/Cell.js.map +1 -0
  70. package/dist/esm/packages/taco/src/components/Table2/components/column/Footer.js +32 -0
  71. package/dist/esm/packages/taco/src/components/Table2/components/column/Footer.js.map +1 -0
  72. package/dist/esm/packages/taco/src/components/Table2/components/column/Header.js +243 -0
  73. package/dist/esm/packages/taco/src/components/Table2/components/column/Header.js.map +1 -0
  74. package/dist/esm/packages/taco/src/components/Table2/components/column/Indicator.js +73 -0
  75. package/dist/esm/packages/taco/src/components/Table2/components/column/Indicator.js.map +1 -0
  76. package/dist/esm/packages/taco/src/components/Table2/components/column/ValidationError.js +30 -0
  77. package/dist/esm/packages/taco/src/components/Table2/components/column/ValidationError.js.map +1 -0
  78. package/dist/esm/packages/taco/src/components/Table2/components/column/utils.js +39 -0
  79. package/dist/esm/packages/taco/src/components/Table2/components/column/utils.js.map +1 -0
  80. package/dist/esm/packages/taco/src/components/Table2/components/filters/FiltersButton.js +155 -0
  81. package/dist/esm/packages/taco/src/components/Table2/components/filters/FiltersButton.js.map +1 -0
  82. package/dist/esm/packages/taco/src/components/Table2/components/filters/components/Column.js +31 -0
  83. package/dist/esm/packages/taco/src/components/Table2/components/filters/components/Column.js.map +1 -0
  84. package/dist/esm/packages/taco/src/components/Table2/components/filters/components/ColumnFilter.js +129 -0
  85. package/dist/esm/packages/taco/src/components/Table2/components/filters/components/ColumnFilter.js.map +1 -0
  86. package/dist/esm/packages/taco/src/components/Table2/components/filters/components/Comparator.js +68 -0
  87. package/dist/esm/packages/taco/src/components/Table2/components/filters/components/Comparator.js.map +1 -0
  88. package/dist/esm/packages/taco/src/components/Table2/components/filters/components/EmptyFilter.js +63 -0
  89. package/dist/esm/packages/taco/src/components/Table2/components/filters/components/EmptyFilter.js.map +1 -0
  90. package/dist/esm/packages/taco/src/components/Table2/components/filters/components/InferredControl.js +99 -0
  91. package/dist/esm/packages/taco/src/components/Table2/components/filters/components/InferredControl.js.map +1 -0
  92. package/dist/esm/packages/taco/src/components/Table2/components/row/Context.js +58 -0
  93. package/dist/esm/packages/taco/src/components/Table2/components/row/Context.js.map +1 -0
  94. package/dist/esm/packages/taco/src/components/Table2/components/row/ExpandedRow.js +36 -0
  95. package/dist/esm/packages/taco/src/components/Table2/components/row/ExpandedRow.js.map +1 -0
  96. package/dist/esm/packages/taco/src/components/Table2/components/row/Row.js +43 -0
  97. package/dist/esm/packages/taco/src/components/Table2/components/row/Row.js.map +1 -0
  98. package/dist/esm/packages/taco/src/components/Table2/hooks/listeners/useActiveRowStateListener.js +19 -0
  99. package/dist/esm/packages/taco/src/components/Table2/hooks/listeners/useActiveRowStateListener.js.map +1 -0
  100. package/dist/esm/packages/taco/src/components/Table2/hooks/listeners/useColumnOffsetStateListener.js +28 -0
  101. package/dist/esm/packages/taco/src/components/Table2/hooks/listeners/useColumnOffsetStateListener.js.map +1 -0
  102. package/dist/esm/packages/taco/src/components/Table2/hooks/listeners/useFilterStateListener.js +12 -0
  103. package/dist/esm/packages/taco/src/components/Table2/hooks/listeners/useFilterStateListener.js.map +1 -0
  104. package/dist/esm/packages/taco/src/components/Table2/hooks/listeners/useRowSelectionListener.js +18 -0
  105. package/dist/esm/packages/taco/src/components/Table2/hooks/listeners/useRowSelectionListener.js.map +1 -0
  106. package/dist/esm/packages/taco/src/components/Table2/hooks/listeners/useSettingsStateListener.js +25 -0
  107. package/dist/esm/packages/taco/src/components/Table2/hooks/listeners/useSettingsStateListener.js.map +1 -0
  108. package/dist/esm/packages/taco/src/components/Table2/hooks/useActiveRow.js +33 -0
  109. package/dist/esm/packages/taco/src/components/Table2/hooks/useActiveRow.js.map +1 -0
  110. package/dist/esm/packages/taco/src/components/Table2/hooks/useColumnDefinitions.js +122 -0
  111. package/dist/esm/packages/taco/src/components/Table2/hooks/useColumnDefinitions.js.map +1 -0
  112. package/dist/esm/packages/taco/src/components/Table2/hooks/useEditMode.js +112 -0
  113. package/dist/esm/packages/taco/src/components/Table2/hooks/useEditMode.js.map +1 -0
  114. package/dist/esm/packages/taco/src/components/Table2/hooks/useGridTemplate.js +34 -0
  115. package/dist/esm/packages/taco/src/components/Table2/hooks/useGridTemplate.js.map +1 -0
  116. package/dist/esm/packages/taco/src/components/Table2/hooks/useTable.js +222 -0
  117. package/dist/esm/packages/taco/src/components/Table2/hooks/useTable.js.map +1 -0
  118. package/dist/esm/packages/taco/src/components/Table2/hooks/useTableShortcuts.js +46 -0
  119. package/dist/esm/packages/taco/src/components/Table2/hooks/useTableShortcuts.js.map +1 -0
  120. package/dist/esm/packages/taco/src/components/Table2/hooks/useVirtualiser.js +48 -0
  121. package/dist/esm/packages/taco/src/components/Table2/hooks/useVirtualiser.js.map +1 -0
  122. package/dist/esm/packages/taco/src/components/Table2/types.js +18 -0
  123. package/dist/esm/packages/taco/src/components/Table2/types.js.map +1 -0
  124. package/dist/esm/packages/taco/src/components/Table2/utilities/cell.js +41 -0
  125. package/dist/esm/packages/taco/src/components/Table2/utilities/cell.js.map +1 -0
  126. package/dist/esm/packages/taco/src/components/Table2/utilities/columns.js +387 -0
  127. package/dist/esm/packages/taco/src/components/Table2/utilities/columns.js.map +1 -0
  128. package/dist/esm/packages/taco/src/components/Table2/utilities/filterFn.js +100 -0
  129. package/dist/esm/packages/taco/src/components/Table2/utilities/filterFn.js.map +1 -0
  130. package/dist/esm/packages/taco/src/components/Table3/Table3.js +1 -1
  131. package/dist/esm/packages/taco/src/components/Table3/Table3.js.map +1 -1
  132. package/dist/esm/packages/taco/src/components/Table3/components/columns/cell/DisplayCell.js +4 -1
  133. package/dist/esm/packages/taco/src/components/Table3/components/columns/cell/DisplayCell.js.map +1 -1
  134. package/dist/esm/packages/taco/src/components/Table3/components/columns/cell/EditingCell.js +4 -1
  135. package/dist/esm/packages/taco/src/components/Table3/components/columns/cell/EditingCell.js.map +1 -1
  136. package/dist/esm/packages/taco/src/components/Table3/components/columns/footer/Footer.js.map +1 -1
  137. package/dist/esm/packages/taco/src/components/Table3/components/columns/header/Header.js.map +1 -1
  138. package/dist/esm/packages/taco/src/components/Table3/components/columns/header/SortIndicator.js.map +1 -1
  139. package/dist/esm/packages/taco/src/components/Table3/components/columns/styles.js.map +1 -1
  140. package/dist/esm/packages/taco/src/components/Table3/components/toolbar/ColumnSettings.js +2 -2
  141. package/dist/esm/packages/taco/src/components/Table3/components/toolbar/PrintButton/PrintIFrame.js +4 -3
  142. package/dist/esm/packages/taco/src/components/Table3/components/toolbar/PrintButton/PrintIFrame.js.map +1 -1
  143. package/dist/esm/packages/taco/src/components/Table3/hooks/useConvertChildrenToColumns.js.map +1 -1
  144. package/dist/esm/packages/taco/src/components/Table3/hooks/useTable.js.map +1 -1
  145. package/dist/esm/packages/taco/src/components/Table3/hooks/{useTableData.js → useTableDataLoader.js} +3 -3
  146. package/dist/esm/packages/taco/src/components/Table3/hooks/useTableDataLoader.js.map +1 -0
  147. package/dist/esm/packages/taco/src/components/Table3/types.js.map +1 -1
  148. package/dist/esm/packages/taco/src/components/Truncate/Truncate.js +32 -0
  149. package/dist/esm/packages/taco/src/components/Truncate/Truncate.js.map +1 -0
  150. package/dist/esm/packages/taco/src/index.js +3 -2
  151. package/dist/esm/packages/taco/src/index.js.map +1 -1
  152. package/dist/esm/packages/taco/src/utils/dom.js +2 -1
  153. package/dist/esm/packages/taco/src/utils/dom.js.map +1 -1
  154. package/dist/esm/packages/taco/src/utils/hooks/useTruncated.js +20 -0
  155. package/dist/esm/packages/taco/src/utils/hooks/useTruncated.js.map +1 -0
  156. package/dist/index.d.ts +1 -0
  157. package/dist/taco.cjs.development.js +4023 -362
  158. package/dist/taco.cjs.development.js.map +1 -1
  159. package/dist/taco.cjs.production.min.js +1 -1
  160. package/dist/taco.cjs.production.min.js.map +1 -1
  161. package/package.json +2 -3
  162. package/types.json +2220 -377
  163. package/dist/components/Table3/hooks/useTableData.d.ts +0 -23
  164. package/dist/esm/packages/taco/src/components/Table3/hooks/useTableData.js.map +0 -1
@@ -0,0 +1,46 @@
1
+ import React from 'react';
2
+ import { OnChangeFn, RowData } from '@tanstack/react-table';
3
+ import { RowClickHandler, RowDensity, Table2Children, Table2Props } from '../types';
4
+ import { ColumnOffsetState } from '../types';
5
+ import { ActiveRowHandler, ActiveRowMoveHandler } from './useActiveRow';
6
+ import { useEditMode } from './useEditMode';
7
+ declare module '@tanstack/table-core' {
8
+ interface TableMeta<TData extends RowData> {
9
+ activeRowIndex: number;
10
+ setActiveRowIndex: ActiveRowHandler;
11
+ moveToPreviousRow: ActiveRowMoveHandler<TData>;
12
+ moveToNextRow: ActiveRowMoveHandler<TData>;
13
+ columnOffsets: ColumnOffsetState;
14
+ enableRowDensity: boolean;
15
+ rowDensity: RowDensity;
16
+ setRowDensity: OnChangeFn<RowDensity>;
17
+ enableRowDragging: boolean;
18
+ dragging: Record<string, boolean>;
19
+ setDragging: OnChangeFn<Record<string, boolean>>;
20
+ enableColumnFreezing: boolean;
21
+ enableColumnReordering: boolean;
22
+ enableColumnHiding: boolean;
23
+ shouldPauseSortingAndFiltering: boolean;
24
+ setShouldPauseSortingAndFiltering: OnChangeFn<boolean>;
25
+ shouldPauseHoverState: boolean;
26
+ setShouldPauseHoverState: OnChangeFn<boolean>;
27
+ frozenColumnsCount: number;
28
+ setFrozenColumnsCount: OnChangeFn<number>;
29
+ onRowClick?: RowClickHandler<TData>;
30
+ editMode: useEditMode;
31
+ dataColumnStartOffset: number;
32
+ dataColumnEndOffset: number;
33
+ shouldDisableTableActions: boolean;
34
+ setShouldDisableTableActions: OnChangeFn<boolean>;
35
+ focussableColumnIndexes: number[];
36
+ addFocussableColumnIndex: (index: number) => void;
37
+ resetFocussableColumnIndexes: () => void;
38
+ tableRef: React.RefObject<HTMLDivElement>;
39
+ lastSortedOrFilteredRows: React.MutableRefObject<Array<any>>;
40
+ }
41
+ }
42
+ export declare function useTable<TType = any>(children: Table2Children, props: Table2Props<TType>, ref: React.RefObject<HTMLDivElement>): {
43
+ rows: any;
44
+ table: import("@tanstack/react-table").Table<any>;
45
+ footers: Record<string, import("../types").Table2ColumnFooterRenderer>;
46
+ };
@@ -0,0 +1,2 @@
1
+ import { Table2Shortcuts } from '../types';
2
+ export declare function useTableShortcuts<TType = any>(shortcuts: Table2Shortcuts<TType> | undefined, activeRow: TType): void;
@@ -0,0 +1,23 @@
1
+ import React from 'react';
2
+ import { OnChangeFn } from '@tanstack/react-table';
3
+ import { VirtualItem } from 'react-virtual';
4
+ declare type ExpandedRowSizeState = Record<string, number>;
5
+ declare type useVirtualiser = {
6
+ virtualiser: {
7
+ virtualItems: VirtualItem[];
8
+ totalSize: number;
9
+ scrollToOffset: (index: number, options?: any) => void;
10
+ scrollToIndex: (index: number, options?: any) => void;
11
+ measure: () => void;
12
+ };
13
+ virtualiserOffsets: {
14
+ top: number;
15
+ bottom: number;
16
+ };
17
+ setExpandedRowSizes: OnChangeFn<ExpandedRowSizeState>;
18
+ };
19
+ export declare const useVirtualiser: ({ rows, table }: {
20
+ rows: any;
21
+ table: any;
22
+ }, tableRef: React.RefObject<HTMLElement>) => useVirtualiser;
23
+ export {};
@@ -0,0 +1,148 @@
1
+ import React from 'react';
2
+ import { BuiltInSortingFn, ColumnFiltersState, ColumnOrderState, ColumnSizingState, OnChangeFn, Row, SortingState, VisibilityState } from '@tanstack/react-table';
3
+ import { DialogProps } from '../Dialog/Dialog';
4
+ import { IconName } from '../Icon/Icon';
5
+ import { MenuProps } from '../Menu/Menu';
6
+ export declare enum Table2FilterComparator {
7
+ Contains = 0,
8
+ DoesNotContain = 1,
9
+ IsEqualTo = 2,
10
+ IsNotEqualTo = 3,
11
+ IsGreaterThan = 4,
12
+ IsLessThan = 5,
13
+ IsBetween = 6,
14
+ IsOneOf = 7,
15
+ IsNoneOf = 8,
16
+ IsAllOf = 9,
17
+ IsEmpty = 10,
18
+ IsNotEmpty = 11
19
+ }
20
+ export declare type Table2Filter<TType = any> = {
21
+ comparator?: Table2FilterComparator;
22
+ value: TType | TType[];
23
+ };
24
+ export declare type ColumnOffsetState = Record<string, number | undefined>;
25
+ export declare type RowDensity = 'compact' | 'normal' | 'comfortable' | 'spacious';
26
+ export declare type CellAlignment = 'left' | 'center' | 'right';
27
+ export declare type SortDirection = 'asc' | 'desc';
28
+ export declare type ColumnDataType = 'auto' | 'alphanumeric' | 'alphanumericCaseSensitive' | 'datetime' | 'boolean';
29
+ export declare type Table2ColumnHeaderRenderer<TType = any> = (value: any, row: TType) => JSX.Element | string | null;
30
+ export declare type Table2ColumnHeaderMenu = (props: Partial<MenuProps>) => JSX.Element;
31
+ export declare type Table2ColumnFooterRenderer = (values: any[]) => JSX.Element | string | null;
32
+ export declare type Table2ColumnControlProps = {
33
+ className?: string;
34
+ disabled?: boolean;
35
+ invalid?: boolean;
36
+ onBlur: (newValue?: any) => Promise<void>;
37
+ onFocus: React.FocusEventHandler;
38
+ readOnly?: boolean;
39
+ ref: React.RefObject<HTMLElement>;
40
+ setValue: (value: any) => void;
41
+ value: any;
42
+ 'data-inline-editing-component'?: 'true';
43
+ };
44
+ export declare type Table2ColumnControlRenderer<TType = any> = ((props: Table2ColumnControlProps, row?: TType) => JSX.Element) | 'datepicker' | 'input' | 'switch';
45
+ export declare type SortFn<TType = unknown> = ((rowA: TType, rowB: TType, columnId: string) => -1 | 0 | 1) | BuiltInSortingFn | 'auto';
46
+ export declare type Table2ColumnProps<TType = any> = {
47
+ accessor: string;
48
+ align?: CellAlignment;
49
+ className?: string | ((row: Row<TType>) => string);
50
+ control?: Table2ColumnControlRenderer<TType>;
51
+ dataType?: ColumnDataType;
52
+ defaultActiveColumnIndex?: number;
53
+ defaultActiveRowIndex?: number;
54
+ defaultHidden?: boolean;
55
+ disableFiltering?: boolean;
56
+ disableHiding?: boolean;
57
+ disableReordering?: boolean;
58
+ disableResizing?: boolean;
59
+ disableSorting?: boolean;
60
+ defaultWidth?: number | 'grow';
61
+ header: string;
62
+ headerClassName?: string;
63
+ footer?: Table2ColumnFooterRenderer;
64
+ renderer?: Table2ColumnHeaderRenderer<TType>;
65
+ menu?: Table2ColumnHeaderMenu;
66
+ minWidth?: number;
67
+ sort?: SortDirection;
68
+ sortFn?: SortFn<TType>;
69
+ tooltip?: string;
70
+ };
71
+ export declare type Table2ActionProps<TType> = {
72
+ dialog?: (rows: TType[], resetSelectedRows: () => void) => (props: Partial<DialogProps>) => JSX.Element;
73
+ disabled?: boolean | ((rows: TType[]) => boolean);
74
+ icon: IconName | ((rows: TType[]) => IconName);
75
+ onClick?: (rows: TType[], resetSelectedRows: () => void) => void;
76
+ text: string | ((rows: TType[]) => string);
77
+ visible?: boolean | ((rows: TType[]) => boolean);
78
+ };
79
+ export declare type Table2RowActionRenderer<TType = unknown> = (row: TType) => JSX.Element | null;
80
+ export declare type Table2Settings = {
81
+ columnFilters?: ColumnFiltersState;
82
+ columnOrder?: ColumnOrderState;
83
+ columnSizing?: ColumnSizingState;
84
+ columnVisibility?: VisibilityState;
85
+ frozenColumnCount?: number;
86
+ globalFilter?: string;
87
+ rowDensity?: RowDensity;
88
+ sorting?: SortingState;
89
+ };
90
+ export declare type RowClickHandler<TType = any> = (row: TType) => void;
91
+ export declare type RowDragHandler<TType = any> = (rows: TType[], showPlaceholder: (string: any) => void, setDataTransfer: (data: string) => void) => void;
92
+ export declare type RowDropHandler<TType = any> = (event: React.DragEvent, row: TType) => void;
93
+ export declare type RowSelectionHandler<TType = any> = (rows: TType[], allSelected: boolean) => void;
94
+ export declare type RowExpansionRenderer<TType = any> = (row: TType) => (() => JSX.Element) | null;
95
+ export declare type SortHandler = OnChangeFn<SortingState>;
96
+ export declare type SettingsHandler = OnChangeFn<Table2Settings>;
97
+ export declare type SaveHandlerErrorResponse = Record<string, string | undefined | null> | null;
98
+ export declare type SaveHandler<TType = any> = (row: TType, accessor: string) => Promise<SaveHandlerErrorResponse | void>;
99
+ export declare type DataColumnIndexes = {
100
+ dataColumnStartOffset: number;
101
+ dataColumnEndOffset: number;
102
+ };
103
+ export declare type Table2Children<TType = any> = (React.ReactElement<Table2ColumnProps<TType>> | boolean | null | undefined)[];
104
+ export declare type Table2ShortcutHandlerFn<TType = any> = (row: TType) => void;
105
+ export declare type Table2ShortcutHandlerObject<TType = any> = {
106
+ handler: Table2ShortcutHandlerFn<TType>;
107
+ meta?: boolean;
108
+ shift?: boolean;
109
+ };
110
+ export declare type Table2Shortcuts<TType = any> = Record<string, Table2ShortcutHandlerFn<TType> | Table2ShortcutHandlerObject<TType>>;
111
+ export declare type Table2Props<TType = any> = Omit<React.HTMLAttributes<HTMLDivElement>, 'children'> & {
112
+ actionsForRow?: Table2RowActionRenderer<TType>[];
113
+ actionsForRowLength?: number;
114
+ children: Table2Children;
115
+ className?: string;
116
+ data: TType[];
117
+ defaultActiveRowIndex?: number;
118
+ disableColumnFiltering?: boolean;
119
+ disableColumnHiding?: boolean;
120
+ disableColumnFreezing?: boolean;
121
+ disableColumnReordering?: boolean;
122
+ disableColumnResizing?: boolean;
123
+ disableRowDensity?: boolean;
124
+ disableRowExpansion?: boolean;
125
+ disableRowSelection?: boolean;
126
+ disableMultipleRowSelection?: boolean;
127
+ disableSearch?: boolean;
128
+ disableSorting?: boolean;
129
+ emptyState?: () => JSX.Element;
130
+ expandedRowRenderer?: RowExpansionRenderer<TType>;
131
+ length?: number;
132
+ loadMore?: () => Promise<void>;
133
+ manualColumnFiltering?: boolean;
134
+ manualSearch?: boolean;
135
+ manualSorting?: boolean;
136
+ onChangeSettings?: SettingsHandler;
137
+ onRowClick?: RowClickHandler<TType>;
138
+ onRowDrag?: RowDragHandler<TType>;
139
+ onRowDrop?: RowDropHandler<TType>;
140
+ onRowSelect?: RowSelectionHandler<TType>;
141
+ onSave?: SaveHandler<TType>;
142
+ shortcuts?: Table2Shortcuts<TType>;
143
+ toolbarLeft?: JSX.Element;
144
+ toolbarRight?: JSX.Element;
145
+ settings?: Table2Settings;
146
+ _experimentalActionsForTable?: Table2ActionProps<TType>[];
147
+ _experimentalActionsForTableSummary?: (rows: TType[]) => JSX.Element | string;
148
+ };
@@ -0,0 +1,14 @@
1
+ import { Column } from '@tanstack/react-table';
2
+ import { CellAlignment, RowDensity } from '../types';
3
+ export declare const getCellSizingClasses: (density?: RowDensity, editing?: boolean) => string;
4
+ export declare const getCellAlignmentClasses: (alignment?: CellAlignment) => {
5
+ 'justify-start text-left': boolean;
6
+ 'justify-end text-right': boolean;
7
+ 'justify-center text-center': boolean;
8
+ };
9
+ export declare const getFrozenShadowClasses: (column: Column<any, any>, frozenColumns: string[], isHorizontallyOffset: boolean) => {
10
+ 'shadow-[6px_0px_6px_rgb(0_0_0/8%),1px_0px_0px_theme(colors.grey.300)]': boolean;
11
+ 'shadow-[1px_0px_0px_theme(colors.grey.300)]': boolean;
12
+ };
13
+ export declare const focussableNodeNames: string[];
14
+ export declare const isKeyboardFocusableElement: (element: Element) => boolean;
@@ -0,0 +1,16 @@
1
+ import React from 'react';
2
+ import { ColumnDef, DisplayColumnDef } from '@tanstack/react-table';
3
+ import { RowDragHandler, RowExpansionRenderer } from '../types';
4
+ import { LocalizationTexts } from '../../Provider/Localization';
5
+ export declare const COLUMN_ID_FOR_DRAGGABLE = "__draggable";
6
+ export declare const COLUMN_ID_FOR_SELECTION = "__select";
7
+ export declare const COLUMN_ID_FOR_EXPANSION = "__expansion";
8
+ export declare const COLUMN_ID_FOR_ACTIONS = "__actions";
9
+ export declare const isInternalFrozenColumn: (id: string) => boolean;
10
+ export declare const isInternalColumn: (id: string) => boolean;
11
+ export declare const MIN_COLUMN_SIZE = 80;
12
+ export declare function createRowDraggableColumn<TType = any>(onRowDrag: RowDragHandler<TType>, texts: LocalizationTexts): DisplayColumnDef<TType, any>;
13
+ export declare function createRowSelectionColumn<TType = any>(enableMultipleRowSelection: boolean, lastSelectedRowIndex: React.MutableRefObject<number | undefined>, onRowDrag: RowDragHandler<TType> | undefined, tableRef: React.RefObject<HTMLDivElement>, texts: LocalizationTexts): DisplayColumnDef<TType, any>;
14
+ export declare function createRowExpansionColumn<TType = any>(expandedRowRenderer: RowExpansionRenderer<TType>, texts: LocalizationTexts): DisplayColumnDef<TType, any>;
15
+ export declare function createRowActionsColumn<TType = any>(rowActions: any, rowActionsLength: any, texts: LocalizationTexts): DisplayColumnDef<TType, any>;
16
+ export declare function ensureOrdering<TType = unknown>(columns: ColumnDef<TType>[], settingsOrder: string[] | undefined): string[];
@@ -0,0 +1,3 @@
1
+ import { Table2Filter } from '../types';
2
+ export declare const globalFilterFn: (value: string, query: string) => boolean;
3
+ export declare const columnFilterFn: (value: any, filter: Table2Filter) => boolean;
@@ -1,11 +1,12 @@
1
1
  import React from 'react';
2
2
  import { Table3ColumnProps, Table3Props, Table3Ref } from './types';
3
3
  import './style.css';
4
- export { useTableData } from './hooks/useTableData';
5
- export type { useTable3DataFetcher, useTable3DataOptions, useTableDataValues } from './hooks/useTableData';
6
4
  declare type Table3WithStatics<TType = unknown> = React.ForwardRefExoticComponent<Table3Props<TType>> & {
7
5
  Column: (props: Table3ColumnProps) => null;
8
6
  } & (<TType>(props: Table3Props<TType> & {
9
7
  ref?: React.Ref<Table3Ref>;
10
8
  }) => JSX.Element);
11
9
  export declare const Table3: Table3WithStatics<unknown>;
10
+ export { useTable3DataLoader } from './hooks/useTableDataLoader';
11
+ export type { useTable3DataFetcher, useTable3DataOptions, useTableDataValues } from './hooks/useTableDataLoader';
12
+ export type { Table3Ref, Table3Props, Table3Preset, Table3Settings, Table3SettingsAdapter, Table3RowHeight, Table3FilterComparator, Table3FilterHandler, Table3SearchHandler, Table3LoadPageHandler, Table3LoadAllHandler, Table3RowGotoHandler, Table3SortHandler, Table3Shortcuts, Table3ShortcutHandlerFn, Table3ShortcutHandlerObject, Table3FontSize, Table3SortDirection, Table3SortFn, Table3RowActionRenderer, Table3RowSelectionHandler, Table3RowExpansionRenderer, Table3RowDropHandler, Table3RowDragHandler, Table3RowClickHandler, Table3ColumnProps, Table3ColumnAlignment, Table3ColumnDataType, Table3ColumnHeaderMenu, Table3ColumnClassNameHandler, Table3ColumnFooterRenderer, Table3ColumnRenderer, Table3ColumnControlRenderer, Table3ColumnControlProps, } from './types';
@@ -1,13 +1,13 @@
1
1
  import React from 'react';
2
2
  import { CellContext } from '@tanstack/react-table';
3
- import { ColumnAlignment } from '../../../types';
3
+ import { Table3ColumnAlignment } from '../../../types';
4
4
  export declare type DisplayCellProps<TType = unknown> = CellContext<TType, unknown> & {
5
5
  children?: string | JSX.Element;
6
6
  className?: string;
7
7
  };
8
8
  export declare function DisplayCell<TType = unknown>(props: DisplayCellProps<TType>): JSX.Element;
9
9
  export declare type MemoedDisplayCellProps<TType = unknown> = {
10
- align?: ColumnAlignment;
10
+ align?: Table3ColumnAlignment;
11
11
  children: JSX.Element | string | null;
12
12
  className?: string;
13
13
  data: TType;
@@ -1,12 +1,12 @@
1
1
  /// <reference types="react" />
2
2
  import { ColumnMeta, HeaderContext } from '@tanstack/react-table';
3
- import { ColumnAlignment, Table3ColumnFooterRenderer } from '../../../types';
3
+ import { Table3ColumnAlignment, Table3ColumnFooterRenderer } from '../../../types';
4
4
  export declare type FooterProps<TType = unknown> = HeaderContext<TType, unknown> & {
5
5
  renderer?: Table3ColumnFooterRenderer<TType>;
6
6
  };
7
7
  export declare function Footer<TType = unknown>(props: FooterProps<TType>): JSX.Element;
8
8
  export declare type MemoedFooterProps<TType = unknown> = Omit<FooterProps<TType>, 'header' | 'column' | 'scrollToIndex'> & {
9
- align?: ColumnAlignment;
9
+ align?: Table3ColumnAlignment;
10
10
  id: string;
11
11
  index: number;
12
12
  isFrozen: boolean;
@@ -1,12 +1,12 @@
1
1
  /// <reference types="react" />
2
2
  import { ColumnMeta, HeaderContext } from '@tanstack/react-table';
3
- import { ColumnAlignment, SortDirection, TableStrategy } from '../../../types';
3
+ import { Table3ColumnAlignment, Table3SortDirection, TableStrategy } from '../../../types';
4
4
  export declare type HeaderProps<TType = unknown> = HeaderContext<TType, unknown> & {
5
5
  children?: string | JSX.Element;
6
6
  };
7
7
  export declare function Header<TType = unknown>(props: HeaderProps<TType>): JSX.Element;
8
8
  export declare type MemoedHeaderProps<TType = unknown> = Omit<HeaderProps<TType>, 'column' | 'header'> & {
9
- align?: ColumnAlignment;
9
+ align?: Table3ColumnAlignment;
10
10
  canFreeze: boolean;
11
11
  canHide: boolean;
12
12
  canResize: boolean;
@@ -23,5 +23,5 @@ export declare type MemoedHeaderProps<TType = unknown> = Omit<HeaderProps<TType>
23
23
  onResize: (event: unknown) => void;
24
24
  onSort: (event: unknown) => void;
25
25
  scrollToIndex: TableStrategy['scrollToIndex'];
26
- sortDirection: false | SortDirection;
26
+ sortDirection: false | Table3SortDirection;
27
27
  };
@@ -1,11 +1,11 @@
1
1
  import React from 'react';
2
- import { SortDirection } from '../../../types';
2
+ import { Table3SortDirection } from '../../../types';
3
3
  declare type SortIndicatorProps = {
4
- direction: false | SortDirection;
4
+ direction: false | Table3SortDirection;
5
5
  };
6
6
  export declare function SortIndicator(props: SortIndicatorProps): any;
7
7
  export declare const getAriaSort: (direction: any) => any;
8
- export declare function getSortAttributes(toggleSorting: (event: unknown) => void, sortDirection: false | SortDirection): {
8
+ export declare function getSortAttributes(toggleSorting: (event: unknown) => void, sortDirection: false | Table3SortDirection): {
9
9
  'aria-sort': any;
10
10
  onClick: (event: React.MouseEvent) => void;
11
11
  };
@@ -1,4 +1,4 @@
1
- import { ColumnAlignment } from '../../types';
1
+ import { Table3ColumnAlignment } from '../../types';
2
2
  export declare const MIN_COLUMN_SIZE = 80;
3
- export declare const getCellAlignmentClasses: (alignment?: ColumnAlignment) => string;
3
+ export declare const getCellAlignmentClasses: (alignment?: Table3ColumnAlignment) => string;
4
4
  export declare const getInputAppearanceClassnames: () => string;
@@ -1,6 +1,6 @@
1
1
  import React from 'react';
2
2
  import { RowData } from '@tanstack/react-table';
3
- import { ColumnAlignment, Table3ColumnRenderer, Table3Props, Table3ColumnHeaderMenu, Table3ColumnControlRenderer, ColumnDataType, Table3ColumnClassNameHandler, Table3ColumnFooterRenderer, TableStrategy } from '../types';
3
+ import { Table3ColumnAlignment, Table3ColumnRenderer, Table3Props, Table3ColumnHeaderMenu, Table3ColumnControlRenderer, Table3ColumnDataType, Table3ColumnClassNameHandler, Table3ColumnFooterRenderer, TableStrategy } from '../types';
4
4
  import { useCurrentRow } from './features/useCurrentRow';
5
5
  import { usePauseHoverState } from './features/usePauseHoverState';
6
6
  import { useRowHeight } from './features/useRowHeight';
@@ -34,10 +34,10 @@ declare module '@tanstack/table-core' {
34
34
  search: ReturnType<typeof useSearch>;
35
35
  }
36
36
  interface ColumnMeta<TData extends RowData, TValue> {
37
- align?: ColumnAlignment;
37
+ align?: Table3ColumnAlignment;
38
38
  className?: Table3ColumnClassNameHandler<TData>;
39
39
  control?: Table3ColumnControlRenderer<TData>;
40
- dataType?: ColumnDataType;
40
+ dataType?: Table3ColumnDataType;
41
41
  defaultWidth?: number;
42
42
  enableOrdering: boolean;
43
43
  enableSearch: boolean;
@@ -0,0 +1,23 @@
1
+ import { ColumnFilter, Table3ColumnSort, Table3FilterHandler, Table3LoadAllHandler, Table3LoadPageHandler, Table3SearchHandler, Table3SortHandler } from '../types';
2
+ export declare type useTable3DataFetcher<TType = unknown> = (pageIndex: number, pageSize: number, sorting: Table3ColumnSort[], filters: ColumnFilter[], search: string | undefined) => Promise<{
3
+ data: TType[];
4
+ length: number;
5
+ }>;
6
+ export declare type useTable3AllDataFetcher<TType = unknown> = (sorting: Table3ColumnSort[], filters: ColumnFilter[], search: string | undefined) => Promise<{
7
+ data: TType[];
8
+ length: number;
9
+ }>;
10
+ export declare type useTable3DataOptions = {
11
+ pageSize: number;
12
+ };
13
+ export declare type useTableDataValues<TType = unknown> = {
14
+ data: TType[];
15
+ length: number | undefined;
16
+ loadAll: Table3LoadAllHandler;
17
+ loadPage: Table3LoadPageHandler;
18
+ onFilter: Table3FilterHandler;
19
+ onSearch: Table3SearchHandler;
20
+ onSort: Table3SortHandler;
21
+ pageSize: number;
22
+ };
23
+ export declare function useTable3DataLoader<TType = unknown>(fetch: useTable3DataFetcher<TType>, fetchAll: useTable3AllDataFetcher<TType>, options?: useTable3DataOptions): useTableDataValues<TType>;
@@ -1,13 +1,13 @@
1
1
  /// <reference types="react" />
2
- import { ColumnFilter as RTColumnFilter, ColumnFiltersState, ColumnOrderState, ColumnPinningState, ColumnSizingState, ColumnSort as RTColumnSort, SortingState, VisibilityState, BuiltInSortingFn } from '@tanstack/react-table';
2
+ import { ColumnFilter as RTColumnFilter, ColumnFiltersState, ColumnOrderState, ColumnPinningState, ColumnSizingState, ColumnSort as RTTableColumnSort, SortingState, VisibilityState, BuiltInSortingFn } from '@tanstack/react-table';
3
3
  import { MenuProps } from '../Menu/Menu';
4
- export declare type SortDirection = 'asc' | 'desc';
5
- export declare type SortFn<TType = unknown> = ((rowA: TType, rowB: TType, columnId: string) => -1 | 0 | 1) | BuiltInSortingFn | 'auto';
4
+ export declare type Table3SortDirection = 'asc' | 'desc';
5
+ export declare type Table3SortFn<TType = unknown> = ((rowA: TType, rowB: TType, columnId: string) => -1 | 0 | 1) | BuiltInSortingFn | 'auto';
6
6
  export declare type Table3ColumnRenderer<TValue = unknown, TType = unknown> = (value: TValue, row: TType) => JSX.Element | string | null;
7
7
  export declare type Table3ColumnFooterRenderer<TValue = unknown> = (values: TValue[]) => JSX.Element | string | null;
8
8
  export declare type Table3ColumnClassNameHandler<TType = unknown> = string | ((row: TType) => string);
9
- export declare type ColumnAlignment = 'left' | 'center' | 'right';
10
- export declare type ColumnDataType = 'auto' | 'alphanumeric' | 'alphanumericCaseSensitive' | 'datetime' | 'boolean';
9
+ export declare type Table3ColumnAlignment = 'left' | 'center' | 'right';
10
+ export declare type Table3ColumnDataType = 'auto' | 'alphanumeric' | 'alphanumericCaseSensitive' | 'datetime' | 'boolean';
11
11
  export declare type Table3ColumnHeaderMenu = (props: Partial<MenuProps>) => JSX.Element;
12
12
  export declare type Table3ColumnControlProps = {
13
13
  className?: string;
@@ -23,10 +23,10 @@ export declare type Table3ColumnControlProps = {
23
23
  export declare type Table3ColumnControlRenderer<TType = unknown> = ((props: Table3ColumnControlProps, row?: TType) => JSX.Element) | 'datepicker' | 'input' | 'switch';
24
24
  export declare type Table3ColumnProps<TType = unknown> = {
25
25
  accessor: string;
26
- align?: ColumnAlignment;
26
+ align?: Table3ColumnAlignment;
27
27
  className?: Table3ColumnClassNameHandler<TType>;
28
28
  control?: Table3ColumnControlRenderer<TType>;
29
- dataType?: ColumnDataType;
29
+ dataType?: Table3ColumnDataType;
30
30
  defaultHidden?: boolean;
31
31
  defaultWidth?: number | 'grow';
32
32
  enableFiltering?: boolean;
@@ -41,8 +41,8 @@ export declare type Table3ColumnProps<TType = unknown> = {
41
41
  headerClassName?: string;
42
42
  menu?: Table3ColumnHeaderMenu;
43
43
  renderer?: Table3ColumnRenderer<unknown, TType>;
44
- sort?: SortDirection;
45
- sortFn?: SortFn<TType>;
44
+ sort?: Table3SortDirection;
45
+ sortFn?: Table3SortFn<TType>;
46
46
  tooltip?: string;
47
47
  };
48
48
  export declare type DeprecatedRowDensity = 'compact' | 'normal' | 'comfortable' | 'spacious';
@@ -54,7 +54,6 @@ export declare type Table3RowDropHandler<TType = any> = (event: React.DragEvent,
54
54
  export declare type Table3RowExpansionRenderer<TType = unknown> = (row: TType) => (() => JSX.Element) | null;
55
55
  export declare type Table3RowSelectionHandler<TType = unknown> = (rows: TType[]) => void;
56
56
  export declare type Table3RowActionRenderer<TType = unknown> = (row: TType) => JSX.Element;
57
- export declare type Table3RenderStrategy = 'static' | 'virtual';
58
57
  export declare type Table3Preset = 'display' | 'editable';
59
58
  export declare type Table3Settings = {
60
59
  columnFilters?: ColumnFiltersState;
@@ -95,11 +94,11 @@ export declare type Table3Filter = {
95
94
  export declare type ColumnFilter = RTColumnFilter;
96
95
  export declare type Table3FilterHandler = (filters: ColumnFilter[]) => void;
97
96
  export declare type Table3SearchHandler = (query: string | undefined) => Promise<void>;
98
- export declare type Table3LoadPageHandler = (pageIndex: number, sorting: ColumnSort[], filters: ColumnFilter[], search: string | undefined) => Promise<void>;
99
- export declare type Table3LoadAllHandler = (sorting: ColumnSort[], filters: ColumnFilter[], search: string | undefined) => Promise<void>;
100
- export declare type Table3RowGotoHandler = (column: string, query: string, sorting: ColumnSort[], filters: ColumnFilter[], search: string | undefined) => Promise<number>;
101
- export declare type ColumnSort = RTColumnSort;
102
- export declare type Table3SortHandler = (sorting: ColumnSort[]) => void;
97
+ export declare type Table3LoadPageHandler = (pageIndex: number, sorting: Table3ColumnSort[], filters: ColumnFilter[], search: string | undefined) => Promise<void>;
98
+ export declare type Table3LoadAllHandler = (sorting: Table3ColumnSort[], filters: ColumnFilter[], search: string | undefined) => Promise<void>;
99
+ export declare type Table3RowGotoHandler = (column: string, query: string, sorting: Table3ColumnSort[], filters: ColumnFilter[], search: string | undefined) => Promise<number>;
100
+ export declare type Table3ColumnSort = RTTableColumnSort;
101
+ export declare type Table3SortHandler = (sorting: Table3ColumnSort[]) => void;
103
102
  export declare type TableStrategy = {
104
103
  renderBody: () => JSX.Element | JSX.Element[] | null;
105
104
  scrollToIndex: (index: number, options?: {
@@ -133,7 +132,7 @@ export declare type Table3Options = {
133
132
  enableSearch: boolean;
134
133
  enableSorting: boolean;
135
134
  };
136
- export declare type CommonTable3Props<TType = unknown> = Partial<Table3Options> & {
135
+ export declare type Table3CommonProps<TType = unknown> = Partial<Table3Options> & {
137
136
  actionsForRow?: Table3RowActionRenderer<TType>[];
138
137
  actionsForRowLength?: number;
139
138
  children: (React.ReactElement<Table3ColumnProps<TType>> | boolean | null | undefined)[];
@@ -159,19 +158,19 @@ export declare type CommonTable3Props<TType = unknown> = Partial<Table3Options>
159
158
  toolbarLeft?: JSX.Element;
160
159
  toolbarRight?: JSX.Element;
161
160
  };
162
- interface ClientTable3Props<TType = unknown> extends CommonTable3Props<TType> {
161
+ interface Table3ClientProps<TType = unknown> extends Table3CommonProps<TType> {
163
162
  length?: never;
164
163
  loadPage?: never;
165
164
  loadAll?: never;
166
165
  pageSize?: never;
167
166
  }
168
- interface ServerTable3Props<TType = unknown> extends CommonTable3Props<TType> {
167
+ interface Table3ServerProps<TType = unknown> extends Table3CommonProps<TType> {
169
168
  length: number | undefined;
170
169
  loadPage: Table3LoadPageHandler;
171
170
  loadAll: Table3LoadAllHandler;
172
171
  pageSize?: number;
173
172
  }
174
- export declare type Table3Props<TType = unknown> = ClientTable3Props<TType> | ServerTable3Props<TType>;
173
+ export declare type Table3Props<TType = unknown> = Table3ClientProps<TType> | Table3ServerProps<TType>;
175
174
  export declare type Table3Ref = HTMLDivElement & {
176
175
  instance: {
177
176
  resetFiltering: () => void;
@@ -68,6 +68,116 @@ const defaultLocalisationTexts = {
68
68
  newSubRow: 'New row (shift + n)',
69
69
  loading: 'Loading...'
70
70
  },
71
+ table2: {
72
+ columns: {
73
+ resize: {
74
+ tooltip: 'Resize column'
75
+ },
76
+ actions: {
77
+ tooltip: 'Other actions'
78
+ },
79
+ drag: {
80
+ tooltip: 'Drag row'
81
+ },
82
+ expansion: {
83
+ collapse: 'Collapse row',
84
+ collapseAll: 'Collapse all rows',
85
+ expand: 'Expand row',
86
+ expandAll: 'Expand all rows'
87
+ },
88
+ select: {
89
+ deselect: 'Deselect row',
90
+ deselectAll: 'Deselect all rows',
91
+ select: 'Select row',
92
+ selectAll: 'Select all rows'
93
+ },
94
+ menu: {
95
+ hideColumn: 'Hide column',
96
+ freezeColumns: (count = 1) => count === 1 ? 'Freeze the first column' : `Freeze first ${count} columns`,
97
+ unfreezeColumns: 'Unfreeze all columns'
98
+ }
99
+ },
100
+ columnSettings: {
101
+ search: 'Search column...',
102
+ tooltip: 'Column settings',
103
+ button: 'Columns',
104
+ noResults: 'No results'
105
+ },
106
+ editing: {
107
+ button: 'Edit',
108
+ tooltip: 'Edit',
109
+ tooltipDisabled: 'There are no visible columns that support editing',
110
+ rowIndicator: {
111
+ rowWillMove: 'Row will move due to sorting',
112
+ rowWillBeHidden: 'Row will hide due to filtering',
113
+ rowWillMoveReasonSearch: 'Due to a search filter applied to this table, this row will be hidden as soon as you select another row',
114
+ rowWillMoveReasonFilter: "Due to a filter applied to the column '[COLUMN]', this row will be hidden as soon as you select another row",
115
+ rowWillMoveReasonSorting: "Due to sorting applied to the column '[COLUMN]', this row will move position as soon as you select another row"
116
+ }
117
+ },
118
+ filters: {
119
+ button: 'Filters',
120
+ buttons: {
121
+ addNewFilter: 'Add new filter',
122
+ clearFilters: 'Clear all filters'
123
+ },
124
+ comparators: {
125
+ contains: 'Contains',
126
+ doesNotContain: 'Does not contain',
127
+ isEqualTo: 'Is',
128
+ isNotEqualTo: 'Is not',
129
+ isGreaterThan: 'Is greater than',
130
+ isLessThan: 'Is less than',
131
+ isBetween: 'Is between',
132
+ isOneOf: 'Is one of',
133
+ isNoneOf: 'Is none of',
134
+ isAllOf: 'Is all of',
135
+ isEmpty: 'Is empty',
136
+ isNotEmpty: 'Is not empty'
137
+ },
138
+ conditions: {
139
+ and: 'And',
140
+ where: 'Where'
141
+ },
142
+ emptyFilter: {
143
+ condition: 'Condition',
144
+ value: 'Value'
145
+ },
146
+ tooltip: 'Apply filters',
147
+ total: 'Viewing [CURRENT] of [TOTAL]'
148
+ },
149
+ footer: {
150
+ summary: {
151
+ records: 'Records:',
152
+ selected: 'Records selected:'
153
+ }
154
+ },
155
+ rowDensity: {
156
+ tooltip: 'Row density',
157
+ compact: 'compact',
158
+ normal: 'normal',
159
+ comfortable: 'comfortable',
160
+ spacious: 'spacious'
161
+ },
162
+ search: {
163
+ placeholder: 'Search...'
164
+ },
165
+ shortcuts: {
166
+ tooltip: 'View keyboard shortcuts',
167
+ search: 'Search',
168
+ filter: 'Filter',
169
+ previousRow: 'Previous row',
170
+ nextRow: 'Next row',
171
+ editCell: 'Edit cell',
172
+ previousColumn: 'Previous column',
173
+ nextColumn: 'Next column',
174
+ rowClick: 'Activate current row',
175
+ selectRow: 'Select current row',
176
+ selectAllRows: 'Select all rows',
177
+ expandRow: 'Expand current row',
178
+ collapseRow: 'Collapse current row'
179
+ }
180
+ },
71
181
  table3: {
72
182
  columns: {
73
183
  actions: {