@deephaven/jsapi-utils 0.47.1-beta.0 → 0.47.1-beta.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/FilterUtils.d.ts +67 -0
- package/dist/FilterUtils.d.ts.map +1 -0
- package/dist/FilterUtils.js +141 -0
- package/dist/FilterUtils.js.map +1 -0
- package/dist/TableUtils.d.ts +27 -0
- package/dist/TableUtils.d.ts.map +1 -1
- package/dist/TableUtils.js +106 -18
- package/dist/TableUtils.js.map +1 -1
- package/dist/ViewportDataUtils.d.ts +7 -15
- package/dist/ViewportDataUtils.d.ts.map +1 -1
- package/dist/ViewportDataUtils.js +13 -24
- package/dist/ViewportDataUtils.js.map +1 -1
- package/dist/index.d.ts +1 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +1 -0
- package/dist/index.js.map +1 -1
- package/package.json +7 -8
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
import type { Column, FilterCondition, Table, TreeTable } from '@deephaven/jsapi-types';
|
|
2
|
+
import type { SelectionT } from '@deephaven/utils';
|
|
3
|
+
import TableUtils from './TableUtils';
|
|
4
|
+
export interface FilterConditionFactory {
|
|
5
|
+
(table: Table | TreeTable | null | undefined): FilterCondition | null;
|
|
6
|
+
}
|
|
7
|
+
/**
|
|
8
|
+
* Create args for a filter derived from a combobox selection.
|
|
9
|
+
* @param value
|
|
10
|
+
*/
|
|
11
|
+
export declare function createComboboxFilterArgs(value: string, allValue: string): {
|
|
12
|
+
operator: 'eq' | 'notEq';
|
|
13
|
+
value: string;
|
|
14
|
+
};
|
|
15
|
+
/**
|
|
16
|
+
* Create a filter condition factory for a `contains` filter that matches the
|
|
17
|
+
* given search text.
|
|
18
|
+
* @param tableUtils TableUtils instance to create filter from
|
|
19
|
+
* @param columnNames Names of the columns to filter
|
|
20
|
+
* @param searchText Text to search (will be trimmed of leading / trailing whitespace)
|
|
21
|
+
*/
|
|
22
|
+
export declare function createSearchTextFilter(tableUtils: TableUtils, columnNames: string | string[], searchText: string): FilterConditionFactory;
|
|
23
|
+
/**
|
|
24
|
+
* Create a filter condition factory function.
|
|
25
|
+
* @param columnNames Column names that filter conditions will target
|
|
26
|
+
* @param createColumnCondition Function that can create a `FilterCondition` from
|
|
27
|
+
* a given column. This will be run across all columns corresponding to the given
|
|
28
|
+
* list of column names.
|
|
29
|
+
* @param conditionOperator Operator that will be used to combine multiple
|
|
30
|
+
* `FilterConditions` if multiple column names are given.
|
|
31
|
+
*/
|
|
32
|
+
export declare function createFilterConditionFactory(columnNames: string | string[], createColumnCondition: (column: Column) => FilterCondition, conditionOperator?: 'and' | 'or'): FilterConditionFactory;
|
|
33
|
+
/**
|
|
34
|
+
* Create a filter condition factory for a filter operator that matches the
|
|
35
|
+
* given value.
|
|
36
|
+
* @param tableUtils TableUtils instance to create filter from
|
|
37
|
+
* @param columnNames Column names to compare value to
|
|
38
|
+
* @param value Value to match
|
|
39
|
+
* @param operator Operator to use for matching
|
|
40
|
+
*/
|
|
41
|
+
export declare function createValueFilter(tableUtils: TableUtils, columnNames: string | string[], value: string, operator: 'contains' | 'containsIgnoreCase' | 'eq' | 'eqIgnoreCase' | 'notEq' | 'notEqIgnoreCase'): FilterConditionFactory;
|
|
42
|
+
/**
|
|
43
|
+
* Create a filter condition factory for a filter that matches a given Selection.
|
|
44
|
+
* If column is not found or selection parameter is 'all', the factory will return
|
|
45
|
+
* null to indicate the results will be unfiltered.
|
|
46
|
+
* @param tableUtils TableUtils instance to create filter from
|
|
47
|
+
* @param columnName The column name to filter
|
|
48
|
+
* @param selection 'all' or an array of values to filter by
|
|
49
|
+
* @param emptySelectionEqAll If true, empty selection means select
|
|
50
|
+
* all. If false, it means select none.
|
|
51
|
+
* @param invertSelection Invert the selection (eg. All items are selected,
|
|
52
|
+
* then you deselect items)
|
|
53
|
+
*/
|
|
54
|
+
export declare function createSelectedValuesFilter<TValue>(tableUtils: TableUtils, columnName: string, selection: SelectionT<TValue>, emptySelectionEqAll: boolean, invertSelection: boolean): FilterConditionFactory;
|
|
55
|
+
/**
|
|
56
|
+
* Creates a `notNullOrEmptyFilterCondition` function.
|
|
57
|
+
* @param tableUtils TableUtils instance to use for making filters.
|
|
58
|
+
*/
|
|
59
|
+
export declare function createNotNullOrEmptyFilterCondition(tableUtils: TableUtils): (column: Column) => FilterCondition;
|
|
60
|
+
/**
|
|
61
|
+
* Creates a `showOnlyEmptyFilterCondition` function that can be toggled on or
|
|
62
|
+
* off.
|
|
63
|
+
* @param tableUtils TableUtils instance to use for making filters.
|
|
64
|
+
* @param isOn Flag to indicate if the filter should be on or off.
|
|
65
|
+
*/
|
|
66
|
+
export declare function createShowOnlyEmptyFilterCondition(tableUtils: TableUtils, isOn: boolean): (column: Column) => FilterCondition;
|
|
67
|
+
//# sourceMappingURL=FilterUtils.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FilterUtils.d.ts","sourceRoot":"","sources":["../src/FilterUtils.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,MAAM,EACN,eAAe,EACf,KAAK,EACL,SAAS,EACV,MAAM,wBAAwB,CAAC;AAChC,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AACnD,OAAO,UAAU,MAAM,cAAc,CAAC;AAEtC,MAAM,WAAW,sBAAsB;IACrC,CAAC,KAAK,EAAE,KAAK,GAAG,SAAS,GAAG,IAAI,GAAG,SAAS,GAAG,eAAe,GAAG,IAAI,CAAC;CACvE;AAED;;;GAGG;AACH,wBAAgB,wBAAwB,CACtC,KAAK,EAAE,MAAM,EACb,QAAQ,EAAE,MAAM,GACf;IACD,QAAQ,EAAE,IAAI,GAAG,OAAO,CAAC;IACzB,KAAK,EAAE,MAAM,CAAC;CACf,CAIA;AAED;;;;;;GAMG;AACH,wBAAgB,sBAAsB,CACpC,UAAU,EAAE,UAAU,EACtB,WAAW,EAAE,MAAM,GAAG,MAAM,EAAE,EAC9B,UAAU,EAAE,MAAM,GACjB,sBAAsB,CA2BxB;AAED;;;;;;;;GAQG;AACH,wBAAgB,4BAA4B,CAC1C,WAAW,EAAE,MAAM,GAAG,MAAM,EAAE,EAC9B,qBAAqB,EAAE,CAAC,MAAM,EAAE,MAAM,KAAK,eAAe,EAC1D,iBAAiB,GAAE,KAAK,GAAG,IAAW,GACrC,sBAAsB,CAkBxB;AAED;;;;;;;GAOG;AACH,wBAAgB,iBAAiB,CAC/B,UAAU,EAAE,UAAU,EACtB,WAAW,EAAE,MAAM,GAAG,MAAM,EAAE,EAC9B,KAAK,EAAE,MAAM,EACb,QAAQ,EACJ,UAAU,GACV,oBAAoB,GACpB,IAAI,GACJ,cAAc,GACd,OAAO,GACP,iBAAiB,GACpB,sBAAsB,CAUxB;AAED;;;;;;;;;;;GAWG;AACH,wBAAgB,0BAA0B,CAAC,MAAM,EAC/C,UAAU,EAAE,UAAU,EACtB,UAAU,EAAE,MAAM,EAClB,SAAS,EAAE,UAAU,CAAC,MAAM,CAAC,EAC7B,mBAAmB,EAAE,OAAO,EAC5B,eAAe,EAAE,OAAO,GACvB,sBAAsB,CAwBxB;AAED;;;GAGG;AACH,wBAAgB,mCAAmC,CAAC,UAAU,EAAE,UAAU,YAM9D,MAAM,KACb,eAAe,CAOnB;AAED;;;;;GAKG;AACH,wBAAgB,kCAAkC,CAChD,UAAU,EAAE,UAAU,EACtB,IAAI,EAAE,OAAO,YAQH,MAAM,KACb,eAAe,CAYnB"}
|
|
@@ -0,0 +1,141 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Create args for a filter derived from a combobox selection.
|
|
3
|
+
* @param value
|
|
4
|
+
*/
|
|
5
|
+
export function createComboboxFilterArgs(value, allValue) {
|
|
6
|
+
return value === allValue ? {
|
|
7
|
+
operator: 'notEq',
|
|
8
|
+
value: ''
|
|
9
|
+
} // this is synonymous with "no filter"
|
|
10
|
+
: {
|
|
11
|
+
operator: 'eq',
|
|
12
|
+
value
|
|
13
|
+
};
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
/**
|
|
17
|
+
* Create a filter condition factory for a `contains` filter that matches the
|
|
18
|
+
* given search text.
|
|
19
|
+
* @param tableUtils TableUtils instance to create filter from
|
|
20
|
+
* @param columnNames Names of the columns to filter
|
|
21
|
+
* @param searchText Text to search (will be trimmed of leading / trailing whitespace)
|
|
22
|
+
*/
|
|
23
|
+
export function createSearchTextFilter(tableUtils, columnNames, searchText) {
|
|
24
|
+
/**
|
|
25
|
+
* Creates a filter condition that matches based on search text.
|
|
26
|
+
* @param maybeTable Table to filter
|
|
27
|
+
*/
|
|
28
|
+
return function searchTextFilter(maybeTable) {
|
|
29
|
+
var searchTextTrimmed = searchText.trim();
|
|
30
|
+
if (searchTextTrimmed === '') {
|
|
31
|
+
return null;
|
|
32
|
+
}
|
|
33
|
+
var factory = createFilterConditionFactory(columnNames, col => col.filter().containsIgnoreCase(tableUtils.makeFilterValue(col.type, searchTextTrimmed)), 'or');
|
|
34
|
+
return factory(maybeTable);
|
|
35
|
+
};
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
/**
|
|
39
|
+
* Create a filter condition factory function.
|
|
40
|
+
* @param columnNames Column names that filter conditions will target
|
|
41
|
+
* @param createColumnCondition Function that can create a `FilterCondition` from
|
|
42
|
+
* a given column. This will be run across all columns corresponding to the given
|
|
43
|
+
* list of column names.
|
|
44
|
+
* @param conditionOperator Operator that will be used to combine multiple
|
|
45
|
+
* `FilterConditions` if multiple column names are given.
|
|
46
|
+
*/
|
|
47
|
+
export function createFilterConditionFactory(columnNames, createColumnCondition) {
|
|
48
|
+
var conditionOperator = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'or';
|
|
49
|
+
return function filterConditionFactory(maybeTable) {
|
|
50
|
+
var maybeColumns = maybeTable === null || maybeTable === void 0 ? void 0 : maybeTable.findColumns(typeof columnNames === 'string' ? [columnNames] : columnNames);
|
|
51
|
+
if (maybeColumns == null || maybeColumns.length === 0) {
|
|
52
|
+
return null;
|
|
53
|
+
}
|
|
54
|
+
var filterConditions = maybeColumns.map(createColumnCondition);
|
|
55
|
+
return filterConditions.reduce((current, next) => current[conditionOperator](next));
|
|
56
|
+
};
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
/**
|
|
60
|
+
* Create a filter condition factory for a filter operator that matches the
|
|
61
|
+
* given value.
|
|
62
|
+
* @param tableUtils TableUtils instance to create filter from
|
|
63
|
+
* @param columnNames Column names to compare value to
|
|
64
|
+
* @param value Value to match
|
|
65
|
+
* @param operator Operator to use for matching
|
|
66
|
+
*/
|
|
67
|
+
export function createValueFilter(tableUtils, columnNames, value, operator) {
|
|
68
|
+
/**
|
|
69
|
+
* Creates a filter condition that matches based on matching a given value.
|
|
70
|
+
* @param maybeTable Table to filter
|
|
71
|
+
*/
|
|
72
|
+
return createFilterConditionFactory(columnNames, col => col.filter()[operator](tableUtils.makeFilterValue(col.type, value)), 'or');
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
/**
|
|
76
|
+
* Create a filter condition factory for a filter that matches a given Selection.
|
|
77
|
+
* If column is not found or selection parameter is 'all', the factory will return
|
|
78
|
+
* null to indicate the results will be unfiltered.
|
|
79
|
+
* @param tableUtils TableUtils instance to create filter from
|
|
80
|
+
* @param columnName The column name to filter
|
|
81
|
+
* @param selection 'all' or an array of values to filter by
|
|
82
|
+
* @param emptySelectionEqAll If true, empty selection means select
|
|
83
|
+
* all. If false, it means select none.
|
|
84
|
+
* @param invertSelection Invert the selection (eg. All items are selected,
|
|
85
|
+
* then you deselect items)
|
|
86
|
+
*/
|
|
87
|
+
export function createSelectedValuesFilter(tableUtils, columnName, selection, emptySelectionEqAll, invertSelection) {
|
|
88
|
+
/**
|
|
89
|
+
* Creates a filter condition that matches rows for selected values. Returns
|
|
90
|
+
* null to indicate no filtering.
|
|
91
|
+
* @param maybeTable the table to filter
|
|
92
|
+
*/
|
|
93
|
+
return function selectedValuesFilter(maybeTable) {
|
|
94
|
+
var maybeColumn = maybeTable === null || maybeTable === void 0 ? void 0 : maybeTable.findColumn(columnName);
|
|
95
|
+
var isAllSelected = selection === 'all' || emptySelectionEqAll && selection.size === 0;
|
|
96
|
+
if (maybeColumn == null || isAllSelected) {
|
|
97
|
+
return null;
|
|
98
|
+
}
|
|
99
|
+
return tableUtils.makeSelectValueFilter(maybeColumn, [...selection.keys()], invertSelection);
|
|
100
|
+
};
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
/**
|
|
104
|
+
* Creates a `notNullOrEmptyFilterCondition` function.
|
|
105
|
+
* @param tableUtils TableUtils instance to use for making filters.
|
|
106
|
+
*/
|
|
107
|
+
export function createNotNullOrEmptyFilterCondition(tableUtils) {
|
|
108
|
+
/**
|
|
109
|
+
* Returns a filter condition that matches values in a given column that are
|
|
110
|
+
* not null or empty string.
|
|
111
|
+
*/
|
|
112
|
+
return function notNullOrEmptyFilterCondition(column) {
|
|
113
|
+
return column.filter().isNull().not().and(column.filter().notEq(tableUtils.makeFilterValue(column.type, '')));
|
|
114
|
+
};
|
|
115
|
+
}
|
|
116
|
+
|
|
117
|
+
/**
|
|
118
|
+
* Creates a `showOnlyEmptyFilterCondition` function that can be toggled on or
|
|
119
|
+
* off.
|
|
120
|
+
* @param tableUtils TableUtils instance to use for making filters.
|
|
121
|
+
* @param isOn Flag to indicate if the filter should be on or off.
|
|
122
|
+
*/
|
|
123
|
+
export function createShowOnlyEmptyFilterCondition(tableUtils, isOn) {
|
|
124
|
+
/**
|
|
125
|
+
* Returns a filter condition that matches values in a given column. If the
|
|
126
|
+
* `isOn` param is true, this will filter to only null or empty string values.
|
|
127
|
+
* If `isOn` is false, it will return a filter that matches all values.
|
|
128
|
+
*/
|
|
129
|
+
return function showOnlyEmptyFilterCondition(column) {
|
|
130
|
+
var filter = column.filter();
|
|
131
|
+
var emptyStringValue = tableUtils.makeFilterValue(column.type, '');
|
|
132
|
+
var eqEmptyStringCondition = filter.eq(emptyStringValue);
|
|
133
|
+
if (isOn) {
|
|
134
|
+
return filter.isNull().or(eqEmptyStringCondition);
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
// If filter is off, return a condition that will always be true
|
|
138
|
+
return eqEmptyStringCondition.or(filter.notEq(emptyStringValue));
|
|
139
|
+
};
|
|
140
|
+
}
|
|
141
|
+
//# sourceMappingURL=FilterUtils.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FilterUtils.js","names":["createComboboxFilterArgs","value","allValue","operator","createSearchTextFilter","tableUtils","columnNames","searchText","searchTextFilter","maybeTable","searchTextTrimmed","trim","factory","createFilterConditionFactory","col","filter","containsIgnoreCase","makeFilterValue","type","createColumnCondition","conditionOperator","filterConditionFactory","maybeColumns","findColumns","length","filterConditions","map","reduce","current","next","createValueFilter","createSelectedValuesFilter","columnName","selection","emptySelectionEqAll","invertSelection","selectedValuesFilter","maybeColumn","findColumn","isAllSelected","size","makeSelectValueFilter","keys","createNotNullOrEmptyFilterCondition","notNullOrEmptyFilterCondition","column","isNull","not","and","notEq","createShowOnlyEmptyFilterCondition","isOn","showOnlyEmptyFilterCondition","emptyStringValue","eqEmptyStringCondition","eq","or"],"sources":["../src/FilterUtils.ts"],"sourcesContent":["import type {\n Column,\n FilterCondition,\n Table,\n TreeTable,\n} from '@deephaven/jsapi-types';\nimport type { SelectionT } from '@deephaven/utils';\nimport TableUtils from './TableUtils';\n\nexport interface FilterConditionFactory {\n (table: Table | TreeTable | null | undefined): FilterCondition | null;\n}\n\n/**\n * Create args for a filter derived from a combobox selection.\n * @param value\n */\nexport function createComboboxFilterArgs(\n value: string,\n allValue: string\n): {\n operator: 'eq' | 'notEq';\n value: string;\n} {\n return value === allValue\n ? { operator: 'notEq', value: '' } // this is synonymous with \"no filter\"\n : { operator: 'eq', value };\n}\n\n/**\n * Create a filter condition factory for a `contains` filter that matches the\n * given search text.\n * @param tableUtils TableUtils instance to create filter from\n * @param columnNames Names of the columns to filter\n * @param searchText Text to search (will be trimmed of leading / trailing whitespace)\n */\nexport function createSearchTextFilter(\n tableUtils: TableUtils,\n columnNames: string | string[],\n searchText: string\n): FilterConditionFactory {\n /**\n * Creates a filter condition that matches based on search text.\n * @param maybeTable Table to filter\n */\n return function searchTextFilter(\n maybeTable: Table | TreeTable | null | undefined\n ): FilterCondition | null {\n const searchTextTrimmed = searchText.trim();\n\n if (searchTextTrimmed === '') {\n return null;\n }\n\n const factory = createFilterConditionFactory(\n columnNames,\n col =>\n col\n .filter()\n .containsIgnoreCase(\n tableUtils.makeFilterValue(col.type, searchTextTrimmed)\n ),\n 'or'\n );\n\n return factory(maybeTable);\n };\n}\n\n/**\n * Create a filter condition factory function.\n * @param columnNames Column names that filter conditions will target\n * @param createColumnCondition Function that can create a `FilterCondition` from\n * a given column. This will be run across all columns corresponding to the given\n * list of column names.\n * @param conditionOperator Operator that will be used to combine multiple\n * `FilterConditions` if multiple column names are given.\n */\nexport function createFilterConditionFactory(\n columnNames: string | string[],\n createColumnCondition: (column: Column) => FilterCondition,\n conditionOperator: 'and' | 'or' = 'or'\n): FilterConditionFactory {\n return function filterConditionFactory(\n maybeTable: Table | TreeTable | null | undefined\n ): FilterCondition | null {\n const maybeColumns = maybeTable?.findColumns(\n typeof columnNames === 'string' ? [columnNames] : columnNames\n );\n\n if (maybeColumns == null || maybeColumns.length === 0) {\n return null;\n }\n\n const filterConditions = maybeColumns.map(createColumnCondition);\n\n return filterConditions.reduce((current, next) =>\n current[conditionOperator](next)\n );\n };\n}\n\n/**\n * Create a filter condition factory for a filter operator that matches the\n * given value.\n * @param tableUtils TableUtils instance to create filter from\n * @param columnNames Column names to compare value to\n * @param value Value to match\n * @param operator Operator to use for matching\n */\nexport function createValueFilter(\n tableUtils: TableUtils,\n columnNames: string | string[],\n value: string,\n operator:\n | 'contains'\n | 'containsIgnoreCase'\n | 'eq'\n | 'eqIgnoreCase'\n | 'notEq'\n | 'notEqIgnoreCase'\n): FilterConditionFactory {\n /**\n * Creates a filter condition that matches based on matching a given value.\n * @param maybeTable Table to filter\n */\n return createFilterConditionFactory(\n columnNames,\n col => col.filter()[operator](tableUtils.makeFilterValue(col.type, value)),\n 'or'\n );\n}\n\n/**\n * Create a filter condition factory for a filter that matches a given Selection.\n * If column is not found or selection parameter is 'all', the factory will return\n * null to indicate the results will be unfiltered.\n * @param tableUtils TableUtils instance to create filter from\n * @param columnName The column name to filter\n * @param selection 'all' or an array of values to filter by\n * @param emptySelectionEqAll If true, empty selection means select\n * all. If false, it means select none.\n * @param invertSelection Invert the selection (eg. All items are selected,\n * then you deselect items)\n */\nexport function createSelectedValuesFilter<TValue>(\n tableUtils: TableUtils,\n columnName: string,\n selection: SelectionT<TValue>,\n emptySelectionEqAll: boolean,\n invertSelection: boolean\n): FilterConditionFactory {\n /**\n * Creates a filter condition that matches rows for selected values. Returns\n * null to indicate no filtering.\n * @param maybeTable the table to filter\n */\n return function selectedValuesFilter(\n maybeTable: Table | TreeTable | null | undefined\n ): FilterCondition | null {\n const maybeColumn = maybeTable?.findColumn(columnName);\n\n const isAllSelected =\n selection === 'all' || (emptySelectionEqAll && selection.size === 0);\n\n if (maybeColumn == null || isAllSelected) {\n return null;\n }\n\n return tableUtils.makeSelectValueFilter(\n maybeColumn,\n [...selection.keys()],\n invertSelection\n );\n };\n}\n\n/**\n * Creates a `notNullOrEmptyFilterCondition` function.\n * @param tableUtils TableUtils instance to use for making filters.\n */\nexport function createNotNullOrEmptyFilterCondition(tableUtils: TableUtils) {\n /**\n * Returns a filter condition that matches values in a given column that are\n * not null or empty string.\n */\n return function notNullOrEmptyFilterCondition(\n column: Column\n ): FilterCondition {\n return column\n .filter()\n .isNull()\n .not()\n .and(column.filter().notEq(tableUtils.makeFilterValue(column.type, '')));\n };\n}\n\n/**\n * Creates a `showOnlyEmptyFilterCondition` function that can be toggled on or\n * off.\n * @param tableUtils TableUtils instance to use for making filters.\n * @param isOn Flag to indicate if the filter should be on or off.\n */\nexport function createShowOnlyEmptyFilterCondition(\n tableUtils: TableUtils,\n isOn: boolean\n) {\n /**\n * Returns a filter condition that matches values in a given column. If the\n * `isOn` param is true, this will filter to only null or empty string values.\n * If `isOn` is false, it will return a filter that matches all values.\n */\n return function showOnlyEmptyFilterCondition(\n column: Column\n ): FilterCondition {\n const filter = column.filter();\n const emptyStringValue = tableUtils.makeFilterValue(column.type, '');\n const eqEmptyStringCondition = filter.eq(emptyStringValue);\n\n if (isOn) {\n return filter.isNull().or(eqEmptyStringCondition);\n }\n\n // If filter is off, return a condition that will always be true\n return eqEmptyStringCondition.or(filter.notEq(emptyStringValue));\n };\n}\n"],"mappings":"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"}
|
package/dist/TableUtils.d.ts
CHANGED
|
@@ -2,6 +2,7 @@ import { TypeValue as FilterTypeValue, OperatorValue as FilterOperatorValue } fr
|
|
|
2
2
|
import type { Column, CustomColumn, dh as DhType, FilterCondition, FilterValue, LongWrapper, Sort, Table, TreeTable } from '@deephaven/jsapi-types';
|
|
3
3
|
import { CancelablePromise } from '@deephaven/utils';
|
|
4
4
|
import { ColumnName } from './Formatter';
|
|
5
|
+
import { FilterConditionFactory } from './FilterUtils';
|
|
5
6
|
type Values<T> = T[keyof T];
|
|
6
7
|
export type DataType = Values<typeof TableUtils.dataType>;
|
|
7
8
|
export type SortDirection = Values<typeof TableUtils.sortDirection>;
|
|
@@ -53,6 +54,13 @@ export declare class TableUtils {
|
|
|
53
54
|
readonly POST_SORT: "post-sort";
|
|
54
55
|
}>;
|
|
55
56
|
static NUMBER_REGEX: RegExp;
|
|
57
|
+
/**
|
|
58
|
+
* Copy a given table and apply filters.
|
|
59
|
+
* @param maybeTable Table to copy and apply filters to
|
|
60
|
+
* @param filterFactories Filter condition factories to apply
|
|
61
|
+
* @returns A derived, filtered table
|
|
62
|
+
*/
|
|
63
|
+
static copyTableAndApplyFilters<T extends Table | null | undefined, R extends T extends Table ? T : null>(maybeTable: T, ...filterFactories: FilterConditionFactory[]): Promise<R>;
|
|
56
64
|
/**
|
|
57
65
|
* Executes a callback on a given table and returns a Promise that will resolve
|
|
58
66
|
* the next time a particular event type fires on the table.
|
|
@@ -162,6 +170,25 @@ export declare class TableUtils {
|
|
|
162
170
|
static sortColumns(columns: readonly Column[], isAscending?: boolean): Column[];
|
|
163
171
|
dh: DhType;
|
|
164
172
|
constructor(dh: DhType);
|
|
173
|
+
/**
|
|
174
|
+
* Create a table containing a distinct list of values for given column name and
|
|
175
|
+
* applies the given sort direction.
|
|
176
|
+
* @param table Source table to derive table from
|
|
177
|
+
* @param columnName Column to dermine distinct values
|
|
178
|
+
* @param sortDirection Direction to sort
|
|
179
|
+
* @param filterConditionFactories Optional filters to apply. Note that these
|
|
180
|
+
* will be applied before the `selectCall` in case we need to base the filtering
|
|
181
|
+
* on columns other than the distinct value column
|
|
182
|
+
*/
|
|
183
|
+
createDistinctSortedColumnTable(table: Table | null | undefined, columnName: string, sortDirection: 'asc' | 'desc', ...filterConditionFactories: FilterConditionFactory[]): Promise<Table | null>;
|
|
184
|
+
/**
|
|
185
|
+
* Check if any columns contain a given value.
|
|
186
|
+
* @param table Table to search for values
|
|
187
|
+
* @param columnNames Column names to search
|
|
188
|
+
* @param value Value to search for
|
|
189
|
+
* @param isCaseSensitive Whether the value check is case sensitive
|
|
190
|
+
*/
|
|
191
|
+
doesColumnValueExist(table: Table | null | undefined, columnNames: string | string[], value: string, isCaseSensitive: boolean): Promise<boolean | null>;
|
|
165
192
|
/**
|
|
166
193
|
* Create filter with the provided column and text. Handles multiple filters joined with && or ||
|
|
167
194
|
* @param column The column to set the filter on
|
package/dist/TableUtils.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TableUtils.d.ts","sourceRoot":"","sources":["../src/TableUtils.ts"],"names":[],"mappings":"AAAA,OAAO,EAGL,SAAS,IAAI,eAAe,EAC5B,aAAa,IAAI,mBAAmB,EACrC,MAAM,oBAAoB,CAAC;AAE5B,OAAO,KAAK,EACV,MAAM,EACN,YAAY,EACZ,EAAE,IAAI,MAAM,EACZ,eAAe,EACf,WAAW,EACX,WAAW,EAEX,IAAI,EACJ,KAAK,EACL,SAAS,EACV,MAAM,wBAAwB,CAAC;AAChC,OAAO,
|
|
1
|
+
{"version":3,"file":"TableUtils.d.ts","sourceRoot":"","sources":["../src/TableUtils.ts"],"names":[],"mappings":"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"}
|
package/dist/TableUtils.js
CHANGED
|
@@ -5,13 +5,36 @@ function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return typ
|
|
|
5
5
|
function _toPrimitive(input, hint) { if (typeof input !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (typeof res !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
|
|
6
6
|
import { Type as FilterType, Operator as FilterOperator } from '@deephaven/filters';
|
|
7
7
|
import Log from '@deephaven/log';
|
|
8
|
-
import { PromiseUtils, TextUtils, TimeoutError } from '@deephaven/utils';
|
|
8
|
+
import { bindAllMethods, PromiseUtils, removeNullAndUndefined, TextUtils, TimeoutError } from '@deephaven/utils';
|
|
9
9
|
import DateUtils from "./DateUtils.js";
|
|
10
|
+
import { createValueFilter } from "./FilterUtils.js";
|
|
11
|
+
import { getSize } from "./ViewportDataUtils.js";
|
|
10
12
|
var log = Log.module('TableUtils');
|
|
11
13
|
/** Utility class to provide some functions for working with tables */
|
|
12
14
|
export class TableUtils {
|
|
13
15
|
// Regex looking for a negative or positive integer or decimal number
|
|
14
16
|
|
|
17
|
+
/**
|
|
18
|
+
* Copy a given table and apply filters.
|
|
19
|
+
* @param maybeTable Table to copy and apply filters to
|
|
20
|
+
* @param filterFactories Filter condition factories to apply
|
|
21
|
+
* @returns A derived, filtered table
|
|
22
|
+
*/
|
|
23
|
+
static copyTableAndApplyFilters(maybeTable) {
|
|
24
|
+
var _arguments = arguments;
|
|
25
|
+
return _asyncToGenerator(function* () {
|
|
26
|
+
if (maybeTable == null) {
|
|
27
|
+
return null;
|
|
28
|
+
}
|
|
29
|
+
var derivedTable = yield maybeTable.copy();
|
|
30
|
+
for (var _len = _arguments.length, filterFactories = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {
|
|
31
|
+
filterFactories[_key - 1] = _arguments[_key];
|
|
32
|
+
}
|
|
33
|
+
derivedTable.applyFilter(removeNullAndUndefined(...filterFactories.map(f => f(derivedTable))));
|
|
34
|
+
return derivedTable;
|
|
35
|
+
})();
|
|
36
|
+
}
|
|
37
|
+
|
|
15
38
|
/**
|
|
16
39
|
* Executes a callback on a given table and returns a Promise that will resolve
|
|
17
40
|
* the next time a particular event type fires on the table.
|
|
@@ -514,6 +537,71 @@ export class TableUtils {
|
|
|
514
537
|
constructor(dh) {
|
|
515
538
|
_defineProperty(this, "dh", void 0);
|
|
516
539
|
this.dh = dh;
|
|
540
|
+
bindAllMethods(this);
|
|
541
|
+
}
|
|
542
|
+
|
|
543
|
+
/**
|
|
544
|
+
* Create a table containing a distinct list of values for given column name and
|
|
545
|
+
* applies the given sort direction.
|
|
546
|
+
* @param table Source table to derive table from
|
|
547
|
+
* @param columnName Column to dermine distinct values
|
|
548
|
+
* @param sortDirection Direction to sort
|
|
549
|
+
* @param filterConditionFactories Optional filters to apply. Note that these
|
|
550
|
+
* will be applied before the `selectCall` in case we need to base the filtering
|
|
551
|
+
* on columns other than the distinct value column
|
|
552
|
+
*/
|
|
553
|
+
createDistinctSortedColumnTable(table, columnName, sortDirection) {
|
|
554
|
+
var _arguments2 = arguments,
|
|
555
|
+
_this = this;
|
|
556
|
+
return _asyncToGenerator(function* () {
|
|
557
|
+
if (table == null) {
|
|
558
|
+
return null;
|
|
559
|
+
}
|
|
560
|
+
var sourceTable = table;
|
|
561
|
+
|
|
562
|
+
// Applying filters before `selectDistinct` so that we still have access to
|
|
563
|
+
// all columns. Also prevents a filter applied to the final table from
|
|
564
|
+
// clearing this filter.
|
|
565
|
+
for (var _len2 = _arguments2.length, filterConditionFactories = new Array(_len2 > 3 ? _len2 - 3 : 0), _key2 = 3; _key2 < _len2; _key2++) {
|
|
566
|
+
filterConditionFactories[_key2 - 3] = _arguments2[_key2];
|
|
567
|
+
}
|
|
568
|
+
if (filterConditionFactories.length > 0) {
|
|
569
|
+
sourceTable = yield table.copy();
|
|
570
|
+
yield sourceTable.applyFilter(removeNullAndUndefined(...filterConditionFactories.map(f => f(sourceTable))));
|
|
571
|
+
}
|
|
572
|
+
var column = sourceTable.findColumn(columnName);
|
|
573
|
+
var distinctTable = yield sourceTable.selectDistinct([column]);
|
|
574
|
+
|
|
575
|
+
// If we copied the table, dispose the copy. Original is managed outside
|
|
576
|
+
// of this function
|
|
577
|
+
if (sourceTable !== table) {
|
|
578
|
+
sourceTable.close();
|
|
579
|
+
}
|
|
580
|
+
var distinctAscColSort = distinctTable.findColumn(columnName).sort()[sortDirection]();
|
|
581
|
+
return _this.applySort(distinctTable, [distinctAscColSort]);
|
|
582
|
+
})();
|
|
583
|
+
}
|
|
584
|
+
|
|
585
|
+
/**
|
|
586
|
+
* Check if any columns contain a given value.
|
|
587
|
+
* @param table Table to search for values
|
|
588
|
+
* @param columnNames Column names to search
|
|
589
|
+
* @param value Value to search for
|
|
590
|
+
* @param isCaseSensitive Whether the value check is case sensitive
|
|
591
|
+
*/
|
|
592
|
+
doesColumnValueExist(table, columnNames, value, isCaseSensitive) {
|
|
593
|
+
var _this2 = this;
|
|
594
|
+
return _asyncToGenerator(function* () {
|
|
595
|
+
if (table == null) {
|
|
596
|
+
return null;
|
|
597
|
+
}
|
|
598
|
+
var filterConditionFactory = createValueFilter(_this2, columnNames, value, isCaseSensitive ? 'eq' : 'eqIgnoreCase');
|
|
599
|
+
var tableCopy = yield table.copy();
|
|
600
|
+
yield _this2.applyFilter(tableCopy, removeNullAndUndefined(filterConditionFactory(tableCopy)));
|
|
601
|
+
var size = getSize(tableCopy);
|
|
602
|
+
tableCopy.close();
|
|
603
|
+
return size > 0;
|
|
604
|
+
})();
|
|
517
605
|
}
|
|
518
606
|
|
|
519
607
|
/**
|
|
@@ -1098,16 +1186,16 @@ export class TableUtils {
|
|
|
1098
1186
|
* dh.Table.EVENT_FILTERCHANGED event
|
|
1099
1187
|
*/
|
|
1100
1188
|
applyNeverFilter(table, columnName) {
|
|
1101
|
-
var
|
|
1102
|
-
|
|
1189
|
+
var _arguments3 = arguments,
|
|
1190
|
+
_this3 = this;
|
|
1103
1191
|
return _asyncToGenerator(function* () {
|
|
1104
|
-
var timeout =
|
|
1192
|
+
var timeout = _arguments3.length > 2 && _arguments3[2] !== undefined ? _arguments3[2] : TableUtils.APPLY_TABLE_CHANGE_TIMEOUT_MS;
|
|
1105
1193
|
if (table == null) {
|
|
1106
1194
|
return null;
|
|
1107
1195
|
}
|
|
1108
1196
|
var column = table.findColumn(columnName);
|
|
1109
|
-
var filters = [
|
|
1110
|
-
yield
|
|
1197
|
+
var filters = [_this3.makeNeverFilter(column)];
|
|
1198
|
+
yield _this3.applyFilter(table, filters, timeout);
|
|
1111
1199
|
return table;
|
|
1112
1200
|
})();
|
|
1113
1201
|
}
|
|
@@ -1121,13 +1209,13 @@ export class TableUtils {
|
|
|
1121
1209
|
* columns are applied.
|
|
1122
1210
|
*/
|
|
1123
1211
|
applyCustomColumns(table, columns) {
|
|
1124
|
-
var
|
|
1125
|
-
|
|
1212
|
+
var _arguments4 = arguments,
|
|
1213
|
+
_this4 = this;
|
|
1126
1214
|
return _asyncToGenerator(function* () {
|
|
1127
|
-
var timeout =
|
|
1215
|
+
var timeout = _arguments4.length > 2 && _arguments4[2] !== undefined ? _arguments4[2] : TableUtils.APPLY_TABLE_CHANGE_TIMEOUT_MS;
|
|
1128
1216
|
var {
|
|
1129
1217
|
dh
|
|
1130
|
-
} =
|
|
1218
|
+
} = _this4;
|
|
1131
1219
|
return TableUtils.executeAndWaitForEvent(t => t === null || t === void 0 ? void 0 : t.applyCustomColumns(columns), table, dh.Table.EVENT_CUSTOMCOLUMNSCHANGED, timeout);
|
|
1132
1220
|
})();
|
|
1133
1221
|
}
|
|
@@ -1142,13 +1230,13 @@ export class TableUtils {
|
|
|
1142
1230
|
* dh.Table.EVENT_FILTERCHANGED event
|
|
1143
1231
|
*/
|
|
1144
1232
|
applyFilter(table, filters) {
|
|
1145
|
-
var
|
|
1146
|
-
|
|
1233
|
+
var _arguments5 = arguments,
|
|
1234
|
+
_this5 = this;
|
|
1147
1235
|
return _asyncToGenerator(function* () {
|
|
1148
|
-
var timeout =
|
|
1236
|
+
var timeout = _arguments5.length > 2 && _arguments5[2] !== undefined ? _arguments5[2] : TableUtils.APPLY_TABLE_CHANGE_TIMEOUT_MS;
|
|
1149
1237
|
var {
|
|
1150
1238
|
dh
|
|
1151
|
-
} =
|
|
1239
|
+
} = _this5;
|
|
1152
1240
|
return TableUtils.executeAndWaitForEvent(t => t === null || t === void 0 ? void 0 : t.applyFilter(filters), table, dh.Table.EVENT_FILTERCHANGED, timeout);
|
|
1153
1241
|
})();
|
|
1154
1242
|
}
|
|
@@ -1163,13 +1251,13 @@ export class TableUtils {
|
|
|
1163
1251
|
* dh.Table.EVENT_SORTCHANGED event
|
|
1164
1252
|
*/
|
|
1165
1253
|
applySort(table, sorts) {
|
|
1166
|
-
var
|
|
1167
|
-
|
|
1254
|
+
var _arguments6 = arguments,
|
|
1255
|
+
_this6 = this;
|
|
1168
1256
|
return _asyncToGenerator(function* () {
|
|
1169
|
-
var timeout =
|
|
1257
|
+
var timeout = _arguments6.length > 2 && _arguments6[2] !== undefined ? _arguments6[2] : TableUtils.APPLY_TABLE_CHANGE_TIMEOUT_MS;
|
|
1170
1258
|
var {
|
|
1171
1259
|
dh
|
|
1172
|
-
} =
|
|
1260
|
+
} = _this6;
|
|
1173
1261
|
return TableUtils.executeAndWaitForEvent(t => t === null || t === void 0 ? void 0 : t.applySort(sorts), table, dh.Table.EVENT_SORTCHANGED, timeout);
|
|
1174
1262
|
})();
|
|
1175
1263
|
}
|
package/dist/TableUtils.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TableUtils.js","names":["Type","FilterType","Operator","FilterOperator","Log","PromiseUtils","TextUtils","TimeoutError","DateUtils","log","module","TableUtils","getSortIndex","sort","columnName","i","length","s","column","name","getSortForColumn","tableSort","sortIndex","getFilterText","filter","toString","getFilterTypes","columnType","isBooleanType","isTrue","isFalse","isNull","isCharType","isNumberType","isDateType","eq","notEq","greaterThan","greaterThanOrEqualTo","lessThan","lessThanOrEqualTo","isTextType","eqIgnoreCase","notEqIgnoreCase","contains","notContains","startsWith","endsWith","getNextSort","columns","sorts","columnIndex","asc","direction","sortDirection","ascending","desc","makeColumnSort","isAbs","none","descending","abs","toggleSortForColumn","addToExisting","newSort","setSortForColumn","sortColumn","modelColumn","concat","reverse","splice","push","getNormalizedType","dataType","BOOLEAN","CHAR","STRING","DATETIME","DECIMAL","INT","UNKNOWN","isLongType","isIntegerType","isDecimalType","isBigDecimalType","isBigIntegerType","isStringType","getBaseType","split","isCompatibleType","type1","type2","quoteValue","value","charAt","isRangeOperation","operation","makeRangeFilterWithOperation","makeCancelableTablePromise","table","makeCancelable","resolved","close","makeCancelableTableEventPromise","eventName","timeout","matcher","eventCleanup","timeoutId","isPending","wrappedPromise","Promise","resolve","reject","setTimeout","addEventListener","event","debug2","clearTimeout","cancel","removeCommas","replace","makeBooleanValue","text","allowEmpty","toLowerCase","Error","makeNumberValue","cleanText","trim","Number","POSITIVE_INFINITY","NEGATIVE_INFINITY","numberText","NUMBER_REGEX","test","parseFloat","getFilterOperatorString","isTreeTable","expand","undefined","collapse","sortColumns","isAscending","a","b","aName","toUpperCase","bName","constructor","dh","makeQuickFilter","timeZone","orComponents","orFilter","orComponent","andComponents","andFilter","j","andComponent","makeQuickFilterFromComponent","and","or","type","makeQuickNumberFilter","makeQuickBooleanFilter","makeQuickDateFilter","makeQuickCharFilter","makeQuickTextFilter","columnFilter","regex","result","exec","negativeSign","abnormalValue","overflow","FilterCondition","invoke","FilterValue","ofNumber","not","LongWrapper","ofString","error","warn","isNaN","escapeQuickTextFilter","quickFilterText","nullRegex","substring","unescapeQuickTextFilter","prefix","suffix","notEqual","cleanValue","boolValue","e","dateText","filterOperation","makeQuickDateFilterWithOperation","startDate","endDate","parseDateRange","startValue","endValue","startFilter","endFilter","filterValue","makeAdvancedFilter","options","filterItems","filterOperators","invertSelection","selectedValues","filterItem","selectedType","newFilter","makeAdvancedValueFilter","filterOperator","err","selectValueFilter","makeSelectValueFilter","makeFilterValue","in","inIgnoreCase","notIn","notInIgnoreCase","applyNeverFilter","APPLY_TABLE_CHANGE_TIMEOUT_MS","findColumn","filters","makeNeverFilter","applyFilter","applyCustomColumns","executeAndWaitForEvent","t","Table","EVENT_CUSTOMCOLUMNSCHANGED","EVENT_FILTERCHANGED","applySort","EVENT_SORTCHANGED","ofBoolean","DateWrapper","ofJsDate","Date","eqFilter","notEqFilter","makeFilterRawValue","rawValue","makeValue","date","values","isNullSelected","String","fromCharCode","Boolean","Object","freeze","NONE","PRE_SORT","POST_SORT","eventType","eventPromise"],"sources":["../src/TableUtils.ts"],"sourcesContent":["import {\n Type as FilterType,\n Operator as FilterOperator,\n TypeValue as FilterTypeValue,\n OperatorValue as FilterOperatorValue,\n} from '@deephaven/filters';\nimport Log from '@deephaven/log';\nimport type {\n Column,\n CustomColumn,\n dh as DhType,\n FilterCondition,\n FilterValue,\n LongWrapper,\n RemoverFn,\n Sort,\n Table,\n TreeTable,\n} from '@deephaven/jsapi-types';\nimport {\n CancelablePromise,\n PromiseUtils,\n TextUtils,\n TimeoutError,\n} from '@deephaven/utils';\nimport DateUtils from './DateUtils';\nimport { ColumnName } from './Formatter';\n\nconst log = Log.module('TableUtils');\n\ntype Values<T> = T[keyof T];\nexport type DataType = Values<typeof TableUtils.dataType>;\nexport type SortDirection = Values<typeof TableUtils.sortDirection>;\nexport type ReverseType = Values<typeof TableUtils.REVERSE_TYPE>;\nexport type AdvancedFilterItemType = {\n selectedType: FilterTypeValue;\n value: string;\n};\n\nexport interface FilterItem {\n selectedType: FilterTypeValue;\n value: string;\n}\n\nexport type AdvancedFilterOptions = {\n filterItems: FilterItem[];\n filterOperators: FilterOperatorValue[];\n invertSelection: boolean;\n selectedValues: unknown[];\n};\n\nexport type RowDataMapValue = {\n type: string;\n text: string;\n value: unknown;\n isExpandable: boolean;\n isGrouped: boolean;\n visibleIndex: number;\n};\n\nexport type RowDataMap = Record<ColumnName, RowDataMapValue>;\n\n/** Utility class to provide some functions for working with tables */\nexport class TableUtils {\n static dataType = {\n BOOLEAN: 'boolean',\n CHAR: 'char',\n DATETIME: 'datetime',\n DECIMAL: 'decimal',\n INT: 'int',\n STRING: 'string',\n UNKNOWN: 'unknown',\n } as const;\n\n static sortDirection = {\n ascending: 'ASC',\n descending: 'DESC',\n reverse: 'REVERSE',\n none: null,\n } as const;\n\n static APPLY_TABLE_CHANGE_TIMEOUT_MS = 30000;\n\n static REVERSE_TYPE = Object.freeze({\n NONE: 'none',\n PRE_SORT: 'pre-sort',\n POST_SORT: 'post-sort',\n } as const);\n\n // Regex looking for a negative or positive integer or decimal number\n static NUMBER_REGEX = /^-?\\d+(\\.\\d+)?$/;\n\n /**\n * Executes a callback on a given table and returns a Promise that will resolve\n * the next time a particular event type fires on the table.\n * @param exec Callback function to execute.\n * @param table Table that gets passed to the `exec` function and that is\n * subscribed to for a given `eventType`.\n * @param eventType The event type to listen for.\n * @param timeout If the event doesn't fire within the timeout, the returned\n * Promise will be rejected.\n * @returns a Promise to the original table that resolves on next `eventType`\n * event\n */\n static executeAndWaitForEvent = async <T extends Table | TreeTable>(\n exec: (maybeTable: T | null | undefined) => void,\n table: T | null | undefined,\n eventType: string,\n timeout = TableUtils.APPLY_TABLE_CHANGE_TIMEOUT_MS\n ): Promise<T | null> => {\n if (table == null) {\n return null;\n }\n\n const eventPromise = TableUtils.makeCancelableTableEventPromise(\n table,\n eventType,\n timeout\n );\n\n exec(table);\n\n await eventPromise;\n\n return table;\n };\n\n static getSortIndex(\n sort: readonly Sort[],\n columnName: ColumnName\n ): number | null {\n for (let i = 0; i < sort.length; i += 1) {\n const s = sort[i];\n if (s.column?.name === columnName) {\n return i;\n }\n }\n\n return null;\n }\n\n /**\n * @param tableSort The sorts from the table to get the sort from\n * @param columnName The name of the column to get the sort for\n * @returns The sort for the column, or null if it's not sorted\n */\n static getSortForColumn(\n tableSort: readonly Sort[],\n columnName: ColumnName\n ): Sort | null {\n const sortIndex = TableUtils.getSortIndex(tableSort, columnName);\n if (sortIndex != null) {\n return tableSort[sortIndex];\n }\n return null;\n }\n\n static getFilterText(filter?: FilterCondition | null): string | null {\n if (filter) {\n return filter.toString();\n }\n return null;\n }\n\n /** Return the valid filter types for the column */\n static getFilterTypes(columnType: string): FilterTypeValue[] {\n if (TableUtils.isBooleanType(columnType)) {\n return [FilterType.isTrue, FilterType.isFalse, FilterType.isNull];\n }\n if (\n TableUtils.isCharType(columnType) ||\n TableUtils.isNumberType(columnType) ||\n TableUtils.isDateType(columnType)\n ) {\n return [\n FilterType.eq,\n FilterType.notEq,\n FilterType.greaterThan,\n FilterType.greaterThanOrEqualTo,\n FilterType.lessThan,\n FilterType.lessThanOrEqualTo,\n ];\n }\n if (TableUtils.isTextType(columnType)) {\n return [\n FilterType.eq,\n FilterType.eqIgnoreCase,\n FilterType.notEq,\n FilterType.notEqIgnoreCase,\n FilterType.contains,\n FilterType.notContains,\n FilterType.startsWith,\n FilterType.endsWith,\n ];\n }\n return [];\n }\n\n static getNextSort(\n columns: readonly Column[],\n sorts: readonly Sort[],\n columnIndex: number\n ): Sort | null {\n if (columnIndex < 0 || columnIndex >= columns.length) {\n return null;\n }\n\n const sort = TableUtils.getSortForColumn(sorts, columns[columnIndex].name);\n if (sort === null) {\n return columns[columnIndex].sort().asc();\n }\n if (sort.direction === TableUtils.sortDirection.ascending) {\n return sort.desc();\n }\n return null;\n }\n\n static makeColumnSort(\n columns: readonly Column[],\n columnIndex: number,\n direction: SortDirection,\n isAbs: boolean\n ): Sort | null {\n if (columnIndex < 0 || columnIndex >= columns.length) {\n return null;\n }\n\n if (direction === TableUtils.sortDirection.none) {\n return null;\n }\n\n let sort = columns[columnIndex].sort();\n\n switch (direction) {\n case TableUtils.sortDirection.ascending:\n sort = sort.asc();\n break;\n case TableUtils.sortDirection.descending:\n sort = sort.desc();\n break;\n default:\n break;\n }\n if (isAbs) {\n sort = sort.abs();\n }\n return sort;\n }\n\n /**\n * Toggles the sort for the specified column\n * @param sorts The current sorts from IrisGrid.state\n * @param columns The columns to apply the sort to\n * @param columnIndex The column index to apply the sort to\n * @param addToExisting Add this sort to the existing sort\n */\n static toggleSortForColumn(\n sorts: readonly Sort[],\n columns: readonly Column[],\n columnIndex: number,\n addToExisting = false\n ): Sort[] {\n if (columnIndex < 0 || columnIndex >= columns.length) {\n return [];\n }\n\n const newSort = TableUtils.getNextSort(columns, sorts, columnIndex);\n\n return TableUtils.setSortForColumn(\n sorts,\n columns[columnIndex].name,\n newSort,\n addToExisting\n );\n }\n\n static sortColumn(\n sorts: readonly Sort[],\n columns: readonly Column[],\n modelColumn: number,\n direction: SortDirection,\n isAbs: boolean,\n addToExisting: boolean\n ): Sort[] {\n if (modelColumn < 0 || modelColumn >= columns.length) {\n return [];\n }\n\n const newSort = TableUtils.makeColumnSort(\n columns,\n modelColumn,\n direction,\n isAbs\n );\n\n return TableUtils.setSortForColumn(\n sorts,\n columns[modelColumn].name,\n newSort,\n addToExisting\n );\n }\n\n /**\n * Sets the sort for the given column *and* removes any reverses\n * @param tableSort The current sorts from IrisGrid.state\n * @param columnName The column name to apply the sort to\n * @param sort The sort object to add\n * @param addToExisting Add this sort to the existing sort\n * @returns Returns the modified array of sorts - removing reverses\n */\n static setSortForColumn(\n tableSort: readonly Sort[],\n columnName: ColumnName,\n sort: Sort | null,\n addToExisting = false\n ): Sort[] {\n const sortIndex = TableUtils.getSortIndex(tableSort, columnName);\n let sorts: Sort[] = [];\n if (addToExisting) {\n sorts = sorts.concat(\n tableSort.filter(\n ({ direction }) => direction !== TableUtils.sortDirection.reverse\n )\n );\n if (sortIndex !== null) {\n sorts.splice(sortIndex, 1);\n }\n }\n\n if (sort !== null) {\n sorts.push(sort);\n }\n\n return sorts;\n }\n\n static getNormalizedType(columnType?: string | null): DataType {\n switch (columnType) {\n case 'boolean':\n case 'java.lang.Boolean':\n case TableUtils.dataType.BOOLEAN:\n return TableUtils.dataType.BOOLEAN;\n case 'char':\n case 'java.lang.Character':\n case TableUtils.dataType.CHAR:\n return TableUtils.dataType.CHAR;\n case 'java.lang.String':\n case TableUtils.dataType.STRING:\n return TableUtils.dataType.STRING;\n case 'io.deephaven.db.tables.utils.DBDateTime':\n case 'io.deephaven.time.DateTime':\n case 'com.illumon.iris.db.tables.utils.DBDateTime':\n case 'java.time.Instant':\n case 'java.time.ZonedDateTime':\n case TableUtils.dataType.DATETIME:\n return TableUtils.dataType.DATETIME;\n case 'double':\n case 'java.lang.Double':\n case 'float':\n case 'java.lang.Float':\n case 'java.math.BigDecimal':\n case TableUtils.dataType.DECIMAL:\n return TableUtils.dataType.DECIMAL;\n case 'int':\n case 'java.lang.Integer':\n case 'long':\n case 'java.lang.Long':\n case 'short':\n case 'java.lang.Short':\n case 'byte':\n case 'java.lang.Byte':\n case 'java.math.BigInteger':\n case TableUtils.dataType.INT:\n return TableUtils.dataType.INT;\n default:\n return TableUtils.dataType.UNKNOWN;\n }\n }\n\n static isLongType(columnType: string): boolean {\n switch (columnType) {\n case 'long':\n case 'java.lang.Long':\n return true;\n default:\n return false;\n }\n }\n\n static isDateType(columnType: string): boolean {\n switch (columnType) {\n case 'io.deephaven.db.tables.utils.DBDateTime':\n case 'io.deephaven.time.DateTime':\n case 'java.time.Instant':\n case 'java.time.ZonedDateTime':\n case 'com.illumon.iris.db.tables.utils.DBDateTime':\n return true;\n default:\n return false;\n }\n }\n\n static isNumberType(columnType: string): boolean {\n return (\n TableUtils.isIntegerType(columnType) ||\n TableUtils.isDecimalType(columnType)\n );\n }\n\n static isIntegerType(columnType: string): boolean {\n switch (columnType) {\n case 'int':\n case 'java.lang.Integer':\n case 'java.math.BigInteger':\n case 'long':\n case 'java.lang.Long':\n case 'short':\n case 'java.lang.Short':\n case 'byte':\n case 'java.lang.Byte':\n return true;\n default:\n return false;\n }\n }\n\n static isDecimalType(columnType: string): boolean {\n switch (columnType) {\n case 'double':\n case 'java.lang.Double':\n case 'java.math.BigDecimal':\n case 'float':\n case 'java.lang.Float':\n return true;\n default:\n return false;\n }\n }\n\n static isBigDecimalType(columnType: string): boolean {\n switch (columnType) {\n case 'java.math.BigDecimal':\n return true;\n default:\n return false;\n }\n }\n\n static isBigIntegerType(columnType: string): boolean {\n switch (columnType) {\n case 'java.math.BigInteger':\n return true;\n default:\n return false;\n }\n }\n\n static isBooleanType(columnType: string): boolean {\n switch (columnType) {\n case 'boolean':\n case 'java.lang.Boolean':\n return true;\n default:\n return false;\n }\n }\n\n static isCharType(columnType: string): boolean {\n switch (columnType) {\n case 'char':\n case 'java.lang.Character':\n return true;\n default:\n return false;\n }\n }\n\n static isStringType(columnType: string): boolean {\n switch (columnType) {\n case 'java.lang.String':\n return true;\n default:\n return false;\n }\n }\n\n static isTextType(columnType: string): boolean {\n return this.isStringType(columnType) || this.isCharType(columnType);\n }\n\n /**\n * Get base column type\n * @param columnType Column type\n * @returns Element type for array columns, original type for non-array columns\n */\n static getBaseType(columnType: string): string {\n return columnType.split('[]')[0];\n }\n\n /**\n * Check if the column types are compatible\n * @param type1 Column type to check\n * @param type2 Column type to check\n * @returns True, if types are compatible\n */\n static isCompatibleType(\n type1?: string | null,\n type2?: string | null\n ): boolean {\n return (\n TableUtils.getNormalizedType(type1) ===\n TableUtils.getNormalizedType(type2)\n );\n }\n\n /**\n * Adds quotes to a value if they're not already added\n * @param value Value to add quotes around\n */\n static quoteValue(value: string): string {\n if (\n value.length >= 2 &&\n ((value.charAt(0) === '\"' && value.charAt(value.length - 1) === '\"') ||\n (value.charAt(0) === \"'\" && value.charAt(value.length - 1) === \"'\"))\n ) {\n return value;\n }\n return `\"${value}\"`;\n }\n\n static isRangeOperation(operation: string): boolean {\n switch (operation) {\n case '<':\n case '<=':\n case '=<':\n case '>':\n case '>=':\n case '=>':\n return true;\n default:\n return false;\n }\n }\n\n /**\n * @param filter The column filter to apply the range operation to\n * @param operation The range operation to run\n * @param value The value to use for the operation\n * @returns The condition with the specified operation\n */\n static makeRangeFilterWithOperation(\n filter: FilterValue,\n operation: string,\n value: FilterValue\n ): FilterCondition | null {\n switch (operation) {\n case '=':\n return filter.eq(value);\n case '<':\n return filter.lessThan(value);\n case '<=':\n case '=<':\n return filter.lessThanOrEqualTo(value);\n case '>':\n return filter.greaterThan(value);\n case '>=':\n case '=>':\n return filter.greaterThanOrEqualTo(value);\n case '!=':\n case '!':\n return filter.notEq(value);\n default:\n return null;\n }\n }\n\n /**\n * Wraps a table promise in a cancelable promise that will close the table if the promise is cancelled.\n * Use in a component that loads a table, and call cancel when unmounting.\n * @param table The table promise to wrap\n */\n static makeCancelableTablePromise(\n table: Promise<Table> | Table\n ): CancelablePromise<Table> {\n return PromiseUtils.makeCancelable(table, resolved => {\n resolved.close();\n });\n }\n\n /**\n * Make a cancelable promise for a one-shot table event with a timeout.\n * @param table Table to listen for events on\n * @param eventName Event to listen for\n * @param timeout Event timeout in milliseconds, defaults to 0\n * @param matcher Optional function to determine if the promise can be resolved or stays pending\n * @returns Resolves with the event data\n */\n static makeCancelableTableEventPromise(\n table: Table | TreeTable,\n eventName: string,\n timeout = 0,\n matcher: ((event: CustomEvent) => boolean) | null = null\n ): CancelablePromise<CustomEvent> {\n let eventCleanup: RemoverFn;\n let timeoutId: ReturnType<typeof setTimeout>;\n let isPending = true;\n const wrappedPromise = new Promise((resolve, reject) => {\n timeoutId = setTimeout(() => {\n eventCleanup();\n isPending = false;\n reject(new TimeoutError(`Event \"${eventName}\" timed out.`));\n }, timeout);\n eventCleanup = table.addEventListener(eventName, event => {\n if (matcher != null && !matcher(event)) {\n log.debug2('Event triggered, but matcher returned false.');\n return;\n }\n log.debug2('Event triggered, resolving.');\n eventCleanup();\n clearTimeout(timeoutId);\n isPending = false;\n resolve(event);\n });\n }) as CancelablePromise<CustomEvent>;\n wrappedPromise.cancel = () => {\n if (isPending) {\n log.debug2('Pending promise cleanup.');\n eventCleanup();\n clearTimeout(timeoutId);\n isPending = false;\n return;\n }\n log.debug2('Ignoring non-pending promise cancel.');\n };\n return wrappedPromise;\n }\n\n static removeCommas(value: string): string {\n return value.replace(/[\\s|,]/g, '');\n }\n\n static makeBooleanValue(text: string, allowEmpty = false): boolean | null {\n if (text === '' && allowEmpty) {\n return null;\n }\n\n switch (text?.toLowerCase()) {\n case 'null':\n return null;\n case '0':\n case 'f':\n case 'fa':\n case 'fal':\n case 'fals':\n case 'false':\n case 'n':\n case 'no':\n return false;\n case '1':\n case 't':\n case 'tr':\n case 'tru':\n case 'true':\n case 'y':\n case 'ye':\n case 'yes':\n return true;\n default:\n throw new Error(`Invalid boolean '${text}'`);\n }\n }\n\n static makeNumberValue(text: string): number | null {\n if (text === 'null' || text === '') {\n return null;\n }\n\n const cleanText = text.toLowerCase().trim();\n if (cleanText === '∞' || cleanText === 'infinity' || cleanText === 'inf') {\n return Number.POSITIVE_INFINITY;\n }\n if (\n cleanText === '-∞' ||\n cleanText === '-infinity' ||\n cleanText === '-inf'\n ) {\n return Number.NEGATIVE_INFINITY;\n }\n\n const numberText = TableUtils.removeCommas(cleanText);\n if (TableUtils.NUMBER_REGEX.test(numberText)) {\n return parseFloat(numberText);\n }\n\n throw new Error(`Invalid number '${text}'`);\n }\n\n static getFilterOperatorString(operation: FilterTypeValue): string {\n switch (operation) {\n case FilterType.eq:\n return '=';\n case FilterType.notEq:\n return '!=';\n case FilterType.greaterThan:\n return '>';\n case FilterType.greaterThanOrEqualTo:\n return '>=';\n case FilterType.lessThan:\n return '<';\n case FilterType.lessThanOrEqualTo:\n return '<=';\n case FilterType.contains:\n return '~';\n case FilterType.notContains:\n return '!~';\n default:\n throw new Error(`Unexpected filter type ${operation}`);\n }\n }\n\n static isTreeTable(table: unknown): table is TreeTable {\n return (\n table != null &&\n (table as TreeTable).expand !== undefined &&\n (table as TreeTable).collapse !== undefined\n );\n }\n\n /**\n * Copies the provided array, sorts by column name case insensitive, and returns the sorted array.\n * @param columns The columns to sort\n * @param isAscending Whether to sort ascending\n */\n static sortColumns(columns: readonly Column[], isAscending = true): Column[] {\n return [...columns].sort((a, b) => {\n const aName = a.name.toUpperCase();\n const bName = b.name.toUpperCase();\n return TextUtils.sort(aName, bName, isAscending);\n });\n }\n\n dh: DhType;\n\n constructor(dh: DhType) {\n this.dh = dh;\n }\n\n /**\n * Create filter with the provided column and text. Handles multiple filters joined with && or ||\n * @param column The column to set the filter on\n * @param text The text string to create the filter from\n * @param timeZone The time zone to make this value in if it is a date type. E.g. America/New_York\n * @returns Returns the created filter, null if text could not be parsed\n */\n makeQuickFilter(\n column: Column,\n text: string,\n timeZone?: string\n ): FilterCondition | null {\n const orComponents = text.split('||');\n let orFilter = null;\n for (let i = 0; i < orComponents.length; i += 1) {\n const orComponent = orComponents[i];\n const andComponents = orComponent.split('&&');\n let andFilter = null;\n for (let j = 0; j < andComponents.length; j += 1) {\n const andComponent = andComponents[j].trim();\n if (andComponent.length > 0) {\n const filter = this.makeQuickFilterFromComponent(\n column,\n andComponent,\n timeZone\n );\n if (filter) {\n if (andFilter) {\n andFilter = andFilter.and(filter);\n } else {\n andFilter = filter;\n }\n } else {\n throw new Error(`Unable to parse quick filter from text ${text}`);\n }\n }\n }\n\n if (orFilter && andFilter) {\n orFilter = orFilter.or(andFilter);\n } else {\n orFilter = andFilter;\n }\n }\n\n return orFilter;\n }\n\n /**\n * Create filter with the provided column and text of one component (no multiple conditions)\n * @param column The column to set the filter on\n * @param text The text string to create the filter from\n * @param timeZone The time zone to make this filter in if it is a date type. E.g. America/New_York\n * @returns Returns the created filter, null if text could not be parsed\n */\n makeQuickFilterFromComponent(\n column: Column,\n text: string,\n timeZone?: string\n ): FilterCondition | null {\n const { type } = column;\n if (TableUtils.isNumberType(type)) {\n return this.makeQuickNumberFilter(column, text);\n }\n if (TableUtils.isBooleanType(type)) {\n return this.makeQuickBooleanFilter(column, text);\n }\n if (timeZone != null && TableUtils.isDateType(type)) {\n return this.makeQuickDateFilter(column, text, timeZone);\n }\n if (TableUtils.isCharType(type)) {\n return this.makeQuickCharFilter(column, text);\n }\n return this.makeQuickTextFilter(column, text);\n }\n\n makeQuickNumberFilter(column: Column, text: string): FilterCondition | null {\n const columnFilter = column.filter();\n const { dh } = this;\n let filter = null;\n\n const regex =\n /\\s*(>=|<=|=>|=<|>|<|!=|=|!)?(\\s*-\\s*)?(\\s*\\d*(?:,\\d{3})*(?:\\.\\d*)?\\s*)?(null|nan|infinity|inf|\\u221E)?(.*)/i;\n const result = regex.exec(text);\n\n let operation = null;\n let negativeSign = null;\n let value = null;\n let abnormalValue = null; // includes nan, null and infinity(positive & negative)\n let overflow = null;\n\n if (result !== null && result.length > 3) {\n [, operation, negativeSign, value, abnormalValue, overflow] = result;\n }\n\n if (overflow != null && overflow.trim().length > 0) {\n // Some bad characters after the number, bail out!\n return null;\n }\n\n if (operation == null) {\n operation = '=';\n }\n\n if (abnormalValue != null) {\n if (!(operation === '=' || operation === '!' || operation === '!=')) {\n // only equal and not equal operations are supported for abnormal value filter\n return null;\n }\n abnormalValue = abnormalValue.trim().toLowerCase();\n switch (abnormalValue) {\n case 'null':\n filter = columnFilter.isNull();\n break;\n case 'nan':\n filter = dh.FilterCondition.invoke('isNaN', columnFilter);\n break;\n case 'infinity':\n case 'inf':\n case '\\u221E':\n if (negativeSign != null) {\n filter = dh.FilterCondition.invoke('isInf', columnFilter).and(\n columnFilter.lessThan(dh.FilterValue.ofNumber(0))\n );\n } else {\n filter = dh.FilterCondition.invoke('isInf', columnFilter).and(\n columnFilter.greaterThan(dh.FilterValue.ofNumber(0))\n );\n }\n break;\n default:\n break;\n }\n if (filter !== null && (operation === '!' || operation === '!=')) {\n filter = filter.not();\n }\n return filter;\n }\n\n if (value == null) {\n return null;\n }\n\n value = TableUtils.removeCommas(value);\n if (TableUtils.isLongType(column.type)) {\n try {\n value = dh.FilterValue.ofNumber(\n dh.LongWrapper.ofString(`${negativeSign != null ? '-' : ''}${value}`)\n );\n } catch (error) {\n log.warn('Unable to create long filter', error);\n return null;\n }\n } else {\n value = parseFloat(value);\n if (value == null || Number.isNaN(value)) {\n return null;\n }\n\n value = dh.FilterValue.ofNumber(negativeSign != null ? 0 - value : value);\n }\n\n filter = column.filter();\n\n return TableUtils.makeRangeFilterWithOperation(filter, operation, value);\n }\n\n /**\n * Given a text string from a table, escape quick filter operators in string with \\\n * ex. =test returns \\=test, null returns \\null\n * @param string quickfilter string to escape\n * @returns escaped string\n */\n static escapeQuickTextFilter(quickFilterText: string | null): string | null {\n if (quickFilterText == null) return null;\n const regex = /^(!~|!=|~|=|!)?(.*)/;\n // starts with zero or more \\ followed by and ending with null\n const nullRegex = /^\\\\*null$/;\n const result = regex.exec(quickFilterText);\n let operation: string | null = null;\n let value: string | null = null;\n if (result !== null && result.length > 2) {\n [, operation, value] = result;\n }\n\n if (operation != null) {\n return `\\\\${operation}${value ?? ''}`;\n }\n\n if (value != null && nullRegex.test(value.toLowerCase())) {\n // adds an extra escape character to matching value\n return `\\\\${value}`;\n }\n if (value != null && value.startsWith('*')) {\n return `\\\\${value}`;\n }\n if (value != null && value.endsWith('*') && !value.endsWith('\\\\*')) {\n value = value.substring(0, value.length - 1);\n return `${value}\\\\*`;\n }\n\n return `${operation ?? ''}${value ?? ``}`;\n }\n\n /**\n * Given an escaped quick filter, unescape the operators for giving it to the js api\n * ex. \\=test returns =test, \\null returns null\n * @param string quickfilter string to escape\n * @returns escaped string\n */\n static unescapeQuickTextFilter(quickFilterText: string): string {\n const regex = /^(\\\\!~|\\\\!=|\\\\~|\\\\=|\\\\!)?(.*)/;\n // starts with zero or more \\ followed by and ending with null\n const nullRegex = /^\\\\*null$/;\n const result = regex.exec(quickFilterText);\n let operation: string | null = null;\n let value: string | null = null;\n if (result !== null && result.length > 2) {\n [, operation, value] = result;\n }\n\n if (operation != null) {\n operation = operation.replace('\\\\', '');\n }\n\n if (value != null && nullRegex.test(value.toLowerCase())) {\n // removes the first occurance of the backslash\n value = value.replace('\\\\', '');\n }\n if (operation == null && value != null && value.startsWith('\\\\*')) {\n value = value.substring(1);\n }\n if (operation == null && value != null && value.endsWith('\\\\*')) {\n value = value.substring(0, value.length - 2);\n return `${value}*`;\n }\n\n return `${operation ?? ''}${value ?? ``}`;\n }\n\n makeQuickTextFilter(column: Column, text: string): FilterCondition | null {\n const { dh } = this;\n const cleanText = `${text}`.trim();\n const regex = /^(!~|!=|~|=|!)?(.*)/;\n const result = regex.exec(cleanText);\n\n let operation = null;\n let value = null;\n if (result !== null && result.length > 2) {\n [, operation, value] = result;\n if (value != null) {\n value = value.trim();\n }\n }\n\n if (value == null) {\n return null;\n }\n\n // allow empty strings, but only for explicit equal and not equal\n if (value.length === 0 && !(operation === '=' || operation === '!=')) {\n return null;\n }\n\n // no operation is treated as an implicit equals\n if (operation == null) {\n operation = '=';\n }\n\n const filter = column.filter();\n if (value.toLowerCase() === 'null') {\n // Null is a special case!\n switch (operation) {\n case '=':\n return filter.isNull();\n case '!=':\n case '!':\n return filter.isNull().not();\n default:\n // For all other operations, treat null as a string value\n }\n }\n\n let prefix = null;\n let suffix = null;\n if (value.startsWith('*')) {\n prefix = '*';\n value = value.substring(1);\n } else if (value.endsWith('*') && !value.endsWith('\\\\*')) {\n suffix = '*';\n value = value.substring(0, value.length - 1);\n }\n\n // unescape any escaped operators to allow search for literal operators\n value = TableUtils.unescapeQuickTextFilter(value);\n\n switch (operation) {\n case '~': {\n return filter\n .isNull()\n .not()\n .and(\n filter.invoke(\n 'matches',\n dh.FilterValue.ofString(`(?s)(?i).*\\\\Q${value}\\\\E.*`)\n )\n );\n }\n case '!~':\n return filter\n .isNull()\n .or(\n filter\n .invoke(\n 'matches',\n dh.FilterValue.ofString(`(?s)(?i).*\\\\Q${value}\\\\E.*`)\n )\n .not()\n );\n case '!=':\n if (prefix === '*') {\n // Does not end with\n return filter\n .isNull()\n .or(\n filter\n .invoke(\n 'matches',\n dh.FilterValue.ofString(`(?s)(?i).*\\\\Q${value}\\\\E$`)\n )\n .not()\n );\n }\n if (suffix === '*') {\n // Does not start with\n return filter\n .isNull()\n .or(\n filter\n .invoke(\n 'matches',\n dh.FilterValue.ofString(`(?s)(?i)^\\\\Q${value}\\\\E.*`)\n )\n .not()\n );\n }\n return filter.notEqIgnoreCase(\n dh.FilterValue.ofString(value.toLowerCase())\n );\n case '=':\n if (prefix === '*') {\n // Ends with\n return filter\n .isNull()\n .not()\n .and(\n filter.invoke(\n 'matches',\n dh.FilterValue.ofString(`(?s)(?i).*\\\\Q${value}\\\\E$`)\n )\n );\n }\n if (suffix === '*') {\n // Starts with\n return filter\n .isNull()\n .not()\n .and(\n filter.invoke(\n 'matches',\n dh.FilterValue.ofString(`(?s)(?i)^\\\\Q${value}\\\\E.*`)\n )\n );\n }\n return filter.eqIgnoreCase(\n dh.FilterValue.ofString(value.toLowerCase())\n );\n\n default:\n break;\n }\n\n return null;\n }\n\n // eslint-disable-next-line class-methods-use-this\n makeQuickBooleanFilter(\n column: Column,\n text: string | number\n ): FilterCondition | null {\n const regex = /^(!=|=|!)?(.*)/;\n const result = regex.exec(`${text}`.trim());\n if (result === null) {\n return null;\n }\n const [, operation, value] = result;\n const notEqual = operation === '!' || operation === '!=';\n const cleanValue = value.trim().toLowerCase();\n\n let filter: FilterCondition | FilterValue = column.filter();\n\n try {\n const boolValue = TableUtils.makeBooleanValue(cleanValue);\n if (boolValue != null && boolValue) {\n filter = filter.isTrue();\n } else if (boolValue === null) {\n filter = filter.isNull();\n } else {\n filter = filter.isFalse();\n }\n\n return notEqual ? filter.not() : filter;\n } catch (e) {\n return null;\n }\n }\n\n /**\n * Builds a date filter parsed from the text string which may or may not include an operator.\n * @param column The column to build the filter from, with or without a leading operator.\n * @param text The date string text to parse.\n * @param timeZone The time zone to make this filter in if it is a date type. E.g. America/New_York\n */\n makeQuickDateFilter(\n column: Column,\n text: string,\n timeZone: string\n ): FilterCondition {\n const cleanText = text.trim();\n const regex = /\\s*(>=|<=|=>|=<|>|<|!=|!|=)?(.*)/;\n const result = regex.exec(cleanText);\n if (result == null || result.length <= 2) {\n throw new Error(`Unable to parse date filter: ${text}`);\n }\n\n let operation = null;\n let dateText = null;\n\n [, operation, dateText] = result;\n\n let filterOperation: FilterTypeValue = FilterType.eq;\n switch (operation) {\n case '<':\n filterOperation = FilterType.lessThan;\n break;\n case '<=':\n case '=<':\n filterOperation = FilterType.lessThanOrEqualTo;\n break;\n case '>':\n filterOperation = FilterType.greaterThan;\n break;\n case '>=':\n case '=>':\n filterOperation = FilterType.greaterThanOrEqualTo;\n break;\n case '!=':\n case '!':\n filterOperation = FilterType.notEq;\n break;\n case '=':\n case '==':\n default:\n filterOperation = FilterType.eq;\n break;\n }\n\n return this.makeQuickDateFilterWithOperation(\n column,\n dateText,\n filterOperation,\n timeZone\n );\n }\n\n /**\n * Builds a date filter parsed from the text string with the provided filter.\n * @param column The column to build the filter from.\n * @param text The date string text to parse, without an operator.\n * @param operation The filter operation to use.\n * @param timeZone The time zone to make this filter with. E.g. America/New_York\n */\n makeQuickDateFilterWithOperation(\n column: Column,\n text: string,\n operation: FilterTypeValue,\n timeZone: string\n ): FilterCondition {\n const { dh } = this;\n const [startDate, endDate] = DateUtils.parseDateRange(dh, text, timeZone);\n\n const startValue =\n startDate != null ? dh.FilterValue.ofNumber(startDate) : null;\n const endValue = endDate != null ? dh.FilterValue.ofNumber(endDate) : null;\n\n const filter = column.filter();\n if (startValue == null) {\n return operation === FilterType.notEq\n ? filter.isNull().not()\n : filter.isNull();\n }\n\n switch (operation) {\n case FilterType.eq: {\n if (endValue != null) {\n const startFilter = filter.greaterThanOrEqualTo(startValue);\n const endFilter = filter.lessThan(endValue);\n return startFilter.and(endFilter);\n }\n return filter.eq(startValue);\n }\n case FilterType.lessThan: {\n return filter.lessThan(startValue);\n }\n case FilterType.lessThanOrEqualTo: {\n if (endValue != null) {\n return filter.lessThan(endValue);\n }\n return filter.lessThanOrEqualTo(startValue);\n }\n case FilterType.greaterThan: {\n if (endValue != null) {\n return filter.greaterThanOrEqualTo(endValue);\n }\n return filter.greaterThan(startValue);\n }\n case FilterType.greaterThanOrEqualTo:\n return filter.greaterThanOrEqualTo(startValue);\n case FilterType.notEq: {\n if (endValue != null) {\n const startFilter = filter.lessThan(startValue);\n const endFilter = filter.greaterThanOrEqualTo(endValue);\n return startFilter.or(endFilter);\n }\n return filter.notEq(startValue);\n }\n\n default:\n throw new Error(`Invalid operator: ${operation}`);\n }\n }\n\n makeQuickCharFilter(column: Column, text: string): FilterCondition | null {\n const { dh } = this;\n const cleanText = `${text}`.trim();\n const regex = /^(>=|<=|=>|=<|>|<|!=|=|!)?(null|\".\"|'.'|.)?(.*)/;\n const result = regex.exec(cleanText);\n\n let operation = null;\n let value = null;\n let overflow = null;\n if (result !== null && result.length > 3) {\n [, operation, value, overflow] = result;\n }\n if (overflow != null && overflow.trim().length > 0) {\n // Some bad characters after the number, bail out!\n return null;\n }\n\n if (value == null || value.length === 0) {\n return null;\n }\n\n if (operation == null) {\n operation = '=';\n }\n\n const filter = column.filter();\n if (value.toLowerCase() === 'null') {\n // Null is a special case!\n switch (operation) {\n case '=':\n return filter.isNull();\n case '!=':\n case '!':\n return filter.isNull().not();\n default:\n return null;\n }\n }\n\n // We need to put quotes around range operations or else the API fails\n const filterValue = dh.FilterValue.ofString(\n TableUtils.isRangeOperation(operation)\n ? TableUtils.quoteValue(value)\n : value\n );\n return TableUtils.makeRangeFilterWithOperation(\n filter,\n operation,\n filterValue\n );\n }\n\n makeAdvancedFilter(\n column: Column,\n options: AdvancedFilterOptions,\n timeZone: string\n ): FilterCondition | null {\n const { filterItems, filterOperators, invertSelection, selectedValues } =\n options;\n let filter = null;\n for (let i = 0; i < filterItems.length; i += 1) {\n const filterItem = filterItems[i];\n const { selectedType, value } = filterItem;\n if (\n selectedType != null &&\n selectedType.length > 0 &&\n value != null &&\n value.length > 0\n ) {\n try {\n const newFilter = this.makeAdvancedValueFilter(\n column,\n selectedType,\n value,\n timeZone\n );\n if (newFilter != null) {\n if (i === 0) {\n filter = newFilter;\n } else if (filter !== null && i - 1 < filterOperators.length) {\n const filterOperator = filterOperators[i - 1];\n if (filterOperator === FilterOperator.and) {\n filter = filter.and(newFilter);\n } else if (filterOperator === FilterOperator.or) {\n filter = filter.or(newFilter);\n } else {\n log.error(\n 'Unexpected filter operator',\n filterOperator,\n newFilter\n );\n filter = null;\n break;\n }\n }\n } else {\n log.debug2('Empty filter ignored for', selectedType, value);\n }\n } catch (err) {\n log.error('Unable to create filter', err);\n filter = null;\n break;\n }\n }\n }\n\n const selectValueFilter = this.makeSelectValueFilter(\n column,\n selectedValues,\n invertSelection\n );\n if (selectValueFilter != null) {\n if (filter != null) {\n filter = filter.and(selectValueFilter);\n } else {\n filter = selectValueFilter;\n }\n }\n\n return filter;\n }\n\n makeAdvancedValueFilter(\n column: Column,\n operation: FilterTypeValue,\n value: string,\n timeZone: string\n ): FilterCondition | null {\n const { dh } = this;\n if (TableUtils.isDateType(column.type)) {\n return this.makeQuickDateFilterWithOperation(\n column,\n value,\n operation,\n timeZone\n );\n }\n\n if (\n TableUtils.isNumberType(column.type) ||\n TableUtils.isCharType(column.type)\n ) {\n return this.makeQuickFilter(\n column,\n `${TableUtils.getFilterOperatorString(operation)}${value}`\n );\n }\n\n const filterValue = this.makeFilterValue(column.type, value);\n const filter = column.filter();\n switch (operation) {\n case FilterType.eq:\n return filter.eq(filterValue);\n case FilterType.eqIgnoreCase:\n return filter.eqIgnoreCase(filterValue);\n case FilterType.notEq:\n return filter.notEq(filterValue);\n case FilterType.notEqIgnoreCase:\n return filter.notEqIgnoreCase(filterValue);\n case FilterType.greaterThan:\n return filter.greaterThan(filterValue);\n case FilterType.greaterThanOrEqualTo:\n return filter.greaterThanOrEqualTo(filterValue);\n case FilterType.lessThan:\n return filter.lessThan(filterValue);\n case FilterType.lessThanOrEqualTo:\n return filter.lessThanOrEqualTo(filterValue);\n case FilterType.isTrue:\n return filter.isTrue();\n case FilterType.isFalse:\n return filter.isFalse();\n case FilterType.isNull:\n return filter.isNull();\n case FilterType.contains:\n return filter\n .isNull()\n .not()\n .and(\n filter.invoke(\n 'matches',\n dh.FilterValue.ofString(`(?s)(?i).*\\\\Q${value}\\\\E.*`)\n )\n );\n case FilterType.notContains:\n return filter\n .isNull()\n .or(\n filter\n .invoke(\n 'matches',\n dh.FilterValue.ofString(`(?s)(?i).*\\\\Q${value}\\\\E.*`)\n )\n .not()\n );\n case FilterType.startsWith:\n return filter\n .isNull()\n .not()\n .and(\n filter.invoke(\n 'matches',\n dh.FilterValue.ofString(`(?s)(?i)^\\\\Q${value}\\\\E.*`)\n )\n );\n case FilterType.endsWith:\n return filter\n .isNull()\n .not()\n .and(\n filter.invoke(\n 'matches',\n dh.FilterValue.ofString(`(?s)(?i).*\\\\Q${value}\\\\E$`)\n )\n );\n case FilterType.in:\n case FilterType.inIgnoreCase:\n case FilterType.notIn:\n case FilterType.notInIgnoreCase:\n case FilterType.invoke:\n default:\n throw new Error(`Unexpected filter operation: ${operation}`);\n }\n }\n\n /**\n * Apply a filter to a table that won't match anything.\n * @table The table to apply the filter to\n * @columnName The name of the column to apploy the filter to\n * @param timeout Timeout before cancelling the promise that waits for the next\n * dh.Table.EVENT_FILTERCHANGED event\n * @returns a Promise to the Table that resolves after the next\n * dh.Table.EVENT_FILTERCHANGED event\n */\n async applyNeverFilter<T extends Table | TreeTable>(\n table: T | null | undefined,\n columnName: string,\n timeout = TableUtils.APPLY_TABLE_CHANGE_TIMEOUT_MS\n ): Promise<T | null> {\n if (table == null) {\n return null;\n }\n\n const column = table.findColumn(columnName);\n const filters = [this.makeNeverFilter(column)];\n\n await this.applyFilter(table, filters, timeout);\n\n return table;\n }\n\n /**\n * Apply custom columns to a given table. Return a Promise that resolves with\n * the table once the dh.Table.EVENT_CUSTOMCOLUMNSCHANGED event has fired.\n * @param table The table to apply custom columns to.\n * @param columns The list of column expressions or definitions to apply.\n * @returns A Promise that will be resolved with the given table after the\n * columns are applied.\n */\n async applyCustomColumns(\n table: Table | null | undefined,\n columns: (string | CustomColumn)[],\n timeout = TableUtils.APPLY_TABLE_CHANGE_TIMEOUT_MS\n ): Promise<Table | null> {\n const { dh } = this;\n return TableUtils.executeAndWaitForEvent(\n t => t?.applyCustomColumns(columns),\n table,\n dh.Table.EVENT_CUSTOMCOLUMNSCHANGED,\n timeout\n );\n }\n\n /**\n * Apply filters to a given table.\n * @param table Table to apply filters to\n * @param filters Filters to apply\n * @param timeout Timeout before cancelling the promise that waits for the next\n * dh.Table.EVENT_FILTERCHANGED event\n * @returns a Promise to the Table that resolves after the next\n * dh.Table.EVENT_FILTERCHANGED event\n */\n async applyFilter<T extends Table | TreeTable>(\n table: T | null | undefined,\n filters: FilterCondition[],\n timeout = TableUtils.APPLY_TABLE_CHANGE_TIMEOUT_MS\n ): Promise<T | null> {\n const { dh } = this;\n return TableUtils.executeAndWaitForEvent(\n t => t?.applyFilter(filters),\n table,\n dh.Table.EVENT_FILTERCHANGED,\n timeout\n );\n }\n\n /**\n * Apply sorts to a given Table.\n * @param table The table to apply sorts to\n * @param sorts The sorts to apply\n * @param timeout Timeout before cancelling the promise that waits for the next\n * dh.Table.EVENT_SORTCHANGED event\n * @returns a Promise to the Table that resolves after the next\n * dh.Table.EVENT_SORTCHANGED event\n */\n async applySort<T extends Table | TreeTable>(\n table: T | null | undefined,\n sorts: Sort[],\n timeout = TableUtils.APPLY_TABLE_CHANGE_TIMEOUT_MS\n ): Promise<T | null> {\n const { dh } = this;\n return TableUtils.executeAndWaitForEvent(\n t => t?.applySort(sorts),\n table,\n dh.Table.EVENT_SORTCHANGED,\n timeout\n );\n }\n\n /**\n * Create a filter condition that results in zero results for a given column\n * @param column\n */\n makeNeverFilter(column: Column): FilterCondition {\n const { dh } = this;\n let value = null;\n\n if (TableUtils.isTextType(column.type)) {\n // Use 'a' so that it can work for String or Character types\n value = dh.FilterValue.ofString('a');\n } else if (TableUtils.isBooleanType(column.type)) {\n value = dh.FilterValue.ofBoolean(true);\n } else if (TableUtils.isDateType(column.type)) {\n value = dh.FilterValue.ofNumber(dh.DateWrapper.ofJsDate(new Date()));\n } else {\n value = dh.FilterValue.ofNumber(0);\n }\n\n const eqFilter = column.filter().eq(value);\n const notEqFilter = column.filter().notEq(value);\n\n return eqFilter.and(notEqFilter);\n }\n\n /**\n * @param columnType The column type to make the filter value from.\n * @param value The value to make the filter value from.\n * @returns The FilterValue item for this column/value combination\n */\n makeFilterValue(columnType: string, value: string): FilterValue {\n const { dh } = this;\n const type = TableUtils.getBaseType(columnType);\n if (TableUtils.isTextType(type)) {\n return dh.FilterValue.ofString(value);\n }\n if (TableUtils.isLongType(type)) {\n return dh.FilterValue.ofNumber(\n dh.LongWrapper.ofString(TableUtils.removeCommas(value))\n );\n }\n\n return dh.FilterValue.ofNumber(TableUtils.removeCommas(value));\n }\n\n /**\n * Takes a value and converts it to an `dh.FilterValue`\n *\n * @param columnType The column type to make the filter value from.\n * @param value The value to actually set\n * @returns The FilterValue item for this column/value combination\n */\n makeFilterRawValue(columnType: string, rawValue: unknown): FilterValue {\n const { dh } = this;\n if (TableUtils.isTextType(columnType)) {\n return dh.FilterValue.ofString(rawValue);\n }\n\n if (TableUtils.isBooleanType(columnType)) {\n return dh.FilterValue.ofBoolean(rawValue);\n }\n\n return dh.FilterValue.ofNumber(rawValue);\n }\n\n /**\n * Converts a string value to a value appropriate for the column\n * @param columnType The column type to make the value for\n * @param text The string value to make a type for\n * @param timeZone The time zone to make this value in if it is a date type. E.g. America/New_York\n */\n makeValue(\n columnType: string,\n text: string,\n timeZone: string\n ): string | number | boolean | LongWrapper | null {\n const { dh } = this;\n if (text === 'null') {\n return null;\n }\n if (TableUtils.isTextType(columnType)) {\n return text;\n }\n if (TableUtils.isLongType(columnType)) {\n return dh.LongWrapper.ofString(TableUtils.removeCommas(text));\n }\n if (TableUtils.isBooleanType(columnType)) {\n return TableUtils.makeBooleanValue(text, true);\n }\n if (TableUtils.isDateType(columnType)) {\n const [date] = DateUtils.parseDateRange(dh, text, timeZone);\n return date;\n }\n\n if (TableUtils.isNumberType(columnType)) {\n return TableUtils.makeNumberValue(text);\n }\n\n log.error('Unexpected column type', columnType);\n return null;\n }\n\n /**\n * Create a filter using the selected items\n * Has a flag for invertSelection as we start from a \"Select All\" state and a user just deselects items.\n * Since there may be millions of distinct items, it's easier to build an inverse filter.\n * @param column The column to set the filter on\n * @param selectedValues The values that are selected\n * @param invertSelection Invert the selection (eg. All items are selected, then you deselect items)\n * @returns Returns a `in` or `notIn` FilterCondition as necessary, or null if no filtering should be applied (everything selected)\n */\n makeSelectValueFilter<TInvert extends boolean>(\n column: Column,\n selectedValues: unknown[],\n invertSelection: TInvert\n ): TInvert extends true ? FilterCondition | null : FilterCondition {\n const { dh } = this;\n if (selectedValues.length === 0) {\n if (invertSelection) {\n // No filter means select everything\n return null as TInvert extends true\n ? FilterCondition | null\n : FilterCondition;\n }\n\n // KLUDGE: Return a conflicting filter to show no results.\n // Could recognize this situation at a higher or lower level and pause updates on the\n // table, but this situation should be rare and that wouldn't be much gains for some added complexity\n return this.makeNeverFilter(column);\n }\n\n const values = [];\n let isNullSelected = false;\n for (let i = 0; i < selectedValues.length; i += 1) {\n const value = selectedValues[i];\n if (value == null) {\n isNullSelected = true;\n } else if (TableUtils.isTextType(column.type)) {\n values.push(\n dh.FilterValue.ofString(\n typeof value === 'number' ? String.fromCharCode(value) : value\n )\n );\n } else if (TableUtils.isBooleanType(column.type)) {\n values.push(dh.FilterValue.ofBoolean(Boolean(value)));\n } else {\n values.push(dh.FilterValue.ofNumber(value));\n }\n }\n\n if (isNullSelected) {\n if (values.length > 0) {\n if (invertSelection) {\n return column\n .filter()\n .isNull()\n .not()\n .and(column.filter().notIn(values));\n }\n return column.filter().isNull().or(column.filter().in(values));\n }\n if (invertSelection) {\n return column.filter().isNull().not();\n }\n\n return column.filter().isNull();\n }\n\n if (invertSelection) {\n return column.filter().notIn(values);\n }\n\n return column.filter().in(values);\n }\n}\n\nexport default TableUtils;\n"],"mappings":";;;;;AAAA,SACEA,IAAI,IAAIC,UAAU,EAClBC,QAAQ,IAAIC,cAAc,QAGrB,oBAAoB;AAC3B,OAAOC,GAAG,MAAM,gBAAgB;AAahC,SAEEC,YAAY,EACZC,SAAS,EACTC,YAAY,QACP,kBAAkB;AAAC,OACnBC,SAAS;AAGhB,IAAMC,GAAG,GAAGL,GAAG,CAACM,MAAM,CAAC,YAAY,CAAC;AAkCpC;AACA,OAAO,MAAMC,UAAU,CAAC;EA0BtB;;EAGA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;EAwBE,OAAOC,YAAY,CACjBC,IAAqB,EACrBC,UAAsB,EACP;IACf,KAAK,IAAIC,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAGF,IAAI,CAACG,MAAM,EAAED,CAAC,IAAI,CAAC,EAAE;MAAA;MACvC,IAAME,CAAC,GAAGJ,IAAI,CAACE,CAAC,CAAC;MACjB,IAAI,cAAAE,CAAC,CAACC,MAAM,8CAAR,UAAUC,IAAI,MAAKL,UAAU,EAAE;QACjC,OAAOC,CAAC;MACV;IACF;IAEA,OAAO,IAAI;EACb;;EAEA;AACF;AACA;AACA;AACA;EACE,OAAOK,gBAAgB,CACrBC,SAA0B,EAC1BP,UAAsB,EACT;IACb,IAAMQ,SAAS,GAAGX,UAAU,CAACC,YAAY,CAACS,SAAS,EAAEP,UAAU,CAAC;IAChE,IAAIQ,SAAS,IAAI,IAAI,EAAE;MACrB,OAAOD,SAAS,CAACC,SAAS,CAAC;IAC7B;IACA,OAAO,IAAI;EACb;EAEA,OAAOC,aAAa,CAACC,MAA+B,EAAiB;IACnE,IAAIA,MAAM,EAAE;MACV,OAAOA,MAAM,CAACC,QAAQ,EAAE;IAC1B;IACA,OAAO,IAAI;EACb;;EAEA;EACA,OAAOC,cAAc,CAACC,UAAkB,EAAqB;IAC3D,IAAIhB,UAAU,CAACiB,aAAa,CAACD,UAAU,CAAC,EAAE;MACxC,OAAO,CAAC1B,UAAU,CAAC4B,MAAM,EAAE5B,UAAU,CAAC6B,OAAO,EAAE7B,UAAU,CAAC8B,MAAM,CAAC;IACnE;IACA,IACEpB,UAAU,CAACqB,UAAU,CAACL,UAAU,CAAC,IACjChB,UAAU,CAACsB,YAAY,CAACN,UAAU,CAAC,IACnChB,UAAU,CAACuB,UAAU,CAACP,UAAU,CAAC,EACjC;MACA,OAAO,CACL1B,UAAU,CAACkC,EAAE,EACblC,UAAU,CAACmC,KAAK,EAChBnC,UAAU,CAACoC,WAAW,EACtBpC,UAAU,CAACqC,oBAAoB,EAC/BrC,UAAU,CAACsC,QAAQ,EACnBtC,UAAU,CAACuC,iBAAiB,CAC7B;IACH;IACA,IAAI7B,UAAU,CAAC8B,UAAU,CAACd,UAAU,CAAC,EAAE;MACrC,OAAO,CACL1B,UAAU,CAACkC,EAAE,EACblC,UAAU,CAACyC,YAAY,EACvBzC,UAAU,CAACmC,KAAK,EAChBnC,UAAU,CAAC0C,eAAe,EAC1B1C,UAAU,CAAC2C,QAAQ,EACnB3C,UAAU,CAAC4C,WAAW,EACtB5C,UAAU,CAAC6C,UAAU,EACrB7C,UAAU,CAAC8C,QAAQ,CACpB;IACH;IACA,OAAO,EAAE;EACX;EAEA,OAAOC,WAAW,CAChBC,OAA0B,EAC1BC,KAAsB,EACtBC,WAAmB,EACN;IACb,IAAIA,WAAW,GAAG,CAAC,IAAIA,WAAW,IAAIF,OAAO,CAACjC,MAAM,EAAE;MACpD,OAAO,IAAI;IACb;IAEA,IAAMH,IAAI,GAAGF,UAAU,CAACS,gBAAgB,CAAC8B,KAAK,EAAED,OAAO,CAACE,WAAW,CAAC,CAAChC,IAAI,CAAC;IAC1E,IAAIN,IAAI,KAAK,IAAI,EAAE;MACjB,OAAOoC,OAAO,CAACE,WAAW,CAAC,CAACtC,IAAI,EAAE,CAACuC,GAAG,EAAE;IAC1C;IACA,IAAIvC,IAAI,CAACwC,SAAS,KAAK1C,UAAU,CAAC2C,aAAa,CAACC,SAAS,EAAE;MACzD,OAAO1C,IAAI,CAAC2C,IAAI,EAAE;IACpB;IACA,OAAO,IAAI;EACb;EAEA,OAAOC,cAAc,CACnBR,OAA0B,EAC1BE,WAAmB,EACnBE,SAAwB,EACxBK,KAAc,EACD;IACb,IAAIP,WAAW,GAAG,CAAC,IAAIA,WAAW,IAAIF,OAAO,CAACjC,MAAM,EAAE;MACpD,OAAO,IAAI;IACb;IAEA,IAAIqC,SAAS,KAAK1C,UAAU,CAAC2C,aAAa,CAACK,IAAI,EAAE;MAC/C,OAAO,IAAI;IACb;IAEA,IAAI9C,IAAI,GAAGoC,OAAO,CAACE,WAAW,CAAC,CAACtC,IAAI,EAAE;IAEtC,QAAQwC,SAAS;MACf,KAAK1C,UAAU,CAAC2C,aAAa,CAACC,SAAS;QACrC1C,IAAI,GAAGA,IAAI,CAACuC,GAAG,EAAE;QACjB;MACF,KAAKzC,UAAU,CAAC2C,aAAa,CAACM,UAAU;QACtC/C,IAAI,GAAGA,IAAI,CAAC2C,IAAI,EAAE;QAClB;MACF;QACE;IAAM;IAEV,IAAIE,KAAK,EAAE;MACT7C,IAAI,GAAGA,IAAI,CAACgD,GAAG,EAAE;IACnB;IACA,OAAOhD,IAAI;EACb;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;EACE,OAAOiD,mBAAmB,CACxBZ,KAAsB,EACtBD,OAA0B,EAC1BE,WAAmB,EAEX;IAAA,IADRY,aAAa,uEAAG,KAAK;IAErB,IAAIZ,WAAW,GAAG,CAAC,IAAIA,WAAW,IAAIF,OAAO,CAACjC,MAAM,EAAE;MACpD,OAAO,EAAE;IACX;IAEA,IAAMgD,OAAO,GAAGrD,UAAU,CAACqC,WAAW,CAACC,OAAO,EAAEC,KAAK,EAAEC,WAAW,CAAC;IAEnE,OAAOxC,UAAU,CAACsD,gBAAgB,CAChCf,KAAK,EACLD,OAAO,CAACE,WAAW,CAAC,CAAChC,IAAI,EACzB6C,OAAO,EACPD,aAAa,CACd;EACH;EAEA,OAAOG,UAAU,CACfhB,KAAsB,EACtBD,OAA0B,EAC1BkB,WAAmB,EACnBd,SAAwB,EACxBK,KAAc,EACdK,aAAsB,EACd;IACR,IAAII,WAAW,GAAG,CAAC,IAAIA,WAAW,IAAIlB,OAAO,CAACjC,MAAM,EAAE;MACpD,OAAO,EAAE;IACX;IAEA,IAAMgD,OAAO,GAAGrD,UAAU,CAAC8C,cAAc,CACvCR,OAAO,EACPkB,WAAW,EACXd,SAAS,EACTK,KAAK,CACN;IAED,OAAO/C,UAAU,CAACsD,gBAAgB,CAChCf,KAAK,EACLD,OAAO,CAACkB,WAAW,CAAC,CAAChD,IAAI,EACzB6C,OAAO,EACPD,aAAa,CACd;EACH;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;EACE,OAAOE,gBAAgB,CACrB5C,SAA0B,EAC1BP,UAAsB,EACtBD,IAAiB,EAET;IAAA,IADRkD,aAAa,uEAAG,KAAK;IAErB,IAAMzC,SAAS,GAAGX,UAAU,CAACC,YAAY,CAACS,SAAS,EAAEP,UAAU,CAAC;IAChE,IAAIoC,KAAa,GAAG,EAAE;IACtB,IAAIa,aAAa,EAAE;MACjBb,KAAK,GAAGA,KAAK,CAACkB,MAAM,CAClB/C,SAAS,CAACG,MAAM,CACd;QAAA,IAAC;UAAE6B;QAAU,CAAC;QAAA,OAAKA,SAAS,KAAK1C,UAAU,CAAC2C,aAAa,CAACe,OAAO;MAAA,EAClE,CACF;MACD,IAAI/C,SAAS,KAAK,IAAI,EAAE;QACtB4B,KAAK,CAACoB,MAAM,CAAChD,SAAS,EAAE,CAAC,CAAC;MAC5B;IACF;IAEA,IAAIT,IAAI,KAAK,IAAI,EAAE;MACjBqC,KAAK,CAACqB,IAAI,CAAC1D,IAAI,CAAC;IAClB;IAEA,OAAOqC,KAAK;EACd;EAEA,OAAOsB,iBAAiB,CAAC7C,UAA0B,EAAY;IAC7D,QAAQA,UAAU;MAChB,KAAK,SAAS;MACd,KAAK,mBAAmB;MACxB,KAAKhB,UAAU,CAAC8D,QAAQ,CAACC,OAAO;QAC9B,OAAO/D,UAAU,CAAC8D,QAAQ,CAACC,OAAO;MACpC,KAAK,MAAM;MACX,KAAK,qBAAqB;MAC1B,KAAK/D,UAAU,CAAC8D,QAAQ,CAACE,IAAI;QAC3B,OAAOhE,UAAU,CAAC8D,QAAQ,CAACE,IAAI;MACjC,KAAK,kBAAkB;MACvB,KAAKhE,UAAU,CAAC8D,QAAQ,CAACG,MAAM;QAC7B,OAAOjE,UAAU,CAAC8D,QAAQ,CAACG,MAAM;MACnC,KAAK,yCAAyC;MAC9C,KAAK,4BAA4B;MACjC,KAAK,6CAA6C;MAClD,KAAK,mBAAmB;MACxB,KAAK,yBAAyB;MAC9B,KAAKjE,UAAU,CAAC8D,QAAQ,CAACI,QAAQ;QAC/B,OAAOlE,UAAU,CAAC8D,QAAQ,CAACI,QAAQ;MACrC,KAAK,QAAQ;MACb,KAAK,kBAAkB;MACvB,KAAK,OAAO;MACZ,KAAK,iBAAiB;MACtB,KAAK,sBAAsB;MAC3B,KAAKlE,UAAU,CAAC8D,QAAQ,CAACK,OAAO;QAC9B,OAAOnE,UAAU,CAAC8D,QAAQ,CAACK,OAAO;MACpC,KAAK,KAAK;MACV,KAAK,mBAAmB;MACxB,KAAK,MAAM;MACX,KAAK,gBAAgB;MACrB,KAAK,OAAO;MACZ,KAAK,iBAAiB;MACtB,KAAK,MAAM;MACX,KAAK,gBAAgB;MACrB,KAAK,sBAAsB;MAC3B,KAAKnE,UAAU,CAAC8D,QAAQ,CAACM,GAAG;QAC1B,OAAOpE,UAAU,CAAC8D,QAAQ,CAACM,GAAG;MAChC;QACE,OAAOpE,UAAU,CAAC8D,QAAQ,CAACO,OAAO;IAAC;EAEzC;EAEA,OAAOC,UAAU,CAACtD,UAAkB,EAAW;IAC7C,QAAQA,UAAU;MAChB,KAAK,MAAM;MACX,KAAK,gBAAgB;QACnB,OAAO,IAAI;MACb;QACE,OAAO,KAAK;IAAC;EAEnB;EAEA,OAAOO,UAAU,CAACP,UAAkB,EAAW;IAC7C,QAAQA,UAAU;MAChB,KAAK,yCAAyC;MAC9C,KAAK,4BAA4B;MACjC,KAAK,mBAAmB;MACxB,KAAK,yBAAyB;MAC9B,KAAK,6CAA6C;QAChD,OAAO,IAAI;MACb;QACE,OAAO,KAAK;IAAC;EAEnB;EAEA,OAAOM,YAAY,CAACN,UAAkB,EAAW;IAC/C,OACEhB,UAAU,CAACuE,aAAa,CAACvD,UAAU,CAAC,IACpChB,UAAU,CAACwE,aAAa,CAACxD,UAAU,CAAC;EAExC;EAEA,OAAOuD,aAAa,CAACvD,UAAkB,EAAW;IAChD,QAAQA,UAAU;MAChB,KAAK,KAAK;MACV,KAAK,mBAAmB;MACxB,KAAK,sBAAsB;MAC3B,KAAK,MAAM;MACX,KAAK,gBAAgB;MACrB,KAAK,OAAO;MACZ,KAAK,iBAAiB;MACtB,KAAK,MAAM;MACX,KAAK,gBAAgB;QACnB,OAAO,IAAI;MACb;QACE,OAAO,KAAK;IAAC;EAEnB;EAEA,OAAOwD,aAAa,CAACxD,UAAkB,EAAW;IAChD,QAAQA,UAAU;MAChB,KAAK,QAAQ;MACb,KAAK,kBAAkB;MACvB,KAAK,sBAAsB;MAC3B,KAAK,OAAO;MACZ,KAAK,iBAAiB;QACpB,OAAO,IAAI;MACb;QACE,OAAO,KAAK;IAAC;EAEnB;EAEA,OAAOyD,gBAAgB,CAACzD,UAAkB,EAAW;IACnD,QAAQA,UAAU;MAChB,KAAK,sBAAsB;QACzB,OAAO,IAAI;MACb;QACE,OAAO,KAAK;IAAC;EAEnB;EAEA,OAAO0D,gBAAgB,CAAC1D,UAAkB,EAAW;IACnD,QAAQA,UAAU;MAChB,KAAK,sBAAsB;QACzB,OAAO,IAAI;MACb;QACE,OAAO,KAAK;IAAC;EAEnB;EAEA,OAAOC,aAAa,CAACD,UAAkB,EAAW;IAChD,QAAQA,UAAU;MAChB,KAAK,SAAS;MACd,KAAK,mBAAmB;QACtB,OAAO,IAAI;MACb;QACE,OAAO,KAAK;IAAC;EAEnB;EAEA,OAAOK,UAAU,CAACL,UAAkB,EAAW;IAC7C,QAAQA,UAAU;MAChB,KAAK,MAAM;MACX,KAAK,qBAAqB;QACxB,OAAO,IAAI;MACb;QACE,OAAO,KAAK;IAAC;EAEnB;EAEA,OAAO2D,YAAY,CAAC3D,UAAkB,EAAW;IAC/C,QAAQA,UAAU;MAChB,KAAK,kBAAkB;QACrB,OAAO,IAAI;MACb;QACE,OAAO,KAAK;IAAC;EAEnB;EAEA,OAAOc,UAAU,CAACd,UAAkB,EAAW;IAC7C,OAAO,IAAI,CAAC2D,YAAY,CAAC3D,UAAU,CAAC,IAAI,IAAI,CAACK,UAAU,CAACL,UAAU,CAAC;EACrE;;EAEA;AACF;AACA;AACA;AACA;EACE,OAAO4D,WAAW,CAAC5D,UAAkB,EAAU;IAC7C,OAAOA,UAAU,CAAC6D,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;EAClC;;EAEA;AACF;AACA;AACA;AACA;AACA;EACE,OAAOC,gBAAgB,CACrBC,KAAqB,EACrBC,KAAqB,EACZ;IACT,OACEhF,UAAU,CAAC6D,iBAAiB,CAACkB,KAAK,CAAC,KACnC/E,UAAU,CAAC6D,iBAAiB,CAACmB,KAAK,CAAC;EAEvC;;EAEA;AACF;AACA;AACA;EACE,OAAOC,UAAU,CAACC,KAAa,EAAU;IACvC,IACEA,KAAK,CAAC7E,MAAM,IAAI,CAAC,KACf6E,KAAK,CAACC,MAAM,CAAC,CAAC,CAAC,KAAK,GAAG,IAAID,KAAK,CAACC,MAAM,CAACD,KAAK,CAAC7E,MAAM,GAAG,CAAC,CAAC,KAAK,GAAG,IAChE6E,KAAK,CAACC,MAAM,CAAC,CAAC,CAAC,KAAK,GAAG,IAAID,KAAK,CAACC,MAAM,CAACD,KAAK,CAAC7E,MAAM,GAAG,CAAC,CAAC,KAAK,GAAI,CAAC,EACtE;MACA,OAAO6E,KAAK;IACd;IACA,mBAAWA,KAAK;EAClB;EAEA,OAAOE,gBAAgB,CAACC,SAAiB,EAAW;IAClD,QAAQA,SAAS;MACf,KAAK,GAAG;MACR,KAAK,IAAI;MACT,KAAK,IAAI;MACT,KAAK,GAAG;MACR,KAAK,IAAI;MACT,KAAK,IAAI;QACP,OAAO,IAAI;MACb;QACE,OAAO,KAAK;IAAC;EAEnB;;EAEA;AACF;AACA;AACA;AACA;AACA;EACE,OAAOC,4BAA4B,CACjCzE,MAAmB,EACnBwE,SAAiB,EACjBH,KAAkB,EACM;IACxB,QAAQG,SAAS;MACf,KAAK,GAAG;QACN,OAAOxE,MAAM,CAACW,EAAE,CAAC0D,KAAK,CAAC;MACzB,KAAK,GAAG;QACN,OAAOrE,MAAM,CAACe,QAAQ,CAACsD,KAAK,CAAC;MAC/B,KAAK,IAAI;MACT,KAAK,IAAI;QACP,OAAOrE,MAAM,CAACgB,iBAAiB,CAACqD,KAAK,CAAC;MACxC,KAAK,GAAG;QACN,OAAOrE,MAAM,CAACa,WAAW,CAACwD,KAAK,CAAC;MAClC,KAAK,IAAI;MACT,KAAK,IAAI;QACP,OAAOrE,MAAM,CAACc,oBAAoB,CAACuD,KAAK,CAAC;MAC3C,KAAK,IAAI;MACT,KAAK,GAAG;QACN,OAAOrE,MAAM,CAACY,KAAK,CAACyD,KAAK,CAAC;MAC5B;QACE,OAAO,IAAI;IAAC;EAElB;;EAEA;AACF;AACA;AACA;AACA;EACE,OAAOK,0BAA0B,CAC/BC,KAA6B,EACH;IAC1B,OAAO9F,YAAY,CAAC+F,cAAc,CAACD,KAAK,EAAEE,QAAQ,IAAI;MACpDA,QAAQ,CAACC,KAAK,EAAE;IAClB,CAAC,CAAC;EACJ;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;EACE,OAAOC,+BAA+B,CACpCJ,KAAwB,EACxBK,SAAiB,EAGe;IAAA,IAFhCC,OAAO,uEAAG,CAAC;IAAA,IACXC,OAAiD,uEAAG,IAAI;IAExD,IAAIC,YAAuB;IAC3B,IAAIC,SAAwC;IAC5C,IAAIC,SAAS,GAAG,IAAI;IACpB,IAAMC,cAAc,GAAG,IAAIC,OAAO,CAAC,CAACC,OAAO,EAAEC,MAAM,KAAK;MACtDL,SAAS,GAAGM,UAAU,CAAC,MAAM;QAC3BP,YAAY,EAAE;QACdE,SAAS,GAAG,KAAK;QACjBI,MAAM,CAAC,IAAI1G,YAAY,mBAAWiG,SAAS,mBAAe,CAAC;MAC7D,CAAC,EAAEC,OAAO,CAAC;MACXE,YAAY,GAAGR,KAAK,CAACgB,gBAAgB,CAACX,SAAS,EAAEY,KAAK,IAAI;QACxD,IAAIV,OAAO,IAAI,IAAI,IAAI,CAACA,OAAO,CAACU,KAAK,CAAC,EAAE;UACtC3G,GAAG,CAAC4G,MAAM,CAAC,8CAA8C,CAAC;UAC1D;QACF;QACA5G,GAAG,CAAC4G,MAAM,CAAC,6BAA6B,CAAC;QACzCV,YAAY,EAAE;QACdW,YAAY,CAACV,SAAS,CAAC;QACvBC,SAAS,GAAG,KAAK;QACjBG,OAAO,CAACI,KAAK,CAAC;MAChB,CAAC,CAAC;IACJ,CAAC,CAAmC;IACpCN,cAAc,CAACS,MAAM,GAAG,MAAM;MAC5B,IAAIV,SAAS,EAAE;QACbpG,GAAG,CAAC4G,MAAM,CAAC,0BAA0B,CAAC;QACtCV,YAAY,EAAE;QACdW,YAAY,CAACV,SAAS,CAAC;QACvBC,SAAS,GAAG,KAAK;QACjB;MACF;MACApG,GAAG,CAAC4G,MAAM,CAAC,sCAAsC,CAAC;IACpD,CAAC;IACD,OAAOP,cAAc;EACvB;EAEA,OAAOU,YAAY,CAAC3B,KAAa,EAAU;IACzC,OAAOA,KAAK,CAAC4B,OAAO,CAAC,SAAS,EAAE,EAAE,CAAC;EACrC;EAEA,OAAOC,gBAAgB,CAACC,IAAY,EAAsC;IAAA,IAApCC,UAAU,uEAAG,KAAK;IACtD,IAAID,IAAI,KAAK,EAAE,IAAIC,UAAU,EAAE;MAC7B,OAAO,IAAI;IACb;IAEA,QAAQD,IAAI,aAAJA,IAAI,uBAAJA,IAAI,CAAEE,WAAW,EAAE;MACzB,KAAK,MAAM;QACT,OAAO,IAAI;MACb,KAAK,GAAG;MACR,KAAK,GAAG;MACR,KAAK,IAAI;MACT,KAAK,KAAK;MACV,KAAK,MAAM;MACX,KAAK,OAAO;MACZ,KAAK,GAAG;MACR,KAAK,IAAI;QACP,OAAO,KAAK;MACd,KAAK,GAAG;MACR,KAAK,GAAG;MACR,KAAK,IAAI;MACT,KAAK,KAAK;MACV,KAAK,MAAM;MACX,KAAK,GAAG;MACR,KAAK,IAAI;MACT,KAAK,KAAK;QACR,OAAO,IAAI;MACb;QACE,MAAM,IAAIC,KAAK,4BAAqBH,IAAI,OAAI;IAAC;EAEnD;EAEA,OAAOI,eAAe,CAACJ,IAAY,EAAiB;IAClD,IAAIA,IAAI,KAAK,MAAM,IAAIA,IAAI,KAAK,EAAE,EAAE;MAClC,OAAO,IAAI;IACb;IAEA,IAAMK,SAAS,GAAGL,IAAI,CAACE,WAAW,EAAE,CAACI,IAAI,EAAE;IAC3C,IAAID,SAAS,KAAK,GAAG,IAAIA,SAAS,KAAK,UAAU,IAAIA,SAAS,KAAK,KAAK,EAAE;MACxE,OAAOE,MAAM,CAACC,iBAAiB;IACjC;IACA,IACEH,SAAS,KAAK,IAAI,IAClBA,SAAS,KAAK,WAAW,IACzBA,SAAS,KAAK,MAAM,EACpB;MACA,OAAOE,MAAM,CAACE,iBAAiB;IACjC;IAEA,IAAMC,UAAU,GAAG1H,UAAU,CAAC6G,YAAY,CAACQ,SAAS,CAAC;IACrD,IAAIrH,UAAU,CAAC2H,YAAY,CAACC,IAAI,CAACF,UAAU,CAAC,EAAE;MAC5C,OAAOG,UAAU,CAACH,UAAU,CAAC;IAC/B;IAEA,MAAM,IAAIP,KAAK,2BAAoBH,IAAI,OAAI;EAC7C;EAEA,OAAOc,uBAAuB,CAACzC,SAA0B,EAAU;IACjE,QAAQA,SAAS;MACf,KAAK/F,UAAU,CAACkC,EAAE;QAChB,OAAO,GAAG;MACZ,KAAKlC,UAAU,CAACmC,KAAK;QACnB,OAAO,IAAI;MACb,KAAKnC,UAAU,CAACoC,WAAW;QACzB,OAAO,GAAG;MACZ,KAAKpC,UAAU,CAACqC,oBAAoB;QAClC,OAAO,IAAI;MACb,KAAKrC,UAAU,CAACsC,QAAQ;QACtB,OAAO,GAAG;MACZ,KAAKtC,UAAU,CAACuC,iBAAiB;QAC/B,OAAO,IAAI;MACb,KAAKvC,UAAU,CAAC2C,QAAQ;QACtB,OAAO,GAAG;MACZ,KAAK3C,UAAU,CAAC4C,WAAW;QACzB,OAAO,IAAI;MACb;QACE,MAAM,IAAIiF,KAAK,kCAA2B9B,SAAS,EAAG;IAAC;EAE7D;EAEA,OAAO0C,WAAW,CAACvC,KAAc,EAAsB;IACrD,OACEA,KAAK,IAAI,IAAI,IACZA,KAAK,CAAewC,MAAM,KAAKC,SAAS,IACxCzC,KAAK,CAAe0C,QAAQ,KAAKD,SAAS;EAE/C;;EAEA;AACF;AACA;AACA;AACA;EACE,OAAOE,WAAW,CAAC7F,OAA0B,EAAgC;IAAA,IAA9B8F,WAAW,uEAAG,IAAI;IAC/D,OAAO,CAAC,GAAG9F,OAAO,CAAC,CAACpC,IAAI,CAAC,CAACmI,CAAC,EAAEC,CAAC,KAAK;MACjC,IAAMC,KAAK,GAAGF,CAAC,CAAC7H,IAAI,CAACgI,WAAW,EAAE;MAClC,IAAMC,KAAK,GAAGH,CAAC,CAAC9H,IAAI,CAACgI,WAAW,EAAE;MAClC,OAAO7I,SAAS,CAACO,IAAI,CAACqI,KAAK,EAAEE,KAAK,EAAEL,WAAW,CAAC;IAClD,CAAC,CAAC;EACJ;EAIAM,WAAW,CAACC,EAAU,EAAE;IAAA;IACtB,IAAI,CAACA,EAAE,GAAGA,EAAE;EACd;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;EACEC,eAAe,CACbrI,MAAc,EACdyG,IAAY,EACZ6B,QAAiB,EACO;IACxB,IAAMC,YAAY,GAAG9B,IAAI,CAACnC,KAAK,CAAC,IAAI,CAAC;IACrC,IAAIkE,QAAQ,GAAG,IAAI;IACnB,KAAK,IAAI3I,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAG0I,YAAY,CAACzI,MAAM,EAAED,CAAC,IAAI,CAAC,EAAE;MAC/C,IAAM4I,WAAW,GAAGF,YAAY,CAAC1I,CAAC,CAAC;MACnC,IAAM6I,aAAa,GAAGD,WAAW,CAACnE,KAAK,CAAC,IAAI,CAAC;MAC7C,IAAIqE,SAAS,GAAG,IAAI;MACpB,KAAK,IAAIC,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAGF,aAAa,CAAC5I,MAAM,EAAE8I,CAAC,IAAI,CAAC,EAAE;QAChD,IAAMC,YAAY,GAAGH,aAAa,CAACE,CAAC,CAAC,CAAC7B,IAAI,EAAE;QAC5C,IAAI8B,YAAY,CAAC/I,MAAM,GAAG,CAAC,EAAE;UAC3B,IAAMQ,MAAM,GAAG,IAAI,CAACwI,4BAA4B,CAC9C9I,MAAM,EACN6I,YAAY,EACZP,QAAQ,CACT;UACD,IAAIhI,MAAM,EAAE;YACV,IAAIqI,SAAS,EAAE;cACbA,SAAS,GAAGA,SAAS,CAACI,GAAG,CAACzI,MAAM,CAAC;YACnC,CAAC,MAAM;cACLqI,SAAS,GAAGrI,MAAM;YACpB;UACF,CAAC,MAAM;YACL,MAAM,IAAIsG,KAAK,kDAA2CH,IAAI,EAAG;UACnE;QACF;MACF;MAEA,IAAI+B,QAAQ,IAAIG,SAAS,EAAE;QACzBH,QAAQ,GAAGA,QAAQ,CAACQ,EAAE,CAACL,SAAS,CAAC;MACnC,CAAC,MAAM;QACLH,QAAQ,GAAGG,SAAS;MACtB;IACF;IAEA,OAAOH,QAAQ;EACjB;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;EACEM,4BAA4B,CAC1B9I,MAAc,EACdyG,IAAY,EACZ6B,QAAiB,EACO;IACxB,IAAM;MAAEW;IAAK,CAAC,GAAGjJ,MAAM;IACvB,IAAIP,UAAU,CAACsB,YAAY,CAACkI,IAAI,CAAC,EAAE;MACjC,OAAO,IAAI,CAACC,qBAAqB,CAAClJ,MAAM,EAAEyG,IAAI,CAAC;IACjD;IACA,IAAIhH,UAAU,CAACiB,aAAa,CAACuI,IAAI,CAAC,EAAE;MAClC,OAAO,IAAI,CAACE,sBAAsB,CAACnJ,MAAM,EAAEyG,IAAI,CAAC;IAClD;IACA,IAAI6B,QAAQ,IAAI,IAAI,IAAI7I,UAAU,CAACuB,UAAU,CAACiI,IAAI,CAAC,EAAE;MACnD,OAAO,IAAI,CAACG,mBAAmB,CAACpJ,MAAM,EAAEyG,IAAI,EAAE6B,QAAQ,CAAC;IACzD;IACA,IAAI7I,UAAU,CAACqB,UAAU,CAACmI,IAAI,CAAC,EAAE;MAC/B,OAAO,IAAI,CAACI,mBAAmB,CAACrJ,MAAM,EAAEyG,IAAI,CAAC;IAC/C;IACA,OAAO,IAAI,CAAC6C,mBAAmB,CAACtJ,MAAM,EAAEyG,IAAI,CAAC;EAC/C;EAEAyC,qBAAqB,CAAClJ,MAAc,EAAEyG,IAAY,EAA0B;IAC1E,IAAM8C,YAAY,GAAGvJ,MAAM,CAACM,MAAM,EAAE;IACpC,IAAM;MAAE8H;IAAG,CAAC,GAAG,IAAI;IACnB,IAAI9H,MAAM,GAAG,IAAI;IAEjB,IAAMkJ,KAAK,GACT,6GAA6G;IAC/G,IAAMC,MAAM,GAAGD,KAAK,CAACE,IAAI,CAACjD,IAAI,CAAC;IAE/B,IAAI3B,SAAS,GAAG,IAAI;IACpB,IAAI6E,YAAY,GAAG,IAAI;IACvB,IAAIhF,KAAK,GAAG,IAAI;IAChB,IAAIiF,aAAa,GAAG,IAAI,CAAC,CAAC;IAC1B,IAAIC,QAAQ,GAAG,IAAI;IAEnB,IAAIJ,MAAM,KAAK,IAAI,IAAIA,MAAM,CAAC3J,MAAM,GAAG,CAAC,EAAE;MACxC,GAAGgF,SAAS,EAAE6E,YAAY,EAAEhF,KAAK,EAAEiF,aAAa,EAAEC,QAAQ,CAAC,GAAGJ,MAAM;IACtE;IAEA,IAAII,QAAQ,IAAI,IAAI,IAAIA,QAAQ,CAAC9C,IAAI,EAAE,CAACjH,MAAM,GAAG,CAAC,EAAE;MAClD;MACA,OAAO,IAAI;IACb;IAEA,IAAIgF,SAAS,IAAI,IAAI,EAAE;MACrBA,SAAS,GAAG,GAAG;IACjB;IAEA,IAAI8E,aAAa,IAAI,IAAI,EAAE;MACzB,IAAI,EAAE9E,SAAS,KAAK,GAAG,IAAIA,SAAS,KAAK,GAAG,IAAIA,SAAS,KAAK,IAAI,CAAC,EAAE;QACnE;QACA,OAAO,IAAI;MACb;MACA8E,aAAa,GAAGA,aAAa,CAAC7C,IAAI,EAAE,CAACJ,WAAW,EAAE;MAClD,QAAQiD,aAAa;QACnB,KAAK,MAAM;UACTtJ,MAAM,GAAGiJ,YAAY,CAAC1I,MAAM,EAAE;UAC9B;QACF,KAAK,KAAK;UACRP,MAAM,GAAG8H,EAAE,CAAC0B,eAAe,CAACC,MAAM,CAAC,OAAO,EAAER,YAAY,CAAC;UACzD;QACF,KAAK,UAAU;QACf,KAAK,KAAK;QACV,KAAK,QAAQ;UACX,IAAII,YAAY,IAAI,IAAI,EAAE;YACxBrJ,MAAM,GAAG8H,EAAE,CAAC0B,eAAe,CAACC,MAAM,CAAC,OAAO,EAAER,YAAY,CAAC,CAACR,GAAG,CAC3DQ,YAAY,CAAClI,QAAQ,CAAC+G,EAAE,CAAC4B,WAAW,CAACC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAClD;UACH,CAAC,MAAM;YACL3J,MAAM,GAAG8H,EAAE,CAAC0B,eAAe,CAACC,MAAM,CAAC,OAAO,EAAER,YAAY,CAAC,CAACR,GAAG,CAC3DQ,YAAY,CAACpI,WAAW,CAACiH,EAAE,CAAC4B,WAAW,CAACC,QAAQ,CAAC,CAAC,CAAC,CAAC,CACrD;UACH;UACA;QACF;UACE;MAAM;MAEV,IAAI3J,MAAM,KAAK,IAAI,KAAKwE,SAAS,KAAK,GAAG,IAAIA,SAAS,KAAK,IAAI,CAAC,EAAE;QAChExE,MAAM,GAAGA,MAAM,CAAC4J,GAAG,EAAE;MACvB;MACA,OAAO5J,MAAM;IACf;IAEA,IAAIqE,KAAK,IAAI,IAAI,EAAE;MACjB,OAAO,IAAI;IACb;IAEAA,KAAK,GAAGlF,UAAU,CAAC6G,YAAY,CAAC3B,KAAK,CAAC;IACtC,IAAIlF,UAAU,CAACsE,UAAU,CAAC/D,MAAM,CAACiJ,IAAI,CAAC,EAAE;MACtC,IAAI;QACFtE,KAAK,GAAGyD,EAAE,CAAC4B,WAAW,CAACC,QAAQ,CAC7B7B,EAAE,CAAC+B,WAAW,CAACC,QAAQ,WAAIT,YAAY,IAAI,IAAI,GAAG,GAAG,GAAG,EAAE,SAAGhF,KAAK,EAAG,CACtE;MACH,CAAC,CAAC,OAAO0F,KAAK,EAAE;QACd9K,GAAG,CAAC+K,IAAI,CAAC,8BAA8B,EAAED,KAAK,CAAC;QAC/C,OAAO,IAAI;MACb;IACF,CAAC,MAAM;MACL1F,KAAK,GAAG2C,UAAU,CAAC3C,KAAK,CAAC;MACzB,IAAIA,KAAK,IAAI,IAAI,IAAIqC,MAAM,CAACuD,KAAK,CAAC5F,KAAK,CAAC,EAAE;QACxC,OAAO,IAAI;MACb;MAEAA,KAAK,GAAGyD,EAAE,CAAC4B,WAAW,CAACC,QAAQ,CAACN,YAAY,IAAI,IAAI,GAAG,CAAC,GAAGhF,KAAK,GAAGA,KAAK,CAAC;IAC3E;IAEArE,MAAM,GAAGN,MAAM,CAACM,MAAM,EAAE;IAExB,OAAOb,UAAU,CAACsF,4BAA4B,CAACzE,MAAM,EAAEwE,SAAS,EAAEH,KAAK,CAAC;EAC1E;;EAEA;AACF;AACA;AACA;AACA;AACA;EACE,OAAO6F,qBAAqB,CAACC,eAA8B,EAAiB;IAAA;IAC1E,IAAIA,eAAe,IAAI,IAAI,EAAE,OAAO,IAAI;IACxC,IAAMjB,KAAK,GAAG,qBAAqB;IACnC;IACA,IAAMkB,SAAS,GAAG,WAAW;IAC7B,IAAMjB,MAAM,GAAGD,KAAK,CAACE,IAAI,CAACe,eAAe,CAAC;IAC1C,IAAI3F,SAAwB,GAAG,IAAI;IACnC,IAAIH,KAAoB,GAAG,IAAI;IAC/B,IAAI8E,MAAM,KAAK,IAAI,IAAIA,MAAM,CAAC3J,MAAM,GAAG,CAAC,EAAE;MACxC,GAAGgF,SAAS,EAAEH,KAAK,CAAC,GAAG8E,MAAM;IAC/B;IAEA,IAAI3E,SAAS,IAAI,IAAI,EAAE;MAAA;MACrB,mBAAYA,SAAS,mBAAGH,KAAK,2CAAI,EAAE;IACrC;IAEA,IAAIA,KAAK,IAAI,IAAI,IAAI+F,SAAS,CAACrD,IAAI,CAAC1C,KAAK,CAACgC,WAAW,EAAE,CAAC,EAAE;MACxD;MACA,mBAAYhC,KAAK;IACnB;IACA,IAAIA,KAAK,IAAI,IAAI,IAAIA,KAAK,CAAC/C,UAAU,CAAC,GAAG,CAAC,EAAE;MAC1C,mBAAY+C,KAAK;IACnB;IACA,IAAIA,KAAK,IAAI,IAAI,IAAIA,KAAK,CAAC9C,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC8C,KAAK,CAAC9C,QAAQ,CAAC,KAAK,CAAC,EAAE;MAClE8C,KAAK,GAAGA,KAAK,CAACgG,SAAS,CAAC,CAAC,EAAEhG,KAAK,CAAC7E,MAAM,GAAG,CAAC,CAAC;MAC5C,iBAAU6E,KAAK;IACjB;IAEA,+BAAUG,SAAS,mDAAI,EAAE,oBAAGH,KAAK;EACnC;;EAEA;AACF;AACA;AACA;AACA;AACA;EACE,OAAOiG,uBAAuB,CAACH,eAAuB,EAAU;IAAA;IAC9D,IAAMjB,KAAK,GAAG,+BAA+B;IAC7C;IACA,IAAMkB,SAAS,GAAG,WAAW;IAC7B,IAAMjB,MAAM,GAAGD,KAAK,CAACE,IAAI,CAACe,eAAe,CAAC;IAC1C,IAAI3F,SAAwB,GAAG,IAAI;IACnC,IAAIH,KAAoB,GAAG,IAAI;IAC/B,IAAI8E,MAAM,KAAK,IAAI,IAAIA,MAAM,CAAC3J,MAAM,GAAG,CAAC,EAAE;MACxC,GAAGgF,SAAS,EAAEH,KAAK,CAAC,GAAG8E,MAAM;IAC/B;IAEA,IAAI3E,SAAS,IAAI,IAAI,EAAE;MACrBA,SAAS,GAAGA,SAAS,CAACyB,OAAO,CAAC,IAAI,EAAE,EAAE,CAAC;IACzC;IAEA,IAAI5B,KAAK,IAAI,IAAI,IAAI+F,SAAS,CAACrD,IAAI,CAAC1C,KAAK,CAACgC,WAAW,EAAE,CAAC,EAAE;MACxD;MACAhC,KAAK,GAAGA,KAAK,CAAC4B,OAAO,CAAC,IAAI,EAAE,EAAE,CAAC;IACjC;IACA,IAAIzB,SAAS,IAAI,IAAI,IAAIH,KAAK,IAAI,IAAI,IAAIA,KAAK,CAAC/C,UAAU,CAAC,KAAK,CAAC,EAAE;MACjE+C,KAAK,GAAGA,KAAK,CAACgG,SAAS,CAAC,CAAC,CAAC;IAC5B;IACA,IAAI7F,SAAS,IAAI,IAAI,IAAIH,KAAK,IAAI,IAAI,IAAIA,KAAK,CAAC9C,QAAQ,CAAC,KAAK,CAAC,EAAE;MAC/D8C,KAAK,GAAGA,KAAK,CAACgG,SAAS,CAAC,CAAC,EAAEhG,KAAK,CAAC7E,MAAM,GAAG,CAAC,CAAC;MAC5C,iBAAU6E,KAAK;IACjB;IAEA,gCAAUG,SAAS,qDAAI,EAAE,oBAAGH,KAAK;EACnC;EAEA2E,mBAAmB,CAACtJ,MAAc,EAAEyG,IAAY,EAA0B;IACxE,IAAM;MAAE2B;IAAG,CAAC,GAAG,IAAI;IACnB,IAAMtB,SAAS,GAAG,UAAGL,IAAI,EAAGM,IAAI,EAAE;IAClC,IAAMyC,KAAK,GAAG,qBAAqB;IACnC,IAAMC,MAAM,GAAGD,KAAK,CAACE,IAAI,CAAC5C,SAAS,CAAC;IAEpC,IAAIhC,SAAS,GAAG,IAAI;IACpB,IAAIH,KAAK,GAAG,IAAI;IAChB,IAAI8E,MAAM,KAAK,IAAI,IAAIA,MAAM,CAAC3J,MAAM,GAAG,CAAC,EAAE;MACxC,GAAGgF,SAAS,EAAEH,KAAK,CAAC,GAAG8E,MAAM;MAC7B,IAAI9E,KAAK,IAAI,IAAI,EAAE;QACjBA,KAAK,GAAGA,KAAK,CAACoC,IAAI,EAAE;MACtB;IACF;IAEA,IAAIpC,KAAK,IAAI,IAAI,EAAE;MACjB,OAAO,IAAI;IACb;;IAEA;IACA,IAAIA,KAAK,CAAC7E,MAAM,KAAK,CAAC,IAAI,EAAEgF,SAAS,KAAK,GAAG,IAAIA,SAAS,KAAK,IAAI,CAAC,EAAE;MACpE,OAAO,IAAI;IACb;;IAEA;IACA,IAAIA,SAAS,IAAI,IAAI,EAAE;MACrBA,SAAS,GAAG,GAAG;IACjB;IAEA,IAAMxE,MAAM,GAAGN,MAAM,CAACM,MAAM,EAAE;IAC9B,IAAIqE,KAAK,CAACgC,WAAW,EAAE,KAAK,MAAM,EAAE;MAClC;MACA,QAAQ7B,SAAS;QACf,KAAK,GAAG;UACN,OAAOxE,MAAM,CAACO,MAAM,EAAE;QACxB,KAAK,IAAI;QACT,KAAK,GAAG;UACN,OAAOP,MAAM,CAACO,MAAM,EAAE,CAACqJ,GAAG,EAAE;QAC9B;QACA;MAAA;IAEJ;;IAEA,IAAIW,MAAM,GAAG,IAAI;IACjB,IAAIC,MAAM,GAAG,IAAI;IACjB,IAAInG,KAAK,CAAC/C,UAAU,CAAC,GAAG,CAAC,EAAE;MACzBiJ,MAAM,GAAG,GAAG;MACZlG,KAAK,GAAGA,KAAK,CAACgG,SAAS,CAAC,CAAC,CAAC;IAC5B,CAAC,MAAM,IAAIhG,KAAK,CAAC9C,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC8C,KAAK,CAAC9C,QAAQ,CAAC,KAAK,CAAC,EAAE;MACxDiJ,MAAM,GAAG,GAAG;MACZnG,KAAK,GAAGA,KAAK,CAACgG,SAAS,CAAC,CAAC,EAAEhG,KAAK,CAAC7E,MAAM,GAAG,CAAC,CAAC;IAC9C;;IAEA;IACA6E,KAAK,GAAGlF,UAAU,CAACmL,uBAAuB,CAACjG,KAAK,CAAC;IAEjD,QAAQG,SAAS;MACf,KAAK,GAAG;QAAE;UACR,OAAOxE,MAAM,CACVO,MAAM,EAAE,CACRqJ,GAAG,EAAE,CACLnB,GAAG,CACFzI,MAAM,CAACyJ,MAAM,CACX,SAAS,EACT3B,EAAE,CAAC4B,WAAW,CAACI,QAAQ,wBAAiBzF,KAAK,WAAQ,CACtD,CACF;QACL;MACA,KAAK,IAAI;QACP,OAAOrE,MAAM,CACVO,MAAM,EAAE,CACRmI,EAAE,CACD1I,MAAM,CACHyJ,MAAM,CACL,SAAS,EACT3B,EAAE,CAAC4B,WAAW,CAACI,QAAQ,wBAAiBzF,KAAK,WAAQ,CACtD,CACAuF,GAAG,EAAE,CACT;MACL,KAAK,IAAI;QACP,IAAIW,MAAM,KAAK,GAAG,EAAE;UAClB;UACA,OAAOvK,MAAM,CACVO,MAAM,EAAE,CACRmI,EAAE,CACD1I,MAAM,CACHyJ,MAAM,CACL,SAAS,EACT3B,EAAE,CAAC4B,WAAW,CAACI,QAAQ,wBAAiBzF,KAAK,UAAO,CACrD,CACAuF,GAAG,EAAE,CACT;QACL;QACA,IAAIY,MAAM,KAAK,GAAG,EAAE;UAClB;UACA,OAAOxK,MAAM,CACVO,MAAM,EAAE,CACRmI,EAAE,CACD1I,MAAM,CACHyJ,MAAM,CACL,SAAS,EACT3B,EAAE,CAAC4B,WAAW,CAACI,QAAQ,uBAAgBzF,KAAK,WAAQ,CACrD,CACAuF,GAAG,EAAE,CACT;QACL;QACA,OAAO5J,MAAM,CAACmB,eAAe,CAC3B2G,EAAE,CAAC4B,WAAW,CAACI,QAAQ,CAACzF,KAAK,CAACgC,WAAW,EAAE,CAAC,CAC7C;MACH,KAAK,GAAG;QACN,IAAIkE,MAAM,KAAK,GAAG,EAAE;UAClB;UACA,OAAOvK,MAAM,CACVO,MAAM,EAAE,CACRqJ,GAAG,EAAE,CACLnB,GAAG,CACFzI,MAAM,CAACyJ,MAAM,CACX,SAAS,EACT3B,EAAE,CAAC4B,WAAW,CAACI,QAAQ,wBAAiBzF,KAAK,UAAO,CACrD,CACF;QACL;QACA,IAAImG,MAAM,KAAK,GAAG,EAAE;UAClB;UACA,OAAOxK,MAAM,CACVO,MAAM,EAAE,CACRqJ,GAAG,EAAE,CACLnB,GAAG,CACFzI,MAAM,CAACyJ,MAAM,CACX,SAAS,EACT3B,EAAE,CAAC4B,WAAW,CAACI,QAAQ,uBAAgBzF,KAAK,WAAQ,CACrD,CACF;QACL;QACA,OAAOrE,MAAM,CAACkB,YAAY,CACxB4G,EAAE,CAAC4B,WAAW,CAACI,QAAQ,CAACzF,KAAK,CAACgC,WAAW,EAAE,CAAC,CAC7C;MAEH;QACE;IAAM;IAGV,OAAO,IAAI;EACb;;EAEA;EACAwC,sBAAsB,CACpBnJ,MAAc,EACdyG,IAAqB,EACG;IACxB,IAAM+C,KAAK,GAAG,gBAAgB;IAC9B,IAAMC,MAAM,GAAGD,KAAK,CAACE,IAAI,CAAC,UAAGjD,IAAI,EAAGM,IAAI,EAAE,CAAC;IAC3C,IAAI0C,MAAM,KAAK,IAAI,EAAE;MACnB,OAAO,IAAI;IACb;IACA,IAAM,GAAG3E,SAAS,EAAEH,KAAK,CAAC,GAAG8E,MAAM;IACnC,IAAMsB,QAAQ,GAAGjG,SAAS,KAAK,GAAG,IAAIA,SAAS,KAAK,IAAI;IACxD,IAAMkG,UAAU,GAAGrG,KAAK,CAACoC,IAAI,EAAE,CAACJ,WAAW,EAAE;IAE7C,IAAIrG,MAAqC,GAAGN,MAAM,CAACM,MAAM,EAAE;IAE3D,IAAI;MACF,IAAM2K,SAAS,GAAGxL,UAAU,CAAC+G,gBAAgB,CAACwE,UAAU,CAAC;MACzD,IAAIC,SAAS,IAAI,IAAI,IAAIA,SAAS,EAAE;QAClC3K,MAAM,GAAGA,MAAM,CAACK,MAAM,EAAE;MAC1B,CAAC,MAAM,IAAIsK,SAAS,KAAK,IAAI,EAAE;QAC7B3K,MAAM,GAAGA,MAAM,CAACO,MAAM,EAAE;MAC1B,CAAC,MAAM;QACLP,MAAM,GAAGA,MAAM,CAACM,OAAO,EAAE;MAC3B;MAEA,OAAOmK,QAAQ,GAAGzK,MAAM,CAAC4J,GAAG,EAAE,GAAG5J,MAAM;IACzC,CAAC,CAAC,OAAO4K,CAAC,EAAE;MACV,OAAO,IAAI;IACb;EACF;;EAEA;AACF;AACA;AACA;AACA;AACA;EACE9B,mBAAmB,CACjBpJ,MAAc,EACdyG,IAAY,EACZ6B,QAAgB,EACC;IACjB,IAAMxB,SAAS,GAAGL,IAAI,CAACM,IAAI,EAAE;IAC7B,IAAMyC,KAAK,GAAG,kCAAkC;IAChD,IAAMC,MAAM,GAAGD,KAAK,CAACE,IAAI,CAAC5C,SAAS,CAAC;IACpC,IAAI2C,MAAM,IAAI,IAAI,IAAIA,MAAM,CAAC3J,MAAM,IAAI,CAAC,EAAE;MACxC,MAAM,IAAI8G,KAAK,wCAAiCH,IAAI,EAAG;IACzD;IAEA,IAAI3B,SAAS,GAAG,IAAI;IACpB,IAAIqG,QAAQ,GAAG,IAAI;IAEnB,GAAGrG,SAAS,EAAEqG,QAAQ,CAAC,GAAG1B,MAAM;IAEhC,IAAI2B,eAAgC,GAAGrM,UAAU,CAACkC,EAAE;IACpD,QAAQ6D,SAAS;MACf,KAAK,GAAG;QACNsG,eAAe,GAAGrM,UAAU,CAACsC,QAAQ;QACrC;MACF,KAAK,IAAI;MACT,KAAK,IAAI;QACP+J,eAAe,GAAGrM,UAAU,CAACuC,iBAAiB;QAC9C;MACF,KAAK,GAAG;QACN8J,eAAe,GAAGrM,UAAU,CAACoC,WAAW;QACxC;MACF,KAAK,IAAI;MACT,KAAK,IAAI;QACPiK,eAAe,GAAGrM,UAAU,CAACqC,oBAAoB;QACjD;MACF,KAAK,IAAI;MACT,KAAK,GAAG;QACNgK,eAAe,GAAGrM,UAAU,CAACmC,KAAK;QAClC;MACF,KAAK,GAAG;MACR,KAAK,IAAI;MACT;QACEkK,eAAe,GAAGrM,UAAU,CAACkC,EAAE;QAC/B;IAAM;IAGV,OAAO,IAAI,CAACoK,gCAAgC,CAC1CrL,MAAM,EACNmL,QAAQ,EACRC,eAAe,EACf9C,QAAQ,CACT;EACH;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;EACE+C,gCAAgC,CAC9BrL,MAAc,EACdyG,IAAY,EACZ3B,SAA0B,EAC1BwD,QAAgB,EACC;IACjB,IAAM;MAAEF;IAAG,CAAC,GAAG,IAAI;IACnB,IAAM,CAACkD,SAAS,EAAEC,OAAO,CAAC,GAAGjM,SAAS,CAACkM,cAAc,CAACpD,EAAE,EAAE3B,IAAI,EAAE6B,QAAQ,CAAC;IAEzE,IAAMmD,UAAU,GACdH,SAAS,IAAI,IAAI,GAAGlD,EAAE,CAAC4B,WAAW,CAACC,QAAQ,CAACqB,SAAS,CAAC,GAAG,IAAI;IAC/D,IAAMI,QAAQ,GAAGH,OAAO,IAAI,IAAI,GAAGnD,EAAE,CAAC4B,WAAW,CAACC,QAAQ,CAACsB,OAAO,CAAC,GAAG,IAAI;IAE1E,IAAMjL,MAAM,GAAGN,MAAM,CAACM,MAAM,EAAE;IAC9B,IAAImL,UAAU,IAAI,IAAI,EAAE;MACtB,OAAO3G,SAAS,KAAK/F,UAAU,CAACmC,KAAK,GACjCZ,MAAM,CAACO,MAAM,EAAE,CAACqJ,GAAG,EAAE,GACrB5J,MAAM,CAACO,MAAM,EAAE;IACrB;IAEA,QAAQiE,SAAS;MACf,KAAK/F,UAAU,CAACkC,EAAE;QAAE;UAClB,IAAIyK,QAAQ,IAAI,IAAI,EAAE;YACpB,IAAMC,WAAW,GAAGrL,MAAM,CAACc,oBAAoB,CAACqK,UAAU,CAAC;YAC3D,IAAMG,SAAS,GAAGtL,MAAM,CAACe,QAAQ,CAACqK,QAAQ,CAAC;YAC3C,OAAOC,WAAW,CAAC5C,GAAG,CAAC6C,SAAS,CAAC;UACnC;UACA,OAAOtL,MAAM,CAACW,EAAE,CAACwK,UAAU,CAAC;QAC9B;MACA,KAAK1M,UAAU,CAACsC,QAAQ;QAAE;UACxB,OAAOf,MAAM,CAACe,QAAQ,CAACoK,UAAU,CAAC;QACpC;MACA,KAAK1M,UAAU,CAACuC,iBAAiB;QAAE;UACjC,IAAIoK,QAAQ,IAAI,IAAI,EAAE;YACpB,OAAOpL,MAAM,CAACe,QAAQ,CAACqK,QAAQ,CAAC;UAClC;UACA,OAAOpL,MAAM,CAACgB,iBAAiB,CAACmK,UAAU,CAAC;QAC7C;MACA,KAAK1M,UAAU,CAACoC,WAAW;QAAE;UAC3B,IAAIuK,QAAQ,IAAI,IAAI,EAAE;YACpB,OAAOpL,MAAM,CAACc,oBAAoB,CAACsK,QAAQ,CAAC;UAC9C;UACA,OAAOpL,MAAM,CAACa,WAAW,CAACsK,UAAU,CAAC;QACvC;MACA,KAAK1M,UAAU,CAACqC,oBAAoB;QAClC,OAAOd,MAAM,CAACc,oBAAoB,CAACqK,UAAU,CAAC;MAChD,KAAK1M,UAAU,CAACmC,KAAK;QAAE;UACrB,IAAIwK,QAAQ,IAAI,IAAI,EAAE;YACpB,IAAMC,YAAW,GAAGrL,MAAM,CAACe,QAAQ,CAACoK,UAAU,CAAC;YAC/C,IAAMG,UAAS,GAAGtL,MAAM,CAACc,oBAAoB,CAACsK,QAAQ,CAAC;YACvD,OAAOC,YAAW,CAAC3C,EAAE,CAAC4C,UAAS,CAAC;UAClC;UACA,OAAOtL,MAAM,CAACY,KAAK,CAACuK,UAAU,CAAC;QACjC;MAEA;QACE,MAAM,IAAI7E,KAAK,6BAAsB9B,SAAS,EAAG;IAAC;EAExD;EAEAuE,mBAAmB,CAACrJ,MAAc,EAAEyG,IAAY,EAA0B;IACxE,IAAM;MAAE2B;IAAG,CAAC,GAAG,IAAI;IACnB,IAAMtB,SAAS,GAAG,UAAGL,IAAI,EAAGM,IAAI,EAAE;IAClC,IAAMyC,KAAK,GAAG,iDAAiD;IAC/D,IAAMC,MAAM,GAAGD,KAAK,CAACE,IAAI,CAAC5C,SAAS,CAAC;IAEpC,IAAIhC,SAAS,GAAG,IAAI;IACpB,IAAIH,KAAK,GAAG,IAAI;IAChB,IAAIkF,QAAQ,GAAG,IAAI;IACnB,IAAIJ,MAAM,KAAK,IAAI,IAAIA,MAAM,CAAC3J,MAAM,GAAG,CAAC,EAAE;MACxC,GAAGgF,SAAS,EAAEH,KAAK,EAAEkF,QAAQ,CAAC,GAAGJ,MAAM;IACzC;IACA,IAAII,QAAQ,IAAI,IAAI,IAAIA,QAAQ,CAAC9C,IAAI,EAAE,CAACjH,MAAM,GAAG,CAAC,EAAE;MAClD;MACA,OAAO,IAAI;IACb;IAEA,IAAI6E,KAAK,IAAI,IAAI,IAAIA,KAAK,CAAC7E,MAAM,KAAK,CAAC,EAAE;MACvC,OAAO,IAAI;IACb;IAEA,IAAIgF,SAAS,IAAI,IAAI,EAAE;MACrBA,SAAS,GAAG,GAAG;IACjB;IAEA,IAAMxE,MAAM,GAAGN,MAAM,CAACM,MAAM,EAAE;IAC9B,IAAIqE,KAAK,CAACgC,WAAW,EAAE,KAAK,MAAM,EAAE;MAClC;MACA,QAAQ7B,SAAS;QACf,KAAK,GAAG;UACN,OAAOxE,MAAM,CAACO,MAAM,EAAE;QACxB,KAAK,IAAI;QACT,KAAK,GAAG;UACN,OAAOP,MAAM,CAACO,MAAM,EAAE,CAACqJ,GAAG,EAAE;QAC9B;UACE,OAAO,IAAI;MAAC;IAElB;;IAEA;IACA,IAAM2B,WAAW,GAAGzD,EAAE,CAAC4B,WAAW,CAACI,QAAQ,CACzC3K,UAAU,CAACoF,gBAAgB,CAACC,SAAS,CAAC,GAClCrF,UAAU,CAACiF,UAAU,CAACC,KAAK,CAAC,GAC5BA,KAAK,CACV;IACD,OAAOlF,UAAU,CAACsF,4BAA4B,CAC5CzE,MAAM,EACNwE,SAAS,EACT+G,WAAW,CACZ;EACH;EAEAC,kBAAkB,CAChB9L,MAAc,EACd+L,OAA8B,EAC9BzD,QAAgB,EACQ;IACxB,IAAM;MAAE0D,WAAW;MAAEC,eAAe;MAAEC,eAAe;MAAEC;IAAe,CAAC,GACrEJ,OAAO;IACT,IAAIzL,MAAM,GAAG,IAAI;IACjB,KAAK,IAAIT,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAGmM,WAAW,CAAClM,MAAM,EAAED,CAAC,IAAI,CAAC,EAAE;MAC9C,IAAMuM,UAAU,GAAGJ,WAAW,CAACnM,CAAC,CAAC;MACjC,IAAM;QAAEwM,YAAY;QAAE1H;MAAM,CAAC,GAAGyH,UAAU;MAC1C,IACEC,YAAY,IAAI,IAAI,IACpBA,YAAY,CAACvM,MAAM,GAAG,CAAC,IACvB6E,KAAK,IAAI,IAAI,IACbA,KAAK,CAAC7E,MAAM,GAAG,CAAC,EAChB;QACA,IAAI;UACF,IAAMwM,SAAS,GAAG,IAAI,CAACC,uBAAuB,CAC5CvM,MAAM,EACNqM,YAAY,EACZ1H,KAAK,EACL2D,QAAQ,CACT;UACD,IAAIgE,SAAS,IAAI,IAAI,EAAE;YACrB,IAAIzM,CAAC,KAAK,CAAC,EAAE;cACXS,MAAM,GAAGgM,SAAS;YACpB,CAAC,MAAM,IAAIhM,MAAM,KAAK,IAAI,IAAIT,CAAC,GAAG,CAAC,GAAGoM,eAAe,CAACnM,MAAM,EAAE;cAC5D,IAAM0M,cAAc,GAAGP,eAAe,CAACpM,CAAC,GAAG,CAAC,CAAC;cAC7C,IAAI2M,cAAc,KAAKvN,cAAc,CAAC8J,GAAG,EAAE;gBACzCzI,MAAM,GAAGA,MAAM,CAACyI,GAAG,CAACuD,SAAS,CAAC;cAChC,CAAC,MAAM,IAAIE,cAAc,KAAKvN,cAAc,CAAC+J,EAAE,EAAE;gBAC/C1I,MAAM,GAAGA,MAAM,CAAC0I,EAAE,CAACsD,SAAS,CAAC;cAC/B,CAAC,MAAM;gBACL/M,GAAG,CAAC8K,KAAK,CACP,4BAA4B,EAC5BmC,cAAc,EACdF,SAAS,CACV;gBACDhM,MAAM,GAAG,IAAI;gBACb;cACF;YACF;UACF,CAAC,MAAM;YACLf,GAAG,CAAC4G,MAAM,CAAC,0BAA0B,EAAEkG,YAAY,EAAE1H,KAAK,CAAC;UAC7D;QACF,CAAC,CAAC,OAAO8H,GAAG,EAAE;UACZlN,GAAG,CAAC8K,KAAK,CAAC,yBAAyB,EAAEoC,GAAG,CAAC;UACzCnM,MAAM,GAAG,IAAI;UACb;QACF;MACF;IACF;IAEA,IAAMoM,iBAAiB,GAAG,IAAI,CAACC,qBAAqB,CAClD3M,MAAM,EACNmM,cAAc,EACdD,eAAe,CAChB;IACD,IAAIQ,iBAAiB,IAAI,IAAI,EAAE;MAC7B,IAAIpM,MAAM,IAAI,IAAI,EAAE;QAClBA,MAAM,GAAGA,MAAM,CAACyI,GAAG,CAAC2D,iBAAiB,CAAC;MACxC,CAAC,MAAM;QACLpM,MAAM,GAAGoM,iBAAiB;MAC5B;IACF;IAEA,OAAOpM,MAAM;EACf;EAEAiM,uBAAuB,CACrBvM,MAAc,EACd8E,SAA0B,EAC1BH,KAAa,EACb2D,QAAgB,EACQ;IACxB,IAAM;MAAEF;IAAG,CAAC,GAAG,IAAI;IACnB,IAAI3I,UAAU,CAACuB,UAAU,CAAChB,MAAM,CAACiJ,IAAI,CAAC,EAAE;MACtC,OAAO,IAAI,CAACoC,gCAAgC,CAC1CrL,MAAM,EACN2E,KAAK,EACLG,SAAS,EACTwD,QAAQ,CACT;IACH;IAEA,IACE7I,UAAU,CAACsB,YAAY,CAACf,MAAM,CAACiJ,IAAI,CAAC,IACpCxJ,UAAU,CAACqB,UAAU,CAACd,MAAM,CAACiJ,IAAI,CAAC,EAClC;MACA,OAAO,IAAI,CAACZ,eAAe,CACzBrI,MAAM,YACHP,UAAU,CAAC8H,uBAAuB,CAACzC,SAAS,CAAC,SAAGH,KAAK,EACzD;IACH;IAEA,IAAMkH,WAAW,GAAG,IAAI,CAACe,eAAe,CAAC5M,MAAM,CAACiJ,IAAI,EAAEtE,KAAK,CAAC;IAC5D,IAAMrE,MAAM,GAAGN,MAAM,CAACM,MAAM,EAAE;IAC9B,QAAQwE,SAAS;MACf,KAAK/F,UAAU,CAACkC,EAAE;QAChB,OAAOX,MAAM,CAACW,EAAE,CAAC4K,WAAW,CAAC;MAC/B,KAAK9M,UAAU,CAACyC,YAAY;QAC1B,OAAOlB,MAAM,CAACkB,YAAY,CAACqK,WAAW,CAAC;MACzC,KAAK9M,UAAU,CAACmC,KAAK;QACnB,OAAOZ,MAAM,CAACY,KAAK,CAAC2K,WAAW,CAAC;MAClC,KAAK9M,UAAU,CAAC0C,eAAe;QAC7B,OAAOnB,MAAM,CAACmB,eAAe,CAACoK,WAAW,CAAC;MAC5C,KAAK9M,UAAU,CAACoC,WAAW;QACzB,OAAOb,MAAM,CAACa,WAAW,CAAC0K,WAAW,CAAC;MACxC,KAAK9M,UAAU,CAACqC,oBAAoB;QAClC,OAAOd,MAAM,CAACc,oBAAoB,CAACyK,WAAW,CAAC;MACjD,KAAK9M,UAAU,CAACsC,QAAQ;QACtB,OAAOf,MAAM,CAACe,QAAQ,CAACwK,WAAW,CAAC;MACrC,KAAK9M,UAAU,CAACuC,iBAAiB;QAC/B,OAAOhB,MAAM,CAACgB,iBAAiB,CAACuK,WAAW,CAAC;MAC9C,KAAK9M,UAAU,CAAC4B,MAAM;QACpB,OAAOL,MAAM,CAACK,MAAM,EAAE;MACxB,KAAK5B,UAAU,CAAC6B,OAAO;QACrB,OAAON,MAAM,CAACM,OAAO,EAAE;MACzB,KAAK7B,UAAU,CAAC8B,MAAM;QACpB,OAAOP,MAAM,CAACO,MAAM,EAAE;MACxB,KAAK9B,UAAU,CAAC2C,QAAQ;QACtB,OAAOpB,MAAM,CACVO,MAAM,EAAE,CACRqJ,GAAG,EAAE,CACLnB,GAAG,CACFzI,MAAM,CAACyJ,MAAM,CACX,SAAS,EACT3B,EAAE,CAAC4B,WAAW,CAACI,QAAQ,wBAAiBzF,KAAK,WAAQ,CACtD,CACF;MACL,KAAK5F,UAAU,CAAC4C,WAAW;QACzB,OAAOrB,MAAM,CACVO,MAAM,EAAE,CACRmI,EAAE,CACD1I,MAAM,CACHyJ,MAAM,CACL,SAAS,EACT3B,EAAE,CAAC4B,WAAW,CAACI,QAAQ,wBAAiBzF,KAAK,WAAQ,CACtD,CACAuF,GAAG,EAAE,CACT;MACL,KAAKnL,UAAU,CAAC6C,UAAU;QACxB,OAAOtB,MAAM,CACVO,MAAM,EAAE,CACRqJ,GAAG,EAAE,CACLnB,GAAG,CACFzI,MAAM,CAACyJ,MAAM,CACX,SAAS,EACT3B,EAAE,CAAC4B,WAAW,CAACI,QAAQ,uBAAgBzF,KAAK,WAAQ,CACrD,CACF;MACL,KAAK5F,UAAU,CAAC8C,QAAQ;QACtB,OAAOvB,MAAM,CACVO,MAAM,EAAE,CACRqJ,GAAG,EAAE,CACLnB,GAAG,CACFzI,MAAM,CAACyJ,MAAM,CACX,SAAS,EACT3B,EAAE,CAAC4B,WAAW,CAACI,QAAQ,wBAAiBzF,KAAK,UAAO,CACrD,CACF;MACL,KAAK5F,UAAU,CAAC8N,EAAE;MAClB,KAAK9N,UAAU,CAAC+N,YAAY;MAC5B,KAAK/N,UAAU,CAACgO,KAAK;MACrB,KAAKhO,UAAU,CAACiO,eAAe;MAC/B,KAAKjO,UAAU,CAACgL,MAAM;MACtB;QACE,MAAM,IAAInD,KAAK,wCAAiC9B,SAAS,EAAG;IAAC;EAEnE;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;EACQmI,gBAAgB,CACpBhI,KAA2B,EAC3BrF,UAAkB,EAEC;IAAA;MAAA;IAAA;MAAA,IADnB2F,OAAO,0EAAG9F,UAAU,CAACyN,6BAA6B;MAElD,IAAIjI,KAAK,IAAI,IAAI,EAAE;QACjB,OAAO,IAAI;MACb;MAEA,IAAMjF,MAAM,GAAGiF,KAAK,CAACkI,UAAU,CAACvN,UAAU,CAAC;MAC3C,IAAMwN,OAAO,GAAG,CAAC,KAAI,CAACC,eAAe,CAACrN,MAAM,CAAC,CAAC;MAE9C,MAAM,KAAI,CAACsN,WAAW,CAACrI,KAAK,EAAEmI,OAAO,EAAE7H,OAAO,CAAC;MAE/C,OAAON,KAAK;IAAC;EACf;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;EACQsI,kBAAkB,CACtBtI,KAA+B,EAC/BlD,OAAkC,EAEX;IAAA;MAAA;IAAA;MAAA,IADvBwD,OAAO,6EAAG9F,UAAU,CAACyN,6BAA6B;MAElD,IAAM;QAAE9E;MAAG,CAAC,GAAG,MAAI;MACnB,OAAO3I,UAAU,CAAC+N,sBAAsB,CACtCC,CAAC,IAAIA,CAAC,aAADA,CAAC,uBAADA,CAAC,CAAEF,kBAAkB,CAACxL,OAAO,CAAC,EACnCkD,KAAK,EACLmD,EAAE,CAACsF,KAAK,CAACC,0BAA0B,EACnCpI,OAAO,CACR;IAAC;EACJ;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;EACQ+H,WAAW,CACfrI,KAA2B,EAC3BmI,OAA0B,EAEP;IAAA;MAAA;IAAA;MAAA,IADnB7H,OAAO,6EAAG9F,UAAU,CAACyN,6BAA6B;MAElD,IAAM;QAAE9E;MAAG,CAAC,GAAG,MAAI;MACnB,OAAO3I,UAAU,CAAC+N,sBAAsB,CACtCC,CAAC,IAAIA,CAAC,aAADA,CAAC,uBAADA,CAAC,CAAEH,WAAW,CAACF,OAAO,CAAC,EAC5BnI,KAAK,EACLmD,EAAE,CAACsF,KAAK,CAACE,mBAAmB,EAC5BrI,OAAO,CACR;IAAC;EACJ;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;EACQsI,SAAS,CACb5I,KAA2B,EAC3BjD,KAAa,EAEM;IAAA;MAAA;IAAA;MAAA,IADnBuD,OAAO,6EAAG9F,UAAU,CAACyN,6BAA6B;MAElD,IAAM;QAAE9E;MAAG,CAAC,GAAG,MAAI;MACnB,OAAO3I,UAAU,CAAC+N,sBAAsB,CACtCC,CAAC,IAAIA,CAAC,aAADA,CAAC,uBAADA,CAAC,CAAEI,SAAS,CAAC7L,KAAK,CAAC,EACxBiD,KAAK,EACLmD,EAAE,CAACsF,KAAK,CAACI,iBAAiB,EAC1BvI,OAAO,CACR;IAAC;EACJ;;EAEA;AACF;AACA;AACA;EACE8H,eAAe,CAACrN,MAAc,EAAmB;IAC/C,IAAM;MAAEoI;IAAG,CAAC,GAAG,IAAI;IACnB,IAAIzD,KAAK,GAAG,IAAI;IAEhB,IAAIlF,UAAU,CAAC8B,UAAU,CAACvB,MAAM,CAACiJ,IAAI,CAAC,EAAE;MACtC;MACAtE,KAAK,GAAGyD,EAAE,CAAC4B,WAAW,CAACI,QAAQ,CAAC,GAAG,CAAC;IACtC,CAAC,MAAM,IAAI3K,UAAU,CAACiB,aAAa,CAACV,MAAM,CAACiJ,IAAI,CAAC,EAAE;MAChDtE,KAAK,GAAGyD,EAAE,CAAC4B,WAAW,CAAC+D,SAAS,CAAC,IAAI,CAAC;IACxC,CAAC,MAAM,IAAItO,UAAU,CAACuB,UAAU,CAAChB,MAAM,CAACiJ,IAAI,CAAC,EAAE;MAC7CtE,KAAK,GAAGyD,EAAE,CAAC4B,WAAW,CAACC,QAAQ,CAAC7B,EAAE,CAAC4F,WAAW,CAACC,QAAQ,CAAC,IAAIC,IAAI,EAAE,CAAC,CAAC;IACtE,CAAC,MAAM;MACLvJ,KAAK,GAAGyD,EAAE,CAAC4B,WAAW,CAACC,QAAQ,CAAC,CAAC,CAAC;IACpC;IAEA,IAAMkE,QAAQ,GAAGnO,MAAM,CAACM,MAAM,EAAE,CAACW,EAAE,CAAC0D,KAAK,CAAC;IAC1C,IAAMyJ,WAAW,GAAGpO,MAAM,CAACM,MAAM,EAAE,CAACY,KAAK,CAACyD,KAAK,CAAC;IAEhD,OAAOwJ,QAAQ,CAACpF,GAAG,CAACqF,WAAW,CAAC;EAClC;;EAEA;AACF;AACA;AACA;AACA;EACExB,eAAe,CAACnM,UAAkB,EAAEkE,KAAa,EAAe;IAC9D,IAAM;MAAEyD;IAAG,CAAC,GAAG,IAAI;IACnB,IAAMa,IAAI,GAAGxJ,UAAU,CAAC4E,WAAW,CAAC5D,UAAU,CAAC;IAC/C,IAAIhB,UAAU,CAAC8B,UAAU,CAAC0H,IAAI,CAAC,EAAE;MAC/B,OAAOb,EAAE,CAAC4B,WAAW,CAACI,QAAQ,CAACzF,KAAK,CAAC;IACvC;IACA,IAAIlF,UAAU,CAACsE,UAAU,CAACkF,IAAI,CAAC,EAAE;MAC/B,OAAOb,EAAE,CAAC4B,WAAW,CAACC,QAAQ,CAC5B7B,EAAE,CAAC+B,WAAW,CAACC,QAAQ,CAAC3K,UAAU,CAAC6G,YAAY,CAAC3B,KAAK,CAAC,CAAC,CACxD;IACH;IAEA,OAAOyD,EAAE,CAAC4B,WAAW,CAACC,QAAQ,CAACxK,UAAU,CAAC6G,YAAY,CAAC3B,KAAK,CAAC,CAAC;EAChE;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;EACE0J,kBAAkB,CAAC5N,UAAkB,EAAE6N,QAAiB,EAAe;IACrE,IAAM;MAAElG;IAAG,CAAC,GAAG,IAAI;IACnB,IAAI3I,UAAU,CAAC8B,UAAU,CAACd,UAAU,CAAC,EAAE;MACrC,OAAO2H,EAAE,CAAC4B,WAAW,CAACI,QAAQ,CAACkE,QAAQ,CAAC;IAC1C;IAEA,IAAI7O,UAAU,CAACiB,aAAa,CAACD,UAAU,CAAC,EAAE;MACxC,OAAO2H,EAAE,CAAC4B,WAAW,CAAC+D,SAAS,CAACO,QAAQ,CAAC;IAC3C;IAEA,OAAOlG,EAAE,CAAC4B,WAAW,CAACC,QAAQ,CAACqE,QAAQ,CAAC;EAC1C;;EAEA;AACF;AACA;AACA;AACA;AACA;EACEC,SAAS,CACP9N,UAAkB,EAClBgG,IAAY,EACZ6B,QAAgB,EACgC;IAChD,IAAM;MAAEF;IAAG,CAAC,GAAG,IAAI;IACnB,IAAI3B,IAAI,KAAK,MAAM,EAAE;MACnB,OAAO,IAAI;IACb;IACA,IAAIhH,UAAU,CAAC8B,UAAU,CAACd,UAAU,CAAC,EAAE;MACrC,OAAOgG,IAAI;IACb;IACA,IAAIhH,UAAU,CAACsE,UAAU,CAACtD,UAAU,CAAC,EAAE;MACrC,OAAO2H,EAAE,CAAC+B,WAAW,CAACC,QAAQ,CAAC3K,UAAU,CAAC6G,YAAY,CAACG,IAAI,CAAC,CAAC;IAC/D;IACA,IAAIhH,UAAU,CAACiB,aAAa,CAACD,UAAU,CAAC,EAAE;MACxC,OAAOhB,UAAU,CAAC+G,gBAAgB,CAACC,IAAI,EAAE,IAAI,CAAC;IAChD;IACA,IAAIhH,UAAU,CAACuB,UAAU,CAACP,UAAU,CAAC,EAAE;MACrC,IAAM,CAAC+N,IAAI,CAAC,GAAGlP,SAAS,CAACkM,cAAc,CAACpD,EAAE,EAAE3B,IAAI,EAAE6B,QAAQ,CAAC;MAC3D,OAAOkG,IAAI;IACb;IAEA,IAAI/O,UAAU,CAACsB,YAAY,CAACN,UAAU,CAAC,EAAE;MACvC,OAAOhB,UAAU,CAACoH,eAAe,CAACJ,IAAI,CAAC;IACzC;IAEAlH,GAAG,CAAC8K,KAAK,CAAC,wBAAwB,EAAE5J,UAAU,CAAC;IAC/C,OAAO,IAAI;EACb;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;EACEkM,qBAAqB,CACnB3M,MAAc,EACdmM,cAAyB,EACzBD,eAAwB,EACyC;IACjE,IAAM;MAAE9D;IAAG,CAAC,GAAG,IAAI;IACnB,IAAI+D,cAAc,CAACrM,MAAM,KAAK,CAAC,EAAE;MAC/B,IAAIoM,eAAe,EAAE;QACnB;QACA,OAAO,IAAI;MAGb;;MAEA;MACA;MACA;MACA,OAAO,IAAI,CAACmB,eAAe,CAACrN,MAAM,CAAC;IACrC;IAEA,IAAMyO,MAAM,GAAG,EAAE;IACjB,IAAIC,cAAc,GAAG,KAAK;IAC1B,KAAK,IAAI7O,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAGsM,cAAc,CAACrM,MAAM,EAAED,CAAC,IAAI,CAAC,EAAE;MACjD,IAAM8E,KAAK,GAAGwH,cAAc,CAACtM,CAAC,CAAC;MAC/B,IAAI8E,KAAK,IAAI,IAAI,EAAE;QACjB+J,cAAc,GAAG,IAAI;MACvB,CAAC,MAAM,IAAIjP,UAAU,CAAC8B,UAAU,CAACvB,MAAM,CAACiJ,IAAI,CAAC,EAAE;QAC7CwF,MAAM,CAACpL,IAAI,CACT+E,EAAE,CAAC4B,WAAW,CAACI,QAAQ,CACrB,OAAOzF,KAAK,KAAK,QAAQ,GAAGgK,MAAM,CAACC,YAAY,CAACjK,KAAK,CAAC,GAAGA,KAAK,CAC/D,CACF;MACH,CAAC,MAAM,IAAIlF,UAAU,CAACiB,aAAa,CAACV,MAAM,CAACiJ,IAAI,CAAC,EAAE;QAChDwF,MAAM,CAACpL,IAAI,CAAC+E,EAAE,CAAC4B,WAAW,CAAC+D,SAAS,CAACc,OAAO,CAAClK,KAAK,CAAC,CAAC,CAAC;MACvD,CAAC,MAAM;QACL8J,MAAM,CAACpL,IAAI,CAAC+E,EAAE,CAAC4B,WAAW,CAACC,QAAQ,CAACtF,KAAK,CAAC,CAAC;MAC7C;IACF;IAEA,IAAI+J,cAAc,EAAE;MAClB,IAAID,MAAM,CAAC3O,MAAM,GAAG,CAAC,EAAE;QACrB,IAAIoM,eAAe,EAAE;UACnB,OAAOlM,MAAM,CACVM,MAAM,EAAE,CACRO,MAAM,EAAE,CACRqJ,GAAG,EAAE,CACLnB,GAAG,CAAC/I,MAAM,CAACM,MAAM,EAAE,CAACyM,KAAK,CAAC0B,MAAM,CAAC,CAAC;QACvC;QACA,OAAOzO,MAAM,CAACM,MAAM,EAAE,CAACO,MAAM,EAAE,CAACmI,EAAE,CAAChJ,MAAM,CAACM,MAAM,EAAE,CAACuM,EAAE,CAAC4B,MAAM,CAAC,CAAC;MAChE;MACA,IAAIvC,eAAe,EAAE;QACnB,OAAOlM,MAAM,CAACM,MAAM,EAAE,CAACO,MAAM,EAAE,CAACqJ,GAAG,EAAE;MACvC;MAEA,OAAOlK,MAAM,CAACM,MAAM,EAAE,CAACO,MAAM,EAAE;IACjC;IAEA,IAAIqL,eAAe,EAAE;MACnB,OAAOlM,MAAM,CAACM,MAAM,EAAE,CAACyM,KAAK,CAAC0B,MAAM,CAAC;IACtC;IAEA,OAAOzO,MAAM,CAACM,MAAM,EAAE,CAACuM,EAAE,CAAC4B,MAAM,CAAC;EACnC;AACF;AAAC,gBAvrDYhP,UAAU,cACH;EAChB+D,OAAO,EAAE,SAAS;EAClBC,IAAI,EAAE,MAAM;EACZE,QAAQ,EAAE,UAAU;EACpBC,OAAO,EAAE,SAAS;EAClBC,GAAG,EAAE,KAAK;EACVH,MAAM,EAAE,QAAQ;EAChBI,OAAO,EAAE;AACX,CAAC;AAAA,gBATUrE,UAAU,mBAWE;EACrB4C,SAAS,EAAE,KAAK;EAChBK,UAAU,EAAE,MAAM;EAClBS,OAAO,EAAE,SAAS;EAClBV,IAAI,EAAE;AACR,CAAC;AAAA,gBAhBUhD,UAAU,mCAkBkB,KAAK;AAAA,gBAlBjCA,UAAU,kBAoBCqP,MAAM,CAACC,MAAM,CAAC;EAClCC,IAAI,EAAE,MAAM;EACZC,QAAQ,EAAE,UAAU;EACpBC,SAAS,EAAE;AACb,CAAC,CAAU;AAAA,gBAxBAzP,UAAU,kBA2BC,iBAAiB;AAAA,gBA3B5BA,UAAU;EAAA,8BAyCW,WAC9BiK,IAAgD,EAChDzE,KAA2B,EAC3BkK,SAAiB,EAEK;IAAA,IADtB5J,OAAO,uEAAG9F,UAAU,CAACyN,6BAA6B;IAElD,IAAIjI,KAAK,IAAI,IAAI,EAAE;MACjB,OAAO,IAAI;IACb;IAEA,IAAMmK,YAAY,GAAG3P,UAAU,CAAC4F,+BAA+B,CAC7DJ,KAAK,EACLkK,SAAS,EACT5J,OAAO,CACR;IAEDmE,IAAI,CAACzE,KAAK,CAAC;IAEX,MAAMmK,YAAY;IAElB,OAAOnK,KAAK;EACd,CAAC;EAAA;IAAA;EAAA;AAAA;AA2nDH,eAAexF,UAAU"}
|
|
1
|
+
{"version":3,"file":"TableUtils.js","names":["Type","FilterType","Operator","FilterOperator","Log","bindAllMethods","PromiseUtils","removeNullAndUndefined","TextUtils","TimeoutError","DateUtils","createValueFilter","getSize","log","module","TableUtils","copyTableAndApplyFilters","maybeTable","derivedTable","copy","filterFactories","applyFilter","map","f","getSortIndex","sort","columnName","i","length","s","column","name","getSortForColumn","tableSort","sortIndex","getFilterText","filter","toString","getFilterTypes","columnType","isBooleanType","isTrue","isFalse","isNull","isCharType","isNumberType","isDateType","eq","notEq","greaterThan","greaterThanOrEqualTo","lessThan","lessThanOrEqualTo","isTextType","eqIgnoreCase","notEqIgnoreCase","contains","notContains","startsWith","endsWith","getNextSort","columns","sorts","columnIndex","asc","direction","sortDirection","ascending","desc","makeColumnSort","isAbs","none","descending","abs","toggleSortForColumn","addToExisting","newSort","setSortForColumn","sortColumn","modelColumn","concat","reverse","splice","push","getNormalizedType","dataType","BOOLEAN","CHAR","STRING","DATETIME","DECIMAL","INT","UNKNOWN","isLongType","isIntegerType","isDecimalType","isBigDecimalType","isBigIntegerType","isStringType","getBaseType","split","isCompatibleType","type1","type2","quoteValue","value","charAt","isRangeOperation","operation","makeRangeFilterWithOperation","makeCancelableTablePromise","table","makeCancelable","resolved","close","makeCancelableTableEventPromise","eventName","timeout","matcher","eventCleanup","timeoutId","isPending","wrappedPromise","Promise","resolve","reject","setTimeout","addEventListener","event","debug2","clearTimeout","cancel","removeCommas","replace","makeBooleanValue","text","allowEmpty","toLowerCase","Error","makeNumberValue","cleanText","trim","Number","POSITIVE_INFINITY","NEGATIVE_INFINITY","numberText","NUMBER_REGEX","test","parseFloat","getFilterOperatorString","isTreeTable","expand","undefined","collapse","sortColumns","isAscending","a","b","aName","toUpperCase","bName","constructor","dh","createDistinctSortedColumnTable","sourceTable","filterConditionFactories","findColumn","distinctTable","selectDistinct","distinctAscColSort","applySort","doesColumnValueExist","columnNames","isCaseSensitive","filterConditionFactory","tableCopy","size","makeQuickFilter","timeZone","orComponents","orFilter","orComponent","andComponents","andFilter","j","andComponent","makeQuickFilterFromComponent","and","or","type","makeQuickNumberFilter","makeQuickBooleanFilter","makeQuickDateFilter","makeQuickCharFilter","makeQuickTextFilter","columnFilter","regex","result","exec","negativeSign","abnormalValue","overflow","FilterCondition","invoke","FilterValue","ofNumber","not","LongWrapper","ofString","error","warn","isNaN","escapeQuickTextFilter","quickFilterText","nullRegex","substring","unescapeQuickTextFilter","prefix","suffix","notEqual","cleanValue","boolValue","e","dateText","filterOperation","makeQuickDateFilterWithOperation","startDate","endDate","parseDateRange","startValue","endValue","startFilter","endFilter","filterValue","makeAdvancedFilter","options","filterItems","filterOperators","invertSelection","selectedValues","filterItem","selectedType","newFilter","makeAdvancedValueFilter","filterOperator","err","selectValueFilter","makeSelectValueFilter","makeFilterValue","in","inIgnoreCase","notIn","notInIgnoreCase","applyNeverFilter","APPLY_TABLE_CHANGE_TIMEOUT_MS","filters","makeNeverFilter","applyCustomColumns","executeAndWaitForEvent","t","Table","EVENT_CUSTOMCOLUMNSCHANGED","EVENT_FILTERCHANGED","EVENT_SORTCHANGED","ofBoolean","DateWrapper","ofJsDate","Date","eqFilter","notEqFilter","makeFilterRawValue","rawValue","makeValue","date","values","isNullSelected","String","fromCharCode","Boolean","Object","freeze","NONE","PRE_SORT","POST_SORT","eventType","eventPromise"],"sources":["../src/TableUtils.ts"],"sourcesContent":["import {\n Type as FilterType,\n Operator as FilterOperator,\n TypeValue as FilterTypeValue,\n OperatorValue as FilterOperatorValue,\n} from '@deephaven/filters';\nimport Log from '@deephaven/log';\nimport type {\n Column,\n CustomColumn,\n dh as DhType,\n FilterCondition,\n FilterValue,\n LongWrapper,\n RemoverFn,\n Sort,\n Table,\n TreeTable,\n} from '@deephaven/jsapi-types';\nimport {\n bindAllMethods,\n CancelablePromise,\n PromiseUtils,\n removeNullAndUndefined,\n TextUtils,\n TimeoutError,\n} from '@deephaven/utils';\nimport DateUtils from './DateUtils';\nimport { ColumnName } from './Formatter';\nimport { createValueFilter, FilterConditionFactory } from './FilterUtils';\nimport { getSize } from './ViewportDataUtils';\n\nconst log = Log.module('TableUtils');\n\ntype Values<T> = T[keyof T];\nexport type DataType = Values<typeof TableUtils.dataType>;\nexport type SortDirection = Values<typeof TableUtils.sortDirection>;\nexport type ReverseType = Values<typeof TableUtils.REVERSE_TYPE>;\nexport type AdvancedFilterItemType = {\n selectedType: FilterTypeValue;\n value: string;\n};\n\nexport interface FilterItem {\n selectedType: FilterTypeValue;\n value: string;\n}\n\nexport type AdvancedFilterOptions = {\n filterItems: FilterItem[];\n filterOperators: FilterOperatorValue[];\n invertSelection: boolean;\n selectedValues: unknown[];\n};\n\nexport type RowDataMapValue = {\n type: string;\n text: string;\n value: unknown;\n isExpandable: boolean;\n isGrouped: boolean;\n visibleIndex: number;\n};\n\nexport type RowDataMap = Record<ColumnName, RowDataMapValue>;\n\n/** Utility class to provide some functions for working with tables */\nexport class TableUtils {\n static dataType = {\n BOOLEAN: 'boolean',\n CHAR: 'char',\n DATETIME: 'datetime',\n DECIMAL: 'decimal',\n INT: 'int',\n STRING: 'string',\n UNKNOWN: 'unknown',\n } as const;\n\n static sortDirection = {\n ascending: 'ASC',\n descending: 'DESC',\n reverse: 'REVERSE',\n none: null,\n } as const;\n\n static APPLY_TABLE_CHANGE_TIMEOUT_MS = 30000;\n\n static REVERSE_TYPE = Object.freeze({\n NONE: 'none',\n PRE_SORT: 'pre-sort',\n POST_SORT: 'post-sort',\n } as const);\n\n // Regex looking for a negative or positive integer or decimal number\n static NUMBER_REGEX = /^-?\\d+(\\.\\d+)?$/;\n\n /**\n * Copy a given table and apply filters.\n * @param maybeTable Table to copy and apply filters to\n * @param filterFactories Filter condition factories to apply\n * @returns A derived, filtered table\n */\n static async copyTableAndApplyFilters<\n T extends Table | null | undefined,\n R extends T extends Table ? T : null,\n >(maybeTable: T, ...filterFactories: FilterConditionFactory[]): Promise<R> {\n if (maybeTable == null) {\n return null as R;\n }\n\n const derivedTable = await maybeTable.copy();\n\n derivedTable.applyFilter(\n removeNullAndUndefined(...filterFactories.map(f => f(derivedTable)))\n );\n\n return derivedTable as R;\n }\n\n /**\n * Executes a callback on a given table and returns a Promise that will resolve\n * the next time a particular event type fires on the table.\n * @param exec Callback function to execute.\n * @param table Table that gets passed to the `exec` function and that is\n * subscribed to for a given `eventType`.\n * @param eventType The event type to listen for.\n * @param timeout If the event doesn't fire within the timeout, the returned\n * Promise will be rejected.\n * @returns a Promise to the original table that resolves on next `eventType`\n * event\n */\n static executeAndWaitForEvent = async <T extends Table | TreeTable>(\n exec: (maybeTable: T | null | undefined) => void,\n table: T | null | undefined,\n eventType: string,\n timeout = TableUtils.APPLY_TABLE_CHANGE_TIMEOUT_MS\n ): Promise<T | null> => {\n if (table == null) {\n return null;\n }\n\n const eventPromise = TableUtils.makeCancelableTableEventPromise(\n table,\n eventType,\n timeout\n );\n\n exec(table);\n\n await eventPromise;\n\n return table;\n };\n\n static getSortIndex(\n sort: readonly Sort[],\n columnName: ColumnName\n ): number | null {\n for (let i = 0; i < sort.length; i += 1) {\n const s = sort[i];\n if (s.column?.name === columnName) {\n return i;\n }\n }\n\n return null;\n }\n\n /**\n * @param tableSort The sorts from the table to get the sort from\n * @param columnName The name of the column to get the sort for\n * @returns The sort for the column, or null if it's not sorted\n */\n static getSortForColumn(\n tableSort: readonly Sort[],\n columnName: ColumnName\n ): Sort | null {\n const sortIndex = TableUtils.getSortIndex(tableSort, columnName);\n if (sortIndex != null) {\n return tableSort[sortIndex];\n }\n return null;\n }\n\n static getFilterText(filter?: FilterCondition | null): string | null {\n if (filter) {\n return filter.toString();\n }\n return null;\n }\n\n /** Return the valid filter types for the column */\n static getFilterTypes(columnType: string): FilterTypeValue[] {\n if (TableUtils.isBooleanType(columnType)) {\n return [FilterType.isTrue, FilterType.isFalse, FilterType.isNull];\n }\n if (\n TableUtils.isCharType(columnType) ||\n TableUtils.isNumberType(columnType) ||\n TableUtils.isDateType(columnType)\n ) {\n return [\n FilterType.eq,\n FilterType.notEq,\n FilterType.greaterThan,\n FilterType.greaterThanOrEqualTo,\n FilterType.lessThan,\n FilterType.lessThanOrEqualTo,\n ];\n }\n if (TableUtils.isTextType(columnType)) {\n return [\n FilterType.eq,\n FilterType.eqIgnoreCase,\n FilterType.notEq,\n FilterType.notEqIgnoreCase,\n FilterType.contains,\n FilterType.notContains,\n FilterType.startsWith,\n FilterType.endsWith,\n ];\n }\n return [];\n }\n\n static getNextSort(\n columns: readonly Column[],\n sorts: readonly Sort[],\n columnIndex: number\n ): Sort | null {\n if (columnIndex < 0 || columnIndex >= columns.length) {\n return null;\n }\n\n const sort = TableUtils.getSortForColumn(sorts, columns[columnIndex].name);\n if (sort === null) {\n return columns[columnIndex].sort().asc();\n }\n if (sort.direction === TableUtils.sortDirection.ascending) {\n return sort.desc();\n }\n return null;\n }\n\n static makeColumnSort(\n columns: readonly Column[],\n columnIndex: number,\n direction: SortDirection,\n isAbs: boolean\n ): Sort | null {\n if (columnIndex < 0 || columnIndex >= columns.length) {\n return null;\n }\n\n if (direction === TableUtils.sortDirection.none) {\n return null;\n }\n\n let sort = columns[columnIndex].sort();\n\n switch (direction) {\n case TableUtils.sortDirection.ascending:\n sort = sort.asc();\n break;\n case TableUtils.sortDirection.descending:\n sort = sort.desc();\n break;\n default:\n break;\n }\n if (isAbs) {\n sort = sort.abs();\n }\n return sort;\n }\n\n /**\n * Toggles the sort for the specified column\n * @param sorts The current sorts from IrisGrid.state\n * @param columns The columns to apply the sort to\n * @param columnIndex The column index to apply the sort to\n * @param addToExisting Add this sort to the existing sort\n */\n static toggleSortForColumn(\n sorts: readonly Sort[],\n columns: readonly Column[],\n columnIndex: number,\n addToExisting = false\n ): Sort[] {\n if (columnIndex < 0 || columnIndex >= columns.length) {\n return [];\n }\n\n const newSort = TableUtils.getNextSort(columns, sorts, columnIndex);\n\n return TableUtils.setSortForColumn(\n sorts,\n columns[columnIndex].name,\n newSort,\n addToExisting\n );\n }\n\n static sortColumn(\n sorts: readonly Sort[],\n columns: readonly Column[],\n modelColumn: number,\n direction: SortDirection,\n isAbs: boolean,\n addToExisting: boolean\n ): Sort[] {\n if (modelColumn < 0 || modelColumn >= columns.length) {\n return [];\n }\n\n const newSort = TableUtils.makeColumnSort(\n columns,\n modelColumn,\n direction,\n isAbs\n );\n\n return TableUtils.setSortForColumn(\n sorts,\n columns[modelColumn].name,\n newSort,\n addToExisting\n );\n }\n\n /**\n * Sets the sort for the given column *and* removes any reverses\n * @param tableSort The current sorts from IrisGrid.state\n * @param columnName The column name to apply the sort to\n * @param sort The sort object to add\n * @param addToExisting Add this sort to the existing sort\n * @returns Returns the modified array of sorts - removing reverses\n */\n static setSortForColumn(\n tableSort: readonly Sort[],\n columnName: ColumnName,\n sort: Sort | null,\n addToExisting = false\n ): Sort[] {\n const sortIndex = TableUtils.getSortIndex(tableSort, columnName);\n let sorts: Sort[] = [];\n if (addToExisting) {\n sorts = sorts.concat(\n tableSort.filter(\n ({ direction }) => direction !== TableUtils.sortDirection.reverse\n )\n );\n if (sortIndex !== null) {\n sorts.splice(sortIndex, 1);\n }\n }\n\n if (sort !== null) {\n sorts.push(sort);\n }\n\n return sorts;\n }\n\n static getNormalizedType(columnType?: string | null): DataType {\n switch (columnType) {\n case 'boolean':\n case 'java.lang.Boolean':\n case TableUtils.dataType.BOOLEAN:\n return TableUtils.dataType.BOOLEAN;\n case 'char':\n case 'java.lang.Character':\n case TableUtils.dataType.CHAR:\n return TableUtils.dataType.CHAR;\n case 'java.lang.String':\n case TableUtils.dataType.STRING:\n return TableUtils.dataType.STRING;\n case 'io.deephaven.db.tables.utils.DBDateTime':\n case 'io.deephaven.time.DateTime':\n case 'com.illumon.iris.db.tables.utils.DBDateTime':\n case 'java.time.Instant':\n case 'java.time.ZonedDateTime':\n case TableUtils.dataType.DATETIME:\n return TableUtils.dataType.DATETIME;\n case 'double':\n case 'java.lang.Double':\n case 'float':\n case 'java.lang.Float':\n case 'java.math.BigDecimal':\n case TableUtils.dataType.DECIMAL:\n return TableUtils.dataType.DECIMAL;\n case 'int':\n case 'java.lang.Integer':\n case 'long':\n case 'java.lang.Long':\n case 'short':\n case 'java.lang.Short':\n case 'byte':\n case 'java.lang.Byte':\n case 'java.math.BigInteger':\n case TableUtils.dataType.INT:\n return TableUtils.dataType.INT;\n default:\n return TableUtils.dataType.UNKNOWN;\n }\n }\n\n static isLongType(columnType: string): boolean {\n switch (columnType) {\n case 'long':\n case 'java.lang.Long':\n return true;\n default:\n return false;\n }\n }\n\n static isDateType(columnType: string): boolean {\n switch (columnType) {\n case 'io.deephaven.db.tables.utils.DBDateTime':\n case 'io.deephaven.time.DateTime':\n case 'java.time.Instant':\n case 'java.time.ZonedDateTime':\n case 'com.illumon.iris.db.tables.utils.DBDateTime':\n return true;\n default:\n return false;\n }\n }\n\n static isNumberType(columnType: string): boolean {\n return (\n TableUtils.isIntegerType(columnType) ||\n TableUtils.isDecimalType(columnType)\n );\n }\n\n static isIntegerType(columnType: string): boolean {\n switch (columnType) {\n case 'int':\n case 'java.lang.Integer':\n case 'java.math.BigInteger':\n case 'long':\n case 'java.lang.Long':\n case 'short':\n case 'java.lang.Short':\n case 'byte':\n case 'java.lang.Byte':\n return true;\n default:\n return false;\n }\n }\n\n static isDecimalType(columnType: string): boolean {\n switch (columnType) {\n case 'double':\n case 'java.lang.Double':\n case 'java.math.BigDecimal':\n case 'float':\n case 'java.lang.Float':\n return true;\n default:\n return false;\n }\n }\n\n static isBigDecimalType(columnType: string): boolean {\n switch (columnType) {\n case 'java.math.BigDecimal':\n return true;\n default:\n return false;\n }\n }\n\n static isBigIntegerType(columnType: string): boolean {\n switch (columnType) {\n case 'java.math.BigInteger':\n return true;\n default:\n return false;\n }\n }\n\n static isBooleanType(columnType: string): boolean {\n switch (columnType) {\n case 'boolean':\n case 'java.lang.Boolean':\n return true;\n default:\n return false;\n }\n }\n\n static isCharType(columnType: string): boolean {\n switch (columnType) {\n case 'char':\n case 'java.lang.Character':\n return true;\n default:\n return false;\n }\n }\n\n static isStringType(columnType: string): boolean {\n switch (columnType) {\n case 'java.lang.String':\n return true;\n default:\n return false;\n }\n }\n\n static isTextType(columnType: string): boolean {\n return this.isStringType(columnType) || this.isCharType(columnType);\n }\n\n /**\n * Get base column type\n * @param columnType Column type\n * @returns Element type for array columns, original type for non-array columns\n */\n static getBaseType(columnType: string): string {\n return columnType.split('[]')[0];\n }\n\n /**\n * Check if the column types are compatible\n * @param type1 Column type to check\n * @param type2 Column type to check\n * @returns True, if types are compatible\n */\n static isCompatibleType(\n type1?: string | null,\n type2?: string | null\n ): boolean {\n return (\n TableUtils.getNormalizedType(type1) ===\n TableUtils.getNormalizedType(type2)\n );\n }\n\n /**\n * Adds quotes to a value if they're not already added\n * @param value Value to add quotes around\n */\n static quoteValue(value: string): string {\n if (\n value.length >= 2 &&\n ((value.charAt(0) === '\"' && value.charAt(value.length - 1) === '\"') ||\n (value.charAt(0) === \"'\" && value.charAt(value.length - 1) === \"'\"))\n ) {\n return value;\n }\n return `\"${value}\"`;\n }\n\n static isRangeOperation(operation: string): boolean {\n switch (operation) {\n case '<':\n case '<=':\n case '=<':\n case '>':\n case '>=':\n case '=>':\n return true;\n default:\n return false;\n }\n }\n\n /**\n * @param filter The column filter to apply the range operation to\n * @param operation The range operation to run\n * @param value The value to use for the operation\n * @returns The condition with the specified operation\n */\n static makeRangeFilterWithOperation(\n filter: FilterValue,\n operation: string,\n value: FilterValue\n ): FilterCondition | null {\n switch (operation) {\n case '=':\n return filter.eq(value);\n case '<':\n return filter.lessThan(value);\n case '<=':\n case '=<':\n return filter.lessThanOrEqualTo(value);\n case '>':\n return filter.greaterThan(value);\n case '>=':\n case '=>':\n return filter.greaterThanOrEqualTo(value);\n case '!=':\n case '!':\n return filter.notEq(value);\n default:\n return null;\n }\n }\n\n /**\n * Wraps a table promise in a cancelable promise that will close the table if the promise is cancelled.\n * Use in a component that loads a table, and call cancel when unmounting.\n * @param table The table promise to wrap\n */\n static makeCancelableTablePromise(\n table: Promise<Table> | Table\n ): CancelablePromise<Table> {\n return PromiseUtils.makeCancelable(table, resolved => {\n resolved.close();\n });\n }\n\n /**\n * Make a cancelable promise for a one-shot table event with a timeout.\n * @param table Table to listen for events on\n * @param eventName Event to listen for\n * @param timeout Event timeout in milliseconds, defaults to 0\n * @param matcher Optional function to determine if the promise can be resolved or stays pending\n * @returns Resolves with the event data\n */\n static makeCancelableTableEventPromise(\n table: Table | TreeTable,\n eventName: string,\n timeout = 0,\n matcher: ((event: CustomEvent) => boolean) | null = null\n ): CancelablePromise<CustomEvent> {\n let eventCleanup: RemoverFn;\n let timeoutId: ReturnType<typeof setTimeout>;\n let isPending = true;\n const wrappedPromise = new Promise((resolve, reject) => {\n timeoutId = setTimeout(() => {\n eventCleanup();\n isPending = false;\n reject(new TimeoutError(`Event \"${eventName}\" timed out.`));\n }, timeout);\n eventCleanup = table.addEventListener(eventName, event => {\n if (matcher != null && !matcher(event)) {\n log.debug2('Event triggered, but matcher returned false.');\n return;\n }\n log.debug2('Event triggered, resolving.');\n eventCleanup();\n clearTimeout(timeoutId);\n isPending = false;\n resolve(event);\n });\n }) as CancelablePromise<CustomEvent>;\n wrappedPromise.cancel = () => {\n if (isPending) {\n log.debug2('Pending promise cleanup.');\n eventCleanup();\n clearTimeout(timeoutId);\n isPending = false;\n return;\n }\n log.debug2('Ignoring non-pending promise cancel.');\n };\n return wrappedPromise;\n }\n\n static removeCommas(value: string): string {\n return value.replace(/[\\s|,]/g, '');\n }\n\n static makeBooleanValue(text: string, allowEmpty = false): boolean | null {\n if (text === '' && allowEmpty) {\n return null;\n }\n\n switch (text?.toLowerCase()) {\n case 'null':\n return null;\n case '0':\n case 'f':\n case 'fa':\n case 'fal':\n case 'fals':\n case 'false':\n case 'n':\n case 'no':\n return false;\n case '1':\n case 't':\n case 'tr':\n case 'tru':\n case 'true':\n case 'y':\n case 'ye':\n case 'yes':\n return true;\n default:\n throw new Error(`Invalid boolean '${text}'`);\n }\n }\n\n static makeNumberValue(text: string): number | null {\n if (text === 'null' || text === '') {\n return null;\n }\n\n const cleanText = text.toLowerCase().trim();\n if (cleanText === '∞' || cleanText === 'infinity' || cleanText === 'inf') {\n return Number.POSITIVE_INFINITY;\n }\n if (\n cleanText === '-∞' ||\n cleanText === '-infinity' ||\n cleanText === '-inf'\n ) {\n return Number.NEGATIVE_INFINITY;\n }\n\n const numberText = TableUtils.removeCommas(cleanText);\n if (TableUtils.NUMBER_REGEX.test(numberText)) {\n return parseFloat(numberText);\n }\n\n throw new Error(`Invalid number '${text}'`);\n }\n\n static getFilterOperatorString(operation: FilterTypeValue): string {\n switch (operation) {\n case FilterType.eq:\n return '=';\n case FilterType.notEq:\n return '!=';\n case FilterType.greaterThan:\n return '>';\n case FilterType.greaterThanOrEqualTo:\n return '>=';\n case FilterType.lessThan:\n return '<';\n case FilterType.lessThanOrEqualTo:\n return '<=';\n case FilterType.contains:\n return '~';\n case FilterType.notContains:\n return '!~';\n default:\n throw new Error(`Unexpected filter type ${operation}`);\n }\n }\n\n static isTreeTable(table: unknown): table is TreeTable {\n return (\n table != null &&\n (table as TreeTable).expand !== undefined &&\n (table as TreeTable).collapse !== undefined\n );\n }\n\n /**\n * Copies the provided array, sorts by column name case insensitive, and returns the sorted array.\n * @param columns The columns to sort\n * @param isAscending Whether to sort ascending\n */\n static sortColumns(columns: readonly Column[], isAscending = true): Column[] {\n return [...columns].sort((a, b) => {\n const aName = a.name.toUpperCase();\n const bName = b.name.toUpperCase();\n return TextUtils.sort(aName, bName, isAscending);\n });\n }\n\n dh: DhType;\n\n constructor(dh: DhType) {\n this.dh = dh;\n bindAllMethods(this);\n }\n\n /**\n * Create a table containing a distinct list of values for given column name and\n * applies the given sort direction.\n * @param table Source table to derive table from\n * @param columnName Column to dermine distinct values\n * @param sortDirection Direction to sort\n * @param filterConditionFactories Optional filters to apply. Note that these\n * will be applied before the `selectCall` in case we need to base the filtering\n * on columns other than the distinct value column\n */\n async createDistinctSortedColumnTable(\n table: Table | null | undefined,\n columnName: string,\n sortDirection: 'asc' | 'desc',\n ...filterConditionFactories: FilterConditionFactory[]\n ): Promise<Table | null> {\n if (table == null) {\n return null;\n }\n\n let sourceTable = table;\n\n // Applying filters before `selectDistinct` so that we still have access to\n // all columns. Also prevents a filter applied to the final table from\n // clearing this filter.\n if (filterConditionFactories.length > 0) {\n sourceTable = await table.copy();\n\n await sourceTable.applyFilter(\n removeNullAndUndefined(\n ...filterConditionFactories.map(f => f(sourceTable))\n )\n );\n }\n\n const column = sourceTable.findColumn(columnName);\n const distinctTable = await sourceTable.selectDistinct([column]);\n\n // If we copied the table, dispose the copy. Original is managed outside\n // of this function\n if (sourceTable !== table) {\n sourceTable.close();\n }\n\n const distinctAscColSort = distinctTable\n .findColumn(columnName)\n .sort()\n [sortDirection]();\n\n return this.applySort(distinctTable, [distinctAscColSort]);\n }\n\n /**\n * Check if any columns contain a given value.\n * @param table Table to search for values\n * @param columnNames Column names to search\n * @param value Value to search for\n * @param isCaseSensitive Whether the value check is case sensitive\n */\n async doesColumnValueExist(\n table: Table | null | undefined,\n columnNames: string | string[],\n value: string,\n isCaseSensitive: boolean\n ): Promise<boolean | null> {\n if (table == null) {\n return null;\n }\n\n const filterConditionFactory = createValueFilter(\n this,\n columnNames,\n value,\n isCaseSensitive ? 'eq' : 'eqIgnoreCase'\n );\n\n const tableCopy = await table.copy();\n\n await this.applyFilter(\n tableCopy,\n removeNullAndUndefined(filterConditionFactory(tableCopy))\n );\n\n const size = getSize(tableCopy);\n\n tableCopy.close();\n\n return size > 0;\n }\n\n /**\n * Create filter with the provided column and text. Handles multiple filters joined with && or ||\n * @param column The column to set the filter on\n * @param text The text string to create the filter from\n * @param timeZone The time zone to make this value in if it is a date type. E.g. America/New_York\n * @returns Returns the created filter, null if text could not be parsed\n */\n makeQuickFilter(\n column: Column,\n text: string,\n timeZone?: string\n ): FilterCondition | null {\n const orComponents = text.split('||');\n let orFilter = null;\n for (let i = 0; i < orComponents.length; i += 1) {\n const orComponent = orComponents[i];\n const andComponents = orComponent.split('&&');\n let andFilter = null;\n for (let j = 0; j < andComponents.length; j += 1) {\n const andComponent = andComponents[j].trim();\n if (andComponent.length > 0) {\n const filter = this.makeQuickFilterFromComponent(\n column,\n andComponent,\n timeZone\n );\n if (filter) {\n if (andFilter) {\n andFilter = andFilter.and(filter);\n } else {\n andFilter = filter;\n }\n } else {\n throw new Error(`Unable to parse quick filter from text ${text}`);\n }\n }\n }\n\n if (orFilter && andFilter) {\n orFilter = orFilter.or(andFilter);\n } else {\n orFilter = andFilter;\n }\n }\n\n return orFilter;\n }\n\n /**\n * Create filter with the provided column and text of one component (no multiple conditions)\n * @param column The column to set the filter on\n * @param text The text string to create the filter from\n * @param timeZone The time zone to make this filter in if it is a date type. E.g. America/New_York\n * @returns Returns the created filter, null if text could not be parsed\n */\n makeQuickFilterFromComponent(\n column: Column,\n text: string,\n timeZone?: string\n ): FilterCondition | null {\n const { type } = column;\n if (TableUtils.isNumberType(type)) {\n return this.makeQuickNumberFilter(column, text);\n }\n if (TableUtils.isBooleanType(type)) {\n return this.makeQuickBooleanFilter(column, text);\n }\n if (timeZone != null && TableUtils.isDateType(type)) {\n return this.makeQuickDateFilter(column, text, timeZone);\n }\n if (TableUtils.isCharType(type)) {\n return this.makeQuickCharFilter(column, text);\n }\n return this.makeQuickTextFilter(column, text);\n }\n\n makeQuickNumberFilter(column: Column, text: string): FilterCondition | null {\n const columnFilter = column.filter();\n const { dh } = this;\n let filter = null;\n\n const regex =\n /\\s*(>=|<=|=>|=<|>|<|!=|=|!)?(\\s*-\\s*)?(\\s*\\d*(?:,\\d{3})*(?:\\.\\d*)?\\s*)?(null|nan|infinity|inf|\\u221E)?(.*)/i;\n const result = regex.exec(text);\n\n let operation = null;\n let negativeSign = null;\n let value = null;\n let abnormalValue = null; // includes nan, null and infinity(positive & negative)\n let overflow = null;\n\n if (result !== null && result.length > 3) {\n [, operation, negativeSign, value, abnormalValue, overflow] = result;\n }\n\n if (overflow != null && overflow.trim().length > 0) {\n // Some bad characters after the number, bail out!\n return null;\n }\n\n if (operation == null) {\n operation = '=';\n }\n\n if (abnormalValue != null) {\n if (!(operation === '=' || operation === '!' || operation === '!=')) {\n // only equal and not equal operations are supported for abnormal value filter\n return null;\n }\n abnormalValue = abnormalValue.trim().toLowerCase();\n switch (abnormalValue) {\n case 'null':\n filter = columnFilter.isNull();\n break;\n case 'nan':\n filter = dh.FilterCondition.invoke('isNaN', columnFilter);\n break;\n case 'infinity':\n case 'inf':\n case '\\u221E':\n if (negativeSign != null) {\n filter = dh.FilterCondition.invoke('isInf', columnFilter).and(\n columnFilter.lessThan(dh.FilterValue.ofNumber(0))\n );\n } else {\n filter = dh.FilterCondition.invoke('isInf', columnFilter).and(\n columnFilter.greaterThan(dh.FilterValue.ofNumber(0))\n );\n }\n break;\n default:\n break;\n }\n if (filter !== null && (operation === '!' || operation === '!=')) {\n filter = filter.not();\n }\n return filter;\n }\n\n if (value == null) {\n return null;\n }\n\n value = TableUtils.removeCommas(value);\n if (TableUtils.isLongType(column.type)) {\n try {\n value = dh.FilterValue.ofNumber(\n dh.LongWrapper.ofString(`${negativeSign != null ? '-' : ''}${value}`)\n );\n } catch (error) {\n log.warn('Unable to create long filter', error);\n return null;\n }\n } else {\n value = parseFloat(value);\n if (value == null || Number.isNaN(value)) {\n return null;\n }\n\n value = dh.FilterValue.ofNumber(negativeSign != null ? 0 - value : value);\n }\n\n filter = column.filter();\n\n return TableUtils.makeRangeFilterWithOperation(filter, operation, value);\n }\n\n /**\n * Given a text string from a table, escape quick filter operators in string with \\\n * ex. =test returns \\=test, null returns \\null\n * @param string quickfilter string to escape\n * @returns escaped string\n */\n static escapeQuickTextFilter(quickFilterText: string | null): string | null {\n if (quickFilterText == null) return null;\n const regex = /^(!~|!=|~|=|!)?(.*)/;\n // starts with zero or more \\ followed by and ending with null\n const nullRegex = /^\\\\*null$/;\n const result = regex.exec(quickFilterText);\n let operation: string | null = null;\n let value: string | null = null;\n if (result !== null && result.length > 2) {\n [, operation, value] = result;\n }\n\n if (operation != null) {\n return `\\\\${operation}${value ?? ''}`;\n }\n\n if (value != null && nullRegex.test(value.toLowerCase())) {\n // adds an extra escape character to matching value\n return `\\\\${value}`;\n }\n if (value != null && value.startsWith('*')) {\n return `\\\\${value}`;\n }\n if (value != null && value.endsWith('*') && !value.endsWith('\\\\*')) {\n value = value.substring(0, value.length - 1);\n return `${value}\\\\*`;\n }\n\n return `${operation ?? ''}${value ?? ``}`;\n }\n\n /**\n * Given an escaped quick filter, unescape the operators for giving it to the js api\n * ex. \\=test returns =test, \\null returns null\n * @param string quickfilter string to escape\n * @returns escaped string\n */\n static unescapeQuickTextFilter(quickFilterText: string): string {\n const regex = /^(\\\\!~|\\\\!=|\\\\~|\\\\=|\\\\!)?(.*)/;\n // starts with zero or more \\ followed by and ending with null\n const nullRegex = /^\\\\*null$/;\n const result = regex.exec(quickFilterText);\n let operation: string | null = null;\n let value: string | null = null;\n if (result !== null && result.length > 2) {\n [, operation, value] = result;\n }\n\n if (operation != null) {\n operation = operation.replace('\\\\', '');\n }\n\n if (value != null && nullRegex.test(value.toLowerCase())) {\n // removes the first occurance of the backslash\n value = value.replace('\\\\', '');\n }\n if (operation == null && value != null && value.startsWith('\\\\*')) {\n value = value.substring(1);\n }\n if (operation == null && value != null && value.endsWith('\\\\*')) {\n value = value.substring(0, value.length - 2);\n return `${value}*`;\n }\n\n return `${operation ?? ''}${value ?? ``}`;\n }\n\n makeQuickTextFilter(column: Column, text: string): FilterCondition | null {\n const { dh } = this;\n const cleanText = `${text}`.trim();\n const regex = /^(!~|!=|~|=|!)?(.*)/;\n const result = regex.exec(cleanText);\n\n let operation = null;\n let value = null;\n if (result !== null && result.length > 2) {\n [, operation, value] = result;\n if (value != null) {\n value = value.trim();\n }\n }\n\n if (value == null) {\n return null;\n }\n\n // allow empty strings, but only for explicit equal and not equal\n if (value.length === 0 && !(operation === '=' || operation === '!=')) {\n return null;\n }\n\n // no operation is treated as an implicit equals\n if (operation == null) {\n operation = '=';\n }\n\n const filter = column.filter();\n if (value.toLowerCase() === 'null') {\n // Null is a special case!\n switch (operation) {\n case '=':\n return filter.isNull();\n case '!=':\n case '!':\n return filter.isNull().not();\n default:\n // For all other operations, treat null as a string value\n }\n }\n\n let prefix = null;\n let suffix = null;\n if (value.startsWith('*')) {\n prefix = '*';\n value = value.substring(1);\n } else if (value.endsWith('*') && !value.endsWith('\\\\*')) {\n suffix = '*';\n value = value.substring(0, value.length - 1);\n }\n\n // unescape any escaped operators to allow search for literal operators\n value = TableUtils.unescapeQuickTextFilter(value);\n\n switch (operation) {\n case '~': {\n return filter\n .isNull()\n .not()\n .and(\n filter.invoke(\n 'matches',\n dh.FilterValue.ofString(`(?s)(?i).*\\\\Q${value}\\\\E.*`)\n )\n );\n }\n case '!~':\n return filter\n .isNull()\n .or(\n filter\n .invoke(\n 'matches',\n dh.FilterValue.ofString(`(?s)(?i).*\\\\Q${value}\\\\E.*`)\n )\n .not()\n );\n case '!=':\n if (prefix === '*') {\n // Does not end with\n return filter\n .isNull()\n .or(\n filter\n .invoke(\n 'matches',\n dh.FilterValue.ofString(`(?s)(?i).*\\\\Q${value}\\\\E$`)\n )\n .not()\n );\n }\n if (suffix === '*') {\n // Does not start with\n return filter\n .isNull()\n .or(\n filter\n .invoke(\n 'matches',\n dh.FilterValue.ofString(`(?s)(?i)^\\\\Q${value}\\\\E.*`)\n )\n .not()\n );\n }\n return filter.notEqIgnoreCase(\n dh.FilterValue.ofString(value.toLowerCase())\n );\n case '=':\n if (prefix === '*') {\n // Ends with\n return filter\n .isNull()\n .not()\n .and(\n filter.invoke(\n 'matches',\n dh.FilterValue.ofString(`(?s)(?i).*\\\\Q${value}\\\\E$`)\n )\n );\n }\n if (suffix === '*') {\n // Starts with\n return filter\n .isNull()\n .not()\n .and(\n filter.invoke(\n 'matches',\n dh.FilterValue.ofString(`(?s)(?i)^\\\\Q${value}\\\\E.*`)\n )\n );\n }\n return filter.eqIgnoreCase(\n dh.FilterValue.ofString(value.toLowerCase())\n );\n\n default:\n break;\n }\n\n return null;\n }\n\n // eslint-disable-next-line class-methods-use-this\n makeQuickBooleanFilter(\n column: Column,\n text: string | number\n ): FilterCondition | null {\n const regex = /^(!=|=|!)?(.*)/;\n const result = regex.exec(`${text}`.trim());\n if (result === null) {\n return null;\n }\n const [, operation, value] = result;\n const notEqual = operation === '!' || operation === '!=';\n const cleanValue = value.trim().toLowerCase();\n\n let filter: FilterCondition | FilterValue = column.filter();\n\n try {\n const boolValue = TableUtils.makeBooleanValue(cleanValue);\n if (boolValue != null && boolValue) {\n filter = filter.isTrue();\n } else if (boolValue === null) {\n filter = filter.isNull();\n } else {\n filter = filter.isFalse();\n }\n\n return notEqual ? filter.not() : filter;\n } catch (e) {\n return null;\n }\n }\n\n /**\n * Builds a date filter parsed from the text string which may or may not include an operator.\n * @param column The column to build the filter from, with or without a leading operator.\n * @param text The date string text to parse.\n * @param timeZone The time zone to make this filter in if it is a date type. E.g. America/New_York\n */\n makeQuickDateFilter(\n column: Column,\n text: string,\n timeZone: string\n ): FilterCondition {\n const cleanText = text.trim();\n const regex = /\\s*(>=|<=|=>|=<|>|<|!=|!|=)?(.*)/;\n const result = regex.exec(cleanText);\n if (result == null || result.length <= 2) {\n throw new Error(`Unable to parse date filter: ${text}`);\n }\n\n let operation = null;\n let dateText = null;\n\n [, operation, dateText] = result;\n\n let filterOperation: FilterTypeValue = FilterType.eq;\n switch (operation) {\n case '<':\n filterOperation = FilterType.lessThan;\n break;\n case '<=':\n case '=<':\n filterOperation = FilterType.lessThanOrEqualTo;\n break;\n case '>':\n filterOperation = FilterType.greaterThan;\n break;\n case '>=':\n case '=>':\n filterOperation = FilterType.greaterThanOrEqualTo;\n break;\n case '!=':\n case '!':\n filterOperation = FilterType.notEq;\n break;\n case '=':\n case '==':\n default:\n filterOperation = FilterType.eq;\n break;\n }\n\n return this.makeQuickDateFilterWithOperation(\n column,\n dateText,\n filterOperation,\n timeZone\n );\n }\n\n /**\n * Builds a date filter parsed from the text string with the provided filter.\n * @param column The column to build the filter from.\n * @param text The date string text to parse, without an operator.\n * @param operation The filter operation to use.\n * @param timeZone The time zone to make this filter with. E.g. America/New_York\n */\n makeQuickDateFilterWithOperation(\n column: Column,\n text: string,\n operation: FilterTypeValue,\n timeZone: string\n ): FilterCondition {\n const { dh } = this;\n const [startDate, endDate] = DateUtils.parseDateRange(dh, text, timeZone);\n\n const startValue =\n startDate != null ? dh.FilterValue.ofNumber(startDate) : null;\n const endValue = endDate != null ? dh.FilterValue.ofNumber(endDate) : null;\n\n const filter = column.filter();\n if (startValue == null) {\n return operation === FilterType.notEq\n ? filter.isNull().not()\n : filter.isNull();\n }\n\n switch (operation) {\n case FilterType.eq: {\n if (endValue != null) {\n const startFilter = filter.greaterThanOrEqualTo(startValue);\n const endFilter = filter.lessThan(endValue);\n return startFilter.and(endFilter);\n }\n return filter.eq(startValue);\n }\n case FilterType.lessThan: {\n return filter.lessThan(startValue);\n }\n case FilterType.lessThanOrEqualTo: {\n if (endValue != null) {\n return filter.lessThan(endValue);\n }\n return filter.lessThanOrEqualTo(startValue);\n }\n case FilterType.greaterThan: {\n if (endValue != null) {\n return filter.greaterThanOrEqualTo(endValue);\n }\n return filter.greaterThan(startValue);\n }\n case FilterType.greaterThanOrEqualTo:\n return filter.greaterThanOrEqualTo(startValue);\n case FilterType.notEq: {\n if (endValue != null) {\n const startFilter = filter.lessThan(startValue);\n const endFilter = filter.greaterThanOrEqualTo(endValue);\n return startFilter.or(endFilter);\n }\n return filter.notEq(startValue);\n }\n\n default:\n throw new Error(`Invalid operator: ${operation}`);\n }\n }\n\n makeQuickCharFilter(column: Column, text: string): FilterCondition | null {\n const { dh } = this;\n const cleanText = `${text}`.trim();\n const regex = /^(>=|<=|=>|=<|>|<|!=|=|!)?(null|\".\"|'.'|.)?(.*)/;\n const result = regex.exec(cleanText);\n\n let operation = null;\n let value = null;\n let overflow = null;\n if (result !== null && result.length > 3) {\n [, operation, value, overflow] = result;\n }\n if (overflow != null && overflow.trim().length > 0) {\n // Some bad characters after the number, bail out!\n return null;\n }\n\n if (value == null || value.length === 0) {\n return null;\n }\n\n if (operation == null) {\n operation = '=';\n }\n\n const filter = column.filter();\n if (value.toLowerCase() === 'null') {\n // Null is a special case!\n switch (operation) {\n case '=':\n return filter.isNull();\n case '!=':\n case '!':\n return filter.isNull().not();\n default:\n return null;\n }\n }\n\n // We need to put quotes around range operations or else the API fails\n const filterValue = dh.FilterValue.ofString(\n TableUtils.isRangeOperation(operation)\n ? TableUtils.quoteValue(value)\n : value\n );\n return TableUtils.makeRangeFilterWithOperation(\n filter,\n operation,\n filterValue\n );\n }\n\n makeAdvancedFilter(\n column: Column,\n options: AdvancedFilterOptions,\n timeZone: string\n ): FilterCondition | null {\n const { filterItems, filterOperators, invertSelection, selectedValues } =\n options;\n let filter = null;\n for (let i = 0; i < filterItems.length; i += 1) {\n const filterItem = filterItems[i];\n const { selectedType, value } = filterItem;\n if (\n selectedType != null &&\n selectedType.length > 0 &&\n value != null &&\n value.length > 0\n ) {\n try {\n const newFilter = this.makeAdvancedValueFilter(\n column,\n selectedType,\n value,\n timeZone\n );\n if (newFilter != null) {\n if (i === 0) {\n filter = newFilter;\n } else if (filter !== null && i - 1 < filterOperators.length) {\n const filterOperator = filterOperators[i - 1];\n if (filterOperator === FilterOperator.and) {\n filter = filter.and(newFilter);\n } else if (filterOperator === FilterOperator.or) {\n filter = filter.or(newFilter);\n } else {\n log.error(\n 'Unexpected filter operator',\n filterOperator,\n newFilter\n );\n filter = null;\n break;\n }\n }\n } else {\n log.debug2('Empty filter ignored for', selectedType, value);\n }\n } catch (err) {\n log.error('Unable to create filter', err);\n filter = null;\n break;\n }\n }\n }\n\n const selectValueFilter = this.makeSelectValueFilter(\n column,\n selectedValues,\n invertSelection\n );\n if (selectValueFilter != null) {\n if (filter != null) {\n filter = filter.and(selectValueFilter);\n } else {\n filter = selectValueFilter;\n }\n }\n\n return filter;\n }\n\n makeAdvancedValueFilter(\n column: Column,\n operation: FilterTypeValue,\n value: string,\n timeZone: string\n ): FilterCondition | null {\n const { dh } = this;\n if (TableUtils.isDateType(column.type)) {\n return this.makeQuickDateFilterWithOperation(\n column,\n value,\n operation,\n timeZone\n );\n }\n\n if (\n TableUtils.isNumberType(column.type) ||\n TableUtils.isCharType(column.type)\n ) {\n return this.makeQuickFilter(\n column,\n `${TableUtils.getFilterOperatorString(operation)}${value}`\n );\n }\n\n const filterValue = this.makeFilterValue(column.type, value);\n const filter = column.filter();\n switch (operation) {\n case FilterType.eq:\n return filter.eq(filterValue);\n case FilterType.eqIgnoreCase:\n return filter.eqIgnoreCase(filterValue);\n case FilterType.notEq:\n return filter.notEq(filterValue);\n case FilterType.notEqIgnoreCase:\n return filter.notEqIgnoreCase(filterValue);\n case FilterType.greaterThan:\n return filter.greaterThan(filterValue);\n case FilterType.greaterThanOrEqualTo:\n return filter.greaterThanOrEqualTo(filterValue);\n case FilterType.lessThan:\n return filter.lessThan(filterValue);\n case FilterType.lessThanOrEqualTo:\n return filter.lessThanOrEqualTo(filterValue);\n case FilterType.isTrue:\n return filter.isTrue();\n case FilterType.isFalse:\n return filter.isFalse();\n case FilterType.isNull:\n return filter.isNull();\n case FilterType.contains:\n return filter\n .isNull()\n .not()\n .and(\n filter.invoke(\n 'matches',\n dh.FilterValue.ofString(`(?s)(?i).*\\\\Q${value}\\\\E.*`)\n )\n );\n case FilterType.notContains:\n return filter\n .isNull()\n .or(\n filter\n .invoke(\n 'matches',\n dh.FilterValue.ofString(`(?s)(?i).*\\\\Q${value}\\\\E.*`)\n )\n .not()\n );\n case FilterType.startsWith:\n return filter\n .isNull()\n .not()\n .and(\n filter.invoke(\n 'matches',\n dh.FilterValue.ofString(`(?s)(?i)^\\\\Q${value}\\\\E.*`)\n )\n );\n case FilterType.endsWith:\n return filter\n .isNull()\n .not()\n .and(\n filter.invoke(\n 'matches',\n dh.FilterValue.ofString(`(?s)(?i).*\\\\Q${value}\\\\E$`)\n )\n );\n case FilterType.in:\n case FilterType.inIgnoreCase:\n case FilterType.notIn:\n case FilterType.notInIgnoreCase:\n case FilterType.invoke:\n default:\n throw new Error(`Unexpected filter operation: ${operation}`);\n }\n }\n\n /**\n * Apply a filter to a table that won't match anything.\n * @table The table to apply the filter to\n * @columnName The name of the column to apploy the filter to\n * @param timeout Timeout before cancelling the promise that waits for the next\n * dh.Table.EVENT_FILTERCHANGED event\n * @returns a Promise to the Table that resolves after the next\n * dh.Table.EVENT_FILTERCHANGED event\n */\n async applyNeverFilter<T extends Table | TreeTable>(\n table: T | null | undefined,\n columnName: string,\n timeout = TableUtils.APPLY_TABLE_CHANGE_TIMEOUT_MS\n ): Promise<T | null> {\n if (table == null) {\n return null;\n }\n\n const column = table.findColumn(columnName);\n const filters = [this.makeNeverFilter(column)];\n\n await this.applyFilter(table, filters, timeout);\n\n return table;\n }\n\n /**\n * Apply custom columns to a given table. Return a Promise that resolves with\n * the table once the dh.Table.EVENT_CUSTOMCOLUMNSCHANGED event has fired.\n * @param table The table to apply custom columns to.\n * @param columns The list of column expressions or definitions to apply.\n * @returns A Promise that will be resolved with the given table after the\n * columns are applied.\n */\n async applyCustomColumns(\n table: Table | null | undefined,\n columns: (string | CustomColumn)[],\n timeout = TableUtils.APPLY_TABLE_CHANGE_TIMEOUT_MS\n ): Promise<Table | null> {\n const { dh } = this;\n return TableUtils.executeAndWaitForEvent(\n t => t?.applyCustomColumns(columns),\n table,\n dh.Table.EVENT_CUSTOMCOLUMNSCHANGED,\n timeout\n );\n }\n\n /**\n * Apply filters to a given table.\n * @param table Table to apply filters to\n * @param filters Filters to apply\n * @param timeout Timeout before cancelling the promise that waits for the next\n * dh.Table.EVENT_FILTERCHANGED event\n * @returns a Promise to the Table that resolves after the next\n * dh.Table.EVENT_FILTERCHANGED event\n */\n async applyFilter<T extends Table | TreeTable>(\n table: T | null | undefined,\n filters: FilterCondition[],\n timeout = TableUtils.APPLY_TABLE_CHANGE_TIMEOUT_MS\n ): Promise<T | null> {\n const { dh } = this;\n return TableUtils.executeAndWaitForEvent(\n t => t?.applyFilter(filters),\n table,\n dh.Table.EVENT_FILTERCHANGED,\n timeout\n );\n }\n\n /**\n * Apply sorts to a given Table.\n * @param table The table to apply sorts to\n * @param sorts The sorts to apply\n * @param timeout Timeout before cancelling the promise that waits for the next\n * dh.Table.EVENT_SORTCHANGED event\n * @returns a Promise to the Table that resolves after the next\n * dh.Table.EVENT_SORTCHANGED event\n */\n async applySort<T extends Table | TreeTable>(\n table: T | null | undefined,\n sorts: Sort[],\n timeout = TableUtils.APPLY_TABLE_CHANGE_TIMEOUT_MS\n ): Promise<T | null> {\n const { dh } = this;\n return TableUtils.executeAndWaitForEvent(\n t => t?.applySort(sorts),\n table,\n dh.Table.EVENT_SORTCHANGED,\n timeout\n );\n }\n\n /**\n * Create a filter condition that results in zero results for a given column\n * @param column\n */\n makeNeverFilter(column: Column): FilterCondition {\n const { dh } = this;\n let value = null;\n\n if (TableUtils.isTextType(column.type)) {\n // Use 'a' so that it can work for String or Character types\n value = dh.FilterValue.ofString('a');\n } else if (TableUtils.isBooleanType(column.type)) {\n value = dh.FilterValue.ofBoolean(true);\n } else if (TableUtils.isDateType(column.type)) {\n value = dh.FilterValue.ofNumber(dh.DateWrapper.ofJsDate(new Date()));\n } else {\n value = dh.FilterValue.ofNumber(0);\n }\n\n const eqFilter = column.filter().eq(value);\n const notEqFilter = column.filter().notEq(value);\n\n return eqFilter.and(notEqFilter);\n }\n\n /**\n * @param columnType The column type to make the filter value from.\n * @param value The value to make the filter value from.\n * @returns The FilterValue item for this column/value combination\n */\n makeFilterValue(columnType: string, value: string): FilterValue {\n const { dh } = this;\n const type = TableUtils.getBaseType(columnType);\n if (TableUtils.isTextType(type)) {\n return dh.FilterValue.ofString(value);\n }\n if (TableUtils.isLongType(type)) {\n return dh.FilterValue.ofNumber(\n dh.LongWrapper.ofString(TableUtils.removeCommas(value))\n );\n }\n\n return dh.FilterValue.ofNumber(TableUtils.removeCommas(value));\n }\n\n /**\n * Takes a value and converts it to an `dh.FilterValue`\n *\n * @param columnType The column type to make the filter value from.\n * @param value The value to actually set\n * @returns The FilterValue item for this column/value combination\n */\n makeFilterRawValue(columnType: string, rawValue: unknown): FilterValue {\n const { dh } = this;\n if (TableUtils.isTextType(columnType)) {\n return dh.FilterValue.ofString(rawValue);\n }\n\n if (TableUtils.isBooleanType(columnType)) {\n return dh.FilterValue.ofBoolean(rawValue);\n }\n\n return dh.FilterValue.ofNumber(rawValue);\n }\n\n /**\n * Converts a string value to a value appropriate for the column\n * @param columnType The column type to make the value for\n * @param text The string value to make a type for\n * @param timeZone The time zone to make this value in if it is a date type. E.g. America/New_York\n */\n makeValue(\n columnType: string,\n text: string,\n timeZone: string\n ): string | number | boolean | LongWrapper | null {\n const { dh } = this;\n if (text === 'null') {\n return null;\n }\n if (TableUtils.isTextType(columnType)) {\n return text;\n }\n if (TableUtils.isLongType(columnType)) {\n return dh.LongWrapper.ofString(TableUtils.removeCommas(text));\n }\n if (TableUtils.isBooleanType(columnType)) {\n return TableUtils.makeBooleanValue(text, true);\n }\n if (TableUtils.isDateType(columnType)) {\n const [date] = DateUtils.parseDateRange(dh, text, timeZone);\n return date;\n }\n\n if (TableUtils.isNumberType(columnType)) {\n return TableUtils.makeNumberValue(text);\n }\n\n log.error('Unexpected column type', columnType);\n return null;\n }\n\n /**\n * Create a filter using the selected items\n * Has a flag for invertSelection as we start from a \"Select All\" state and a user just deselects items.\n * Since there may be millions of distinct items, it's easier to build an inverse filter.\n * @param column The column to set the filter on\n * @param selectedValues The values that are selected\n * @param invertSelection Invert the selection (eg. All items are selected, then you deselect items)\n * @returns Returns a `in` or `notIn` FilterCondition as necessary, or null if no filtering should be applied (everything selected)\n */\n makeSelectValueFilter<TInvert extends boolean>(\n column: Column,\n selectedValues: unknown[],\n invertSelection: TInvert\n ): TInvert extends true ? FilterCondition | null : FilterCondition {\n const { dh } = this;\n if (selectedValues.length === 0) {\n if (invertSelection) {\n // No filter means select everything\n return null as TInvert extends true\n ? FilterCondition | null\n : FilterCondition;\n }\n\n // KLUDGE: Return a conflicting filter to show no results.\n // Could recognize this situation at a higher or lower level and pause updates on the\n // table, but this situation should be rare and that wouldn't be much gains for some added complexity\n return this.makeNeverFilter(column);\n }\n\n const values = [];\n let isNullSelected = false;\n for (let i = 0; i < selectedValues.length; i += 1) {\n const value = selectedValues[i];\n if (value == null) {\n isNullSelected = true;\n } else if (TableUtils.isTextType(column.type)) {\n values.push(\n dh.FilterValue.ofString(\n typeof value === 'number' ? String.fromCharCode(value) : value\n )\n );\n } else if (TableUtils.isBooleanType(column.type)) {\n values.push(dh.FilterValue.ofBoolean(Boolean(value)));\n } else {\n values.push(dh.FilterValue.ofNumber(value));\n }\n }\n\n if (isNullSelected) {\n if (values.length > 0) {\n if (invertSelection) {\n return column\n .filter()\n .isNull()\n .not()\n .and(column.filter().notIn(values));\n }\n return column.filter().isNull().or(column.filter().in(values));\n }\n if (invertSelection) {\n return column.filter().isNull().not();\n }\n\n return column.filter().isNull();\n }\n\n if (invertSelection) {\n return column.filter().notIn(values);\n }\n\n return column.filter().in(values);\n }\n}\n\nexport default TableUtils;\n"],"mappings":"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"}
|
|
@@ -1,9 +1,6 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import type { Key } from 'react';
|
|
2
2
|
import type { Column, Row, Table, TreeTable } from '@deephaven/jsapi-types';
|
|
3
|
-
|
|
4
|
-
key: string;
|
|
5
|
-
item?: T;
|
|
6
|
-
}
|
|
3
|
+
import type { KeyedItem } from '@deephaven/utils';
|
|
7
4
|
export type OnTableUpdatedEvent = CustomEvent<{
|
|
8
5
|
offset: number;
|
|
9
6
|
columns: Column[];
|
|
@@ -24,13 +21,15 @@ export type ViewportRow = Row & {
|
|
|
24
21
|
export declare function createKeyFromOffsetRow(row: ViewportRow, offset: number): string;
|
|
25
22
|
/**
|
|
26
23
|
* Creates a handler function for a `dh.Table.EVENT_UPDATED` event. Rows that
|
|
27
|
-
* get passed to the handler will be
|
|
28
|
-
*
|
|
24
|
+
* get passed to the handler will be bulk updated in the given `viewportData`
|
|
25
|
+
* object based on their derived item keys.
|
|
29
26
|
* @param viewportData State object for managing a list of KeyedItem data.
|
|
30
27
|
* @param deserializeRow Converts a DH Row to an item object.
|
|
31
28
|
* @returns Handler function for a `dh.Table.EVENT_UPDATED` event.
|
|
32
29
|
*/
|
|
33
|
-
export declare function createOnTableUpdatedHandler<T>(
|
|
30
|
+
export declare function createOnTableUpdatedHandler<T>({ bulkUpdate }: {
|
|
31
|
+
bulkUpdate: (itemMap: Map<Key, KeyedItem<T>>) => void;
|
|
32
|
+
}, deserializeRow: RowDeserializer<T>): (event: OnTableUpdatedEvent) => void;
|
|
34
33
|
/**
|
|
35
34
|
* Maps a Row to a key / value object. Keys are mapped ver batim from column
|
|
36
35
|
* names.
|
|
@@ -48,13 +47,6 @@ export declare function defaultRowDeserializer<T>(row: ViewportRow, columns: Col
|
|
|
48
47
|
* @param end The ending index to generate
|
|
49
48
|
*/
|
|
50
49
|
export declare function generateEmptyKeyedItems<T>(start: number, end: number): Generator<KeyedItem<T>, void, unknown>;
|
|
51
|
-
/**
|
|
52
|
-
* Get items from a given ListData by a list of keys.
|
|
53
|
-
* @param listData ListData to get items from
|
|
54
|
-
* @param keys Keys to items to be retrieved
|
|
55
|
-
* @returns An array of items matching the given keys
|
|
56
|
-
*/
|
|
57
|
-
export declare function getItemsFromListData<T>(listData: ListData<KeyedItem<T>>, ...keys: string[]): KeyedItem<T>[];
|
|
58
50
|
/**
|
|
59
51
|
* Check a Table to see if it is closed before checking its size property. This
|
|
60
52
|
* is important because calling Table.size on a closed table throws an error. If
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ViewportDataUtils.d.ts","sourceRoot":"","sources":["../src/ViewportDataUtils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"ViewportDataUtils.d.ts","sourceRoot":"","sources":["../src/ViewportDataUtils.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,OAAO,CAAC;AAEjC,OAAO,KAAK,EAAE,MAAM,EAAE,GAAG,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAC;AAE5E,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAElD,MAAM,MAAM,mBAAmB,GAAG,WAAW,CAAC;IAC5C,MAAM,EAAE,MAAM,CAAC;IACf,OAAO,EAAE,MAAM,EAAE,CAAC;IAClB,IAAI,EAAE,WAAW,EAAE,CAAC;CACrB,CAAC,CAAC;AAEH,MAAM,MAAM,eAAe,CAAC,CAAC,IAAI,CAAC,GAAG,EAAE,WAAW,EAAE,OAAO,EAAE,MAAM,EAAE,KAAK,CAAC,CAAC;AAE5E,MAAM,MAAM,WAAW,GAAG,GAAG,GAAG;IAAE,gBAAgB,EAAE,MAAM,CAAA;CAAE,CAAC;AAI7D;;;;;;;GAOG;AACH,wBAAgB,sBAAsB,CAAC,GAAG,EAAE,WAAW,EAAE,MAAM,EAAE,MAAM,UAEtE;AAED;;;;;;;GAOG;AACH,wBAAgB,2BAA2B,CAAC,CAAC,EAC3C,EAAE,UAAU,EAAE,EAAE;IAAE,UAAU,EAAE,CAAC,OAAO,EAAE,GAAG,CAAC,GAAG,EAAE,SAAS,CAAC,CAAC,CAAC,CAAC,KAAK,IAAI,CAAA;CAAE,EACzE,cAAc,EAAE,eAAe,CAAC,CAAC,CAAC,GACjC,CAAC,KAAK,EAAE,mBAAmB,KAAK,IAAI,CAqBtC;AAED;;;;;;GAMG;AACH,wBAAgB,sBAAsB,CAAC,CAAC,EACtC,GAAG,EAAE,WAAW,EAChB,OAAO,EAAE,MAAM,EAAE,GAChB,CAAC,CAMH;AAED;;;;;;;GAOG;AACH,wBAAiB,uBAAuB,CAAC,CAAC,EACxC,KAAK,EAAE,MAAM,EACb,GAAG,EAAE,MAAM,GACV,SAAS,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,OAAO,CAAC,CAKxC;AAED;;;;;;GAMG;AACH,wBAAgB,OAAO,CAAC,KAAK,CAAC,EAAE,KAAK,GAAG,SAAS,GAAG,IAAI,GAAG,MAAM,CAEhE;AAED;;;;GAIG;AACH,wBAAgB,QAAQ,CAAC,KAAK,EAAE,KAAK,GAAG,SAAS,GAAG,OAAO,CAM1D;AAED;;;;;;;;;GASG;AACH,wBAAgB,kBAAkB,CAChC,QAAQ,EAAE,MAAM,EAChB,YAAY,EAAE,MAAM,EACpB,OAAO,EAAE,MAAM,EACf,SAAS,EAAE,MAAM,GAChB,CAAC,MAAM,EAAE,MAAM,CAAC,CAQlB"}
|
|
@@ -16,13 +16,16 @@ export function createKeyFromOffsetRow(row, offset) {
|
|
|
16
16
|
|
|
17
17
|
/**
|
|
18
18
|
* Creates a handler function for a `dh.Table.EVENT_UPDATED` event. Rows that
|
|
19
|
-
* get passed to the handler will be
|
|
20
|
-
*
|
|
19
|
+
* get passed to the handler will be bulk updated in the given `viewportData`
|
|
20
|
+
* object based on their derived item keys.
|
|
21
21
|
* @param viewportData State object for managing a list of KeyedItem data.
|
|
22
22
|
* @param deserializeRow Converts a DH Row to an item object.
|
|
23
23
|
* @returns Handler function for a `dh.Table.EVENT_UPDATED` event.
|
|
24
24
|
*/
|
|
25
|
-
export function createOnTableUpdatedHandler(
|
|
25
|
+
export function createOnTableUpdatedHandler(_ref, deserializeRow) {
|
|
26
|
+
var {
|
|
27
|
+
bulkUpdate
|
|
28
|
+
} = _ref;
|
|
26
29
|
/**
|
|
27
30
|
* Handler for a `dh.Table.EVENT_UPDATED` event.
|
|
28
31
|
*/
|
|
@@ -33,18 +36,17 @@ export function createOnTableUpdatedHandler(viewportData, deserializeRow) {
|
|
|
33
36
|
rows
|
|
34
37
|
} = event.detail;
|
|
35
38
|
log.debug('table updated', event.detail);
|
|
39
|
+
var updateKeyMap = new Map();
|
|
36
40
|
rows.forEach(row => {
|
|
37
41
|
var item = deserializeRow(row, columns);
|
|
38
|
-
var
|
|
39
|
-
|
|
42
|
+
var key = createKeyFromOffsetRow(row, offset);
|
|
43
|
+
updateKeyMap.set(key, {
|
|
44
|
+
key,
|
|
40
45
|
item
|
|
41
|
-
};
|
|
42
|
-
if (viewportData.getItem(keyedItem.key) != null) {
|
|
43
|
-
viewportData.update(keyedItem.key, keyedItem);
|
|
44
|
-
} else {
|
|
45
|
-
viewportData.append(keyedItem);
|
|
46
|
-
}
|
|
46
|
+
});
|
|
47
47
|
});
|
|
48
|
+
log.debug('update keys', updateKeyMap);
|
|
49
|
+
bulkUpdate(updateKeyMap);
|
|
48
50
|
};
|
|
49
51
|
}
|
|
50
52
|
|
|
@@ -80,19 +82,6 @@ export function* generateEmptyKeyedItems(start, end) {
|
|
|
80
82
|
}
|
|
81
83
|
}
|
|
82
84
|
|
|
83
|
-
/**
|
|
84
|
-
* Get items from a given ListData by a list of keys.
|
|
85
|
-
* @param listData ListData to get items from
|
|
86
|
-
* @param keys Keys to items to be retrieved
|
|
87
|
-
* @returns An array of items matching the given keys
|
|
88
|
-
*/
|
|
89
|
-
export function getItemsFromListData(listData) {
|
|
90
|
-
for (var _len = arguments.length, keys = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {
|
|
91
|
-
keys[_key - 1] = arguments[_key];
|
|
92
|
-
}
|
|
93
|
-
return keys.map(key => listData.getItem(key));
|
|
94
|
-
}
|
|
95
|
-
|
|
96
85
|
/**
|
|
97
86
|
* Check a Table to see if it is closed before checking its size property. This
|
|
98
87
|
* is important because calling Table.size on a closed table throws an error. If
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ViewportDataUtils.js","names":["clamp","Log","log","module","createKeyFromOffsetRow","row","offset","String","offsetInSnapshot","createOnTableUpdatedHandler","
|
|
1
|
+
{"version":3,"file":"ViewportDataUtils.js","names":["clamp","Log","log","module","createKeyFromOffsetRow","row","offset","String","offsetInSnapshot","createOnTableUpdatedHandler","deserializeRow","bulkUpdate","onTableUpdated","event","columns","rows","detail","debug","updateKeyMap","Map","forEach","item","key","set","defaultRowDeserializer","reduce","result","col","name","get","generateEmptyKeyedItems","start","end","i","getSize","table","isClosed","size","padFirstAndLastRow","firstRow","viewportSize","padding","tableSize","lastRow","min","max","first","last"],"sources":["../src/ViewportDataUtils.ts"],"sourcesContent":["import type { Key } from 'react';\nimport clamp from 'lodash.clamp';\nimport type { Column, Row, Table, TreeTable } from '@deephaven/jsapi-types';\nimport Log from '@deephaven/log';\nimport type { KeyedItem } from '@deephaven/utils';\n\nexport type OnTableUpdatedEvent = CustomEvent<{\n offset: number;\n columns: Column[];\n rows: ViewportRow[];\n}>;\n\nexport type RowDeserializer<T> = (row: ViewportRow, columns: Column[]) => T;\n\nexport type ViewportRow = Row & { offsetInSnapshot: number };\n\nconst log = Log.module('ViewportDataUtils');\n\n/**\n * Create a unique string key for a row based on its ordinal position in its\n * source table. This is calculated based on it's offset in the viewport\n * (row.offsetInSnapshot) + the offset of the snapshot.\n * @param row Row from a Table update event.\n * @param offset Offset of the current viewport.\n * @returns Unique string key for the oridinal position of the given row.\n */\nexport function createKeyFromOffsetRow(row: ViewportRow, offset: number) {\n return String(row.offsetInSnapshot + offset);\n}\n\n/**\n * Creates a handler function for a `dh.Table.EVENT_UPDATED` event. Rows that\n * get passed to the handler will be bulk updated in the given `viewportData`\n * object based on their derived item keys.\n * @param viewportData State object for managing a list of KeyedItem data.\n * @param deserializeRow Converts a DH Row to an item object.\n * @returns Handler function for a `dh.Table.EVENT_UPDATED` event.\n */\nexport function createOnTableUpdatedHandler<T>(\n { bulkUpdate }: { bulkUpdate: (itemMap: Map<Key, KeyedItem<T>>) => void },\n deserializeRow: RowDeserializer<T>\n): (event: OnTableUpdatedEvent) => void {\n /**\n * Handler for a `dh.Table.EVENT_UPDATED` event.\n */\n return function onTableUpdated(event: OnTableUpdatedEvent) {\n const { columns, offset, rows } = event.detail;\n\n log.debug('table updated', event.detail);\n\n const updateKeyMap = new Map<Key, KeyedItem<T>>();\n\n rows.forEach(row => {\n const item = deserializeRow(row, columns);\n const key = createKeyFromOffsetRow(row, offset);\n updateKeyMap.set(key, { key, item });\n });\n\n log.debug('update keys', updateKeyMap);\n\n bulkUpdate(updateKeyMap);\n };\n}\n\n/**\n * Maps a Row to a key / value object. Keys are mapped ver batim from column\n * names.\n * @param row Row to map to an item.\n * @param columns Columns to map.\n * @returns A key / value object for the row.\n */\nexport function defaultRowDeserializer<T>(\n row: ViewportRow,\n columns: Column[]\n): T {\n return columns.reduce((result, col) => {\n // eslint-disable-next-line no-param-reassign\n result[col.name as keyof T] = row.get(col);\n return result;\n }, {} as T);\n}\n\n/**\n * For windowing to work, the underlying list needs to maintain a KeyedItem for\n * each row in the backing table (even if these rows haven't been loaded yet).\n * This is needed internally by react-spectrum so it can calculate the content\n * area size. This generator can create a range of empty `KeyedItem` objects.\n * @param start The starting index to generate\n * @param end The ending index to generate\n */\nexport function* generateEmptyKeyedItems<T>(\n start: number,\n end: number\n): Generator<KeyedItem<T>, void, unknown> {\n // eslint-disable-next-line no-plusplus\n for (let i = start; i <= end; ++i) {\n yield { key: String(i) };\n }\n}\n\n/**\n * Check a Table to see if it is closed before checking its size property. This\n * is important because calling Table.size on a closed table throws an error. If\n * the table is null or closed, return zero. Otherwise, return the current size.\n * @param table The table to check for its size.\n * @returns The size of the table or zero if the table is null or closed.\n */\nexport function getSize(table?: Table | TreeTable | null): number {\n return table == null || isClosed(table) ? 0 : table.size;\n}\n\n/**\n * Check if a given table is closed. Tree tables don't have an `isClosed` prop,\n * so will always return false.\n * @param table The table to check if it is closed.\n */\nexport function isClosed(table: Table | TreeTable): boolean {\n if ('isClosed' in table) {\n return table.isClosed;\n }\n\n return false;\n}\n\n/**\n * Determine the first and last row index for a viewport + extra leading and\n * trailing padding. Values will be \"clamped\" to stay within the table size.\n * @param firstRow Starting row index for the viewport.\n * @param viewportSize Size of the viewport.\n * @param padding Extra rows to add to the viewport. Will be used for leading\n * and trailing rows.\n * @param tableSize Total table size.\n * @returns Tuple containing indices for the first and last row.\n */\nexport function padFirstAndLastRow(\n firstRow: number,\n viewportSize: number,\n padding: number,\n tableSize: number\n): [number, number] {\n const lastRow = firstRow + viewportSize - 1;\n const [min, max] = [0, tableSize - 1];\n\n const first = clamp(firstRow - padding, min, max);\n const last = clamp(lastRow + padding, min, max);\n\n return [first, last];\n}\n"],"mappings":"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"}
|
package/dist/index.d.ts
CHANGED
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,mBAAmB,CAAC;AAClC,cAAc,cAAc,CAAC;AAC7B,cAAc,aAAa,CAAC;AAC5B,cAAc,aAAa,CAAC;AAC5B,OAAO,EAAE,OAAO,IAAI,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAC7D,cAAc,kBAAkB,CAAC;AACjC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,mBAAmB,CAAC;AAClC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,YAAY,CAAC;AAC3B,cAAc,cAAc,CAAC;AAC7B,cAAc,qBAAqB,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,mBAAmB,CAAC;AAClC,cAAc,cAAc,CAAC;AAC7B,cAAc,aAAa,CAAC;AAC5B,cAAc,eAAe,CAAC;AAC9B,cAAc,aAAa,CAAC;AAC5B,OAAO,EAAE,OAAO,IAAI,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAC7D,cAAc,kBAAkB,CAAC;AACjC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,mBAAmB,CAAC;AAClC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,YAAY,CAAC;AAC3B,cAAc,cAAc,CAAC;AAC7B,cAAc,qBAAqB,CAAC"}
|
package/dist/index.js
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
export * from "./ConnectionUtils.js";
|
|
2
2
|
export * from "./formatters/index.js";
|
|
3
3
|
export * from "./DateUtils.js";
|
|
4
|
+
export * from "./FilterUtils.js";
|
|
4
5
|
export * from "./Formatter.js";
|
|
5
6
|
export { default as FormatterUtils } from "./FormatterUtils.js";
|
|
6
7
|
export * from "./FormatterUtils.js";
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","names":["default","FormatterUtils"],"sources":["../src/index.ts"],"sourcesContent":["export * from './ConnectionUtils';\nexport * from './formatters';\nexport * from './DateUtils';\nexport * from './Formatter';\nexport { default as FormatterUtils } from './FormatterUtils';\nexport * from './FormatterUtils';\nexport * from './MessageUtils';\nexport * from './NoConsolesError';\nexport * from './SessionUtils';\nexport * from './Settings';\nexport * from './TableUtils';\nexport * from './ViewportDataUtils';\n"],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.js","names":["default","FormatterUtils"],"sources":["../src/index.ts"],"sourcesContent":["export * from './ConnectionUtils';\nexport * from './formatters';\nexport * from './DateUtils';\nexport * from './FilterUtils';\nexport * from './Formatter';\nexport { default as FormatterUtils } from './FormatterUtils';\nexport * from './FormatterUtils';\nexport * from './MessageUtils';\nexport * from './NoConsolesError';\nexport * from './SessionUtils';\nexport * from './Settings';\nexport * from './TableUtils';\nexport * from './ViewportDataUtils';\n"],"mappings":";;;;;SAKSA,OAAO,IAAIC,cAAc;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@deephaven/jsapi-utils",
|
|
3
|
-
"version": "0.47.1-beta.
|
|
3
|
+
"version": "0.47.1-beta.2+b43b5b21",
|
|
4
4
|
"description": "Deephaven JSAPI Utils",
|
|
5
5
|
"author": "Deephaven Data Labs LLC",
|
|
6
6
|
"license": "Apache-2.0",
|
|
@@ -21,16 +21,15 @@
|
|
|
21
21
|
"build:babel": "babel ./src --out-dir ./dist --extensions \".ts,.tsx,.js,.jsx\" --source-maps --root-mode upward"
|
|
22
22
|
},
|
|
23
23
|
"dependencies": {
|
|
24
|
-
"@deephaven/filters": "^0.47.1-beta.
|
|
25
|
-
"@deephaven/jsapi-types": "^0.47.1-beta.
|
|
26
|
-
"@deephaven/log": "^0.47.1-beta.
|
|
27
|
-
"@deephaven/utils": "^0.47.1-beta.
|
|
28
|
-
"@react-stately/data": "^3.9.1",
|
|
24
|
+
"@deephaven/filters": "^0.47.1-beta.2+b43b5b21",
|
|
25
|
+
"@deephaven/jsapi-types": "^0.47.1-beta.2+b43b5b21",
|
|
26
|
+
"@deephaven/log": "^0.47.1-beta.2+b43b5b21",
|
|
27
|
+
"@deephaven/utils": "^0.47.1-beta.2+b43b5b21",
|
|
29
28
|
"lodash.clamp": "^4.0.3",
|
|
30
29
|
"shortid": "^2.2.16"
|
|
31
30
|
},
|
|
32
31
|
"devDependencies": {
|
|
33
|
-
"@deephaven/jsapi-shim": "^0.47.1-beta.
|
|
32
|
+
"@deephaven/jsapi-shim": "^0.47.1-beta.2+b43b5b21"
|
|
34
33
|
},
|
|
35
34
|
"files": [
|
|
36
35
|
"dist"
|
|
@@ -39,5 +38,5 @@
|
|
|
39
38
|
"publishConfig": {
|
|
40
39
|
"access": "public"
|
|
41
40
|
},
|
|
42
|
-
"gitHead": "
|
|
41
|
+
"gitHead": "b43b5b21a2ac78b02792f6e14e56ce31bc507a5a"
|
|
43
42
|
}
|