@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.
Files changed (282) hide show
  1. package/dist/AdvancedFilterCreator.css +106 -0
  2. package/dist/AdvancedFilterCreator.css.map +1 -0
  3. package/dist/AdvancedFilterCreator.js +541 -0
  4. package/dist/AdvancedFilterCreator.js.map +1 -0
  5. package/dist/AdvancedFilterCreatorFilterItem.css +9 -0
  6. package/dist/AdvancedFilterCreatorFilterItem.css.map +1 -0
  7. package/dist/AdvancedFilterCreatorFilterItem.js +184 -0
  8. package/dist/AdvancedFilterCreatorFilterItem.js.map +1 -0
  9. package/dist/AdvancedFilterCreatorSelectValue.css +50 -0
  10. package/dist/AdvancedFilterCreatorSelectValue.css.map +1 -0
  11. package/dist/AdvancedFilterCreatorSelectValue.js +301 -0
  12. package/dist/AdvancedFilterCreatorSelectValue.js.map +1 -0
  13. package/dist/AdvancedFilterCreatorSelectValueList.js +272 -0
  14. package/dist/AdvancedFilterCreatorSelectValueList.js.map +1 -0
  15. package/dist/ColumnHeaderGroup.js +61 -0
  16. package/dist/ColumnHeaderGroup.js.map +1 -0
  17. package/dist/ColumnStatistics.css +76 -0
  18. package/dist/ColumnStatistics.css.map +1 -0
  19. package/dist/ColumnStatistics.js +202 -0
  20. package/dist/ColumnStatistics.js.map +1 -0
  21. package/dist/CommonTypes.js +2 -0
  22. package/dist/CommonTypes.js.map +1 -0
  23. package/dist/CrossColumnSearch.css +35 -0
  24. package/dist/CrossColumnSearch.css.map +1 -0
  25. package/dist/CrossColumnSearch.js +199 -0
  26. package/dist/CrossColumnSearch.js.map +1 -0
  27. package/dist/FilterInputField.css +56 -0
  28. package/dist/FilterInputField.css.map +1 -0
  29. package/dist/FilterInputField.js +232 -0
  30. package/dist/FilterInputField.js.map +1 -0
  31. package/dist/GotoRow.css +45 -0
  32. package/dist/GotoRow.css.map +1 -0
  33. package/dist/GotoRow.js +298 -0
  34. package/dist/GotoRow.js.map +1 -0
  35. package/dist/IrisGrid.css +359 -0
  36. package/dist/IrisGrid.css.map +1 -0
  37. package/dist/IrisGrid.js +3651 -0
  38. package/dist/IrisGrid.js.map +1 -0
  39. package/dist/IrisGridBottomBar.css +85 -0
  40. package/dist/IrisGridBottomBar.css.map +1 -0
  41. package/dist/IrisGridBottomBar.js +36 -0
  42. package/dist/IrisGridBottomBar.js.map +1 -0
  43. package/dist/IrisGridCellOverflowModal.css +17 -0
  44. package/dist/IrisGridCellOverflowModal.css.map +1 -0
  45. package/dist/IrisGridCellOverflowModal.js +157 -0
  46. package/dist/IrisGridCellOverflowModal.js.map +1 -0
  47. package/dist/IrisGridCellRendererUtils.js +20 -0
  48. package/dist/IrisGridCellRendererUtils.js.map +1 -0
  49. package/dist/IrisGridCopyHandler.css +64 -0
  50. package/dist/IrisGridCopyHandler.css.map +1 -0
  51. package/dist/IrisGridCopyHandler.js +331 -0
  52. package/dist/IrisGridCopyHandler.js.map +1 -0
  53. package/dist/IrisGridDataBarCellRenderer.js +10 -0
  54. package/dist/IrisGridDataBarCellRenderer.js.map +1 -0
  55. package/dist/IrisGridIcons.js +25 -0
  56. package/dist/IrisGridIcons.js.map +1 -0
  57. package/dist/IrisGridMetricCalculator.js +33 -0
  58. package/dist/IrisGridMetricCalculator.js.map +1 -0
  59. package/dist/IrisGridModel.js +263 -0
  60. package/dist/IrisGridModel.js.map +1 -0
  61. package/dist/IrisGridModelFactory.js +27 -0
  62. package/dist/IrisGridModelFactory.js.map +1 -0
  63. package/dist/IrisGridModelUpdater.js +96 -0
  64. package/dist/IrisGridModelUpdater.js.map +1 -0
  65. package/dist/IrisGridPartitionSelector.css +48 -0
  66. package/dist/IrisGridPartitionSelector.css.map +1 -0
  67. package/dist/IrisGridPartitionSelector.js +198 -0
  68. package/dist/IrisGridPartitionSelector.js.map +1 -0
  69. package/dist/IrisGridProxyModel.js +530 -0
  70. package/dist/IrisGridProxyModel.js.map +1 -0
  71. package/dist/IrisGridRenderer.js +779 -0
  72. package/dist/IrisGridRenderer.js.map +1 -0
  73. package/dist/IrisGridShortcuts.js +59 -0
  74. package/dist/IrisGridShortcuts.js.map +1 -0
  75. package/dist/IrisGridTableModel.js +273 -0
  76. package/dist/IrisGridTableModel.js.map +1 -0
  77. package/dist/IrisGridTableModelTemplate.js +1589 -0
  78. package/dist/IrisGridTableModelTemplate.js.map +1 -0
  79. package/dist/IrisGridTestUtils.js +121 -0
  80. package/dist/IrisGridTestUtils.js.map +1 -0
  81. package/dist/IrisGridTextCellRenderer.js +139 -0
  82. package/dist/IrisGridTextCellRenderer.js.map +1 -0
  83. package/dist/IrisGridTheme.js +96 -0
  84. package/dist/IrisGridTheme.js.map +1 -0
  85. package/dist/IrisGridTheme.module.css +69 -0
  86. package/dist/IrisGridTheme.module.css.map +1 -0
  87. package/dist/IrisGridTreeTableModel.js +145 -0
  88. package/dist/IrisGridTreeTableModel.js.map +1 -0
  89. package/dist/IrisGridUtils.js +1279 -0
  90. package/dist/IrisGridUtils.js.map +1 -0
  91. package/dist/MissingKeyError.js +15 -0
  92. package/dist/MissingKeyError.js.map +1 -0
  93. package/dist/PartitionSelectorSearch.css +22 -0
  94. package/dist/PartitionSelectorSearch.css.map +1 -0
  95. package/dist/PartitionSelectorSearch.js +317 -0
  96. package/dist/PartitionSelectorSearch.js.map +1 -0
  97. package/dist/PendingDataBottomBar.css +13 -0
  98. package/dist/PendingDataBottomBar.css.map +1 -0
  99. package/dist/PendingDataBottomBar.js +98 -0
  100. package/dist/PendingDataBottomBar.js.map +1 -0
  101. package/dist/TableViewportUpdater.js +156 -0
  102. package/dist/TableViewportUpdater.js.map +1 -0
  103. package/dist/ToastBottomBar.js +42 -0
  104. package/dist/ToastBottomBar.js.map +1 -0
  105. package/dist/TreeTableViewportUpdater.js +96 -0
  106. package/dist/TreeTableViewportUpdater.js.map +1 -0
  107. package/dist/declaration.d.js +2 -0
  108. package/dist/declaration.d.js.map +1 -0
  109. package/dist/format-context-menus/CustomFormatAction.css +25 -0
  110. package/dist/format-context-menus/CustomFormatAction.css.map +1 -0
  111. package/dist/format-context-menus/CustomFormatAction.js +132 -0
  112. package/dist/format-context-menus/CustomFormatAction.js.map +1 -0
  113. package/dist/format-context-menus/DateTimeFormatContextMenu.js +53 -0
  114. package/dist/format-context-menus/DateTimeFormatContextMenu.js.map +1 -0
  115. package/dist/format-context-menus/DecimalFormatContextMenu.js +59 -0
  116. package/dist/format-context-menus/DecimalFormatContextMenu.js.map +1 -0
  117. package/dist/format-context-menus/FormatContextMenuUtils.js +63 -0
  118. package/dist/format-context-menus/FormatContextMenuUtils.js.map +1 -0
  119. package/dist/format-context-menus/IntegerFormatContextMenu.js +43 -0
  120. package/dist/format-context-menus/IntegerFormatContextMenu.js.map +1 -0
  121. package/dist/format-context-menus/index.js +4 -0
  122. package/dist/format-context-menus/index.js.map +1 -0
  123. package/dist/index.js +24 -0
  124. package/dist/index.js.map +1 -0
  125. package/dist/key-handlers/ClearFilterKeyHandler.js +21 -0
  126. package/dist/key-handlers/ClearFilterKeyHandler.js.map +1 -0
  127. package/dist/key-handlers/CopyKeyHandler.js +31 -0
  128. package/dist/key-handlers/CopyKeyHandler.js.map +1 -0
  129. package/dist/key-handlers/ReverseKeyHandler.js +32 -0
  130. package/dist/key-handlers/ReverseKeyHandler.js.map +1 -0
  131. package/dist/key-handlers/index.js +4 -0
  132. package/dist/key-handlers/index.js.map +1 -0
  133. package/dist/mousehandlers/IrisGridCellOverflowMouseHandler.js +175 -0
  134. package/dist/mousehandlers/IrisGridCellOverflowMouseHandler.js.map +1 -0
  135. package/dist/mousehandlers/IrisGridColumnSelectMouseHandler.js +139 -0
  136. package/dist/mousehandlers/IrisGridColumnSelectMouseHandler.js.map +1 -0
  137. package/dist/mousehandlers/IrisGridColumnTooltipMouseHandler.js +83 -0
  138. package/dist/mousehandlers/IrisGridColumnTooltipMouseHandler.js.map +1 -0
  139. package/dist/mousehandlers/IrisGridContextMenuHandler.css +19 -0
  140. package/dist/mousehandlers/IrisGridContextMenuHandler.css.map +1 -0
  141. package/dist/mousehandlers/IrisGridContextMenuHandler.js +1220 -0
  142. package/dist/mousehandlers/IrisGridContextMenuHandler.js.map +1 -0
  143. package/dist/mousehandlers/IrisGridDataSelectMouseHandler.js +28 -0
  144. package/dist/mousehandlers/IrisGridDataSelectMouseHandler.js.map +1 -0
  145. package/dist/mousehandlers/IrisGridFilterMouseHandler.js +80 -0
  146. package/dist/mousehandlers/IrisGridFilterMouseHandler.js.map +1 -0
  147. package/dist/mousehandlers/IrisGridRowTreeMouseHandler.js +126 -0
  148. package/dist/mousehandlers/IrisGridRowTreeMouseHandler.js.map +1 -0
  149. package/dist/mousehandlers/IrisGridSortMouseHandler.js +46 -0
  150. package/dist/mousehandlers/IrisGridSortMouseHandler.js.map +1 -0
  151. package/dist/mousehandlers/IrisGridTokenMouseHandler.js +151 -0
  152. package/dist/mousehandlers/IrisGridTokenMouseHandler.js.map +1 -0
  153. package/dist/mousehandlers/PendingMouseHandler.js +39 -0
  154. package/dist/mousehandlers/PendingMouseHandler.js.map +1 -0
  155. package/dist/mousehandlers/index.js +11 -0
  156. package/dist/mousehandlers/index.js.map +1 -0
  157. package/dist/sidebar/AdvancedSettings.js +6 -0
  158. package/dist/sidebar/AdvancedSettings.js.map +1 -0
  159. package/dist/sidebar/AdvancedSettingsMenu.js +29 -0
  160. package/dist/sidebar/AdvancedSettingsMenu.js.map +1 -0
  161. package/dist/sidebar/AdvancedSettingsType.js +7 -0
  162. package/dist/sidebar/AdvancedSettingsType.js.map +1 -0
  163. package/dist/sidebar/ChartBuilder.css +56 -0
  164. package/dist/sidebar/ChartBuilder.css.map +1 -0
  165. package/dist/sidebar/ChartBuilder.js +443 -0
  166. package/dist/sidebar/ChartBuilder.js.map +1 -0
  167. package/dist/sidebar/CustomColumnBuilder.css +58 -0
  168. package/dist/sidebar/CustomColumnBuilder.css.map +1 -0
  169. package/dist/sidebar/CustomColumnBuilder.js +384 -0
  170. package/dist/sidebar/CustomColumnBuilder.js.map +1 -0
  171. package/dist/sidebar/CustomColumnInput.d.ts.map +1 -1
  172. package/dist/sidebar/CustomColumnInput.js +91 -0
  173. package/dist/sidebar/CustomColumnInput.js.map +1 -0
  174. package/dist/sidebar/InputEditor.css +35 -0
  175. package/dist/sidebar/InputEditor.css.map +1 -0
  176. package/dist/sidebar/InputEditor.d.ts +4 -2
  177. package/dist/sidebar/InputEditor.d.ts.map +1 -1
  178. package/dist/sidebar/InputEditor.js +180 -0
  179. package/dist/sidebar/InputEditor.js.map +1 -0
  180. package/dist/sidebar/OptionType.js +19 -0
  181. package/dist/sidebar/OptionType.js.map +1 -0
  182. package/dist/sidebar/RollupRows.css +120 -0
  183. package/dist/sidebar/RollupRows.css.map +1 -0
  184. package/dist/sidebar/RollupRows.js +519 -0
  185. package/dist/sidebar/RollupRows.js.map +1 -0
  186. package/dist/sidebar/SelectDistinctBuilder.css +41 -0
  187. package/dist/sidebar/SelectDistinctBuilder.css.map +1 -0
  188. package/dist/sidebar/SelectDistinctBuilder.js +155 -0
  189. package/dist/sidebar/SelectDistinctBuilder.js.map +1 -0
  190. package/dist/sidebar/TableCsvExporter.css +32 -0
  191. package/dist/sidebar/TableCsvExporter.css.map +1 -0
  192. package/dist/sidebar/TableCsvExporter.js +399 -0
  193. package/dist/sidebar/TableCsvExporter.js.map +1 -0
  194. package/dist/sidebar/TableSaver.js +487 -0
  195. package/dist/sidebar/TableSaver.js.map +1 -0
  196. package/dist/sidebar/aggregations/AggregationEdit.css +61 -0
  197. package/dist/sidebar/aggregations/AggregationEdit.css.map +1 -0
  198. package/dist/sidebar/aggregations/AggregationEdit.js +155 -0
  199. package/dist/sidebar/aggregations/AggregationEdit.js.map +1 -0
  200. package/dist/sidebar/aggregations/AggregationOperation.js +19 -0
  201. package/dist/sidebar/aggregations/AggregationOperation.js.map +1 -0
  202. package/dist/sidebar/aggregations/AggregationUtils.js +59 -0
  203. package/dist/sidebar/aggregations/AggregationUtils.js.map +1 -0
  204. package/dist/sidebar/aggregations/Aggregations.css +43 -0
  205. package/dist/sidebar/aggregations/Aggregations.css.map +1 -0
  206. package/dist/sidebar/aggregations/Aggregations.js +178 -0
  207. package/dist/sidebar/aggregations/Aggregations.js.map +1 -0
  208. package/dist/sidebar/aggregations/index.js +2 -0
  209. package/dist/sidebar/aggregations/index.js.map +1 -0
  210. package/dist/sidebar/conditional-formatting/ColumnFormatEditor.js +123 -0
  211. package/dist/sidebar/conditional-formatting/ColumnFormatEditor.js.map +1 -0
  212. package/dist/sidebar/conditional-formatting/ConditionEditor.js +243 -0
  213. package/dist/sidebar/conditional-formatting/ConditionEditor.js.map +1 -0
  214. package/dist/sidebar/conditional-formatting/ConditionalFormatEditor.css +22 -0
  215. package/dist/sidebar/conditional-formatting/ConditionalFormatEditor.css.map +1 -0
  216. package/dist/sidebar/conditional-formatting/ConditionalFormatEditor.js +109 -0
  217. package/dist/sidebar/conditional-formatting/ConditionalFormatEditor.js.map +1 -0
  218. package/dist/sidebar/conditional-formatting/ConditionalFormattingAPIUtils.js +18 -0
  219. package/dist/sidebar/conditional-formatting/ConditionalFormattingAPIUtils.js.map +1 -0
  220. package/dist/sidebar/conditional-formatting/ConditionalFormattingMenu.css +57 -0
  221. package/dist/sidebar/conditional-formatting/ConditionalFormattingMenu.css.map +1 -0
  222. package/dist/sidebar/conditional-formatting/ConditionalFormattingMenu.js +150 -0
  223. package/dist/sidebar/conditional-formatting/ConditionalFormattingMenu.js.map +1 -0
  224. package/dist/sidebar/conditional-formatting/ConditionalFormattingUtils.js +635 -0
  225. package/dist/sidebar/conditional-formatting/ConditionalFormattingUtils.js.map +1 -0
  226. package/dist/sidebar/conditional-formatting/RowFormatEditor.js +122 -0
  227. package/dist/sidebar/conditional-formatting/RowFormatEditor.js.map +1 -0
  228. package/dist/sidebar/conditional-formatting/StyleEditor.css +55 -0
  229. package/dist/sidebar/conditional-formatting/StyleEditor.css.map +1 -0
  230. package/dist/sidebar/conditional-formatting/StyleEditor.js +150 -0
  231. package/dist/sidebar/conditional-formatting/StyleEditor.js.map +1 -0
  232. package/dist/sidebar/icons/BarIcon.js +24 -0
  233. package/dist/sidebar/icons/BarIcon.js.map +1 -0
  234. package/dist/sidebar/icons/FormatColumnWhereIcon.js +42 -0
  235. package/dist/sidebar/icons/FormatColumnWhereIcon.js.map +1 -0
  236. package/dist/sidebar/icons/FormatRowWhereIcon.js +36 -0
  237. package/dist/sidebar/icons/FormatRowWhereIcon.js.map +1 -0
  238. package/dist/sidebar/icons/HistogramIcon.js +24 -0
  239. package/dist/sidebar/icons/HistogramIcon.js.map +1 -0
  240. package/dist/sidebar/icons/LineIcon.js +27 -0
  241. package/dist/sidebar/icons/LineIcon.js.map +1 -0
  242. package/dist/sidebar/icons/PieIcon.js +24 -0
  243. package/dist/sidebar/icons/PieIcon.js.map +1 -0
  244. package/dist/sidebar/icons/ScatterIcon.js +74 -0
  245. package/dist/sidebar/icons/ScatterIcon.js.map +1 -0
  246. package/dist/sidebar/icons/index.js +8 -0
  247. package/dist/sidebar/icons/index.js.map +1 -0
  248. package/dist/sidebar/index.d.ts +1 -0
  249. package/dist/sidebar/index.d.ts.map +1 -1
  250. package/dist/sidebar/index.js +19 -0
  251. package/dist/sidebar/index.js.map +1 -0
  252. package/dist/sidebar/visibility-ordering-builder/VisibilityOrderingBuilder.css +68 -0
  253. package/dist/sidebar/visibility-ordering-builder/VisibilityOrderingBuilder.css.map +1 -0
  254. package/dist/sidebar/visibility-ordering-builder/VisibilityOrderingBuilder.js +964 -0
  255. package/dist/sidebar/visibility-ordering-builder/VisibilityOrderingBuilder.js.map +1 -0
  256. package/dist/sidebar/visibility-ordering-builder/VisibilityOrderingBuilderUtils.js +132 -0
  257. package/dist/sidebar/visibility-ordering-builder/VisibilityOrderingBuilderUtils.js.map +1 -0
  258. package/dist/sidebar/visibility-ordering-builder/VisibilityOrderingGroup.css +29 -0
  259. package/dist/sidebar/visibility-ordering-builder/VisibilityOrderingGroup.css.map +1 -0
  260. package/dist/sidebar/visibility-ordering-builder/VisibilityOrderingGroup.js +188 -0
  261. package/dist/sidebar/visibility-ordering-builder/VisibilityOrderingGroup.js.map +1 -0
  262. package/dist/sidebar/visibility-ordering-builder/VisibilityOrderingItem.js +81 -0
  263. package/dist/sidebar/visibility-ordering-builder/VisibilityOrderingItem.js.map +1 -0
  264. package/dist/sidebar/visibility-ordering-builder/sortable-tree/PointerSensorWithInteraction.js +30 -0
  265. package/dist/sidebar/visibility-ordering-builder/sortable-tree/PointerSensorWithInteraction.js.map +1 -0
  266. package/dist/sidebar/visibility-ordering-builder/sortable-tree/SortableTree.js +158 -0
  267. package/dist/sidebar/visibility-ordering-builder/sortable-tree/SortableTree.js.map +1 -0
  268. package/dist/sidebar/visibility-ordering-builder/sortable-tree/SortableTreeInner.js +146 -0
  269. package/dist/sidebar/visibility-ordering-builder/sortable-tree/SortableTreeInner.js.map +1 -0
  270. package/dist/sidebar/visibility-ordering-builder/sortable-tree/SortableTreeItem.js +59 -0
  271. package/dist/sidebar/visibility-ordering-builder/sortable-tree/SortableTreeItem.js.map +1 -0
  272. package/dist/sidebar/visibility-ordering-builder/sortable-tree/TreeItem.css +139 -0
  273. package/dist/sidebar/visibility-ordering-builder/sortable-tree/TreeItem.css.map +1 -0
  274. package/dist/sidebar/visibility-ordering-builder/sortable-tree/TreeItem.js +44 -0
  275. package/dist/sidebar/visibility-ordering-builder/sortable-tree/TreeItem.js.map +1 -0
  276. package/dist/sidebar/visibility-ordering-builder/sortable-tree/keyboardCoordinates.js +129 -0
  277. package/dist/sidebar/visibility-ordering-builder/sortable-tree/keyboardCoordinates.js.map +1 -0
  278. package/dist/sidebar/visibility-ordering-builder/sortable-tree/types.js +4 -0
  279. package/dist/sidebar/visibility-ordering-builder/sortable-tree/types.js.map +1 -0
  280. package/dist/sidebar/visibility-ordering-builder/sortable-tree/utilities.js +261 -0
  281. package/dist/sidebar/visibility-ordering-builder/sortable-tree/utilities.js.map +1 -0
  282. 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