@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,263 @@
|
|
|
1
|
+
function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
2
|
+
function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return typeof key === "symbol" ? key : String(key); }
|
|
3
|
+
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); }
|
|
4
|
+
/* eslint-disable class-methods-use-this */
|
|
5
|
+
|
|
6
|
+
import { GridModel } from '@deephaven/grid';
|
|
7
|
+
var EMPTY_ARRAY = [];
|
|
8
|
+
|
|
9
|
+
/**
|
|
10
|
+
* Abstract class that extends the GridModel to have more functionality, like filtering and sorting.
|
|
11
|
+
* For use from IrisGrid.
|
|
12
|
+
* Provides some abstraction from the dh.Table and dh.TreeTable classes, so we can treat them somewhat the same.
|
|
13
|
+
* Note that it still uses dh.Column, dh.FilterCondition, dh.Sort, etc., still. Theoretically should abstract
|
|
14
|
+
* those out as well, so there's no dependency on IrisAPI at all, but it's a lot of work for no real gain at this time.
|
|
15
|
+
*/
|
|
16
|
+
class IrisGridModel extends GridModel {
|
|
17
|
+
constructor(dh) {
|
|
18
|
+
super();
|
|
19
|
+
_defineProperty(this, "dh", void 0);
|
|
20
|
+
_defineProperty(this, "listenerCount", void 0);
|
|
21
|
+
this.dh = dh;
|
|
22
|
+
this.listenerCount = 0;
|
|
23
|
+
}
|
|
24
|
+
// Pulled directly from event-target-shim implementation signature
|
|
25
|
+
// https://github.com/mysticatea/event-target-shim/blob/master/src/lib/event-target.ts#L99
|
|
26
|
+
// Using Parameters<GridModel['addEventListener']> doesn't work
|
|
27
|
+
addEventListener(type0, callback0, options0) {
|
|
28
|
+
super.addEventListener(type0, callback0, options0);
|
|
29
|
+
this.listenerCount += 1;
|
|
30
|
+
if (this.listenerCount === 1) {
|
|
31
|
+
this.startListening();
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
removeEventListener(type0, callback0, options0) {
|
|
35
|
+
super.removeEventListener(type0, callback0, options0);
|
|
36
|
+
this.listenerCount -= 1;
|
|
37
|
+
if (this.listenerCount === 0) {
|
|
38
|
+
this.stopListening();
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
/**
|
|
43
|
+
* Function called when first listener is added.
|
|
44
|
+
* Override for implementation specific behaviour.
|
|
45
|
+
*/
|
|
46
|
+
startListening() {
|
|
47
|
+
// no-op
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
/**
|
|
51
|
+
* Function called when last listener is removed.
|
|
52
|
+
* Override for implementation specific behaviour.
|
|
53
|
+
*/
|
|
54
|
+
stopListening() {
|
|
55
|
+
// no-op
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
/**
|
|
59
|
+
* Gets the columns for this model
|
|
60
|
+
* @returns All columns in the model
|
|
61
|
+
*/
|
|
62
|
+
|
|
63
|
+
/**
|
|
64
|
+
* Gets the columns for the model before any transformations (such as rollups) are applied.
|
|
65
|
+
* @returns All original columns in the model.
|
|
66
|
+
*/
|
|
67
|
+
get originalColumns() {
|
|
68
|
+
return this.columns;
|
|
69
|
+
}
|
|
70
|
+
/**
|
|
71
|
+
* @returns The LayoutHints to use for the columns of this table model
|
|
72
|
+
*/
|
|
73
|
+
get layoutHints() {
|
|
74
|
+
return null;
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
/**
|
|
78
|
+
* @returns Names of columns which should be locked to the front, but not floating
|
|
79
|
+
*/
|
|
80
|
+
get frontColumns() {
|
|
81
|
+
return EMPTY_ARRAY;
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
/**
|
|
85
|
+
* @returns Names of columns which should be locked to the back, but not floating
|
|
86
|
+
*/
|
|
87
|
+
get backColumns() {
|
|
88
|
+
return EMPTY_ARRAY;
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
/**
|
|
92
|
+
* @returns Names of columns which should be frozen to the front and floating
|
|
93
|
+
*/
|
|
94
|
+
get frozenColumns() {
|
|
95
|
+
return EMPTY_ARRAY;
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
/**
|
|
99
|
+
* @param index The column index to check
|
|
100
|
+
* @returns Whether the column is one of LayoutHints' frozen columns
|
|
101
|
+
*/
|
|
102
|
+
isColumnFrozen(index) {
|
|
103
|
+
return false;
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
/**
|
|
107
|
+
* @param index The column index to check
|
|
108
|
+
* @returns Whether the column is sortable
|
|
109
|
+
*/
|
|
110
|
+
isColumnSortable(index) {
|
|
111
|
+
return false;
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
/**
|
|
115
|
+
* @returns True if this model requires a filter to be set
|
|
116
|
+
*/
|
|
117
|
+
get isFilterRequired() {
|
|
118
|
+
return false;
|
|
119
|
+
}
|
|
120
|
+
get isReversible() {
|
|
121
|
+
return true;
|
|
122
|
+
}
|
|
123
|
+
|
|
124
|
+
/**
|
|
125
|
+
* @returns Returns a raw table that is frozen and can be used for exporting data
|
|
126
|
+
*/
|
|
127
|
+
|
|
128
|
+
/**
|
|
129
|
+
* @returns True if this model supports the columnStatistics(column) function
|
|
130
|
+
*/
|
|
131
|
+
get isColumnStatisticsAvailable() {
|
|
132
|
+
return false;
|
|
133
|
+
}
|
|
134
|
+
|
|
135
|
+
/**
|
|
136
|
+
* The description for this model.
|
|
137
|
+
* @returns The description of the model
|
|
138
|
+
*/
|
|
139
|
+
get description() {
|
|
140
|
+
return '';
|
|
141
|
+
}
|
|
142
|
+
|
|
143
|
+
/**
|
|
144
|
+
* @param column The column to get statistics for
|
|
145
|
+
* @returns The column statistics
|
|
146
|
+
*/
|
|
147
|
+
|
|
148
|
+
/**
|
|
149
|
+
* @returns True if this model supports customColumns
|
|
150
|
+
*/
|
|
151
|
+
get isCustomColumnsAvailable() {
|
|
152
|
+
return false;
|
|
153
|
+
}
|
|
154
|
+
|
|
155
|
+
/**
|
|
156
|
+
* @returns True if this model supports customColumns
|
|
157
|
+
*/
|
|
158
|
+
get isFormatColumnsAvailable() {
|
|
159
|
+
return false;
|
|
160
|
+
}
|
|
161
|
+
|
|
162
|
+
/**
|
|
163
|
+
* @returns True if this model supports the export() function
|
|
164
|
+
*/
|
|
165
|
+
get isExportAvailable() {
|
|
166
|
+
return false;
|
|
167
|
+
}
|
|
168
|
+
|
|
169
|
+
/**
|
|
170
|
+
* @returns True if this model supports the valuesTable(column) function
|
|
171
|
+
*/
|
|
172
|
+
get isValuesTableAvailable() {
|
|
173
|
+
return false;
|
|
174
|
+
}
|
|
175
|
+
|
|
176
|
+
/**
|
|
177
|
+
* @returns True if this model should allow the chart builder
|
|
178
|
+
*/
|
|
179
|
+
get isChartBuilderAvailable() {
|
|
180
|
+
return false;
|
|
181
|
+
}
|
|
182
|
+
|
|
183
|
+
/**
|
|
184
|
+
* @returns True if the rollup rows functionality is available
|
|
185
|
+
*/
|
|
186
|
+
get isRollupAvailable() {
|
|
187
|
+
return false;
|
|
188
|
+
}
|
|
189
|
+
|
|
190
|
+
/**
|
|
191
|
+
* @returns True if select distinct functionality is available
|
|
192
|
+
*/
|
|
193
|
+
get isSelectDistinctAvailable() {
|
|
194
|
+
return false;
|
|
195
|
+
}
|
|
196
|
+
|
|
197
|
+
/**
|
|
198
|
+
* @returns True if the totals functionality is available
|
|
199
|
+
*/
|
|
200
|
+
get isTotalsAvailable() {
|
|
201
|
+
return false;
|
|
202
|
+
}
|
|
203
|
+
|
|
204
|
+
/**
|
|
205
|
+
* The names of columns with select distinct enabled
|
|
206
|
+
* @returns An array of column names
|
|
207
|
+
*/
|
|
208
|
+
|
|
209
|
+
/**
|
|
210
|
+
* Check if a column is filterable
|
|
211
|
+
* @param columnIndex The column index to check for filterability
|
|
212
|
+
* @returns True if the current provided column index is filterable, false otherwise
|
|
213
|
+
*/
|
|
214
|
+
isFilterable(columnIndex) {
|
|
215
|
+
return false;
|
|
216
|
+
}
|
|
217
|
+
|
|
218
|
+
/**
|
|
219
|
+
* Set the indices of the viewport
|
|
220
|
+
* @param top Top of viewport
|
|
221
|
+
* @param bottom Bottom of viewport
|
|
222
|
+
* @param columns The columns in the viewport. `null` for all columns
|
|
223
|
+
*/
|
|
224
|
+
|
|
225
|
+
/**
|
|
226
|
+
* Close this model. It can no longer be used after being closed
|
|
227
|
+
*/
|
|
228
|
+
close() {
|
|
229
|
+
// no-op
|
|
230
|
+
}
|
|
231
|
+
|
|
232
|
+
/**
|
|
233
|
+
* Don't allow any rows to be movable in any IrisGrids by default. Just columns.
|
|
234
|
+
*/
|
|
235
|
+
isRowMovable() {
|
|
236
|
+
return false;
|
|
237
|
+
}
|
|
238
|
+
|
|
239
|
+
/**
|
|
240
|
+
* Delete ranges from an input grid. Will delete the entire row, causing data to shift up
|
|
241
|
+
* @param ranges The ranges to delete
|
|
242
|
+
* @returns A promise that resolves successfully when the operation is complete or rejects if there's an error
|
|
243
|
+
*/
|
|
244
|
+
|
|
245
|
+
get isSeekRowAvailable() {
|
|
246
|
+
return false;
|
|
247
|
+
}
|
|
248
|
+
}
|
|
249
|
+
_defineProperty(IrisGridModel, "EVENT", Object.freeze({
|
|
250
|
+
UPDATED: 'UPDATED',
|
|
251
|
+
FORMATTER_UPDATED: 'FORMATTER_UPDATED',
|
|
252
|
+
REQUEST_FAILED: 'REQUEST_FAILED',
|
|
253
|
+
COLUMNS_CHANGED: 'COLUMNS_CHANGED',
|
|
254
|
+
TABLE_CHANGED: 'TABLE_CHANGED',
|
|
255
|
+
FILTERS_CHANGED: 'FILTERS_CHANGED',
|
|
256
|
+
SORTS_CHANGED: 'SORTS_CHANGED',
|
|
257
|
+
DISCONNECT: 'DISCONNECT',
|
|
258
|
+
RECONNECT: 'RECONNECT',
|
|
259
|
+
TOTALS_UPDATED: 'TOTALS_UPDATED',
|
|
260
|
+
PENDING_DATA_UPDATED: 'PENDING_DATA_UPDATED'
|
|
261
|
+
}));
|
|
262
|
+
export default IrisGridModel;
|
|
263
|
+
//# sourceMappingURL=IrisGridModel.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"IrisGridModel.js","names":["GridModel","EMPTY_ARRAY","IrisGridModel","constructor","dh","listenerCount","addEventListener","type0","callback0","options0","startListening","removeEventListener","stopListening","originalColumns","columns","layoutHints","frontColumns","backColumns","frozenColumns","isColumnFrozen","index","isColumnSortable","isFilterRequired","isReversible","isColumnStatisticsAvailable","description","isCustomColumnsAvailable","isFormatColumnsAvailable","isExportAvailable","isValuesTableAvailable","isChartBuilderAvailable","isRollupAvailable","isSelectDistinctAvailable","isTotalsAvailable","isFilterable","columnIndex","close","isRowMovable","isSeekRowAvailable","Object","freeze","UPDATED","FORMATTER_UPDATED","REQUEST_FAILED","COLUMNS_CHANGED","TABLE_CHANGED","FILTERS_CHANGED","SORTS_CHANGED","DISCONNECT","RECONNECT","TOTALS_UPDATED","PENDING_DATA_UPDATED"],"sources":["../src/IrisGridModel.ts"],"sourcesContent":["/* eslint-disable class-methods-use-this */\nimport type { Event, EventTarget } from 'event-target-shim';\nimport {\n GridModel,\n GridRange,\n ModelIndex,\n MoveOperation,\n VisibleIndex,\n} from '@deephaven/grid';\nimport type {\n Column,\n ColumnStatistics,\n CustomColumn,\n dh as DhType,\n FilterCondition,\n Format,\n LayoutHints,\n RollupConfig,\n Row,\n Sort,\n Table,\n ValueTypeUnion,\n} from '@deephaven/jsapi-types';\nimport { Formatter } from '@deephaven/jsapi-utils';\nimport {\n ColumnName,\n UITotalsTableConfig,\n PendingDataMap,\n PendingDataErrorMap,\n} from './CommonTypes';\nimport ColumnHeaderGroup from './ColumnHeaderGroup';\n\ntype IrisGridModelEventNames = typeof IrisGridModel.EVENT[keyof typeof IrisGridModel.EVENT];\n\ntype IrisGridModelEventMap = {\n [E in IrisGridModelEventNames]: Event<E>;\n};\n\nconst EMPTY_ARRAY: never[] = [];\n\n/**\n * Abstract class that extends the GridModel to have more functionality, like filtering and sorting.\n * For use from IrisGrid.\n * Provides some abstraction from the dh.Table and dh.TreeTable classes, so we can treat them somewhat the same.\n * Note that it still uses dh.Column, dh.FilterCondition, dh.Sort, etc., still. Theoretically should abstract\n * those out as well, so there's no dependency on IrisAPI at all, but it's a lot of work for no real gain at this time.\n */\nabstract class IrisGridModel<\n TEventMap extends Record<string, Event<string>> = Record<\n string,\n Event<string>\n >,\n TMode extends 'standard' | 'strict' = 'standard'\n> extends GridModel<TEventMap & IrisGridModelEventMap, TMode> {\n static EVENT = Object.freeze({\n UPDATED: 'UPDATED',\n FORMATTER_UPDATED: 'FORMATTER_UPDATED',\n REQUEST_FAILED: 'REQUEST_FAILED',\n COLUMNS_CHANGED: 'COLUMNS_CHANGED',\n TABLE_CHANGED: 'TABLE_CHANGED',\n FILTERS_CHANGED: 'FILTERS_CHANGED',\n SORTS_CHANGED: 'SORTS_CHANGED',\n DISCONNECT: 'DISCONNECT',\n RECONNECT: 'RECONNECT',\n TOTALS_UPDATED: 'TOTALS_UPDATED',\n PENDING_DATA_UPDATED: 'PENDING_DATA_UPDATED',\n } as const);\n\n constructor(dh: DhType) {\n super();\n\n this.dh = dh;\n this.listenerCount = 0;\n }\n\n dh: DhType;\n\n listenerCount: number;\n\n // Pulled directly from event-target-shim implementation signature\n // https://github.com/mysticatea/event-target-shim/blob/master/src/lib/event-target.ts#L99\n // Using Parameters<GridModel['addEventListener']> doesn't work\n addEventListener<T extends string & keyof TEventMap>(\n type0: T,\n callback0?: EventTarget.EventListener<this, TEventMap[T]> | null,\n options0?: boolean | EventTarget.AddOptions\n ): void {\n super.addEventListener(type0, callback0 as never, options0 as never);\n\n this.listenerCount += 1;\n if (this.listenerCount === 1) {\n this.startListening();\n }\n }\n\n removeEventListener<T extends string & keyof TEventMap>(\n type0: T,\n callback0?: EventTarget.EventListener<this, TEventMap[T]> | null,\n options0?: boolean | EventTarget.Options\n ): void {\n super.removeEventListener(type0, callback0 as never, options0 as never);\n\n this.listenerCount -= 1;\n if (this.listenerCount === 0) {\n this.stopListening();\n }\n }\n\n /**\n * Function called when first listener is added.\n * Override for implementation specific behaviour.\n */\n startListening(): void {\n // no-op\n }\n\n /**\n * Function called when last listener is removed.\n * Override for implementation specific behaviour.\n */\n stopListening(): void {\n // no-op\n }\n\n /**\n * Gets the columns for this model\n * @returns All columns in the model\n */\n abstract get columns(): readonly Column[];\n\n /**\n * Gets the column index for this model\n * @param name The model column name.\n * @returns The numeric index of the requested column.\n */\n abstract getColumnIndexByName(name: string): ModelIndex | undefined;\n\n /**\n * Gets the columns for the model before any transformations (such as rollups) are applied.\n * @returns All original columns in the model.\n */\n get originalColumns(): readonly Column[] {\n return this.columns;\n }\n\n abstract get initialMovedColumns(): readonly MoveOperation[];\n\n /** List of row movements defined by the model. Used as initial movements for IrisGrid */\n abstract get initialMovedRows(): readonly MoveOperation[];\n\n /** List of column header groups defined by the model */\n abstract get initialColumnHeaderGroups(): readonly ColumnHeaderGroup[];\n\n /**\n * Retrieve the grouped columns for this model\n * @returns The columns that are groupe\n */\n abstract get groupedColumns(): readonly Column[];\n\n /**\n * @param column The model column index\n * @param row The model row index\n * @returns The format stored for that cell\n */\n abstract formatForCell(\n column: ModelIndex,\n row: ModelIndex\n ): Format | undefined;\n\n /**\n * @param column The model column index\n * @param row The model row index\n * @returns The value stored for that cell\n */\n abstract valueForCell(column: ModelIndex, row: ModelIndex): unknown;\n\n /**\n * @returns The filters set on this model\n */\n abstract get filter(): readonly FilterCondition[];\n\n /**\n * @param filter The filters to set\n */\n abstract set filter(filter: readonly FilterCondition[]);\n\n /**\n * @returns The formatter used when formatting data\n */\n abstract get formatter(): Formatter;\n\n /**\n * @param formatter The formatter to set\n */\n abstract set formatter(formatter: Formatter);\n\n /**\n * @param value The value to format\n * @param columnType The column type to format\n * @param columnName The column name to format\n */\n abstract displayString(\n value: unknown,\n columnType: string,\n columnName?: ColumnName\n ): string;\n\n /**\n * @returns The sorts used on this model\n */\n abstract get sort(): readonly Sort[];\n\n /**\n * @param sort The sorts to use on this model\n */\n abstract set sort(sort: readonly Sort[]);\n\n /**\n /**\n * @returns The custom columns on this model\n */\n abstract get customColumns(): readonly ColumnName[];\n\n /**\n * @param customColumns The custom columns to use\n */\n abstract set customColumns(customColumns: readonly ColumnName[]);\n\n /**\n * @returns The format columns on this model\n */\n abstract get formatColumns(): readonly CustomColumn[];\n\n /**\n * @param formatColumns The format columns to use\n */\n abstract set formatColumns(formatColumns: readonly CustomColumn[]);\n\n /**\n * @param columns The columns to treat as frozen\n */\n abstract updateFrozenColumns(columns: readonly ColumnName[]): void;\n\n /**\n * @returns The config to use for rolling up this table\n */\n abstract get rollupConfig(): RollupConfig | null;\n\n abstract set rollupConfig(rollupConfig: RollupConfig | null);\n\n /**\n * @returns The config to use for the totals table of this model\n */\n abstract get totalsConfig(): UITotalsTableConfig | null;\n\n abstract set totalsConfig(totalsConfig: UITotalsTableConfig | null);\n\n /**\n * @returns The LayoutHints to use for the columns of this table model\n */\n get layoutHints(): LayoutHints | null {\n return null;\n }\n\n /**\n * @returns Names of columns which should be locked to the front, but not floating\n */\n get frontColumns(): readonly ColumnName[] {\n return EMPTY_ARRAY;\n }\n\n /**\n * @returns Names of columns which should be locked to the back, but not floating\n */\n get backColumns(): readonly ColumnName[] {\n return EMPTY_ARRAY;\n }\n\n /**\n * @returns Names of columns which should be frozen to the front and floating\n */\n get frozenColumns(): readonly ColumnName[] {\n return EMPTY_ARRAY;\n }\n\n /**\n * @param index The column index to check\n * @returns Whether the column is one of LayoutHints' frozen columns\n */\n isColumnFrozen(index: ModelIndex): boolean {\n return false;\n }\n\n /**\n * @param index The column index to check\n * @returns Whether the column is sortable\n */\n isColumnSortable(index: ModelIndex): boolean {\n return false;\n }\n\n /**\n * @returns True if this model requires a filter to be set\n */\n get isFilterRequired(): boolean {\n return false;\n }\n\n get isReversible(): boolean {\n return true;\n }\n\n /**\n * @returns Returns a raw table that is frozen and can be used for exporting data\n */\n abstract export(): Promise<Table>;\n\n /**\n * @returns True if this model supports the columnStatistics(column) function\n */\n get isColumnStatisticsAvailable(): boolean {\n return false;\n }\n\n /**\n * The description for this model.\n * @returns The description of the model\n */\n get description(): string {\n return '';\n }\n\n /**\n * @param column The column to get statistics for\n * @returns The column statistics\n */\n abstract columnStatistics(column: Column): Promise<ColumnStatistics>;\n\n /**\n * @returns True if this model supports customColumns\n */\n get isCustomColumnsAvailable(): boolean {\n return false;\n }\n\n /**\n * @returns True if this model supports customColumns\n */\n get isFormatColumnsAvailable(): boolean {\n return false;\n }\n\n /**\n * @returns True if this model supports the export() function\n */\n get isExportAvailable(): boolean {\n return false;\n }\n\n /**\n * @returns True if this model supports the valuesTable(column) function\n */\n get isValuesTableAvailable(): boolean {\n return false;\n }\n\n /**\n * @returns True if this model should allow the chart builder\n */\n get isChartBuilderAvailable(): boolean {\n return false;\n }\n\n /**\n * @returns True if the rollup rows functionality is available\n */\n get isRollupAvailable(): boolean {\n return false;\n }\n\n /**\n * @returns True if select distinct functionality is available\n */\n get isSelectDistinctAvailable(): boolean {\n return false;\n }\n\n /**\n * @returns True if the totals functionality is available\n */\n get isTotalsAvailable(): boolean {\n return false;\n }\n\n /**\n * The names of columns with select distinct enabled\n * @returns An array of column names\n */\n abstract get selectDistinctColumns(): readonly ColumnName[];\n\n /**\n * Set the columns with select distinct enabled\n * @param names The array of column names to enable select distinct on\n */\n abstract set selectDistinctColumns(names: readonly ColumnName[]);\n\n /**\n * The pending data for this model\n * @returns A map of row index to a map of column name/value pairs\n */\n abstract get pendingDataMap(): PendingDataMap;\n\n /**\n * Set the pending data for this model\n * @param A map of row index to a map of column name/value pairs\n */\n abstract set pendingDataMap(map: PendingDataMap);\n\n /**\n * @returns The count of pending rows to show\n */\n abstract get pendingRowCount(): number;\n\n /**\n * Set the count of pending rows to show\n * @param count The count of pending rows to show\n */\n abstract set pendingRowCount(count: number);\n\n /**\n * Errors for the pending data\n * @returns Map from row number to the error\n */\n abstract get pendingDataErrors(): PendingDataErrorMap;\n\n /**\n * Commit pending data and save all data to the table\n */\n abstract commitPending(): Promise<void>;\n\n /**\n * Check if a column is filterable\n * @param columnIndex The column index to check for filterability\n * @returns True if the current provided column index is filterable, false otherwise\n */\n isFilterable(columnIndex: ModelIndex): boolean {\n return false;\n }\n\n /**\n * Set the indices of the viewport\n * @param top Top of viewport\n * @param bottom Bottom of viewport\n * @param columns The columns in the viewport. `null` for all columns\n */\n abstract setViewport(\n top: VisibleIndex,\n bottom: VisibleIndex,\n columns: Column[] | null\n ): void;\n\n /**\n * Takes a snapshot of the provided ranges\n * @param ranges The model ranges to take the snapshot of\n * @returns Returns the data in a row/column matrix\n */\n abstract snapshot(\n ranges: readonly GridRange[]\n ): Promise<readonly unknown[][]>;\n\n /**\n * @param ranges The ranges to take a snapshot of\n * @param includeHeaders Whether to include the headers in the snapshot or not\n * @param formatValue A function to format a value for a cell. Defaults to model format value.\n * @returns A text formatted snapshot of the data for the specified range set\n */\n abstract textSnapshot(\n ranges: readonly GridRange[],\n includeHeaders?: boolean,\n formatValue?: (value: unknown, column: Column, row?: Row) => string\n ): Promise<string>;\n\n /**\n * @param column The column to get the distinct values for\n * @returns A table partitioned on the column specified\n */\n abstract valuesTable(column: Column): Promise<Table>;\n\n /**\n * Close this model. It can no longer be used after being closed\n */\n close(): void {\n // no-op\n }\n\n /**\n * Don't allow any rows to be movable in any IrisGrids by default. Just columns.\n */\n isRowMovable(): boolean {\n return false;\n }\n\n /**\n * Delete ranges from an input grid. Will delete the entire row, causing data to shift up\n * @param ranges The ranges to delete\n * @returns A promise that resolves successfully when the operation is complete or rejects if there's an error\n */\n abstract delete(ranges: readonly GridRange[]): Promise<void>;\n\n abstract seekRow(\n startRow: number,\n column: Column,\n valueType: ValueTypeUnion,\n value: unknown,\n insensitive?: boolean,\n contains?: boolean,\n isBackwards?: boolean\n ): Promise<number>;\n\n get isSeekRowAvailable(): boolean {\n return false;\n }\n\n abstract get columnHeaderGroups(): readonly ColumnHeaderGroup[];\n\n abstract get columnHeaderGroupMap(): ReadonlyMap<string, ColumnHeaderGroup>;\n\n abstract set columnHeaderGroups(groups: readonly ColumnHeaderGroup[]);\n\n abstract getColumnHeaderParentGroup(\n modelIndex: ModelIndex,\n depth: number\n ): ColumnHeaderGroup | undefined;\n}\n\nexport default IrisGridModel;\n"],"mappings":"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"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } }
|
|
2
|
+
function _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err); } _next(undefined); }); }; }
|
|
3
|
+
import { Formatter, TableUtils } from '@deephaven/jsapi-utils';
|
|
4
|
+
import IrisGridProxyModel from "./IrisGridProxyModel.js";
|
|
5
|
+
/**
|
|
6
|
+
* Factory to create an IrisGridDataModel based on a table or tree table, whatever is passed in.
|
|
7
|
+
*/
|
|
8
|
+
class IrisGridModelFactory {
|
|
9
|
+
/**
|
|
10
|
+
* @param table The Table or TreeTable object to create the model with
|
|
11
|
+
* @param formatter The formatter to use
|
|
12
|
+
* @returns An IrisGridModel that uses the table provided
|
|
13
|
+
*/
|
|
14
|
+
static makeModel(dh, table) {
|
|
15
|
+
var _arguments = arguments;
|
|
16
|
+
return _asyncToGenerator(function* () {
|
|
17
|
+
var formatter = _arguments.length > 2 && _arguments[2] !== undefined ? _arguments[2] : new Formatter(dh);
|
|
18
|
+
var inputTable = null;
|
|
19
|
+
if (!TableUtils.isTreeTable(table) && table.hasInputTable) {
|
|
20
|
+
inputTable = yield table.inputTable();
|
|
21
|
+
}
|
|
22
|
+
return new IrisGridProxyModel(dh, table, formatter, inputTable);
|
|
23
|
+
})();
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
export default IrisGridModelFactory;
|
|
27
|
+
//# sourceMappingURL=IrisGridModelFactory.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"IrisGridModelFactory.js","names":["Formatter","TableUtils","IrisGridProxyModel","IrisGridModelFactory","makeModel","dh","table","formatter","inputTable","isTreeTable","hasInputTable"],"sources":["../src/IrisGridModelFactory.ts"],"sourcesContent":["import type { dh as DhType, Table, TreeTable } from '@deephaven/jsapi-types';\nimport { Formatter, TableUtils } from '@deephaven/jsapi-utils';\nimport IrisGridModel from './IrisGridModel';\nimport IrisGridProxyModel from './IrisGridProxyModel';\n\n/**\n * Factory to create an IrisGridDataModel based on a table or tree table, whatever is passed in.\n */\nclass IrisGridModelFactory {\n /**\n * @param table The Table or TreeTable object to create the model with\n * @param formatter The formatter to use\n * @returns An IrisGridModel that uses the table provided\n */\n static async makeModel(\n dh: DhType,\n table: Table | TreeTable,\n formatter = new Formatter(dh)\n ): Promise<IrisGridModel> {\n let inputTable = null;\n if (!TableUtils.isTreeTable(table) && table.hasInputTable) {\n inputTable = await table.inputTable();\n }\n return new IrisGridProxyModel(dh, table, formatter, inputTable);\n }\n}\n\nexport default IrisGridModelFactory;\n"],"mappings":";;AACA,SAASA,SAAS,EAAEC,UAAU,QAAQ,wBAAwB;AAAC,OAExDC,kBAAkB;AAEzB;AACA;AACA;AACA,MAAMC,oBAAoB,CAAC;EACzB;AACF;AACA;AACA;AACA;EACE,OAAaC,SAAS,CACpBC,EAAU,EACVC,KAAwB,EAEA;IAAA;IAAA;MAAA,IADxBC,SAAS,0EAAG,IAAIP,SAAS,CAACK,EAAE,CAAC;MAE7B,IAAIG,UAAU,GAAG,IAAI;MACrB,IAAI,CAACP,UAAU,CAACQ,WAAW,CAACH,KAAK,CAAC,IAAIA,KAAK,CAACI,aAAa,EAAE;QACzDF,UAAU,SAASF,KAAK,CAACE,UAAU,EAAE;MACvC;MACA,OAAO,IAAIN,kBAAkB,CAACG,EAAE,EAAEC,KAAK,EAAEC,SAAS,EAAEC,UAAU,CAAC;IAAC;EAClE;AACF;AAEA,eAAeL,oBAAoB"}
|
|
@@ -0,0 +1,96 @@
|
|
|
1
|
+
/* eslint-disable react/require-default-props */
|
|
2
|
+
/* eslint-disable no-param-reassign */
|
|
3
|
+
import React, { useEffect, useMemo } from 'react';
|
|
4
|
+
import { TableUtils } from '@deephaven/jsapi-utils';
|
|
5
|
+
import { EMPTY_ARRAY, EMPTY_MAP } from '@deephaven/utils';
|
|
6
|
+
import IrisGridUtils from "./IrisGridUtils.js";
|
|
7
|
+
var COLUMN_BUFFER_PAGES = 1;
|
|
8
|
+
/**
|
|
9
|
+
* React component to keep IrisGridModel in sync
|
|
10
|
+
*/
|
|
11
|
+
var IrisGridModelUpdater = /*#__PURE__*/React.memo(_ref => {
|
|
12
|
+
var {
|
|
13
|
+
model,
|
|
14
|
+
modelColumns,
|
|
15
|
+
top,
|
|
16
|
+
bottom,
|
|
17
|
+
left,
|
|
18
|
+
right,
|
|
19
|
+
filter,
|
|
20
|
+
formatter,
|
|
21
|
+
reverseType = TableUtils.REVERSE_TYPE.NONE,
|
|
22
|
+
sorts,
|
|
23
|
+
customColumns,
|
|
24
|
+
movedColumns,
|
|
25
|
+
hiddenColumns,
|
|
26
|
+
alwaysFetchColumns,
|
|
27
|
+
rollupConfig = null,
|
|
28
|
+
totalsConfig = null,
|
|
29
|
+
selectDistinctColumns = EMPTY_ARRAY,
|
|
30
|
+
pendingRowCount = 0,
|
|
31
|
+
pendingDataMap = EMPTY_MAP,
|
|
32
|
+
frozenColumns,
|
|
33
|
+
formatColumns,
|
|
34
|
+
columnHeaderGroups
|
|
35
|
+
} = _ref;
|
|
36
|
+
var columns = useMemo(() => IrisGridUtils.getModelViewportColumns(modelColumns, left, right, movedColumns, hiddenColumns, alwaysFetchColumns, COLUMN_BUFFER_PAGES), [modelColumns, left, right, movedColumns, hiddenColumns, alwaysFetchColumns]);
|
|
37
|
+
useEffect(function updateFilter() {
|
|
38
|
+
model.filter = filter;
|
|
39
|
+
}, [model, filter]);
|
|
40
|
+
useEffect(function updateSorts() {
|
|
41
|
+
var sortsForModel = [...sorts];
|
|
42
|
+
if (reverseType !== TableUtils.REVERSE_TYPE.NONE) {
|
|
43
|
+
sortsForModel.push(model.dh.Table.reverse());
|
|
44
|
+
}
|
|
45
|
+
model.sort = sortsForModel;
|
|
46
|
+
}, [model, sorts, reverseType]);
|
|
47
|
+
useEffect(function updateFormatter() {
|
|
48
|
+
model.formatter = formatter;
|
|
49
|
+
}, [model, formatter]);
|
|
50
|
+
useEffect(function updateCustomColumns() {
|
|
51
|
+
if (model.isCustomColumnsAvailable) {
|
|
52
|
+
model.customColumns = customColumns;
|
|
53
|
+
}
|
|
54
|
+
}, [model, customColumns]);
|
|
55
|
+
useEffect(function updateFormatColumns() {
|
|
56
|
+
if (model.isFormatColumnsAvailable) {
|
|
57
|
+
model.formatColumns = formatColumns;
|
|
58
|
+
}
|
|
59
|
+
}, [model, formatColumns]);
|
|
60
|
+
useEffect(function updateViewport() {
|
|
61
|
+
model.setViewport(top, bottom, columns);
|
|
62
|
+
}, [model, top, bottom, columns]);
|
|
63
|
+
useEffect(function updateRollupCOnfig() {
|
|
64
|
+
if (model.isRollupAvailable) {
|
|
65
|
+
model.rollupConfig = rollupConfig;
|
|
66
|
+
}
|
|
67
|
+
}, [model, model.isRollupAvailable, rollupConfig]);
|
|
68
|
+
useEffect(function updateSelectDistinctColumns() {
|
|
69
|
+
if (model.isSelectDistinctAvailable) {
|
|
70
|
+
model.selectDistinctColumns = selectDistinctColumns;
|
|
71
|
+
}
|
|
72
|
+
}, [model, selectDistinctColumns]);
|
|
73
|
+
useEffect(function updateTotalsConfig() {
|
|
74
|
+
if (model.isTotalsAvailable) {
|
|
75
|
+
model.totalsConfig = totalsConfig;
|
|
76
|
+
}
|
|
77
|
+
}, [model, model.isTotalsAvailable, totalsConfig]);
|
|
78
|
+
useEffect(function updatePendingRowCount() {
|
|
79
|
+
model.pendingRowCount = pendingRowCount;
|
|
80
|
+
}, [model, pendingRowCount]);
|
|
81
|
+
useEffect(function updatePendingDataMap() {
|
|
82
|
+
model.pendingDataMap = pendingDataMap;
|
|
83
|
+
}, [model, pendingDataMap]);
|
|
84
|
+
useEffect(function updateFrozenColumns() {
|
|
85
|
+
if (frozenColumns) {
|
|
86
|
+
model.updateFrozenColumns(frozenColumns);
|
|
87
|
+
}
|
|
88
|
+
}, [model, frozenColumns]);
|
|
89
|
+
useEffect(function updateColumnHeaderGroups() {
|
|
90
|
+
model.columnHeaderGroups = columnHeaderGroups;
|
|
91
|
+
}, [model, columnHeaderGroups]);
|
|
92
|
+
return null;
|
|
93
|
+
});
|
|
94
|
+
IrisGridModelUpdater.displayName = 'IrisGridModelUpdater';
|
|
95
|
+
export default IrisGridModelUpdater;
|
|
96
|
+
//# sourceMappingURL=IrisGridModelUpdater.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"IrisGridModelUpdater.js","names":["React","useEffect","useMemo","TableUtils","EMPTY_ARRAY","EMPTY_MAP","IrisGridUtils","COLUMN_BUFFER_PAGES","IrisGridModelUpdater","memo","model","modelColumns","top","bottom","left","right","filter","formatter","reverseType","REVERSE_TYPE","NONE","sorts","customColumns","movedColumns","hiddenColumns","alwaysFetchColumns","rollupConfig","totalsConfig","selectDistinctColumns","pendingRowCount","pendingDataMap","frozenColumns","formatColumns","columnHeaderGroups","columns","getModelViewportColumns","updateFilter","updateSorts","sortsForModel","push","dh","Table","reverse","sort","updateFormatter","updateCustomColumns","isCustomColumnsAvailable","updateFormatColumns","isFormatColumnsAvailable","updateViewport","setViewport","updateRollupCOnfig","isRollupAvailable","updateSelectDistinctColumns","isSelectDistinctAvailable","updateTotalsConfig","isTotalsAvailable","updatePendingRowCount","updatePendingDataMap","updateFrozenColumns","updateColumnHeaderGroups","displayName"],"sources":["../src/IrisGridModelUpdater.tsx"],"sourcesContent":["/* eslint-disable react/require-default-props */\n/* eslint-disable no-param-reassign */\nimport React, { useEffect, useMemo } from 'react';\nimport type {\n Column,\n CustomColumn,\n FilterCondition,\n RollupConfig,\n Sort,\n} from '@deephaven/jsapi-types';\nimport { ModelIndex, MoveOperation } from '@deephaven/grid';\nimport { Formatter, ReverseType, TableUtils } from '@deephaven/jsapi-utils';\nimport { EMPTY_ARRAY, EMPTY_MAP } from '@deephaven/utils';\nimport IrisGridUtils from './IrisGridUtils';\nimport { ColumnName, UITotalsTableConfig, PendingDataMap } from './CommonTypes';\nimport IrisGridModel from './IrisGridModel';\nimport type ColumnHeaderGroup from './ColumnHeaderGroup';\n\nconst COLUMN_BUFFER_PAGES = 1;\n\ninterface IrisGridModelUpdaterProps {\n model: IrisGridModel;\n modelColumns: readonly Column[];\n top: number;\n bottom: number;\n left: number | null;\n right: number | null;\n filter: readonly FilterCondition[];\n sorts: readonly Sort[];\n reverseType?: ReverseType;\n customColumns: readonly ColumnName[];\n movedColumns: readonly MoveOperation[];\n hiddenColumns: readonly ModelIndex[];\n frozenColumns?: readonly ColumnName[];\n columnHeaderGroups: readonly ColumnHeaderGroup[];\n formatColumns: readonly CustomColumn[];\n alwaysFetchColumns: readonly ColumnName[];\n formatter: Formatter;\n rollupConfig?: RollupConfig | null;\n totalsConfig?: UITotalsTableConfig | null;\n selectDistinctColumns?: readonly ColumnName[];\n pendingRowCount?: number;\n pendingDataMap?: PendingDataMap;\n}\n\n/**\n * React component to keep IrisGridModel in sync\n */\nconst IrisGridModelUpdater = React.memo(\n ({\n model,\n modelColumns,\n top,\n bottom,\n left,\n right,\n filter,\n formatter,\n reverseType = TableUtils.REVERSE_TYPE.NONE,\n sorts,\n customColumns,\n movedColumns,\n hiddenColumns,\n alwaysFetchColumns,\n rollupConfig = null,\n totalsConfig = null,\n selectDistinctColumns = EMPTY_ARRAY,\n pendingRowCount = 0,\n pendingDataMap = EMPTY_MAP,\n frozenColumns,\n formatColumns,\n columnHeaderGroups,\n }: IrisGridModelUpdaterProps) => {\n const columns = useMemo(\n () =>\n IrisGridUtils.getModelViewportColumns(\n modelColumns,\n left,\n right,\n movedColumns,\n hiddenColumns,\n alwaysFetchColumns,\n COLUMN_BUFFER_PAGES\n ),\n [\n modelColumns,\n left,\n right,\n movedColumns,\n hiddenColumns,\n alwaysFetchColumns,\n ]\n );\n\n useEffect(\n function updateFilter() {\n model.filter = filter;\n },\n [model, filter]\n );\n useEffect(\n function updateSorts() {\n const sortsForModel = [...sorts];\n if (reverseType !== TableUtils.REVERSE_TYPE.NONE) {\n sortsForModel.push(model.dh.Table.reverse());\n }\n model.sort = sortsForModel;\n },\n [model, sorts, reverseType]\n );\n useEffect(\n function updateFormatter() {\n model.formatter = formatter;\n },\n [model, formatter]\n );\n useEffect(\n function updateCustomColumns() {\n if (model.isCustomColumnsAvailable) {\n model.customColumns = customColumns;\n }\n },\n [model, customColumns]\n );\n useEffect(\n function updateFormatColumns() {\n if (model.isFormatColumnsAvailable) {\n model.formatColumns = formatColumns;\n }\n },\n [model, formatColumns]\n );\n useEffect(\n function updateViewport() {\n model.setViewport(top, bottom, columns);\n },\n [model, top, bottom, columns]\n );\n useEffect(\n function updateRollupCOnfig() {\n if (model.isRollupAvailable) {\n model.rollupConfig = rollupConfig;\n }\n },\n [model, model.isRollupAvailable, rollupConfig]\n );\n useEffect(\n function updateSelectDistinctColumns() {\n if (model.isSelectDistinctAvailable) {\n model.selectDistinctColumns = selectDistinctColumns;\n }\n },\n [model, selectDistinctColumns]\n );\n useEffect(\n function updateTotalsConfig() {\n if (model.isTotalsAvailable) {\n model.totalsConfig = totalsConfig;\n }\n },\n [model, model.isTotalsAvailable, totalsConfig]\n );\n useEffect(\n function updatePendingRowCount() {\n model.pendingRowCount = pendingRowCount;\n },\n [model, pendingRowCount]\n );\n useEffect(\n function updatePendingDataMap() {\n model.pendingDataMap = pendingDataMap;\n },\n [model, pendingDataMap]\n );\n useEffect(\n function updateFrozenColumns() {\n if (frozenColumns) {\n model.updateFrozenColumns(frozenColumns);\n }\n },\n [model, frozenColumns]\n );\n useEffect(\n function updateColumnHeaderGroups() {\n model.columnHeaderGroups = columnHeaderGroups;\n },\n [model, columnHeaderGroups]\n );\n\n return null;\n }\n);\n\nIrisGridModelUpdater.displayName = 'IrisGridModelUpdater';\n\nexport default IrisGridModelUpdater;\n"],"mappings":"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"}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
/* stylelint-disable scss/at-import-no-partial-leading-underscore */
|
|
2
|
+
.iris-grid-partition-selector {
|
|
3
|
+
display: flex;
|
|
4
|
+
flex-wrap: wrap;
|
|
5
|
+
background: transparent;
|
|
6
|
+
vertical-align: middle;
|
|
7
|
+
}
|
|
8
|
+
.iris-grid-partition-selector .status-message {
|
|
9
|
+
text-overflow: ellipsis;
|
|
10
|
+
display: flex;
|
|
11
|
+
flex-direction: row;
|
|
12
|
+
align-items: center;
|
|
13
|
+
padding: 0.5em;
|
|
14
|
+
white-space: nowrap;
|
|
15
|
+
}
|
|
16
|
+
.iris-grid-partition-selector div {
|
|
17
|
+
flex-grow: 0;
|
|
18
|
+
}
|
|
19
|
+
.iris-grid-partition-selector .input-group {
|
|
20
|
+
width: auto;
|
|
21
|
+
align-items: center;
|
|
22
|
+
}
|
|
23
|
+
.iris-grid-partition-selector .input-group .form-control {
|
|
24
|
+
background-color: transparent;
|
|
25
|
+
border: 2px solid #f0f0ee;
|
|
26
|
+
border-right: none;
|
|
27
|
+
height: 2.25em;
|
|
28
|
+
}
|
|
29
|
+
.iris-grid-partition-selector .input-group .btn {
|
|
30
|
+
background-color: transparent;
|
|
31
|
+
margin: 0;
|
|
32
|
+
}
|
|
33
|
+
.iris-grid-partition-selector .iris-grid-partition-selector-spacer {
|
|
34
|
+
flex-grow: 1;
|
|
35
|
+
}
|
|
36
|
+
.iris-grid-partition-selector .btn-outline-primary {
|
|
37
|
+
color: #f0f0ee;
|
|
38
|
+
border-color: #f0f0ee;
|
|
39
|
+
margin: 0.35em 0.3em;
|
|
40
|
+
padding: 0.25em 0.5em;
|
|
41
|
+
}
|
|
42
|
+
.iris-grid-partition-selector .btn-close {
|
|
43
|
+
padding: 0 0.5em;
|
|
44
|
+
margin: 0.25em 0.25em 0.25em 0;
|
|
45
|
+
min-width: 0;
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
/*# sourceMappingURL=IrisGridPartitionSelector.css.map */
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sourceRoot":"","sources":["../../../node_modules/@deephaven/components/scss/custom.scss","../src/IrisGridPartitionSelector.scss","../../../node_modules/@deephaven/components/scss/bootstrap_overrides.scss"],"names":[],"mappings":"AAAA;ACGA;EACE;EACA;EACA;EACA;;AACA;EACE;EACA;EACA;EACA;EACA;EACA;;AAEF;EACE;;AAEF;EACE;EACA;;AACA;EACE;EACA;EACA;EACA,QAxB4B;;AA0B9B;EACE;EACA;;AAGJ;EACE;;AAEF;EACE,OCxBa;EDyBb,cCzBa;ED0Bb;EACA;;AAEF;EACE;EACA;EACA","file":"IrisGridPartitionSelector.css","sourcesContent":["/* stylelint-disable scss/at-import-no-partial-leading-underscore */\n// Consumers should be able to resolve bootstrap/ to node_modules/bootstrap\n\n//Make bootstrap functions available for use in overrides\n@import 'bootstrap/scss/_functions.scss';\n@import './bootstrap_overrides.scss';\n\n//_variable imports come after bootstrap default overrides,\n// makes all other variables and mixins from bootstrap available\n/// with just importing customer.scss\n@import 'bootstrap/scss/_variables.scss';\n@import 'bootstrap/scss/_mixins.scss';\n\n//New variables come after imports\n@import './new_variables.scss';\n","@import '@deephaven/components/scss/custom.scss';\n$partition-selector-color: $white;\n$partition-selector-input-height: 2.25em;\n.iris-grid-partition-selector {\n display: flex;\n flex-wrap: wrap;\n background: transparent;\n vertical-align: middle;\n .status-message {\n text-overflow: ellipsis;\n display: flex;\n flex-direction: row;\n align-items: center;\n padding: 0.5em;\n white-space: nowrap;\n }\n div {\n flex-grow: 0;\n }\n .input-group {\n width: auto;\n align-items: center;\n .form-control {\n background-color: transparent;\n border: 2px solid $partition-selector-color;\n border-right: none;\n height: $partition-selector-input-height;\n }\n .btn {\n background-color: transparent;\n margin: 0;\n }\n }\n .iris-grid-partition-selector-spacer {\n flex-grow: 1;\n }\n .btn-outline-primary {\n color: $white;\n border-color: $white;\n margin: 0.35em 0.3em;\n padding: 0.25em 0.5em;\n }\n .btn-close {\n padding: 0 0.5em;\n margin: 0.25em 0.25em 0.25em 0;\n min-width: 0;\n }\n}\n","// Styling overrides for bootstrap\n\n// Override / set color variables\n$red: #f95d84;\n$orange: #f37e3f;\n$yellow: #fcd65b;\n$green: #9edc6f;\n$blue: #76d9e4;\n$purple: #aa9af4;\n\n//Define some UI colors\n$interfacegray: #2d2a2e;\n$interfaceblue: #4878ea;\n$interfacewhite: #f0f0ee; //same as gray-200\n$interfaceblack: #1a171a;\n\n//Define our Gray scale\n$white: $interfacewhite;\n$gray-100: #fcfcfa;\n$gray-200: $interfacewhite;\n$gray-300: #c0bfbf;\n$gray-400: #929192;\n$gray-500: #5b5a5c;\n$gray-600: #555356;\n$gray-700: #403e41;\n$gray-800: #373438;\n$gray-850: #322f33;\n$gray-900: #211f22;\n$black: $interfaceblack;\n$content-bg: $interfacegray;\n$background: $interfaceblack;\n$foreground: $interfacewhite;\n\n//Load colors into map\n$colors: ();\n$colors: map-merge(\n (\n 'red': $red,\n 'orange': $orange,\n 'yellow': $yellow,\n 'green': $green,\n 'blue': $blue,\n 'purple': $purple,\n 'white': $white,\n 'black': $black,\n ),\n $colors\n);\n\n//Set default colors\n$body-bg: $black;\n$body-color: $interfacewhite;\n\n// Set brand colors\n$primary: $interfaceblue;\n$primary-hover: darken($primary, 8%);\n$primary-dark: mix($primary, $content-bg, 25%);\n$primary-light: scale-color($primary, $lightness: -25%);\n$secondary: $gray-500;\n$secondary-hover: darken($secondary, 8%);\n$success: $green;\n$info: $yellow;\n$warning: $orange;\n$danger: $red;\n$danger-hover: darken($danger, 8%);\n$light: $gray-100;\n$mid: $gray-400; //Added a mid color, useful for input styling\n$dark: $gray-800;\n$green-dark: scale-color($green, $lightness: -45%, $saturation: -10%);\n\n$theme-colors: () !default;\n$theme-colors: map-merge(\n (\n 'primary': $primary,\n 'primary-hover': $primary-hover,\n 'primary-light': $primary-light,\n 'primary-dark': $primary-dark,\n 'secondary': $secondary,\n 'success': $success,\n 'info': $info,\n 'warning': $warning,\n 'danger': $danger,\n 'light': $light,\n 'dark': $dark,\n 'mid': $mid,\n 'content-bg': $interfacegray,\n 'background': $interfaceblack,\n 'foreground': $interfacewhite,\n ),\n $theme-colors\n);\n\n$component-active-bg: $primary;\n$theme-color-interval: 9%;\n$yiq-contrasted-threshold: 180;\n\n// Override fonts\n$font-family-sans-serif: 'Fira Sans', -apple-system, blinkmacsystemfont,\n 'Segoe UI', 'Roboto', 'Helvetica Neue', arial, sans-serif; //fira sans then native system ui fallbacks\n$font-family-monospace: 'Fira Mono', menlo, monaco, consolas, 'Liberation Mono',\n 'Courier New', monospace;\n$font-family-base: $font-family-sans-serif;\n\n$headings-font-weight: 400;\n\n//Text overides\n$text-muted: $gray-400;\n\n//Style Selection highlight color\n//so browsers add alpha to your color by default, ignoring opacity 1\n//by setting rgba with 0.99 it tricks browser into thinking there is alpha applied\n$text-select-color: $primary-hover;\n$text-select-color-editor: lighten(\n $gray-700,\n 15%\n); //we lighten it abit to account for that 0.01 loss, and because it needs some anyways.\n\n//Grid variables, same value as default just making easily accessible\n$grid-gutter-width: 30px;\n\n//Visual Overrides\n$border-radius: 4px;\n$box-shadow: 0 0.1rem 1rem rgba($black, 45%); //because our UI is so dark, we need darker default shadows\n$box-shadow-900: 0 0.1rem 1rem rgba(0, 0, 0, 45%); //darkest shadow for $black popups over $black UI\n\n//Override Btn\n$btn-border-radius: 4rem;\n$btn-padding-x: 1.5rem;\n$btn-transition: color 0.12s ease-in-out, background-color 0.12s ease-in-out,\n border-color 0.12s ease-in-out, box-shadow 0.12s ease-in-out; //default 0.15 is too long\n$btn-border-width: 2px;\n\n//Override Inputs\n$input-bg: $gray-600;\n$input-disabled-bg: $gray-800;\n$input-color: $foreground;\n$input-border-color: $gray-400;\n$input-placeholder-color: $gray-400;\n$input-focus-border-color: rgba($primary, 85%);\n\n$input-btn-focus-width: 0.2rem;\n$input-btn-focus-color: rgba($component-active-bg, 35%);\n$input-btn-focus-box-shadow: 0 0 0 $input-btn-focus-width $input-btn-focus-color;\n\n//checkbox\n$custom-control-indicator-bg: $gray-600;\n$custom-control-indicator-bg-size: 75% 75%;\n$custom-control-indicator-disabled-bg: $gray-800;\n$custom-control-indicator-checked-disabled-bg: $gray-800;\n$custom-control-label-disabled-color: $gray-400;\n\n//Custom Select\n$custom-select-indicator-color: $gray-400;\n$custom-select-bg-size: 16px 16px;\n//dhSort icon encoded\n$custom-select-indicator: str-replace(\n url(\"data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='#{$custom-select-indicator-color}' d='M4 7l-.4-.8 4-3.7h.8l4 3.7-.4.8H4zm0 2l-.4.8 4 3.7h.8l4-3.7L12 9H4z'/%3E%3C/svg%3E\"),\n '#',\n '%23'\n);\n$custom-select-focus-box-shadow: $input-btn-focus-box-shadow;\n$custom-select-disabled-color: darken($gray-400, 5%);\n$custom-select-disabled-bg: $gray-800;\n\n//modal\n$modal-content-bg: $gray-200;\n$modal-content-border-width: 0;\n$modal-md: 550px;\n\n// Toast notification\n$toast-bg: $primary-dark;\n$toast-color: $foreground;\n$toast-error-bg: mix($danger, $content-bg, 15%);\n$toast-error-color: $foreground;\n\n//tooltips\n$tooltip-bg: $gray-700;\n$tooltip-color: $foreground;\n$tooltip-box-shadow: 0 0.1rem 1.5rem 0.1rem rgba($black, 80%);\n\n//drowdowns\n$dropdown-bg: $gray-600;\n$dropdown-link-color: $foreground;\n$dropdown-link-hover-color: $foreground;\n$dropdown-link-hover-bg: $primary;\n$dropdown-divider-bg: $gray-700;\n\n//context menus\n$contextmenu-bg: $gray-600;\n$contextmenu-color: $foreground;\n$contextmenu-disabled-color: $text-muted;\n$contextmenu-keyboard-selected-bg: rgba($primary, 50%);\n$contextmenu-selected-bg: $primary;\n$contextmenu-selected-color: $foreground;\n\n//links\n$link-color: $gray-400;\n$link-hover-color: $foreground;\n\n//progress-bar\n$progress-bg: $gray-600;\n$progress-border-radius: 1rem;\n\n// Set global options\n$enable-shadows: false;\n$enable-gradients: false;\n$enable-print-styles: false; //I don't think anyone should expect to \"print\" this app.\n\n// Transition times\n$transition: 0.15s;\n$transition-mid: 0.2s;\n$transition-long: 0.3s;\n$transition-slow: 0.6s;\n\n//form-validation icon, uses vsWarning icon encoded here as svg\n$form-feedback-icon-invalid-color: theme-color('danger');\n$form-feedback-icon-invalid: str-replace(\n url(\"data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 16 16'%3E%3Cg fill='none'%3E%3Cg fill='#{$form-feedback-icon-invalid-color}'%3E%3Cpath d='M7.56 1h.88l6.54 12.26-.44.74H1.44L1 13.26 7.56 1zM8 2.28 2.28 13H13.7L8 2.28zM8.625 12v-1h-1.25v1h1.25zm-1.25-2V6h1.25v4h-1.25z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E \"),\n '#',\n '%23'\n);\n"]}
|