@deephaven/iris-grid 0.43.0 → 0.44.0
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/AdvancedFilterCreator.css +106 -0
- package/dist/AdvancedFilterCreator.css.map +1 -0
- package/dist/AdvancedFilterCreator.js +541 -0
- package/dist/AdvancedFilterCreator.js.map +1 -0
- package/dist/AdvancedFilterCreatorFilterItem.css +9 -0
- package/dist/AdvancedFilterCreatorFilterItem.css.map +1 -0
- package/dist/AdvancedFilterCreatorFilterItem.js +184 -0
- package/dist/AdvancedFilterCreatorFilterItem.js.map +1 -0
- package/dist/AdvancedFilterCreatorSelectValue.css +50 -0
- package/dist/AdvancedFilterCreatorSelectValue.css.map +1 -0
- package/dist/AdvancedFilterCreatorSelectValue.js +301 -0
- package/dist/AdvancedFilterCreatorSelectValue.js.map +1 -0
- package/dist/AdvancedFilterCreatorSelectValueList.js +272 -0
- package/dist/AdvancedFilterCreatorSelectValueList.js.map +1 -0
- package/dist/ColumnHeaderGroup.js +61 -0
- package/dist/ColumnHeaderGroup.js.map +1 -0
- package/dist/ColumnStatistics.css +76 -0
- package/dist/ColumnStatistics.css.map +1 -0
- package/dist/ColumnStatistics.js +202 -0
- package/dist/ColumnStatistics.js.map +1 -0
- package/dist/CommonTypes.js +2 -0
- package/dist/CommonTypes.js.map +1 -0
- package/dist/CrossColumnSearch.css +35 -0
- package/dist/CrossColumnSearch.css.map +1 -0
- package/dist/CrossColumnSearch.js +199 -0
- package/dist/CrossColumnSearch.js.map +1 -0
- package/dist/FilterInputField.css +56 -0
- package/dist/FilterInputField.css.map +1 -0
- package/dist/FilterInputField.js +232 -0
- package/dist/FilterInputField.js.map +1 -0
- package/dist/GotoRow.css +45 -0
- package/dist/GotoRow.css.map +1 -0
- package/dist/GotoRow.js +298 -0
- package/dist/GotoRow.js.map +1 -0
- package/dist/IrisGrid.css +359 -0
- package/dist/IrisGrid.css.map +1 -0
- package/dist/IrisGrid.js +3651 -0
- package/dist/IrisGrid.js.map +1 -0
- package/dist/IrisGridBottomBar.css +85 -0
- package/dist/IrisGridBottomBar.css.map +1 -0
- package/dist/IrisGridBottomBar.js +36 -0
- package/dist/IrisGridBottomBar.js.map +1 -0
- package/dist/IrisGridCellOverflowModal.css +17 -0
- package/dist/IrisGridCellOverflowModal.css.map +1 -0
- package/dist/IrisGridCellOverflowModal.js +157 -0
- package/dist/IrisGridCellOverflowModal.js.map +1 -0
- package/dist/IrisGridCellRendererUtils.js +20 -0
- package/dist/IrisGridCellRendererUtils.js.map +1 -0
- package/dist/IrisGridCopyHandler.css +64 -0
- package/dist/IrisGridCopyHandler.css.map +1 -0
- package/dist/IrisGridCopyHandler.js +331 -0
- package/dist/IrisGridCopyHandler.js.map +1 -0
- package/dist/IrisGridDataBarCellRenderer.js +10 -0
- package/dist/IrisGridDataBarCellRenderer.js.map +1 -0
- package/dist/IrisGridIcons.js +25 -0
- package/dist/IrisGridIcons.js.map +1 -0
- package/dist/IrisGridMetricCalculator.js +33 -0
- package/dist/IrisGridMetricCalculator.js.map +1 -0
- package/dist/IrisGridModel.js +263 -0
- package/dist/IrisGridModel.js.map +1 -0
- package/dist/IrisGridModelFactory.js +27 -0
- package/dist/IrisGridModelFactory.js.map +1 -0
- package/dist/IrisGridModelUpdater.js +96 -0
- package/dist/IrisGridModelUpdater.js.map +1 -0
- package/dist/IrisGridPartitionSelector.css +48 -0
- package/dist/IrisGridPartitionSelector.css.map +1 -0
- package/dist/IrisGridPartitionSelector.js +198 -0
- package/dist/IrisGridPartitionSelector.js.map +1 -0
- package/dist/IrisGridProxyModel.js +530 -0
- package/dist/IrisGridProxyModel.js.map +1 -0
- package/dist/IrisGridRenderer.js +779 -0
- package/dist/IrisGridRenderer.js.map +1 -0
- package/dist/IrisGridShortcuts.js +59 -0
- package/dist/IrisGridShortcuts.js.map +1 -0
- package/dist/IrisGridTableModel.js +273 -0
- package/dist/IrisGridTableModel.js.map +1 -0
- package/dist/IrisGridTableModelTemplate.js +1589 -0
- package/dist/IrisGridTableModelTemplate.js.map +1 -0
- package/dist/IrisGridTestUtils.js +121 -0
- package/dist/IrisGridTestUtils.js.map +1 -0
- package/dist/IrisGridTextCellRenderer.js +139 -0
- package/dist/IrisGridTextCellRenderer.js.map +1 -0
- package/dist/IrisGridTheme.js +96 -0
- package/dist/IrisGridTheme.js.map +1 -0
- package/dist/IrisGridTheme.module.css +69 -0
- package/dist/IrisGridTheme.module.css.map +1 -0
- package/dist/IrisGridTreeTableModel.js +145 -0
- package/dist/IrisGridTreeTableModel.js.map +1 -0
- package/dist/IrisGridUtils.js +1279 -0
- package/dist/IrisGridUtils.js.map +1 -0
- package/dist/MissingKeyError.js +15 -0
- package/dist/MissingKeyError.js.map +1 -0
- package/dist/PartitionSelectorSearch.css +22 -0
- package/dist/PartitionSelectorSearch.css.map +1 -0
- package/dist/PartitionSelectorSearch.js +317 -0
- package/dist/PartitionSelectorSearch.js.map +1 -0
- package/dist/PendingDataBottomBar.css +13 -0
- package/dist/PendingDataBottomBar.css.map +1 -0
- package/dist/PendingDataBottomBar.js +98 -0
- package/dist/PendingDataBottomBar.js.map +1 -0
- package/dist/TableViewportUpdater.js +156 -0
- package/dist/TableViewportUpdater.js.map +1 -0
- package/dist/ToastBottomBar.js +42 -0
- package/dist/ToastBottomBar.js.map +1 -0
- package/dist/TreeTableViewportUpdater.js +96 -0
- package/dist/TreeTableViewportUpdater.js.map +1 -0
- package/dist/declaration.d.js +2 -0
- package/dist/declaration.d.js.map +1 -0
- package/dist/format-context-menus/CustomFormatAction.css +25 -0
- package/dist/format-context-menus/CustomFormatAction.css.map +1 -0
- package/dist/format-context-menus/CustomFormatAction.js +132 -0
- package/dist/format-context-menus/CustomFormatAction.js.map +1 -0
- package/dist/format-context-menus/DateTimeFormatContextMenu.js +53 -0
- package/dist/format-context-menus/DateTimeFormatContextMenu.js.map +1 -0
- package/dist/format-context-menus/DecimalFormatContextMenu.js +59 -0
- package/dist/format-context-menus/DecimalFormatContextMenu.js.map +1 -0
- package/dist/format-context-menus/FormatContextMenuUtils.js +63 -0
- package/dist/format-context-menus/FormatContextMenuUtils.js.map +1 -0
- package/dist/format-context-menus/IntegerFormatContextMenu.js +43 -0
- package/dist/format-context-menus/IntegerFormatContextMenu.js.map +1 -0
- package/dist/format-context-menus/index.js +4 -0
- package/dist/format-context-menus/index.js.map +1 -0
- package/dist/index.js +24 -0
- package/dist/index.js.map +1 -0
- package/dist/key-handlers/ClearFilterKeyHandler.js +21 -0
- package/dist/key-handlers/ClearFilterKeyHandler.js.map +1 -0
- package/dist/key-handlers/CopyKeyHandler.js +31 -0
- package/dist/key-handlers/CopyKeyHandler.js.map +1 -0
- package/dist/key-handlers/ReverseKeyHandler.js +32 -0
- package/dist/key-handlers/ReverseKeyHandler.js.map +1 -0
- package/dist/key-handlers/index.js +4 -0
- package/dist/key-handlers/index.js.map +1 -0
- package/dist/mousehandlers/IrisGridCellOverflowMouseHandler.js +175 -0
- package/dist/mousehandlers/IrisGridCellOverflowMouseHandler.js.map +1 -0
- package/dist/mousehandlers/IrisGridColumnSelectMouseHandler.js +139 -0
- package/dist/mousehandlers/IrisGridColumnSelectMouseHandler.js.map +1 -0
- package/dist/mousehandlers/IrisGridColumnTooltipMouseHandler.js +83 -0
- package/dist/mousehandlers/IrisGridColumnTooltipMouseHandler.js.map +1 -0
- package/dist/mousehandlers/IrisGridContextMenuHandler.css +19 -0
- package/dist/mousehandlers/IrisGridContextMenuHandler.css.map +1 -0
- package/dist/mousehandlers/IrisGridContextMenuHandler.js +1220 -0
- package/dist/mousehandlers/IrisGridContextMenuHandler.js.map +1 -0
- package/dist/mousehandlers/IrisGridDataSelectMouseHandler.js +28 -0
- package/dist/mousehandlers/IrisGridDataSelectMouseHandler.js.map +1 -0
- package/dist/mousehandlers/IrisGridFilterMouseHandler.js +80 -0
- package/dist/mousehandlers/IrisGridFilterMouseHandler.js.map +1 -0
- package/dist/mousehandlers/IrisGridRowTreeMouseHandler.js +126 -0
- package/dist/mousehandlers/IrisGridRowTreeMouseHandler.js.map +1 -0
- package/dist/mousehandlers/IrisGridSortMouseHandler.js +46 -0
- package/dist/mousehandlers/IrisGridSortMouseHandler.js.map +1 -0
- package/dist/mousehandlers/IrisGridTokenMouseHandler.js +151 -0
- package/dist/mousehandlers/IrisGridTokenMouseHandler.js.map +1 -0
- package/dist/mousehandlers/PendingMouseHandler.js +39 -0
- package/dist/mousehandlers/PendingMouseHandler.js.map +1 -0
- package/dist/mousehandlers/index.js +11 -0
- package/dist/mousehandlers/index.js.map +1 -0
- package/dist/sidebar/AdvancedSettings.js +6 -0
- package/dist/sidebar/AdvancedSettings.js.map +1 -0
- package/dist/sidebar/AdvancedSettingsMenu.js +29 -0
- package/dist/sidebar/AdvancedSettingsMenu.js.map +1 -0
- package/dist/sidebar/AdvancedSettingsType.js +7 -0
- package/dist/sidebar/AdvancedSettingsType.js.map +1 -0
- package/dist/sidebar/ChartBuilder.css +56 -0
- package/dist/sidebar/ChartBuilder.css.map +1 -0
- package/dist/sidebar/ChartBuilder.js +443 -0
- package/dist/sidebar/ChartBuilder.js.map +1 -0
- package/dist/sidebar/CustomColumnBuilder.css +58 -0
- package/dist/sidebar/CustomColumnBuilder.css.map +1 -0
- package/dist/sidebar/CustomColumnBuilder.js +384 -0
- package/dist/sidebar/CustomColumnBuilder.js.map +1 -0
- package/dist/sidebar/CustomColumnInput.d.ts.map +1 -1
- package/dist/sidebar/CustomColumnInput.js +91 -0
- package/dist/sidebar/CustomColumnInput.js.map +1 -0
- package/dist/sidebar/InputEditor.css +35 -0
- package/dist/sidebar/InputEditor.css.map +1 -0
- package/dist/sidebar/InputEditor.d.ts +4 -2
- package/dist/sidebar/InputEditor.d.ts.map +1 -1
- package/dist/sidebar/InputEditor.js +180 -0
- package/dist/sidebar/InputEditor.js.map +1 -0
- package/dist/sidebar/OptionType.js +19 -0
- package/dist/sidebar/OptionType.js.map +1 -0
- package/dist/sidebar/RollupRows.css +120 -0
- package/dist/sidebar/RollupRows.css.map +1 -0
- package/dist/sidebar/RollupRows.js +519 -0
- package/dist/sidebar/RollupRows.js.map +1 -0
- package/dist/sidebar/SelectDistinctBuilder.css +41 -0
- package/dist/sidebar/SelectDistinctBuilder.css.map +1 -0
- package/dist/sidebar/SelectDistinctBuilder.js +155 -0
- package/dist/sidebar/SelectDistinctBuilder.js.map +1 -0
- package/dist/sidebar/TableCsvExporter.css +32 -0
- package/dist/sidebar/TableCsvExporter.css.map +1 -0
- package/dist/sidebar/TableCsvExporter.js +399 -0
- package/dist/sidebar/TableCsvExporter.js.map +1 -0
- package/dist/sidebar/TableSaver.js +487 -0
- package/dist/sidebar/TableSaver.js.map +1 -0
- package/dist/sidebar/aggregations/AggregationEdit.css +61 -0
- package/dist/sidebar/aggregations/AggregationEdit.css.map +1 -0
- package/dist/sidebar/aggregations/AggregationEdit.js +155 -0
- package/dist/sidebar/aggregations/AggregationEdit.js.map +1 -0
- package/dist/sidebar/aggregations/AggregationOperation.js +19 -0
- package/dist/sidebar/aggregations/AggregationOperation.js.map +1 -0
- package/dist/sidebar/aggregations/AggregationUtils.js +59 -0
- package/dist/sidebar/aggregations/AggregationUtils.js.map +1 -0
- package/dist/sidebar/aggregations/Aggregations.css +43 -0
- package/dist/sidebar/aggregations/Aggregations.css.map +1 -0
- package/dist/sidebar/aggregations/Aggregations.js +178 -0
- package/dist/sidebar/aggregations/Aggregations.js.map +1 -0
- package/dist/sidebar/aggregations/index.js +2 -0
- package/dist/sidebar/aggregations/index.js.map +1 -0
- package/dist/sidebar/conditional-formatting/ColumnFormatEditor.js +123 -0
- package/dist/sidebar/conditional-formatting/ColumnFormatEditor.js.map +1 -0
- package/dist/sidebar/conditional-formatting/ConditionEditor.js +243 -0
- package/dist/sidebar/conditional-formatting/ConditionEditor.js.map +1 -0
- package/dist/sidebar/conditional-formatting/ConditionalFormatEditor.css +22 -0
- package/dist/sidebar/conditional-formatting/ConditionalFormatEditor.css.map +1 -0
- package/dist/sidebar/conditional-formatting/ConditionalFormatEditor.js +109 -0
- package/dist/sidebar/conditional-formatting/ConditionalFormatEditor.js.map +1 -0
- package/dist/sidebar/conditional-formatting/ConditionalFormattingAPIUtils.js +18 -0
- package/dist/sidebar/conditional-formatting/ConditionalFormattingAPIUtils.js.map +1 -0
- package/dist/sidebar/conditional-formatting/ConditionalFormattingMenu.css +57 -0
- package/dist/sidebar/conditional-formatting/ConditionalFormattingMenu.css.map +1 -0
- package/dist/sidebar/conditional-formatting/ConditionalFormattingMenu.js +150 -0
- package/dist/sidebar/conditional-formatting/ConditionalFormattingMenu.js.map +1 -0
- package/dist/sidebar/conditional-formatting/ConditionalFormattingUtils.js +635 -0
- package/dist/sidebar/conditional-formatting/ConditionalFormattingUtils.js.map +1 -0
- package/dist/sidebar/conditional-formatting/RowFormatEditor.js +122 -0
- package/dist/sidebar/conditional-formatting/RowFormatEditor.js.map +1 -0
- package/dist/sidebar/conditional-formatting/StyleEditor.css +55 -0
- package/dist/sidebar/conditional-formatting/StyleEditor.css.map +1 -0
- package/dist/sidebar/conditional-formatting/StyleEditor.js +150 -0
- package/dist/sidebar/conditional-formatting/StyleEditor.js.map +1 -0
- package/dist/sidebar/icons/BarIcon.js +24 -0
- package/dist/sidebar/icons/BarIcon.js.map +1 -0
- package/dist/sidebar/icons/FormatColumnWhereIcon.js +42 -0
- package/dist/sidebar/icons/FormatColumnWhereIcon.js.map +1 -0
- package/dist/sidebar/icons/FormatRowWhereIcon.js +36 -0
- package/dist/sidebar/icons/FormatRowWhereIcon.js.map +1 -0
- package/dist/sidebar/icons/HistogramIcon.js +24 -0
- package/dist/sidebar/icons/HistogramIcon.js.map +1 -0
- package/dist/sidebar/icons/LineIcon.js +27 -0
- package/dist/sidebar/icons/LineIcon.js.map +1 -0
- package/dist/sidebar/icons/PieIcon.js +24 -0
- package/dist/sidebar/icons/PieIcon.js.map +1 -0
- package/dist/sidebar/icons/ScatterIcon.js +74 -0
- package/dist/sidebar/icons/ScatterIcon.js.map +1 -0
- package/dist/sidebar/icons/index.js +8 -0
- package/dist/sidebar/icons/index.js.map +1 -0
- package/dist/sidebar/index.d.ts +1 -0
- package/dist/sidebar/index.d.ts.map +1 -1
- package/dist/sidebar/index.js +19 -0
- package/dist/sidebar/index.js.map +1 -0
- package/dist/sidebar/visibility-ordering-builder/VisibilityOrderingBuilder.css +68 -0
- package/dist/sidebar/visibility-ordering-builder/VisibilityOrderingBuilder.css.map +1 -0
- package/dist/sidebar/visibility-ordering-builder/VisibilityOrderingBuilder.js +964 -0
- package/dist/sidebar/visibility-ordering-builder/VisibilityOrderingBuilder.js.map +1 -0
- package/dist/sidebar/visibility-ordering-builder/VisibilityOrderingBuilderUtils.js +132 -0
- package/dist/sidebar/visibility-ordering-builder/VisibilityOrderingBuilderUtils.js.map +1 -0
- package/dist/sidebar/visibility-ordering-builder/VisibilityOrderingGroup.css +29 -0
- package/dist/sidebar/visibility-ordering-builder/VisibilityOrderingGroup.css.map +1 -0
- package/dist/sidebar/visibility-ordering-builder/VisibilityOrderingGroup.js +188 -0
- package/dist/sidebar/visibility-ordering-builder/VisibilityOrderingGroup.js.map +1 -0
- package/dist/sidebar/visibility-ordering-builder/VisibilityOrderingItem.js +81 -0
- package/dist/sidebar/visibility-ordering-builder/VisibilityOrderingItem.js.map +1 -0
- package/dist/sidebar/visibility-ordering-builder/sortable-tree/PointerSensorWithInteraction.js +30 -0
- package/dist/sidebar/visibility-ordering-builder/sortable-tree/PointerSensorWithInteraction.js.map +1 -0
- package/dist/sidebar/visibility-ordering-builder/sortable-tree/SortableTree.js +158 -0
- package/dist/sidebar/visibility-ordering-builder/sortable-tree/SortableTree.js.map +1 -0
- package/dist/sidebar/visibility-ordering-builder/sortable-tree/SortableTreeInner.js +146 -0
- package/dist/sidebar/visibility-ordering-builder/sortable-tree/SortableTreeInner.js.map +1 -0
- package/dist/sidebar/visibility-ordering-builder/sortable-tree/SortableTreeItem.js +59 -0
- package/dist/sidebar/visibility-ordering-builder/sortable-tree/SortableTreeItem.js.map +1 -0
- package/dist/sidebar/visibility-ordering-builder/sortable-tree/TreeItem.css +139 -0
- package/dist/sidebar/visibility-ordering-builder/sortable-tree/TreeItem.css.map +1 -0
- package/dist/sidebar/visibility-ordering-builder/sortable-tree/TreeItem.js +44 -0
- package/dist/sidebar/visibility-ordering-builder/sortable-tree/TreeItem.js.map +1 -0
- package/dist/sidebar/visibility-ordering-builder/sortable-tree/keyboardCoordinates.js +129 -0
- package/dist/sidebar/visibility-ordering-builder/sortable-tree/keyboardCoordinates.js.map +1 -0
- package/dist/sidebar/visibility-ordering-builder/sortable-tree/types.js +4 -0
- package/dist/sidebar/visibility-ordering-builder/sortable-tree/types.js.map +1 -0
- package/dist/sidebar/visibility-ordering-builder/sortable-tree/utilities.js +261 -0
- package/dist/sidebar/visibility-ordering-builder/sortable-tree/utilities.js.map +1 -0
- package/package.json +15 -15
|
@@ -0,0 +1,635 @@
|
|
|
1
|
+
import Log from '@deephaven/log';
|
|
2
|
+
import { DateUtils, TableUtils } from '@deephaven/jsapi-utils';
|
|
3
|
+
import { makeColumnFormatColumn, makeRowFormatColumn, makeTernaryFormatRule } from "./ConditionalFormattingAPIUtils.js";
|
|
4
|
+
var log = Log.module('ConditionalFormattingUtils');
|
|
5
|
+
export var FormatterType;
|
|
6
|
+
(function (FormatterType) {
|
|
7
|
+
FormatterType["CONDITIONAL"] = "conditional";
|
|
8
|
+
FormatterType["ROWS"] = "rows";
|
|
9
|
+
})(FormatterType || (FormatterType = {}));
|
|
10
|
+
export var NumberCondition;
|
|
11
|
+
(function (NumberCondition) {
|
|
12
|
+
NumberCondition["IS_EQUAL"] = "is-equal";
|
|
13
|
+
NumberCondition["IS_NOT_EQUAL"] = "is-not-equal";
|
|
14
|
+
NumberCondition["IS_BETWEEN"] = "is-between";
|
|
15
|
+
NumberCondition["GREATER_THAN"] = "greater-than";
|
|
16
|
+
NumberCondition["GREATER_THAN_OR_EQUAL"] = "greater-than-or-equal";
|
|
17
|
+
NumberCondition["LESS_THAN"] = "less-than";
|
|
18
|
+
NumberCondition["LESS_THAN_OR_EQUAL"] = "less-than-or-equal";
|
|
19
|
+
NumberCondition["IS_NULL"] = "is-null";
|
|
20
|
+
NumberCondition["IS_NOT_NULL"] = "is-not-null";
|
|
21
|
+
})(NumberCondition || (NumberCondition = {}));
|
|
22
|
+
export var StringCondition;
|
|
23
|
+
(function (StringCondition) {
|
|
24
|
+
StringCondition["IS_EXACTLY"] = "is-exactly";
|
|
25
|
+
StringCondition["IS_NOT_EXACTLY"] = "is-not-exactly";
|
|
26
|
+
StringCondition["CONTAINS"] = "contains";
|
|
27
|
+
StringCondition["DOES_NOT_CONTAIN"] = "does-not-contain";
|
|
28
|
+
StringCondition["STARTS_WITH"] = "starts-with";
|
|
29
|
+
StringCondition["ENDS_WITH"] = "ends-with";
|
|
30
|
+
StringCondition["IS_NULL"] = "is-null";
|
|
31
|
+
StringCondition["IS_NOT_NULL"] = "is-not-null";
|
|
32
|
+
})(StringCondition || (StringCondition = {}));
|
|
33
|
+
export var DateCondition;
|
|
34
|
+
(function (DateCondition) {
|
|
35
|
+
DateCondition["IS_EXACTLY"] = "is-exactly";
|
|
36
|
+
DateCondition["IS_NOT_EXACTLY"] = "is-not-exactly";
|
|
37
|
+
DateCondition["IS_BEFORE"] = "is-before";
|
|
38
|
+
DateCondition["IS_BEFORE_OR_EQUAL"] = "is-before-or-equal";
|
|
39
|
+
DateCondition["IS_AFTER"] = "is-after";
|
|
40
|
+
DateCondition["IS_AFTER_OR_EQUAL"] = "is-after-or-equal";
|
|
41
|
+
DateCondition["IS_NULL"] = "is-null";
|
|
42
|
+
DateCondition["IS_NOT_NULL"] = "is-not-null";
|
|
43
|
+
})(DateCondition || (DateCondition = {}));
|
|
44
|
+
export var BooleanCondition;
|
|
45
|
+
(function (BooleanCondition) {
|
|
46
|
+
BooleanCondition["IS_TRUE"] = "is-true";
|
|
47
|
+
BooleanCondition["IS_FALSE"] = "is-false";
|
|
48
|
+
BooleanCondition["IS_NULL"] = "is-null";
|
|
49
|
+
BooleanCondition["IS_NOT_NULL"] = "is-not-null";
|
|
50
|
+
})(BooleanCondition || (BooleanCondition = {}));
|
|
51
|
+
export var CharCondition;
|
|
52
|
+
(function (CharCondition) {
|
|
53
|
+
CharCondition["IS_EQUAL"] = "is-equal";
|
|
54
|
+
CharCondition["IS_NOT_EQUAL"] = "is-not-equal";
|
|
55
|
+
CharCondition["IS_NULL"] = "is-null";
|
|
56
|
+
CharCondition["IS_NOT_NULL"] = "is-not-null";
|
|
57
|
+
})(CharCondition || (CharCondition = {}));
|
|
58
|
+
export var FormatStyleType;
|
|
59
|
+
(function (FormatStyleType) {
|
|
60
|
+
FormatStyleType["NO_FORMATTING"] = "no-formatting";
|
|
61
|
+
FormatStyleType["POSITIVE"] = "positive";
|
|
62
|
+
FormatStyleType["NEGATIVE"] = "negative";
|
|
63
|
+
FormatStyleType["WARN"] = "warn";
|
|
64
|
+
FormatStyleType["NEUTRAL"] = "neutral";
|
|
65
|
+
FormatStyleType["ACCENT_1"] = "accent-1";
|
|
66
|
+
FormatStyleType["ACCENT_2"] = "accent-2";
|
|
67
|
+
FormatStyleType["CUSTOM"] = "custom";
|
|
68
|
+
})(FormatStyleType || (FormatStyleType = {}));
|
|
69
|
+
export function getLabelForStyleType(option) {
|
|
70
|
+
switch (option) {
|
|
71
|
+
case FormatStyleType.NO_FORMATTING:
|
|
72
|
+
return 'No formatting';
|
|
73
|
+
case FormatStyleType.POSITIVE:
|
|
74
|
+
return 'Positive';
|
|
75
|
+
case FormatStyleType.NEGATIVE:
|
|
76
|
+
return 'Negative';
|
|
77
|
+
case FormatStyleType.WARN:
|
|
78
|
+
return 'Warn';
|
|
79
|
+
case FormatStyleType.NEUTRAL:
|
|
80
|
+
return 'Neutral';
|
|
81
|
+
case FormatStyleType.ACCENT_1:
|
|
82
|
+
return 'Accent 1';
|
|
83
|
+
case FormatStyleType.ACCENT_2:
|
|
84
|
+
return 'Accent 2';
|
|
85
|
+
case FormatStyleType.CUSTOM:
|
|
86
|
+
return 'Custom...';
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
export function getBackgroundForStyleConfig(config) {
|
|
90
|
+
var {
|
|
91
|
+
type,
|
|
92
|
+
customConfig
|
|
93
|
+
} = config;
|
|
94
|
+
switch (type) {
|
|
95
|
+
case FormatStyleType.NO_FORMATTING:
|
|
96
|
+
return undefined;
|
|
97
|
+
case FormatStyleType.POSITIVE:
|
|
98
|
+
return '#9fde6f';
|
|
99
|
+
case FormatStyleType.NEGATIVE:
|
|
100
|
+
return '#ff6087';
|
|
101
|
+
case FormatStyleType.WARN:
|
|
102
|
+
return '#f67f40';
|
|
103
|
+
case FormatStyleType.NEUTRAL:
|
|
104
|
+
return '#ffd95c';
|
|
105
|
+
case FormatStyleType.ACCENT_1:
|
|
106
|
+
return '#78dce8';
|
|
107
|
+
case FormatStyleType.ACCENT_2:
|
|
108
|
+
return '#ab9bf5';
|
|
109
|
+
case FormatStyleType.CUSTOM:
|
|
110
|
+
return customConfig === null || customConfig === void 0 ? void 0 : customConfig.background;
|
|
111
|
+
default:
|
|
112
|
+
return undefined;
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
export function getColorForStyleConfig(config) {
|
|
116
|
+
var {
|
|
117
|
+
type,
|
|
118
|
+
customConfig
|
|
119
|
+
} = config;
|
|
120
|
+
switch (type) {
|
|
121
|
+
case FormatStyleType.NO_FORMATTING:
|
|
122
|
+
return undefined;
|
|
123
|
+
case FormatStyleType.POSITIVE:
|
|
124
|
+
return '#526a3f';
|
|
125
|
+
case FormatStyleType.NEGATIVE:
|
|
126
|
+
return '#802f44';
|
|
127
|
+
case FormatStyleType.WARN:
|
|
128
|
+
return '#663318';
|
|
129
|
+
case FormatStyleType.NEUTRAL:
|
|
130
|
+
return '#63562b';
|
|
131
|
+
case FormatStyleType.ACCENT_1:
|
|
132
|
+
return '#3f6469';
|
|
133
|
+
case FormatStyleType.ACCENT_2:
|
|
134
|
+
return '#554d72';
|
|
135
|
+
case FormatStyleType.CUSTOM:
|
|
136
|
+
return customConfig === null || customConfig === void 0 ? void 0 : customConfig.color;
|
|
137
|
+
default:
|
|
138
|
+
return undefined;
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
export function getStyleDBString(config) {
|
|
142
|
+
var color = getColorForStyleConfig(config.style);
|
|
143
|
+
var bg = getBackgroundForStyleConfig(config.style);
|
|
144
|
+
if (color === undefined || bg === undefined) {
|
|
145
|
+
return undefined;
|
|
146
|
+
}
|
|
147
|
+
return "bgfg(`".concat(bg, "`, `").concat(color, "`)");
|
|
148
|
+
}
|
|
149
|
+
function getNumberConditionText(config) {
|
|
150
|
+
var {
|
|
151
|
+
column,
|
|
152
|
+
value,
|
|
153
|
+
start,
|
|
154
|
+
end
|
|
155
|
+
} = config;
|
|
156
|
+
return getTextForNumberCondition(column.name, config.condition, value, start, end);
|
|
157
|
+
}
|
|
158
|
+
function getStringConditionText(config) {
|
|
159
|
+
var {
|
|
160
|
+
column,
|
|
161
|
+
value
|
|
162
|
+
} = config;
|
|
163
|
+
return getTextForStringCondition(column.name, config.condition, value);
|
|
164
|
+
}
|
|
165
|
+
function getDateConditionText(config) {
|
|
166
|
+
var {
|
|
167
|
+
column,
|
|
168
|
+
value
|
|
169
|
+
} = config;
|
|
170
|
+
return getTextForDateCondition(column.name, config.condition, value);
|
|
171
|
+
}
|
|
172
|
+
function getBooleanConditionText(config) {
|
|
173
|
+
var {
|
|
174
|
+
column
|
|
175
|
+
} = config;
|
|
176
|
+
return getTextForBooleanCondition(column.name, config.condition);
|
|
177
|
+
}
|
|
178
|
+
function getCharConditionText(config) {
|
|
179
|
+
var {
|
|
180
|
+
column,
|
|
181
|
+
value
|
|
182
|
+
} = config;
|
|
183
|
+
return getTextForCharCondition(column.name, config.condition, value);
|
|
184
|
+
}
|
|
185
|
+
export function getConditionDBString(config) {
|
|
186
|
+
var {
|
|
187
|
+
column
|
|
188
|
+
} = config;
|
|
189
|
+
if (TableUtils.isNumberType(column.type)) {
|
|
190
|
+
return getNumberConditionText(config);
|
|
191
|
+
}
|
|
192
|
+
if (TableUtils.isCharType(column.type)) {
|
|
193
|
+
return getCharConditionText(config);
|
|
194
|
+
}
|
|
195
|
+
if (TableUtils.isStringType(column.type)) {
|
|
196
|
+
return getStringConditionText(config);
|
|
197
|
+
}
|
|
198
|
+
if (TableUtils.isDateType(column.type)) {
|
|
199
|
+
return getDateConditionText(config);
|
|
200
|
+
}
|
|
201
|
+
if (TableUtils.isBooleanType(column.type)) {
|
|
202
|
+
return getBooleanConditionText(config);
|
|
203
|
+
}
|
|
204
|
+
throw new Error('Invalid column type');
|
|
205
|
+
}
|
|
206
|
+
export function getLabelForNumberCondition(condition) {
|
|
207
|
+
switch (condition) {
|
|
208
|
+
case NumberCondition.IS_EQUAL:
|
|
209
|
+
return 'is equal to';
|
|
210
|
+
case NumberCondition.IS_NOT_EQUAL:
|
|
211
|
+
return 'is not equal to';
|
|
212
|
+
case NumberCondition.IS_BETWEEN:
|
|
213
|
+
return 'is between';
|
|
214
|
+
case NumberCondition.GREATER_THAN:
|
|
215
|
+
return 'greater than';
|
|
216
|
+
case NumberCondition.GREATER_THAN_OR_EQUAL:
|
|
217
|
+
return 'greater than or equal to';
|
|
218
|
+
case NumberCondition.LESS_THAN:
|
|
219
|
+
return 'less than';
|
|
220
|
+
case NumberCondition.LESS_THAN_OR_EQUAL:
|
|
221
|
+
return 'less than or equal to';
|
|
222
|
+
case NumberCondition.IS_NULL:
|
|
223
|
+
return 'is null';
|
|
224
|
+
case NumberCondition.IS_NOT_NULL:
|
|
225
|
+
return 'is not null';
|
|
226
|
+
}
|
|
227
|
+
}
|
|
228
|
+
export function getLabelForStringCondition(condition) {
|
|
229
|
+
switch (condition) {
|
|
230
|
+
case StringCondition.IS_EXACTLY:
|
|
231
|
+
return 'is exactly';
|
|
232
|
+
case StringCondition.IS_NOT_EXACTLY:
|
|
233
|
+
return 'is not exactly';
|
|
234
|
+
case StringCondition.CONTAINS:
|
|
235
|
+
return 'contains';
|
|
236
|
+
case StringCondition.DOES_NOT_CONTAIN:
|
|
237
|
+
return 'does not contain';
|
|
238
|
+
case StringCondition.STARTS_WITH:
|
|
239
|
+
return 'starts with';
|
|
240
|
+
case StringCondition.ENDS_WITH:
|
|
241
|
+
return 'ends with';
|
|
242
|
+
case StringCondition.IS_NULL:
|
|
243
|
+
return 'is null';
|
|
244
|
+
case StringCondition.IS_NOT_NULL:
|
|
245
|
+
return 'is not null';
|
|
246
|
+
}
|
|
247
|
+
}
|
|
248
|
+
export function getLabelForDateCondition(condition) {
|
|
249
|
+
switch (condition) {
|
|
250
|
+
case DateCondition.IS_EXACTLY:
|
|
251
|
+
return 'is';
|
|
252
|
+
case DateCondition.IS_NOT_EXACTLY:
|
|
253
|
+
return 'is not';
|
|
254
|
+
case DateCondition.IS_BEFORE:
|
|
255
|
+
return 'is before';
|
|
256
|
+
case DateCondition.IS_BEFORE_OR_EQUAL:
|
|
257
|
+
return 'is before or equal';
|
|
258
|
+
case DateCondition.IS_AFTER:
|
|
259
|
+
return 'is after';
|
|
260
|
+
case DateCondition.IS_AFTER_OR_EQUAL:
|
|
261
|
+
return 'is after or equal';
|
|
262
|
+
case DateCondition.IS_NULL:
|
|
263
|
+
return 'is null';
|
|
264
|
+
case DateCondition.IS_NOT_NULL:
|
|
265
|
+
return 'is not null';
|
|
266
|
+
}
|
|
267
|
+
}
|
|
268
|
+
export function getLabelForBooleanCondition(condition) {
|
|
269
|
+
switch (condition) {
|
|
270
|
+
case BooleanCondition.IS_TRUE:
|
|
271
|
+
return 'is true';
|
|
272
|
+
case BooleanCondition.IS_FALSE:
|
|
273
|
+
return 'is false';
|
|
274
|
+
case BooleanCondition.IS_NULL:
|
|
275
|
+
return 'is null';
|
|
276
|
+
case BooleanCondition.IS_NOT_NULL:
|
|
277
|
+
return 'is not null';
|
|
278
|
+
}
|
|
279
|
+
}
|
|
280
|
+
export function getLabelForCharCondition(condition) {
|
|
281
|
+
switch (condition) {
|
|
282
|
+
case CharCondition.IS_EQUAL:
|
|
283
|
+
return 'is';
|
|
284
|
+
case CharCondition.IS_NOT_EQUAL:
|
|
285
|
+
return 'is not';
|
|
286
|
+
case CharCondition.IS_NULL:
|
|
287
|
+
return 'is null';
|
|
288
|
+
case CharCondition.IS_NOT_NULL:
|
|
289
|
+
return 'is not null';
|
|
290
|
+
}
|
|
291
|
+
}
|
|
292
|
+
export function getDefaultConditionForType(columnType) {
|
|
293
|
+
if (TableUtils.isNumberType(columnType)) {
|
|
294
|
+
return NumberCondition.IS_EQUAL;
|
|
295
|
+
}
|
|
296
|
+
if (TableUtils.isCharType(columnType)) {
|
|
297
|
+
return CharCondition.IS_EQUAL;
|
|
298
|
+
}
|
|
299
|
+
if (TableUtils.isStringType(columnType)) {
|
|
300
|
+
return StringCondition.IS_EXACTLY;
|
|
301
|
+
}
|
|
302
|
+
if (TableUtils.isDateType(columnType)) {
|
|
303
|
+
return DateCondition.IS_EXACTLY;
|
|
304
|
+
}
|
|
305
|
+
if (TableUtils.isBooleanType(columnType)) {
|
|
306
|
+
return BooleanCondition.IS_TRUE;
|
|
307
|
+
}
|
|
308
|
+
throw new Error('Invalid column type');
|
|
309
|
+
}
|
|
310
|
+
export function getDefaultValueForType(columnType) {
|
|
311
|
+
if (TableUtils.isCharType(columnType)) {
|
|
312
|
+
return '';
|
|
313
|
+
}
|
|
314
|
+
if (TableUtils.isStringType(columnType)) {
|
|
315
|
+
return '';
|
|
316
|
+
}
|
|
317
|
+
return undefined;
|
|
318
|
+
}
|
|
319
|
+
export function getConditionConfig(config) {
|
|
320
|
+
var {
|
|
321
|
+
condition,
|
|
322
|
+
value,
|
|
323
|
+
start,
|
|
324
|
+
end
|
|
325
|
+
} = config;
|
|
326
|
+
return {
|
|
327
|
+
condition,
|
|
328
|
+
value,
|
|
329
|
+
start,
|
|
330
|
+
end
|
|
331
|
+
};
|
|
332
|
+
}
|
|
333
|
+
export function getDefaultConditionConfigForType(type) {
|
|
334
|
+
return {
|
|
335
|
+
condition: getDefaultConditionForType(type),
|
|
336
|
+
value: getDefaultValueForType(type),
|
|
337
|
+
start: undefined,
|
|
338
|
+
end: undefined
|
|
339
|
+
};
|
|
340
|
+
}
|
|
341
|
+
export function getDefaultStyleConfig() {
|
|
342
|
+
return {
|
|
343
|
+
type: FormatStyleType.NO_FORMATTING
|
|
344
|
+
};
|
|
345
|
+
}
|
|
346
|
+
function getShortLabelForStringCondition(condition) {
|
|
347
|
+
switch (condition) {
|
|
348
|
+
case StringCondition.IS_EXACTLY:
|
|
349
|
+
return '==';
|
|
350
|
+
case StringCondition.IS_NOT_EXACTLY:
|
|
351
|
+
return '!=';
|
|
352
|
+
case StringCondition.CONTAINS:
|
|
353
|
+
return 'contains';
|
|
354
|
+
case StringCondition.DOES_NOT_CONTAIN:
|
|
355
|
+
return 'does not contain';
|
|
356
|
+
case StringCondition.STARTS_WITH:
|
|
357
|
+
return 'starts with';
|
|
358
|
+
case StringCondition.ENDS_WITH:
|
|
359
|
+
return 'ends with';
|
|
360
|
+
case StringCondition.IS_NULL:
|
|
361
|
+
return 'is null';
|
|
362
|
+
case StringCondition.IS_NOT_NULL:
|
|
363
|
+
return 'is not null';
|
|
364
|
+
}
|
|
365
|
+
}
|
|
366
|
+
function getShortLabelForDateCondition(condition) {
|
|
367
|
+
switch (condition) {
|
|
368
|
+
case DateCondition.IS_EXACTLY:
|
|
369
|
+
return '==';
|
|
370
|
+
case DateCondition.IS_NOT_EXACTLY:
|
|
371
|
+
return '!=';
|
|
372
|
+
case DateCondition.IS_BEFORE:
|
|
373
|
+
return '<';
|
|
374
|
+
case DateCondition.IS_BEFORE_OR_EQUAL:
|
|
375
|
+
return '<=';
|
|
376
|
+
case DateCondition.IS_AFTER:
|
|
377
|
+
return '>';
|
|
378
|
+
case DateCondition.IS_AFTER_OR_EQUAL:
|
|
379
|
+
return '>=';
|
|
380
|
+
case DateCondition.IS_NULL:
|
|
381
|
+
return 'is null';
|
|
382
|
+
case DateCondition.IS_NOT_NULL:
|
|
383
|
+
return 'is not null';
|
|
384
|
+
}
|
|
385
|
+
}
|
|
386
|
+
function getShortLabelForBooleanCondition(condition) {
|
|
387
|
+
switch (condition) {
|
|
388
|
+
case BooleanCondition.IS_TRUE:
|
|
389
|
+
return 'is true';
|
|
390
|
+
case BooleanCondition.IS_FALSE:
|
|
391
|
+
return 'is false';
|
|
392
|
+
case BooleanCondition.IS_NULL:
|
|
393
|
+
return 'is null';
|
|
394
|
+
case BooleanCondition.IS_NOT_NULL:
|
|
395
|
+
return 'is not null';
|
|
396
|
+
}
|
|
397
|
+
}
|
|
398
|
+
function getShortLabelForCharCondition(condition) {
|
|
399
|
+
switch (condition) {
|
|
400
|
+
case CharCondition.IS_EQUAL:
|
|
401
|
+
return '==';
|
|
402
|
+
case CharCondition.IS_NOT_EQUAL:
|
|
403
|
+
return '!=';
|
|
404
|
+
case CharCondition.IS_NULL:
|
|
405
|
+
return 'is null';
|
|
406
|
+
case CharCondition.IS_NOT_NULL:
|
|
407
|
+
return 'is not null';
|
|
408
|
+
}
|
|
409
|
+
}
|
|
410
|
+
export function getShortLabelForNumberCondition(condition) {
|
|
411
|
+
switch (condition) {
|
|
412
|
+
case NumberCondition.IS_EQUAL:
|
|
413
|
+
return '==';
|
|
414
|
+
case NumberCondition.IS_NOT_EQUAL:
|
|
415
|
+
return '!=';
|
|
416
|
+
case NumberCondition.IS_BETWEEN:
|
|
417
|
+
return '==';
|
|
418
|
+
case NumberCondition.GREATER_THAN:
|
|
419
|
+
return '>';
|
|
420
|
+
case NumberCondition.GREATER_THAN_OR_EQUAL:
|
|
421
|
+
return '>=';
|
|
422
|
+
case NumberCondition.LESS_THAN:
|
|
423
|
+
return '<';
|
|
424
|
+
case NumberCondition.LESS_THAN_OR_EQUAL:
|
|
425
|
+
return '<=';
|
|
426
|
+
case NumberCondition.IS_NULL:
|
|
427
|
+
return 'is null';
|
|
428
|
+
case NumberCondition.IS_NOT_NULL:
|
|
429
|
+
return 'is not null';
|
|
430
|
+
}
|
|
431
|
+
}
|
|
432
|
+
export function getTextForNumberCondition(columnName, condition, value, start, end) {
|
|
433
|
+
switch (condition) {
|
|
434
|
+
case NumberCondition.IS_EQUAL:
|
|
435
|
+
return "".concat(columnName, " == ").concat(value);
|
|
436
|
+
case NumberCondition.IS_NOT_EQUAL:
|
|
437
|
+
return "".concat(columnName, " != ").concat(value);
|
|
438
|
+
case NumberCondition.IS_BETWEEN:
|
|
439
|
+
return "".concat(columnName, " > ").concat(start, " && ").concat(columnName, " < ").concat(end);
|
|
440
|
+
case NumberCondition.GREATER_THAN:
|
|
441
|
+
return "".concat(columnName, " > ").concat(value);
|
|
442
|
+
case NumberCondition.GREATER_THAN_OR_EQUAL:
|
|
443
|
+
return "".concat(columnName, " >= ").concat(value);
|
|
444
|
+
case NumberCondition.LESS_THAN:
|
|
445
|
+
return "".concat(columnName, " < ").concat(value);
|
|
446
|
+
case NumberCondition.LESS_THAN_OR_EQUAL:
|
|
447
|
+
return "".concat(columnName, " <= ").concat(value);
|
|
448
|
+
case NumberCondition.IS_NULL:
|
|
449
|
+
return "".concat(columnName, " == null");
|
|
450
|
+
case NumberCondition.IS_NOT_NULL:
|
|
451
|
+
return "".concat(columnName, " != null");
|
|
452
|
+
}
|
|
453
|
+
}
|
|
454
|
+
export function getTextForStringCondition(columnName, condition, value) {
|
|
455
|
+
switch (condition) {
|
|
456
|
+
case StringCondition.IS_EXACTLY:
|
|
457
|
+
return "".concat(columnName, " == \"").concat(value, "\"");
|
|
458
|
+
case StringCondition.IS_NOT_EXACTLY:
|
|
459
|
+
return "".concat(columnName, " != \"").concat(value, "\"");
|
|
460
|
+
case StringCondition.CONTAINS:
|
|
461
|
+
return "".concat(columnName, " != null && ").concat(columnName, ".contains(\"").concat(value, "\")");
|
|
462
|
+
case StringCondition.DOES_NOT_CONTAIN:
|
|
463
|
+
return "".concat(columnName, " != null && !").concat(columnName, ".contains(\"").concat(value, "\")");
|
|
464
|
+
case StringCondition.STARTS_WITH:
|
|
465
|
+
return "".concat(columnName, " != null && ").concat(columnName, ".startsWith(\"").concat(value, "\")");
|
|
466
|
+
case StringCondition.ENDS_WITH:
|
|
467
|
+
return "".concat(columnName, " != null && ").concat(columnName, ".endsWith(\"").concat(value, "\")");
|
|
468
|
+
case StringCondition.IS_NULL:
|
|
469
|
+
return "".concat(columnName, " == null");
|
|
470
|
+
case StringCondition.IS_NOT_NULL:
|
|
471
|
+
return "".concat(columnName, " != null");
|
|
472
|
+
}
|
|
473
|
+
}
|
|
474
|
+
export function getTextForDateCondition(columnName, condition, value) {
|
|
475
|
+
switch (condition) {
|
|
476
|
+
case DateCondition.IS_EXACTLY:
|
|
477
|
+
return "".concat(columnName, " == convertDateTime(\"").concat(value, "\")");
|
|
478
|
+
case DateCondition.IS_NOT_EXACTLY:
|
|
479
|
+
return "".concat(columnName, " != convertDateTime(`").concat(value, "`)");
|
|
480
|
+
case DateCondition.IS_BEFORE:
|
|
481
|
+
return "".concat(columnName, " < convertDateTime(`").concat(value, "`)");
|
|
482
|
+
case DateCondition.IS_BEFORE_OR_EQUAL:
|
|
483
|
+
return "".concat(columnName, " <= convertDateTime(\"").concat(value, "\")");
|
|
484
|
+
case DateCondition.IS_AFTER:
|
|
485
|
+
return "".concat(columnName, " > convertDateTime(`").concat(value, "`)");
|
|
486
|
+
case DateCondition.IS_AFTER_OR_EQUAL:
|
|
487
|
+
return "".concat(columnName, " >= convertDateTime(`").concat(value, "`)");
|
|
488
|
+
case DateCondition.IS_NULL:
|
|
489
|
+
return "".concat(columnName, " == null");
|
|
490
|
+
case DateCondition.IS_NOT_NULL:
|
|
491
|
+
return "".concat(columnName, " != null");
|
|
492
|
+
}
|
|
493
|
+
}
|
|
494
|
+
export function getTextForBooleanCondition(columnName, condition) {
|
|
495
|
+
switch (condition) {
|
|
496
|
+
case BooleanCondition.IS_TRUE:
|
|
497
|
+
return "".concat(columnName, " == true");
|
|
498
|
+
case BooleanCondition.IS_FALSE:
|
|
499
|
+
return "".concat(columnName, " == false");
|
|
500
|
+
case BooleanCondition.IS_NULL:
|
|
501
|
+
return "".concat(columnName, " == null");
|
|
502
|
+
case BooleanCondition.IS_NOT_NULL:
|
|
503
|
+
return "".concat(columnName, " != null");
|
|
504
|
+
}
|
|
505
|
+
}
|
|
506
|
+
export function getTextForCharCondition(columnName, condition, value) {
|
|
507
|
+
switch (condition) {
|
|
508
|
+
case CharCondition.IS_EQUAL:
|
|
509
|
+
return "".concat(columnName, " == '").concat(value, "'");
|
|
510
|
+
case CharCondition.IS_NOT_EQUAL:
|
|
511
|
+
return "".concat(columnName, " != '").concat(value, "'");
|
|
512
|
+
case CharCondition.IS_NULL:
|
|
513
|
+
return "isNull(".concat(columnName, ")");
|
|
514
|
+
case CharCondition.IS_NOT_NULL:
|
|
515
|
+
return "!isNull(".concat(columnName, ")");
|
|
516
|
+
}
|
|
517
|
+
}
|
|
518
|
+
export function getShortLabelForConditionType(columnType, condition) {
|
|
519
|
+
if (TableUtils.isNumberType(columnType)) {
|
|
520
|
+
return getShortLabelForNumberCondition(condition);
|
|
521
|
+
}
|
|
522
|
+
if (TableUtils.isCharType(columnType)) {
|
|
523
|
+
return getShortLabelForCharCondition(condition);
|
|
524
|
+
}
|
|
525
|
+
if (TableUtils.isStringType(columnType)) {
|
|
526
|
+
return getShortLabelForStringCondition(condition);
|
|
527
|
+
}
|
|
528
|
+
if (TableUtils.isDateType(columnType)) {
|
|
529
|
+
return getShortLabelForDateCondition(condition);
|
|
530
|
+
}
|
|
531
|
+
if (TableUtils.isBooleanType(columnType)) {
|
|
532
|
+
return getShortLabelForBooleanCondition(condition);
|
|
533
|
+
}
|
|
534
|
+
throw new Error('Invalid column type');
|
|
535
|
+
}
|
|
536
|
+
|
|
537
|
+
/**
|
|
538
|
+
* Get format columns array for the given columns and formatting rules
|
|
539
|
+
* @param columns Available columns
|
|
540
|
+
* @param rules Formatting rules to build the format columns from
|
|
541
|
+
* @returns Array of format columns
|
|
542
|
+
*/
|
|
543
|
+
export function getFormatColumns(dh, columns, rules) {
|
|
544
|
+
if (rules === undefined) {
|
|
545
|
+
log.debug("no rules passed.");
|
|
546
|
+
return [];
|
|
547
|
+
}
|
|
548
|
+
var result = [];
|
|
549
|
+
// There can be only one row format custom column
|
|
550
|
+
// and multiple column format custom columns (one per column)
|
|
551
|
+
var rowFormatConfig;
|
|
552
|
+
var columnFormatConfigMap = new Map();
|
|
553
|
+
rules.forEach(_ref => {
|
|
554
|
+
var _ref3;
|
|
555
|
+
var {
|
|
556
|
+
config,
|
|
557
|
+
type: formatterType
|
|
558
|
+
} = _ref;
|
|
559
|
+
var {
|
|
560
|
+
column
|
|
561
|
+
} = config;
|
|
562
|
+
// Check both name and type because the type can change
|
|
563
|
+
var col = columns.find(_ref2 => {
|
|
564
|
+
var {
|
|
565
|
+
name,
|
|
566
|
+
type
|
|
567
|
+
} = _ref2;
|
|
568
|
+
return name === column.name && type === column.type;
|
|
569
|
+
});
|
|
570
|
+
if (col === undefined) {
|
|
571
|
+
log.debug("Column ".concat(column.name, ":").concat(column.type, " not found. Ignoring format rule."), config);
|
|
572
|
+
return;
|
|
573
|
+
}
|
|
574
|
+
// Stack ternary format conditions by column
|
|
575
|
+
var [prevRule, prevFormatColumn] = (_ref3 = formatterType === FormatterType.CONDITIONAL ? columnFormatConfigMap.get(col.name) : rowFormatConfig) !== null && _ref3 !== void 0 ? _ref3 : ['null', undefined];
|
|
576
|
+
var rule = makeTernaryFormatRule(config, prevRule);
|
|
577
|
+
if (rule === undefined) {
|
|
578
|
+
log.debug("Ignoring format rule.", config);
|
|
579
|
+
return;
|
|
580
|
+
}
|
|
581
|
+
// Replace existing formatColumn with the new stacked format
|
|
582
|
+
var index = prevFormatColumn === undefined ? -1 : result.indexOf(prevFormatColumn);
|
|
583
|
+
if (index > -1) {
|
|
584
|
+
result.splice(index, 1);
|
|
585
|
+
}
|
|
586
|
+
var formatColumn = formatterType === FormatterType.CONDITIONAL ? makeColumnFormatColumn(col, rule) : makeRowFormatColumn(dh, rule);
|
|
587
|
+
result.push(formatColumn);
|
|
588
|
+
if (formatterType === FormatterType.CONDITIONAL) {
|
|
589
|
+
columnFormatConfigMap.set(col.name, [rule, formatColumn]);
|
|
590
|
+
} else {
|
|
591
|
+
rowFormatConfig = [rule, formatColumn];
|
|
592
|
+
}
|
|
593
|
+
});
|
|
594
|
+
return result;
|
|
595
|
+
}
|
|
596
|
+
|
|
597
|
+
/**
|
|
598
|
+
* Validate that a given date condition + value pair is valid.
|
|
599
|
+
* @param condition
|
|
600
|
+
* @param value
|
|
601
|
+
*/
|
|
602
|
+
export function isDateConditionValid(dh, condition, value) {
|
|
603
|
+
switch (condition) {
|
|
604
|
+
case DateCondition.IS_NULL:
|
|
605
|
+
case DateCondition.IS_NOT_NULL:
|
|
606
|
+
return true;
|
|
607
|
+
default:
|
|
608
|
+
{
|
|
609
|
+
var [dateTimeString, ...rest] = (value !== null && value !== void 0 ? value : '').split(' ');
|
|
610
|
+
// Reconstitute all tokens after the first ' ' in case the user included garbage data at the end
|
|
611
|
+
// e.g. '2020-01-01 NY blah'
|
|
612
|
+
var tzCode = rest.join(' ');
|
|
613
|
+
try {
|
|
614
|
+
DateUtils.parseDateTimeString(dateTimeString);
|
|
615
|
+
} catch (e) {
|
|
616
|
+
log.debug('Invalid datetime string', dateTimeString);
|
|
617
|
+
return false;
|
|
618
|
+
}
|
|
619
|
+
try {
|
|
620
|
+
dh.i18n.TimeZone.getTimeZone(tzCode);
|
|
621
|
+
} catch (e) {
|
|
622
|
+
log.debug('Invalid timezone string', tzCode);
|
|
623
|
+
return false;
|
|
624
|
+
}
|
|
625
|
+
return true;
|
|
626
|
+
}
|
|
627
|
+
}
|
|
628
|
+
}
|
|
629
|
+
export function isSupportedColumn(_ref4) {
|
|
630
|
+
var {
|
|
631
|
+
type
|
|
632
|
+
} = _ref4;
|
|
633
|
+
return TableUtils.isNumberType(type) || TableUtils.isCharType(type) || TableUtils.isStringType(type) || TableUtils.isDateType(type) || TableUtils.isBooleanType(type);
|
|
634
|
+
}
|
|
635
|
+
//# sourceMappingURL=ConditionalFormattingUtils.js.map
|