@deephaven/dashboard-core-plugins 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/ChartBuilderPlugin.js +54 -0
- package/dist/ChartBuilderPlugin.js.map +1 -0
- package/dist/ChartPlugin.js +66 -0
- package/dist/ChartPlugin.js.map +1 -0
- package/dist/ConsolePlugin.js +396 -0
- package/dist/ConsolePlugin.js.map +1 -0
- package/dist/FilterPlugin.js +205 -0
- package/dist/FilterPlugin.js.map +1 -0
- package/dist/GridPlugin.js +74 -0
- package/dist/GridPlugin.js.map +1 -0
- package/dist/LinkerPlugin.js +18 -0
- package/dist/LinkerPlugin.js.map +1 -0
- package/dist/MarkdownPlugin.js +87 -0
- package/dist/MarkdownPlugin.js.map +1 -0
- package/dist/PandasPlugin.js +66 -0
- package/dist/PandasPlugin.js.map +1 -0
- package/dist/controls/ControlType.js +10 -0
- package/dist/controls/ControlType.js.map +1 -0
- package/dist/controls/dropdown-filter/DropdownFilter.css +86 -0
- package/dist/controls/dropdown-filter/DropdownFilter.css.map +1 -0
- package/dist/controls/dropdown-filter/DropdownFilter.js +417 -0
- package/dist/controls/dropdown-filter/DropdownFilter.js.map +1 -0
- package/dist/controls/input-filter/InputFilter.css +75 -0
- package/dist/controls/input-filter/InputFilter.css.map +1 -0
- package/dist/controls/input-filter/InputFilter.js +291 -0
- package/dist/controls/input-filter/InputFilter.js.map +1 -0
- package/dist/controls/markdown/MarkdownContainer.js +30 -0
- package/dist/controls/markdown/MarkdownContainer.js.map +1 -0
- package/dist/controls/markdown/MarkdownEditor.js +52 -0
- package/dist/controls/markdown/MarkdownEditor.js.map +1 -0
- package/dist/controls/markdown/MarkdownStartPage.js +109 -0
- package/dist/controls/markdown/MarkdownStartPage.js.map +1 -0
- package/dist/controls/markdown/MarkdownUtils.js +23 -0
- package/dist/controls/markdown/MarkdownUtils.js.map +1 -0
- package/dist/events/ChartEvent.js +9 -0
- package/dist/events/ChartEvent.js.map +1 -0
- package/dist/events/ConsoleEvent.js +11 -0
- package/dist/events/ConsoleEvent.js.map +1 -0
- package/dist/events/InputFilterEvent.js +14 -0
- package/dist/events/InputFilterEvent.js.map +1 -0
- package/dist/events/IrisGridEvent.js +12 -0
- package/dist/events/IrisGridEvent.js.map +1 -0
- package/dist/events/MarkdownEvent.js +4 -0
- package/dist/events/MarkdownEvent.js.map +1 -0
- package/dist/events/NotebookEvent.js +15 -0
- package/dist/events/NotebookEvent.js.map +1 -0
- package/dist/events/PQEvent.js +9 -0
- package/dist/events/PQEvent.js.map +1 -0
- package/dist/events/PandasEvent.js +8 -0
- package/dist/events/PandasEvent.js.map +1 -0
- package/dist/events/TabEvent.js +12 -0
- package/dist/events/TabEvent.js.map +1 -0
- package/dist/events/index.js +9 -0
- package/dist/events/index.js.map +1 -0
- package/dist/index.js +17 -0
- package/dist/index.js.map +1 -0
- package/dist/linker/ColumnSelectionValidator.js +2 -0
- package/dist/linker/ColumnSelectionValidator.js.map +1 -0
- package/dist/linker/Linker.js +736 -0
- package/dist/linker/Linker.js.map +1 -0
- package/dist/linker/LinkerLink.css +142 -0
- package/dist/linker/LinkerLink.css.map +1 -0
- package/dist/linker/LinkerLink.js +314 -0
- package/dist/linker/LinkerLink.js.map +1 -0
- package/dist/linker/LinkerOverlayContent.css +63 -0
- package/dist/linker/LinkerOverlayContent.css.map +1 -0
- package/dist/linker/LinkerOverlayContent.js +343 -0
- package/dist/linker/LinkerOverlayContent.js.map +1 -0
- package/dist/linker/LinkerUtils.js +139 -0
- package/dist/linker/LinkerUtils.js.map +1 -0
- package/dist/linker/ToolType.js +5 -0
- package/dist/linker/ToolType.js.map +1 -0
- package/dist/linker/index.js +2 -0
- package/dist/linker/index.js.map +1 -0
- package/dist/panels/ChartColumnSelectorOverlay.css +11 -0
- package/dist/panels/ChartColumnSelectorOverlay.css.map +1 -0
- package/dist/panels/ChartColumnSelectorOverlay.js +38 -0
- package/dist/panels/ChartColumnSelectorOverlay.js.map +1 -0
- package/dist/panels/ChartFilterOverlay.css +22 -0
- package/dist/panels/ChartFilterOverlay.css.map +1 -0
- package/dist/panels/ChartFilterOverlay.js +90 -0
- package/dist/panels/ChartFilterOverlay.js.map +1 -0
- package/dist/panels/ChartPanel.css +38 -0
- package/dist/panels/ChartPanel.css.map +1 -0
- package/dist/panels/ChartPanel.js +971 -0
- package/dist/panels/ChartPanel.js.map +1 -0
- package/dist/panels/ChartPanelUtils.js +5 -0
- package/dist/panels/ChartPanelUtils.js.map +1 -0
- package/dist/panels/CommandHistoryPanel.css +19 -0
- package/dist/panels/CommandHistoryPanel.css.map +1 -0
- package/dist/panels/CommandHistoryPanel.js +195 -0
- package/dist/panels/CommandHistoryPanel.js.map +1 -0
- package/dist/panels/ConsolePanel.css +19 -0
- package/dist/panels/ConsolePanel.css.map +1 -0
- package/dist/panels/ConsolePanel.js +365 -0
- package/dist/panels/ConsolePanel.js.map +1 -0
- package/dist/panels/DropdownFilterPanel.css +6 -0
- package/dist/panels/DropdownFilterPanel.css.map +1 -0
- package/dist/panels/DropdownFilterPanel.js +685 -0
- package/dist/panels/DropdownFilterPanel.js.map +1 -0
- package/dist/panels/FileExplorerPanel.css +6 -0
- package/dist/panels/FileExplorerPanel.css.map +1 -0
- package/dist/panels/FileExplorerPanel.js +252 -0
- package/dist/panels/FileExplorerPanel.js.map +1 -0
- package/dist/panels/FilterSetManager.css +112 -0
- package/dist/panels/FilterSetManager.css.map +1 -0
- package/dist/panels/FilterSetManager.js +689 -0
- package/dist/panels/FilterSetManager.js.map +1 -0
- package/dist/panels/FilterSetManagerPanel.css +34 -0
- package/dist/panels/FilterSetManagerPanel.css.map +1 -0
- package/dist/panels/FilterSetManagerPanel.js +345 -0
- package/dist/panels/FilterSetManagerPanel.js.map +1 -0
- package/dist/panels/InputFilterPanel.js +232 -0
- package/dist/panels/InputFilterPanel.js.map +1 -0
- package/dist/panels/IrisGridPanel.css +24 -0
- package/dist/panels/IrisGridPanel.css.map +1 -0
- package/dist/panels/IrisGridPanel.js +1018 -0
- package/dist/panels/IrisGridPanel.js.map +1 -0
- package/dist/panels/IrisGridPanelTooltip.js +39 -0
- package/dist/panels/IrisGridPanelTooltip.js.map +1 -0
- package/dist/panels/LogPanel.css +15 -0
- package/dist/panels/LogPanel.css.map +1 -0
- package/dist/panels/LogPanel.js +110 -0
- package/dist/panels/LogPanel.js.map +1 -0
- package/dist/panels/MarkdownNotebook.css +107 -0
- package/dist/panels/MarkdownNotebook.css.map +1 -0
- package/dist/panels/MarkdownNotebook.js +232 -0
- package/dist/panels/MarkdownNotebook.js.map +1 -0
- package/dist/panels/MarkdownPanel.css +90 -0
- package/dist/panels/MarkdownPanel.css.map +1 -0
- package/dist/panels/MarkdownPanel.js +202 -0
- package/dist/panels/MarkdownPanel.js.map +1 -0
- package/dist/panels/MockFileStorage.js +70 -0
- package/dist/panels/MockFileStorage.js.map +1 -0
- package/dist/panels/MockFileStorageTable.js +80 -0
- package/dist/panels/MockFileStorageTable.js.map +1 -0
- package/dist/panels/NotebookPanel.css +44 -0
- package/dist/panels/NotebookPanel.css.map +1 -0
- package/dist/panels/NotebookPanel.js +1224 -0
- package/dist/panels/NotebookPanel.js.map +1 -0
- package/dist/panels/PandasPanel.css +15 -0
- package/dist/panels/PandasPanel.css.map +1 -0
- package/dist/panels/PandasPanel.js +86 -0
- package/dist/panels/PandasPanel.js.map +1 -0
- package/dist/panels/Panel.js +314 -0
- package/dist/panels/Panel.js.map +1 -0
- package/dist/panels/PanelContextMenu.js +126 -0
- package/dist/panels/PanelContextMenu.js.map +1 -0
- package/dist/panels/RenameDialog.js +156 -0
- package/dist/panels/RenameDialog.js.map +1 -0
- package/dist/panels/WidgetPanel.css +17 -0
- package/dist/panels/WidgetPanel.css.map +1 -0
- package/dist/panels/WidgetPanel.js +189 -0
- package/dist/panels/WidgetPanel.js.map +1 -0
- package/dist/panels/WidgetPanelTooltip.css +40 -0
- package/dist/panels/WidgetPanelTooltip.css.map +1 -0
- package/dist/panels/WidgetPanelTooltip.js +49 -0
- package/dist/panels/WidgetPanelTooltip.js.map +1 -0
- package/dist/panels/index.js +22 -0
- package/dist/panels/index.js.map +1 -0
- package/dist/prop-types/CommonPropTypes.js +9 -0
- package/dist/prop-types/CommonPropTypes.js.map +1 -0
- package/dist/prop-types/UIPropTypes.js +42 -0
- package/dist/prop-types/UIPropTypes.js.map +1 -0
- package/dist/prop-types/index.js +3 -0
- package/dist/prop-types/index.js.map +1 -0
- package/dist/redux/actionTypes.js +3 -0
- package/dist/redux/actionTypes.js.map +1 -0
- package/dist/redux/actions.js +88 -0
- package/dist/redux/actions.js.map +1 -0
- package/dist/redux/index.js +10 -0
- package/dist/redux/index.js.map +1 -0
- package/dist/redux/reducers/connection.js +7 -0
- package/dist/redux/reducers/connection.js.map +1 -0
- package/dist/redux/reducers/index.js +5 -0
- package/dist/redux/reducers/index.js.map +1 -0
- package/dist/redux/reducers/sessionWrapper.js +7 -0
- package/dist/redux/reducers/sessionWrapper.js.map +1 -0
- package/dist/redux/selectors.js +92 -0
- package/dist/redux/selectors.js.map +1 -0
- package/package.json +22 -22
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"IrisGridPanel.js","names":["React","PureComponent","memoize","connect","debounce","DEFAULT_DASHBOARD_ID","LayoutUtils","AdvancedSettings","IrisGrid","IrisGridModel","IrisGridUtils","IrisGridTableModel","isIrisGridTableModelTemplate","TableUtils","Log","getSettings","getUser","getWorkspace","assertNotNull","PromiseUtils","ContextMenuRoot","ConsoleEvent","InputFilterEvent","IrisGridEvent","getInputFiltersForDashboard","getLinksForDashboard","getColumnSelectionValidatorForDashboard","WidgetPanel","IrisGridPanelTooltip","log","module","DEBOUNCE_PANEL_STATE_UPDATE","PLUGIN_COMPONENTS","IrisGridPanel","constructor","props","columns","inputFilters","getInputFiltersForColumns","filter","value","excludePanelIds","id","getIdFromPanel","includes","dashboardLinks","pluginFetchColumns","columnSet","Set","i","length","start","panelId","add","columnName","Plugin","model","user","workspace","pluginState","table","pluginRef","handlePluginFilter","handlePluginFetchColumns","handlePluginStateChange","isSelectingPartition","partition","partitionColumn","advancedSettings","dehydrateIrisGridPanelState","sorts","advancedFilters","customColumnFormatMap","isFilterBarShown","quickFilters","customColumns","reverseType","rollupConfig","showSearchBar","searchValue","selectDistinctColumns","selectedSearchColumns","invertSearchColumns","userColumnWidths","userRowHeights","aggregationSettings","pendingDataMap","frozenColumns","conditionalFormats","columnHeaderGroups","irisGridUtils","dehydrateIrisGridState","metrics","movedColumns","movedRows","isStuckToBottom","isStuckToRight","dehydrateGridState","irisGridPanelState","irisGridState","gridState","onPanelStateUpdate","panelState","oldPanelState","state","getCachedPanelState","getDehydratedIrisGridPanelState","getDehydratedIrisGridState","getDehydratedGridState","debug","setState","handleAdvancedSettingsChange","bind","handleColumnsChanged","handleTableChanged","handleColumnSelected","handleDataSelected","handleError","handleGridStateChange","handlePartitionAppend","handleCreateChart","handleResize","handleShow","handleTabClicked","handleDisconnect","handleReconnect","handleLoadSuccess","handleLoadError","isColumnSelectionValid","handleContextMenu","handleClearAllFilters","irisGrid","createRef","error","isDisconnected","isLoaded","isLoading","isModelReady","undefined","Map","aggregations","showOnTop","DEFAULTS","REVERSE_TYPE","NONE","pluginFilters","modelQueue","irisGridStateOverrides","gridStateOverrides","componentDidMount","initModel","componentDidUpdate","_","prevState","stopModelListening","close","startModelListening","componentWillUnmount","savePanelState","cancel","modelPromise","getTableName","metadata","makeModel","makeCancelable","resolved","then","catch","modelParam","dh","push","m","getModelRollupConfig","originalColumns","initModelQueue","modelInitialized","modelChange","shift","key","get","set","filters","formatter","getFiltersFromInputFilters","timeZone","obj","current","getMenu","tableColumn","columnSelectionValidator","glEventHub","onStateChange","emit","STATE_CHANGED","event","sendColumnsChange","detail","TABLE_CHANGED","column","name","tableName","command","SEND_COMMAND","settings","flush","sourcePanelId","tableSettings","extractTableSettings","CREATE_CHART","COLUMN_SELECTED","row","dataMap","DATA_SELECTED","updateGrid","focus","Error","isCanceled","loadPlugin","loadPanelState","pluginName","clearAllFilters","debug2","COLUMNS_CHANGED","addEventListener","EVENT","DISCONNECT","RECONNECT","removeEventListener","getCoordinateForColumn","gridWrapper","rect","getBoundingClientRect","width","height","columnHeaderHeight","allColumnXs","allColumnWidths","right","columnHeaderMaxDepth","columnIndex","getColumnIndexByName","visibleIndex","getVisibleColumn","columnX","columnWidth","x","Math","max","left","min","y","top","setFilterMap","filterMap","setAdvancedFilterMap","setFilters","indexedQuickFilters","changeFilterColumnNamesToIndexes","isFilterable","indexedAdvancedFilters","hydrateQuickFilters","hydrateAdvancedFilters","setStateOverrides","overrides","unsetFilterValue","originalIrisGridStateOverrides","savedQuickFilters","savedAdvancedFilters","hydrateIrisGridPanelState","hydrateIrisGridState","hydrateGridState","grid","render","children","glContainer","getDownloadWorker","links","theme","errorMessage","description","childrenContent","getPluginContent","permissions","canCopy","canDownloadCsv","getAlwaysFetchColumns","getGridInputFilters","mapStateToProps","localDashboardId","ConnectedIrisGridPanel","forwardRef"],"sources":["../../src/panels/IrisGridPanel.tsx"],"sourcesContent":["// Wrapper for the IrisGrid for use in a golden layout container\n// Will probably need to handle window popping out from golden layout here.\nimport React, {\n PureComponent,\n ReactElement,\n ReactNode,\n RefObject,\n} from 'react';\nimport memoize from 'memoize-one';\nimport { connect } from 'react-redux';\nimport debounce from 'lodash.debounce';\nimport {\n DEFAULT_DASHBOARD_ID,\n LayoutUtils,\n PanelComponent,\n} from '@deephaven/dashboard';\nimport {\n AdvancedSettings,\n IrisGrid,\n IrisGridModel,\n IrisGridUtils,\n IrisGridTableModel,\n isIrisGridTableModelTemplate,\n ColumnName,\n PendingDataMap,\n InputFilter,\n IrisGridThemeType,\n ReadonlyAdvancedFilterMap,\n AggregationSettings,\n AdvancedSettingsType,\n UIRollupConfig,\n UIRow,\n ReadonlyQuickFilterMap,\n FilterMap,\n QuickFilter,\n AdvancedFilter,\n SidebarFormattingRule,\n IrisGridState,\n ChartBuilderSettings,\n DehydratedIrisGridState,\n ColumnHeaderGroup,\n} from '@deephaven/iris-grid';\nimport {\n AdvancedFilterOptions,\n FormattingRule,\n ReverseType,\n TableUtils,\n} from '@deephaven/jsapi-utils';\nimport Log from '@deephaven/log';\nimport {\n getSettings,\n getUser,\n getWorkspace,\n RootState,\n User,\n Workspace,\n} from '@deephaven/redux';\nimport {\n assertNotNull,\n CancelablePromise,\n PromiseUtils,\n} from '@deephaven/utils';\nimport { ContextAction, ContextMenuRoot } from '@deephaven/components';\nimport type { Column, FilterCondition, Sort } from '@deephaven/jsapi-types';\nimport {\n GridRangeIndex,\n GridState,\n ModelIndex,\n ModelSizeMap,\n MoveOperation,\n} from '@deephaven/grid';\nimport type { Container, EventEmitter } from '@deephaven/golden-layout';\nimport { ConsoleEvent, InputFilterEvent, IrisGridEvent } from '../events';\nimport {\n getInputFiltersForDashboard,\n getLinksForDashboard,\n getColumnSelectionValidatorForDashboard,\n} from '../redux';\nimport WidgetPanel from './WidgetPanel';\nimport './IrisGridPanel.scss';\nimport { Link, LinkColumn } from '../linker/LinkerUtils';\nimport IrisGridPanelTooltip from './IrisGridPanelTooltip';\n\nconst log = Log.module('IrisGridPanel');\n\nconst DEBOUNCE_PANEL_STATE_UPDATE = 500;\n\nconst PLUGIN_COMPONENTS = { IrisGrid, IrisGridTableModel, ContextMenuRoot };\n\ntype ModelQueueFunction = (model: IrisGridModel) => void;\n\ntype ModelQueue = ModelQueueFunction[];\n\ninterface Metadata {\n table: string;\n type?: string;\n query?: string;\n querySerial?: string;\n}\n\nexport interface PanelState {\n gridState: {\n isStuckToBottom: boolean;\n isStuckToRight: boolean;\n movedColumns: {\n from: string | ModelIndex | [string, string] | [ModelIndex, ModelIndex];\n to: string | ModelIndex;\n }[];\n movedRows: MoveOperation[];\n };\n irisGridState: DehydratedIrisGridState;\n irisGridPanelState: {\n partitionColumn: ColumnName | null;\n partition: string | null;\n isSelectingPartition: boolean;\n advancedSettings: [AdvancedSettingsType, boolean][];\n };\n pluginState: unknown;\n}\n\n// Some of the properties in the loaded panel state may be omitted\n// even though they can't be undefined in the dehydrated state.\n// This can happen when loading the state saved before the properties were added.\ntype LoadedPanelState = PanelState & {\n irisGridPanelState: PanelState['irisGridPanelState'] &\n Partial<\n Pick<PanelState['irisGridPanelState'], 'partition' | 'partitionColumn'>\n >;\n};\n\nexport interface IrisGridPanelProps {\n children?: ReactNode;\n glContainer: Container;\n glEventHub: EventEmitter;\n metadata: Metadata;\n panelState: LoadedPanelState | null;\n makeModel: () => IrisGridModel | Promise<IrisGridModel>;\n inputFilters: InputFilter[];\n links: Link[];\n columnSelectionValidator?: (\n panel: PanelComponent,\n tableColumn?: LinkColumn\n ) => boolean;\n onStateChange?: (irisGridState: IrisGridState, gridState: GridState) => void;\n onPanelStateUpdate?: (panelState: PanelState) => void;\n user: User;\n workspace: Workspace;\n settings: { timeZone: string };\n\n // Retrieve a download worker for optimizing exporting tables\n getDownloadWorker: () => Promise<ServiceWorker>;\n\n // Load a plugin defined by the table\n loadPlugin: (pluginName: string) => Plugin;\n\n theme: IrisGridThemeType;\n}\n\ninterface IrisGridPanelState {\n error: unknown;\n isDisconnected: boolean;\n isLoaded: boolean;\n isLoading: boolean;\n isModelReady: boolean;\n model?: IrisGridModel;\n\n isStuckToBottom: boolean;\n isStuckToRight: boolean;\n\n // State is hydrated from panel state when table is loaded\n conditionalFormats: readonly SidebarFormattingRule[];\n selectDistinctColumns: readonly ColumnName[];\n advancedFilters: ReadonlyAdvancedFilterMap;\n aggregationSettings: AggregationSettings;\n advancedSettings: Map<AdvancedSettingsType, boolean>;\n customColumns: readonly ColumnName[];\n customColumnFormatMap: Map<string, FormattingRule>;\n isFilterBarShown: boolean;\n quickFilters: ReadonlyQuickFilterMap;\n sorts: readonly Sort[];\n userColumnWidths: ModelSizeMap;\n userRowHeights: ModelSizeMap;\n reverseType: ReverseType;\n movedColumns: readonly MoveOperation[];\n movedRows: readonly MoveOperation[];\n isSelectingPartition: boolean;\n partition: string | null;\n partitionColumn: Column | null;\n rollupConfig?: UIRollupConfig;\n showSearchBar: boolean;\n searchValue: string;\n selectedSearchColumns?: readonly string[];\n invertSearchColumns: boolean;\n Plugin?: Plugin;\n pluginFilters: readonly FilterCondition[];\n pluginFetchColumns: readonly string[];\n modelQueue: ModelQueue;\n pendingDataMap?: PendingDataMap<UIRow>;\n frozenColumns?: readonly ColumnName[];\n columnHeaderGroups?: readonly ColumnHeaderGroup[];\n\n // eslint-disable-next-line react/no-unused-state\n panelState: PanelState | null; // Dehydrated panel state that can load this panel\n irisGridStateOverrides: Partial<DehydratedIrisGridState>;\n gridStateOverrides: Partial<GridState>;\n}\n\nexport class IrisGridPanel extends PureComponent<\n IrisGridPanelProps,\n IrisGridPanelState\n> {\n static defaultProps = {\n onStateChange: (): void => undefined,\n onPanelStateUpdate: (): void => undefined,\n };\n\n static displayName = 'IrisGridPanel';\n\n static COMPONENT = 'IrisGridPanel';\n\n constructor(props: IrisGridPanelProps) {\n super(props);\n\n this.handleAdvancedSettingsChange = this.handleAdvancedSettingsChange.bind(\n this\n );\n this.handleColumnsChanged = this.handleColumnsChanged.bind(this);\n this.handleTableChanged = this.handleTableChanged.bind(this);\n this.handleColumnSelected = this.handleColumnSelected.bind(this);\n this.handleDataSelected = this.handleDataSelected.bind(this);\n this.handleError = this.handleError.bind(this);\n this.handleGridStateChange = this.handleGridStateChange.bind(this);\n this.handlePluginStateChange = this.handlePluginStateChange.bind(this);\n this.handlePartitionAppend = this.handlePartitionAppend.bind(this);\n this.handleCreateChart = this.handleCreateChart.bind(this);\n this.handleResize = this.handleResize.bind(this);\n this.handleShow = this.handleShow.bind(this);\n this.handleTabClicked = this.handleTabClicked.bind(this);\n this.handleDisconnect = this.handleDisconnect.bind(this);\n this.handleReconnect = this.handleReconnect.bind(this);\n this.handleLoadSuccess = this.handleLoadSuccess.bind(this);\n this.handleLoadError = this.handleLoadError.bind(this);\n this.isColumnSelectionValid = this.isColumnSelectionValid.bind(this);\n this.handleContextMenu = this.handleContextMenu.bind(this);\n this.handlePluginFilter = this.handlePluginFilter.bind(this);\n this.handlePluginFetchColumns = this.handlePluginFetchColumns.bind(this);\n this.handleClearAllFilters = this.handleClearAllFilters.bind(this);\n\n this.irisGrid = React.createRef();\n this.pluginRef = React.createRef();\n\n const { panelState } = props;\n\n this.pluginState = null;\n this.irisGridUtils = null;\n\n this.state = {\n error: null,\n isDisconnected: false,\n isLoaded: false,\n isLoading: true,\n isModelReady: false,\n model: undefined,\n\n // State is hydrated from panel state when table is loaded\n advancedFilters: new Map(),\n aggregationSettings: { aggregations: [], showOnTop: false },\n advancedSettings: new Map(AdvancedSettings.DEFAULTS),\n customColumns: [],\n customColumnFormatMap: new Map(),\n isFilterBarShown: false,\n quickFilters: new Map(),\n sorts: [],\n userColumnWidths: new Map(),\n userRowHeights: new Map(),\n reverseType: TableUtils.REVERSE_TYPE.NONE,\n movedColumns: [],\n movedRows: [],\n isSelectingPartition: false,\n partition: null,\n partitionColumn: null,\n rollupConfig: undefined,\n showSearchBar: false,\n searchValue: '',\n selectedSearchColumns: undefined,\n invertSearchColumns: true,\n Plugin: undefined,\n pluginFilters: [],\n pluginFetchColumns: [],\n modelQueue: [],\n pendingDataMap: new Map(),\n frozenColumns: undefined,\n\n // eslint-disable-next-line react/no-unused-state\n panelState, // Dehydrated panel state that can load this panel\n irisGridStateOverrides: {},\n gridStateOverrides: {},\n isStuckToBottom: false,\n isStuckToRight: false,\n conditionalFormats: [],\n selectDistinctColumns: [],\n };\n }\n\n componentDidMount(): void {\n this.initModel();\n }\n\n componentDidUpdate(_: never, prevState: IrisGridPanelState): void {\n const { model } = this.state;\n if (model !== prevState.model) {\n if (prevState.model != null) {\n this.stopModelListening(prevState.model);\n prevState.model.close();\n }\n if (model != null) {\n this.startModelListening(model);\n }\n }\n }\n\n componentWillUnmount(): void {\n this.savePanelState.cancel();\n\n if (this.modelPromise != null) {\n this.modelPromise.cancel();\n this.modelPromise = undefined;\n }\n\n const { model } = this.state;\n if (model) {\n this.stopModelListening(model);\n model.close();\n }\n }\n\n irisGrid: RefObject<IrisGrid>;\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n pluginRef: RefObject<any>;\n\n modelPromise?: CancelablePromise<IrisGridModel>;\n\n irisGridState?: IrisGridState;\n\n gridState?: GridState;\n\n pluginState: unknown;\n\n private irisGridUtils: IrisGridUtils | null;\n\n getTableName(): string {\n const { metadata } = this.props;\n return metadata.table;\n }\n\n getGridInputFilters = memoize(\n (columns: readonly Column[], inputFilters: readonly InputFilter[]) =>\n IrisGridUtils.getInputFiltersForColumns(\n columns,\n // They may have picked a column, but not actually entered a value yet. In that case, don't need to update.\n inputFilters.filter(({ value, excludePanelIds }) => {\n const id = LayoutUtils.getIdFromPanel(this);\n return (\n value != null &&\n (excludePanelIds == null ||\n (id != null && !excludePanelIds.includes(id)))\n );\n })\n )\n );\n\n getAlwaysFetchColumns = memoize(\n (\n dashboardLinks: readonly Link[],\n pluginFetchColumns: readonly string[]\n ): string[] => {\n const id = LayoutUtils.getIdFromPanel(this);\n // Always fetch columns which are the start/source of a link or columns specified by a plugin\n const columnSet = new Set(pluginFetchColumns);\n for (let i = 0; i < dashboardLinks.length; i += 1) {\n const { start } = dashboardLinks[i];\n if (start != null && start.panelId === id) {\n columnSet.add(start.columnName);\n }\n }\n return [...columnSet];\n }\n );\n\n getPluginContent = memoize(\n (\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n Plugin: any,\n model: IrisGridModel | undefined,\n user: User,\n workspace: Workspace,\n pluginState: unknown\n ) => {\n if (\n !model ||\n !isIrisGridTableModelTemplate(model) ||\n Plugin == null ||\n model.table == null\n ) {\n return null;\n }\n\n return (\n <div className=\"iris-grid-plugin\">\n <Plugin\n ref={this.pluginRef}\n filter={this.handlePluginFilter}\n // onFilter is deprecated\n onFilter={this.handlePluginFilter}\n fetchColumns={this.handlePluginFetchColumns}\n // onFetchColumns is deprecated\n onFetchColumns={this.handlePluginFetchColumns}\n table={model.table}\n user={user}\n panel={this}\n workspace={workspace}\n components={PLUGIN_COMPONENTS}\n onStateChange={this.handlePluginStateChange}\n pluginState={pluginState}\n />\n </div>\n );\n }\n );\n\n getDehydratedIrisGridPanelState = memoize(\n (\n model: IrisGridModel,\n isSelectingPartition: boolean,\n partition: string | null,\n partitionColumn: Column | null,\n advancedSettings: Map<AdvancedSettingsType, boolean>\n ) =>\n IrisGridUtils.dehydrateIrisGridPanelState(model, {\n isSelectingPartition,\n partition,\n partitionColumn,\n advancedSettings,\n })\n );\n\n getDehydratedIrisGridState = memoize(\n (\n model: IrisGridModel,\n sorts: readonly Sort[],\n advancedFilters: ReadonlyAdvancedFilterMap,\n customColumnFormatMap: Map<ColumnName, FormattingRule>,\n isFilterBarShown: boolean,\n quickFilters: ReadonlyQuickFilterMap,\n customColumns: readonly ColumnName[],\n reverseType: ReverseType,\n rollupConfig: UIRollupConfig | undefined,\n showSearchBar: boolean,\n searchValue: string,\n selectDistinctColumns: readonly ColumnName[],\n selectedSearchColumns: readonly ColumnName[],\n invertSearchColumns: boolean,\n userColumnWidths: ModelSizeMap,\n userRowHeights: ModelSizeMap,\n aggregationSettings: AggregationSettings,\n pendingDataMap: PendingDataMap<UIRow>,\n frozenColumns: readonly ColumnName[],\n conditionalFormats: readonly SidebarFormattingRule[],\n columnHeaderGroups: readonly ColumnHeaderGroup[]\n ) => {\n assertNotNull(this.irisGridUtils);\n return this.irisGridUtils.dehydrateIrisGridState(model, {\n advancedFilters,\n aggregationSettings,\n customColumnFormatMap,\n isFilterBarShown,\n metrics: {\n userColumnWidths,\n userRowHeights,\n },\n quickFilters,\n customColumns,\n reverseType,\n rollupConfig,\n showSearchBar,\n searchValue,\n selectDistinctColumns,\n selectedSearchColumns,\n sorts,\n invertSearchColumns,\n pendingDataMap,\n frozenColumns,\n conditionalFormats,\n columnHeaderGroups,\n });\n }\n );\n\n getDehydratedGridState = memoize(\n (\n model: IrisGridModel,\n movedColumns: readonly MoveOperation[],\n movedRows: readonly MoveOperation[],\n isStuckToBottom: boolean,\n isStuckToRight: boolean\n ) =>\n IrisGridUtils.dehydrateGridState(model, {\n isStuckToBottom,\n isStuckToRight,\n movedColumns,\n movedRows,\n })\n );\n\n getCachedPanelState = memoize(\n (\n irisGridPanelState: PanelState['irisGridPanelState'],\n irisGridState: PanelState['irisGridState'],\n gridState: PanelState['gridState'],\n pluginState: PanelState['pluginState']\n ): PanelState => ({\n irisGridPanelState,\n irisGridState,\n gridState,\n pluginState,\n })\n );\n\n initModel(): void {\n this.setState({ isModelReady: false, isLoading: true, error: null });\n const { makeModel } = this.props;\n if (this.modelPromise != null) {\n this.modelPromise.cancel();\n }\n this.modelPromise = PromiseUtils.makeCancelable(makeModel(), resolved =>\n resolved.close()\n );\n this.modelPromise.then(this.handleLoadSuccess).catch(this.handleLoadError);\n }\n\n handleLoadSuccess(modelParam: IrisGridModel): void {\n const model = modelParam;\n const { panelState, irisGridStateOverrides } = this.state;\n const modelQueue: ((m: IrisGridModel) => void)[] = [];\n this.irisGridUtils = new IrisGridUtils(model.dh);\n if (panelState != null) {\n const { irisGridState } = panelState;\n const {\n aggregationSettings,\n customColumns,\n selectDistinctColumns = [],\n rollupConfig,\n } = { ...irisGridState, ...irisGridStateOverrides };\n\n if (customColumns.length > 0) {\n modelQueue.push(m => {\n // eslint-disable-next-line no-param-reassign\n m.customColumns = customColumns;\n });\n }\n\n if (rollupConfig != null && rollupConfig.columns.length > 0) {\n // originalColumns might change by the time this model queue item is applied.\n // Instead of pushing a static object, push the function\n // that calculates the config based on the updated model state.\n modelQueue.push(m => {\n // eslint-disable-next-line no-param-reassign\n m.rollupConfig = IrisGridUtils.getModelRollupConfig(\n m.originalColumns,\n rollupConfig,\n aggregationSettings\n );\n });\n }\n\n if (selectDistinctColumns.length > 0) {\n modelQueue.push(m => {\n // eslint-disable-next-line no-param-reassign\n m.selectDistinctColumns = selectDistinctColumns;\n });\n }\n }\n\n this.setState({ model, modelQueue });\n this.initModelQueue(model, modelQueue);\n }\n\n initModelQueue(modelParam: IrisGridModel, modelQueue: ModelQueue): void {\n const model = modelParam;\n if (modelQueue.length === 0) {\n this.modelInitialized(model);\n return;\n }\n const modelChange = modelQueue.shift();\n log.debug('initModelQueue', modelChange);\n // Apply next model change. Triggers columnschanged event.\n if (modelChange) {\n modelChange(model);\n }\n this.setState({ modelQueue });\n }\n\n handleAdvancedSettingsChange(\n key: AdvancedSettingsType,\n value: boolean\n ): void {\n log.debug('handleAdvancedSettingsChange', key, value);\n this.setState(({ advancedSettings }) =>\n advancedSettings.get(key) === value\n ? null\n : { advancedSettings: new Map(advancedSettings).set(key, value) }\n );\n }\n\n handlePluginFilter(filters: InputFilter[]): void {\n const { model } = this.state;\n assertNotNull(model);\n const { columns, formatter } = model;\n const pluginFilters =\n this.irisGridUtils?.getFiltersFromInputFilters(\n columns,\n filters,\n formatter.timeZone\n ) ?? [];\n this.setState({ pluginFilters });\n }\n\n handlePluginFetchColumns(pluginFetchColumns: string[]): void {\n this.setState({ pluginFetchColumns });\n }\n\n handleContextMenu(obj: {\n model: IrisGridModel;\n value: unknown;\n valueText: string | null;\n column: Column;\n rowIndex: GridRangeIndex;\n columnIndex: GridRangeIndex;\n modelRow: GridRangeIndex;\n modelColumn: GridRangeIndex;\n }): ContextAction {\n return this.pluginRef.current?.getMenu?.(obj) ?? [];\n }\n\n isColumnSelectionValid(tableColumn: Column | null): boolean {\n const { columnSelectionValidator } = this.props;\n if (columnSelectionValidator && tableColumn) {\n return columnSelectionValidator(this, tableColumn);\n }\n return false;\n }\n\n handleGridStateChange(\n irisGridState: IrisGridState,\n gridState: GridState\n ): void {\n this.irisGridState = irisGridState;\n this.gridState = gridState;\n\n // Grid sends it's first state change after it's finished loading\n this.setState({ isLoaded: true, isLoading: false });\n\n this.savePanelState();\n\n const { glEventHub, onStateChange } = this.props;\n glEventHub.emit(IrisGridEvent.STATE_CHANGED, this);\n onStateChange?.(irisGridState, gridState);\n }\n\n handlePluginStateChange(pluginState: unknown): void {\n const { irisGridState, gridState } = this;\n this.pluginState = pluginState;\n // Do not save if there is null state\n // The save will happen when the grid loads\n if (irisGridState !== null && gridState !== null) {\n this.savePanelState();\n }\n }\n\n handleColumnsChanged(event: Event): void {\n const { isModelReady, model, modelQueue } = this.state;\n if (isModelReady) {\n this.sendColumnsChange((event as CustomEvent).detail);\n } else {\n assertNotNull(model);\n this.initModelQueue(model, modelQueue);\n }\n }\n\n handleTableChanged(event: Event): void {\n log.debug('handleTableChanged', event);\n const { glEventHub } = this.props;\n const { detail: table } = event as CustomEvent;\n glEventHub.emit(InputFilterEvent.TABLE_CHANGED, this, table);\n }\n\n handlePartitionAppend(column: Column, value: unknown): void {\n const { glEventHub } = this.props;\n const { name } = column;\n const tableName = this.getTableName();\n const command = `${tableName} = ${tableName}.where(\"${name}=\\`${value}\\`\")`;\n glEventHub.emit(ConsoleEvent.SEND_COMMAND, command, false, true);\n }\n\n /**\n * Create a chart with the specified settings\n * @param settings The settings from the chart builder\n * @param settings.type The settings from the chart builder\n * @param settings.series The names of the series\n * @param model The IrisGridModel object\n */\n handleCreateChart(\n settings: ChartBuilderSettings,\n model: IrisGridModel\n ): void {\n // Panel state is stored with the created chart, so flush it first\n this.savePanelState.flush();\n\n this.setState(\n () => null,\n () => {\n const { glEventHub, inputFilters, metadata } = this.props;\n const { table } = metadata;\n const { panelState } = this.state;\n const sourcePanelId = LayoutUtils.getIdFromPanel(this);\n let tableSettings;\n\n if (panelState) {\n tableSettings = IrisGridUtils.extractTableSettings(\n panelState,\n inputFilters\n );\n }\n glEventHub.emit(IrisGridEvent.CREATE_CHART, {\n metadata: {\n settings,\n sourcePanelId,\n table,\n tableSettings,\n },\n table: isIrisGridTableModelTemplate(model) ? model.table : undefined,\n });\n }\n );\n }\n\n handleColumnSelected(column: Column): void {\n const { glEventHub } = this.props;\n glEventHub.emit(IrisGridEvent.COLUMN_SELECTED, this, column);\n }\n\n handleDataSelected(row: ModelIndex, dataMap: Record<string, unknown>): void {\n const { glEventHub } = this.props;\n glEventHub.emit(IrisGridEvent.DATA_SELECTED, this, dataMap);\n }\n\n handleResize(): void {\n this.updateGrid();\n }\n\n handleShow(): void {\n this.updateGrid();\n }\n\n handleTabClicked(): void {\n if (this.irisGrid.current) {\n this.irisGrid.current.focus();\n }\n }\n\n handleError(error: unknown): void {\n log.error(error);\n this.setState({ error, isLoading: false });\n }\n\n handleDisconnect(): void {\n this.setState({\n error: new Error('Table disconnected'),\n isDisconnected: true,\n isLoading: false,\n });\n }\n\n handleReconnect(): void {\n this.setState({ isDisconnected: false, error: null });\n }\n\n handleLoadError(error: unknown): void {\n if (PromiseUtils.isCanceled(error)) {\n return;\n }\n\n this.handleError(error);\n }\n\n modelInitialized(model: IrisGridModel): void {\n const { glEventHub, loadPlugin } = this.props;\n\n this.modelPromise = undefined;\n\n // Custom columns at this point already initialized, can load state\n this.loadPanelState(model);\n\n this.setState({ isModelReady: true });\n\n if (isIrisGridTableModelTemplate(model)) {\n const { table } = model;\n const { pluginName } = table;\n\n if (pluginName !== '') {\n if (loadPlugin != null && pluginName != null) {\n const Plugin = loadPlugin(pluginName);\n this.setState({ Plugin });\n }\n }\n glEventHub.emit(InputFilterEvent.TABLE_CHANGED, this, table);\n }\n\n this.sendColumnsChange(model.columns);\n }\n\n handleClearAllFilters(): void {\n const irisGrid = this.irisGrid.current;\n const { isDisconnected } = this.state;\n if (irisGrid != null && !isDisconnected) {\n irisGrid.clearAllFilters();\n }\n }\n\n sendColumnsChange(columns: readonly Column[]): void {\n log.debug2('sendColumnsChange', columns);\n const { glEventHub } = this.props;\n glEventHub.emit(InputFilterEvent.COLUMNS_CHANGED, this, columns);\n }\n\n startModelListening(model: IrisGridModel): void {\n model.addEventListener(\n IrisGridModel.EVENT.DISCONNECT,\n this.handleDisconnect\n );\n model.addEventListener(IrisGridModel.EVENT.RECONNECT, this.handleReconnect);\n model.addEventListener(\n IrisGridModel.EVENT.COLUMNS_CHANGED,\n this.handleColumnsChanged\n );\n model.addEventListener(\n IrisGridModel.EVENT.TABLE_CHANGED,\n this.handleTableChanged\n );\n }\n\n stopModelListening(model: IrisGridModel): void {\n model.removeEventListener(\n IrisGridModel.EVENT.DISCONNECT,\n this.handleDisconnect\n );\n model.removeEventListener(\n IrisGridModel.EVENT.RECONNECT,\n this.handleReconnect\n );\n model.removeEventListener(\n IrisGridModel.EVENT.COLUMNS_CHANGED,\n this.handleColumnsChanged\n );\n model.removeEventListener(\n IrisGridModel.EVENT.TABLE_CHANGED,\n this.handleTableChanged\n );\n }\n\n getCoordinateForColumn(columnName: ColumnName): [number, number] | null {\n const { model } = this.state;\n if (!model) {\n return null;\n }\n\n const irisGrid = this.irisGrid.current;\n const { gridWrapper } = irisGrid || {};\n const rect = gridWrapper?.getBoundingClientRect() ?? null;\n if (rect == null || rect.width <= 0 || rect.height <= 0) {\n return null;\n }\n assertNotNull(irisGrid);\n const { metrics } = irisGrid.state;\n assertNotNull(metrics);\n const {\n columnHeaderHeight,\n allColumnXs,\n allColumnWidths,\n right,\n columnHeaderMaxDepth,\n } = metrics;\n const columnIndex = model.getColumnIndexByName(columnName);\n assertNotNull(columnIndex);\n const visibleIndex = irisGrid.getVisibleColumn(columnIndex);\n const columnX = allColumnXs.get(visibleIndex) ?? 0;\n const columnWidth = allColumnWidths.get(visibleIndex) ?? 0;\n\n const x = Math.max(\n rect.left,\n Math.min(\n visibleIndex > right\n ? rect.right\n : rect.left + columnX + columnWidth * 0.5,\n rect.right\n )\n );\n const y = rect.top + columnHeaderHeight * columnHeaderMaxDepth;\n\n return [x, y];\n }\n\n setFilterMap(filterMap: FilterMap): void {\n const irisGrid = this.irisGrid.current;\n if (irisGrid != null) {\n irisGrid.setFilterMap(filterMap);\n }\n }\n\n setAdvancedFilterMap(filterMap: ReadonlyAdvancedFilterMap): void {\n const irisGrid = this.irisGrid.current;\n if (irisGrid != null) {\n irisGrid.setAdvancedFilterMap(filterMap);\n }\n }\n\n setFilters({\n quickFilters,\n advancedFilters,\n }: {\n quickFilters: { name: ColumnName; filter: QuickFilter }[];\n advancedFilters: { name: ColumnName; filter: AdvancedFilter }[];\n }): void {\n log.debug('setFilters', quickFilters, advancedFilters);\n const { model, isDisconnected } = this.state;\n const irisGrid = this.irisGrid.current;\n if (irisGrid == null || isDisconnected) {\n log.debug('Ignore setFilters, model disconnected');\n return;\n }\n assertNotNull(model);\n const { columns, formatter } = model;\n const indexedQuickFilters = IrisGridUtils.changeFilterColumnNamesToIndexes(\n model.columns,\n quickFilters\n ).filter(([columnIndex]) => model.isFilterable(columnIndex));\n const indexedAdvancedFilters = IrisGridUtils.changeFilterColumnNamesToIndexes(\n model.columns,\n advancedFilters\n ).filter(([columnIndex]) => model.isFilterable(columnIndex));\n assertNotNull(this.irisGridUtils);\n irisGrid.clearAllFilters();\n irisGrid.setFilters({\n quickFilters: this.irisGridUtils.hydrateQuickFilters(\n columns,\n indexedQuickFilters,\n formatter.timeZone\n ),\n advancedFilters: this.irisGridUtils.hydrateAdvancedFilters(\n columns,\n indexedAdvancedFilters,\n formatter.timeZone\n ),\n });\n }\n\n setStateOverrides(overrides: {\n irisGridState: Partial<DehydratedIrisGridState>;\n gridState: Partial<GridState>;\n }): void {\n log.debug('setStateOverrides', overrides);\n const {\n irisGridState: irisGridStateOverrides,\n gridState: gridStateOverrides,\n } = overrides;\n this.setState({ irisGridStateOverrides, gridStateOverrides }, () => {\n this.initModel();\n });\n }\n\n // eslint-disable-next-line class-methods-use-this\n unsetFilterValue(): void {\n // IrisGridPanel retains the set value after the link is broken\n }\n\n loadPanelState(model: IrisGridModel): void {\n const {\n panelState,\n irisGridStateOverrides: originalIrisGridStateOverrides,\n gridStateOverrides,\n } = this.state;\n if (panelState == null) {\n return;\n }\n\n try {\n const { gridState, irisGridState, irisGridPanelState } = panelState;\n const irisGridStateOverrides = { ...originalIrisGridStateOverrides };\n const {\n quickFilters: savedQuickFilters,\n advancedFilters: savedAdvancedFilters,\n } = irisGridStateOverrides;\n if (savedQuickFilters) {\n irisGridStateOverrides.quickFilters = IrisGridUtils.changeFilterColumnNamesToIndexes(\n model.columns,\n (savedQuickFilters as unknown) as {\n name: string;\n filter: {\n text: string;\n };\n }[]\n );\n }\n if (savedAdvancedFilters) {\n irisGridStateOverrides.advancedFilters = IrisGridUtils.changeFilterColumnNamesToIndexes(\n model.columns,\n (savedAdvancedFilters as unknown) as {\n name: string;\n filter: { options: AdvancedFilterOptions };\n }[]\n );\n }\n const {\n isSelectingPartition,\n partition,\n partitionColumn,\n advancedSettings,\n } = IrisGridUtils.hydrateIrisGridPanelState(model, irisGridPanelState);\n assertNotNull(this.irisGridUtils);\n const {\n advancedFilters,\n customColumns,\n customColumnFormatMap,\n isFilterBarShown,\n quickFilters,\n reverseType,\n rollupConfig,\n aggregationSettings,\n sorts,\n userColumnWidths,\n userRowHeights,\n showSearchBar,\n searchValue,\n selectDistinctColumns,\n selectedSearchColumns,\n invertSearchColumns,\n pendingDataMap,\n frozenColumns,\n conditionalFormats,\n columnHeaderGroups,\n } = this.irisGridUtils.hydrateIrisGridState(model, {\n ...irisGridState,\n ...irisGridStateOverrides,\n });\n const {\n isStuckToBottom,\n isStuckToRight,\n movedColumns,\n movedRows,\n } = IrisGridUtils.hydrateGridState(\n model,\n { ...gridState, ...gridStateOverrides },\n irisGridState.customColumns\n );\n this.setState({\n advancedFilters,\n advancedSettings,\n conditionalFormats,\n customColumns,\n customColumnFormatMap,\n isFilterBarShown,\n isSelectingPartition,\n movedColumns,\n movedRows,\n partition,\n partitionColumn,\n quickFilters,\n reverseType,\n rollupConfig,\n aggregationSettings,\n sorts,\n userColumnWidths,\n userRowHeights,\n showSearchBar,\n searchValue,\n selectDistinctColumns,\n selectedSearchColumns,\n invertSearchColumns,\n pendingDataMap,\n frozenColumns,\n isStuckToBottom,\n isStuckToRight,\n columnHeaderGroups,\n });\n } catch (error) {\n log.error('loadPanelState failed to load panelState', panelState, error);\n }\n }\n\n savePanelState = debounce(() => {\n const { irisGridState, gridState, pluginState } = this;\n assertNotNull(irisGridState);\n const { onPanelStateUpdate } = this.props;\n const {\n model,\n panelState: oldPanelState,\n isSelectingPartition,\n partition,\n partitionColumn,\n advancedSettings,\n } = this.state;\n const {\n advancedFilters,\n aggregationSettings,\n customColumnFormatMap,\n isFilterBarShown,\n quickFilters,\n customColumns,\n reverseType,\n rollupConfig,\n showSearchBar,\n searchValue,\n selectDistinctColumns,\n selectedSearchColumns,\n sorts,\n invertSearchColumns,\n metrics,\n pendingDataMap,\n frozenColumns,\n conditionalFormats,\n columnHeaderGroups,\n } = irisGridState;\n assertNotNull(model);\n assertNotNull(metrics);\n const { userColumnWidths, userRowHeights } = metrics;\n assertNotNull(gridState);\n const {\n isStuckToBottom,\n isStuckToRight,\n movedColumns,\n movedRows,\n } = gridState;\n\n const panelState = this.getCachedPanelState(\n this.getDehydratedIrisGridPanelState(\n model,\n isSelectingPartition,\n partition,\n partitionColumn,\n advancedSettings\n ),\n this.getDehydratedIrisGridState(\n model,\n sorts,\n advancedFilters,\n customColumnFormatMap,\n isFilterBarShown,\n quickFilters,\n customColumns,\n reverseType,\n rollupConfig,\n showSearchBar,\n searchValue,\n selectDistinctColumns,\n selectedSearchColumns,\n invertSearchColumns,\n userColumnWidths,\n userRowHeights,\n aggregationSettings,\n pendingDataMap,\n frozenColumns,\n conditionalFormats,\n columnHeaderGroups\n ),\n this.getDehydratedGridState(\n model,\n movedColumns,\n movedRows,\n isStuckToBottom,\n isStuckToRight\n ),\n pluginState\n );\n\n if (panelState !== oldPanelState) {\n log.debug('Saving panel state', this, panelState);\n\n this.setState({ panelState });\n onPanelStateUpdate?.(panelState);\n }\n }, DEBOUNCE_PANEL_STATE_UPDATE);\n\n updateGrid(): void {\n const grid = this.irisGrid.current?.grid ?? null;\n if (!grid) return;\n\n // handle resize will verify state and draw and update\n grid.handleResize();\n }\n\n render(): ReactElement {\n const {\n children,\n glContainer,\n glEventHub,\n columnSelectionValidator,\n getDownloadWorker,\n inputFilters,\n links,\n metadata,\n panelState,\n user,\n workspace,\n settings,\n theme,\n } = this.props;\n const {\n advancedFilters,\n aggregationSettings,\n advancedSettings,\n conditionalFormats,\n customColumns,\n customColumnFormatMap,\n error,\n isDisconnected,\n isFilterBarShown,\n isSelectingPartition,\n isStuckToBottom,\n isStuckToRight,\n isLoaded,\n isLoading,\n isModelReady,\n model,\n movedColumns,\n movedRows,\n partition,\n partitionColumn,\n quickFilters,\n reverseType,\n rollupConfig,\n sorts,\n userColumnWidths,\n userRowHeights,\n showSearchBar,\n searchValue,\n selectDistinctColumns,\n selectedSearchColumns,\n invertSearchColumns,\n Plugin,\n pluginFilters,\n pluginFetchColumns,\n pendingDataMap,\n frozenColumns,\n columnHeaderGroups,\n } = this.state;\n const errorMessage =\n error != null ? `Unable to open table. ${error}` : undefined;\n const { table: name } = metadata;\n const description = model?.description ?? undefined;\n const pluginState = panelState?.pluginState ?? null;\n const childrenContent =\n children ??\n this.getPluginContent(Plugin, model, user, workspace, pluginState);\n const { permissions } = user;\n const { canCopy, canDownloadCsv } = permissions;\n\n return (\n <WidgetPanel\n errorMessage={errorMessage}\n isDisconnected={isDisconnected}\n isLoading={isLoading}\n isLoaded={isLoaded}\n className=\"iris-grid-panel\"\n glContainer={glContainer}\n glEventHub={glEventHub}\n onClearAllFilters={this.handleClearAllFilters}\n onResize={this.handleResize}\n onShow={this.handleShow}\n onTabFocus={this.handleShow}\n onTabClicked={this.handleTabClicked}\n widgetName={name}\n widgetType=\"Table\"\n description={description}\n componentPanel={this}\n renderTabTooltip={() => (\n <IrisGridPanelTooltip\n model={model}\n widgetName={name}\n glContainer={glContainer}\n description={description}\n />\n )}\n >\n {isModelReady && model && (\n <IrisGrid\n advancedFilters={advancedFilters}\n aggregationSettings={aggregationSettings}\n advancedSettings={advancedSettings}\n alwaysFetchColumns={this.getAlwaysFetchColumns(\n links,\n pluginFetchColumns\n )}\n columnAllowedCursor=\"linker\"\n columnNotAllowedCursor=\"linker-not-allowed\"\n customColumns={customColumns}\n customColumnFormatMap={customColumnFormatMap}\n columnSelectionValidator={this.isColumnSelectionValid}\n conditionalFormats={conditionalFormats}\n inputFilters={this.getGridInputFilters(model.columns, inputFilters)}\n applyInputFiltersOnInit={panelState == null}\n isFilterBarShown={isFilterBarShown}\n isSelectingColumn={columnSelectionValidator != null}\n isSelectingPartition={isSelectingPartition}\n isStuckToBottom={isStuckToBottom}\n isStuckToRight={isStuckToRight}\n movedColumns={movedColumns}\n movedRows={movedRows}\n partition={partition}\n partitionColumn={partitionColumn}\n quickFilters={quickFilters}\n reverseType={reverseType}\n rollupConfig={rollupConfig}\n settings={settings}\n sorts={sorts}\n userColumnWidths={userColumnWidths}\n userRowHeights={userRowHeights}\n model={model}\n showSearchBar={showSearchBar}\n searchValue={searchValue}\n selectedSearchColumns={selectedSearchColumns}\n selectDistinctColumns={selectDistinctColumns}\n invertSearchColumns={invertSearchColumns}\n onColumnSelected={this.handleColumnSelected}\n onCreateChart={this.handleCreateChart}\n onDataSelected={this.handleDataSelected}\n onError={this.handleError}\n onPartitionAppend={this.handlePartitionAppend}\n onStateChange={this.handleGridStateChange}\n onContextMenu={this.handleContextMenu}\n onAdvancedSettingsChange={this.handleAdvancedSettingsChange}\n customFilters={pluginFilters}\n pendingDataMap={pendingDataMap}\n canCopy={canCopy}\n canDownloadCsv={canDownloadCsv}\n ref={this.irisGrid}\n getDownloadWorker={getDownloadWorker}\n frozenColumns={frozenColumns}\n theme={theme}\n columnHeaderGroups={columnHeaderGroups}\n >\n {childrenContent}\n </IrisGrid>\n )}\n </WidgetPanel>\n );\n }\n}\n\nconst mapStateToProps = (\n state: RootState,\n { localDashboardId = DEFAULT_DASHBOARD_ID }: { localDashboardId?: string }\n) => ({\n inputFilters: getInputFiltersForDashboard(state, localDashboardId),\n links: getLinksForDashboard(state, localDashboardId),\n columnSelectionValidator: getColumnSelectionValidatorForDashboard(\n state,\n localDashboardId\n ),\n user: getUser(state),\n workspace: getWorkspace(state),\n settings: getSettings(state),\n});\n\nconst ConnectedIrisGridPanel = connect(mapStateToProps, null, null, {\n forwardRef: true,\n})(IrisGridPanel);\n\nexport default ConnectedIrisGridPanel;\n"],"mappings":"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"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { GLPropTypes } from '@deephaven/dashboard';
|
|
3
|
+
import PropTypes from 'prop-types';
|
|
4
|
+
import WidgetPanelTooltip from "./WidgetPanelTooltip.js";
|
|
5
|
+
function IrisGridPanelTooltip(props) {
|
|
6
|
+
var _model$rowCount, _model$pendingRowCoun, _model$columnCount;
|
|
7
|
+
var {
|
|
8
|
+
model,
|
|
9
|
+
widgetName,
|
|
10
|
+
glContainer,
|
|
11
|
+
description
|
|
12
|
+
} = props;
|
|
13
|
+
var rowCount = ((_model$rowCount = model === null || model === void 0 ? void 0 : model.rowCount) !== null && _model$rowCount !== void 0 ? _model$rowCount : 0) - ((_model$pendingRowCoun = model === null || model === void 0 ? void 0 : model.pendingRowCount) !== null && _model$pendingRowCoun !== void 0 ? _model$pendingRowCoun : 0);
|
|
14
|
+
var formattedRowCount = model === null || model === void 0 ? void 0 : model.displayString(rowCount, 'long');
|
|
15
|
+
var columnCount = (_model$columnCount = model === null || model === void 0 ? void 0 : model.columnCount) !== null && _model$columnCount !== void 0 ? _model$columnCount : 0;
|
|
16
|
+
var formattedcolumnCount = model === null || model === void 0 ? void 0 : model.displayString(columnCount, 'long');
|
|
17
|
+
return /*#__PURE__*/React.createElement(WidgetPanelTooltip, {
|
|
18
|
+
widgetType: "Table",
|
|
19
|
+
widgetName: widgetName,
|
|
20
|
+
glContainer: glContainer,
|
|
21
|
+
description: description
|
|
22
|
+
}, /*#__PURE__*/React.createElement("hr", {
|
|
23
|
+
className: "tab-tooltip-divider"
|
|
24
|
+
}), /*#__PURE__*/React.createElement("span", null, "Number of Columns"), /*#__PURE__*/React.createElement("span", {
|
|
25
|
+
className: "tab-tooltip-statistic-value"
|
|
26
|
+
}, formattedcolumnCount), /*#__PURE__*/React.createElement("span", null, "Number of Rows"), /*#__PURE__*/React.createElement("span", {
|
|
27
|
+
className: "tab-tooltip-statistic-value"
|
|
28
|
+
}, formattedRowCount));
|
|
29
|
+
}
|
|
30
|
+
IrisGridPanelTooltip.propTypes = {
|
|
31
|
+
glContainer: GLPropTypes.Container.isRequired,
|
|
32
|
+
widgetName: PropTypes.string.isRequired,
|
|
33
|
+
description: PropTypes.string
|
|
34
|
+
};
|
|
35
|
+
IrisGridPanelTooltip.defaultProps = {
|
|
36
|
+
description: null
|
|
37
|
+
};
|
|
38
|
+
export default IrisGridPanelTooltip;
|
|
39
|
+
//# sourceMappingURL=IrisGridPanelTooltip.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"IrisGridPanelTooltip.js","names":["React","GLPropTypes","PropTypes","WidgetPanelTooltip","IrisGridPanelTooltip","props","model","widgetName","glContainer","description","rowCount","pendingRowCount","formattedRowCount","displayString","columnCount","formattedcolumnCount","propTypes","Container","isRequired","string","defaultProps"],"sources":["../../src/panels/IrisGridPanelTooltip.tsx"],"sourcesContent":["import React, { ReactElement } from 'react';\nimport { GLPropTypes } from '@deephaven/dashboard';\nimport type { ComponentConfig, Container } from '@deephaven/golden-layout';\nimport { IrisGridModel } from '@deephaven/iris-grid';\nimport PropTypes from 'prop-types';\nimport WidgetPanelTooltip from './WidgetPanelTooltip';\n\ninterface IrisGridPanelTooltipProps {\n model?: IrisGridModel;\n widgetName: string;\n glContainer: Container<ComponentConfig>;\n description?: string;\n}\n\nfunction IrisGridPanelTooltip(props: IrisGridPanelTooltipProps): ReactElement {\n const { model, widgetName, glContainer, description } = props;\n\n const rowCount = (model?.rowCount ?? 0) - (model?.pendingRowCount ?? 0);\n const formattedRowCount = model?.displayString(rowCount, 'long');\n\n const columnCount = model?.columnCount ?? 0;\n const formattedcolumnCount = model?.displayString(columnCount, 'long');\n\n return (\n <WidgetPanelTooltip\n widgetType=\"Table\"\n widgetName={widgetName}\n glContainer={glContainer}\n description={description}\n >\n <hr className=\"tab-tooltip-divider\" />\n <span>Number of Columns</span>\n <span className=\"tab-tooltip-statistic-value\">\n {formattedcolumnCount}\n </span>\n <span>Number of Rows</span>\n <span className=\"tab-tooltip-statistic-value\">{formattedRowCount}</span>\n </WidgetPanelTooltip>\n );\n}\n\nIrisGridPanelTooltip.propTypes = {\n glContainer: GLPropTypes.Container.isRequired,\n widgetName: PropTypes.string.isRequired,\n description: PropTypes.string,\n};\n\nIrisGridPanelTooltip.defaultProps = {\n description: null,\n};\n\nexport default IrisGridPanelTooltip;\n"],"mappings":"AAAA,OAAOA,KAAK,MAAwB,OAAO;AAC3C,SAASC,WAAW,QAAQ,sBAAsB;AAGlD,OAAOC,SAAS,MAAM,YAAY;AAAC,OAC5BC,kBAAkB;AASzB,SAASC,oBAAoB,CAACC,KAAgC,EAAgB;EAAA;EAC5E,IAAM;IAAEC,KAAK;IAAEC,UAAU;IAAEC,WAAW;IAAEC;EAAY,CAAC,GAAGJ,KAAK;EAE7D,IAAMK,QAAQ,GAAG,oBAACJ,KAAK,aAALA,KAAK,uBAALA,KAAK,CAAEI,QAAQ,6DAAI,CAAC,8BAAKJ,KAAK,aAALA,KAAK,uBAALA,KAAK,CAAEK,eAAe,yEAAI,CAAC,CAAC;EACvE,IAAMC,iBAAiB,GAAGN,KAAK,aAALA,KAAK,uBAALA,KAAK,CAAEO,aAAa,CAACH,QAAQ,EAAE,MAAM,CAAC;EAEhE,IAAMI,WAAW,yBAAGR,KAAK,aAALA,KAAK,uBAALA,KAAK,CAAEQ,WAAW,mEAAI,CAAC;EAC3C,IAAMC,oBAAoB,GAAGT,KAAK,aAALA,KAAK,uBAALA,KAAK,CAAEO,aAAa,CAACC,WAAW,EAAE,MAAM,CAAC;EAEtE,oBACE,oBAAC,kBAAkB;IACjB,UAAU,EAAC,OAAO;IAClB,UAAU,EAAEP,UAAW;IACvB,WAAW,EAAEC,WAAY;IACzB,WAAW,EAAEC;EAAY,gBAEzB;IAAI,SAAS,EAAC;EAAqB,EAAG,eACtC,kCAAM,mBAAiB,CAAO,eAC9B;IAAM,SAAS,EAAC;EAA6B,GAC1CM,oBAAoB,CAChB,eACP,kCAAM,gBAAc,CAAO,eAC3B;IAAM,SAAS,EAAC;EAA6B,GAAEH,iBAAiB,CAAQ,CACrD;AAEzB;AAEAR,oBAAoB,CAACY,SAAS,GAAG;EAC/BR,WAAW,EAAEP,WAAW,CAACgB,SAAS,CAACC,UAAU;EAC7CX,UAAU,EAAEL,SAAS,CAACiB,MAAM,CAACD,UAAU;EACvCT,WAAW,EAAEP,SAAS,CAACiB;AACzB,CAAC;AAEDf,oBAAoB,CAACgB,YAAY,GAAG;EAClCX,WAAW,EAAE;AACf,CAAC;AAED,eAAeL,oBAAoB"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
/* stylelint-disable scss/at-import-no-partial-leading-underscore */
|
|
2
|
+
.log-panel-disconnected-message {
|
|
3
|
+
color: #929192;
|
|
4
|
+
display: flex;
|
|
5
|
+
flex-direction: column;
|
|
6
|
+
flex-grow: 1;
|
|
7
|
+
flex-shrink: 1;
|
|
8
|
+
justify-content: center;
|
|
9
|
+
overflow: hidden;
|
|
10
|
+
width: 100%;
|
|
11
|
+
height: 100%;
|
|
12
|
+
text-align: center;
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
/*# sourceMappingURL=LogPanel.css.map */
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sourceRoot":"","sources":["../../../../node_modules/@deephaven/components/scss/custom.scss","../../src/panels/LogPanel.scss","../../../../node_modules/@deephaven/components/scss/bootstrap_overrides.scss"],"names":[],"mappings":"AAAA;ACEA;EACE,OCkBS;EDjBT;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA","file":"LogPanel.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\n.log-panel-disconnected-message {\n color: $text-muted;\n display: flex;\n flex-direction: column;\n flex-grow: 1;\n flex-shrink: 1;\n justify-content: center;\n overflow: hidden;\n width: 100%;\n height: 100%;\n text-align: center;\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"]}
|
|
@@ -0,0 +1,110 @@
|
|
|
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
|
+
// Wrapper for the Console for use in a golden layout container
|
|
5
|
+
// Will probably need to handle window popping out from golden layout here.
|
|
6
|
+
import React, { PureComponent } from 'react';
|
|
7
|
+
import { connect } from 'react-redux';
|
|
8
|
+
import { LogView } from '@deephaven/console';
|
|
9
|
+
import Log from '@deephaven/log';
|
|
10
|
+
import "./LogPanel.css";
|
|
11
|
+
import Panel from "./Panel.js";
|
|
12
|
+
import { getDashboardSessionWrapper } from "../redux/index.js";
|
|
13
|
+
var log = Log.module('LogPanel');
|
|
14
|
+
class LogPanel extends PureComponent {
|
|
15
|
+
constructor(props) {
|
|
16
|
+
super(props);
|
|
17
|
+
_defineProperty(this, "isBottomVisible", void 0);
|
|
18
|
+
_defineProperty(this, "logView", void 0);
|
|
19
|
+
this.handleResize = this.handleResize.bind(this);
|
|
20
|
+
this.handleShow = this.handleShow.bind(this);
|
|
21
|
+
this.handleHide = this.handleHide.bind(this);
|
|
22
|
+
this.handleSessionOpened = this.handleSessionOpened.bind(this);
|
|
23
|
+
this.handleSessionClosed = this.handleSessionClosed.bind(this);
|
|
24
|
+
this.isBottomVisible = true;
|
|
25
|
+
this.logView = null;
|
|
26
|
+
var {
|
|
27
|
+
session
|
|
28
|
+
} = this.props;
|
|
29
|
+
this.state = {
|
|
30
|
+
session
|
|
31
|
+
};
|
|
32
|
+
}
|
|
33
|
+
handleResize() {
|
|
34
|
+
this.updateDimensions();
|
|
35
|
+
}
|
|
36
|
+
handleShow() {
|
|
37
|
+
this.updateDimensions();
|
|
38
|
+
if (this.logView) {
|
|
39
|
+
this.logView.triggerFindWidget();
|
|
40
|
+
if (this.isBottomVisible) {
|
|
41
|
+
this.logView.scrollToBottom();
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
handleHide() {
|
|
46
|
+
if (this.logView) {
|
|
47
|
+
this.isBottomVisible = this.logView.isBottomVisible();
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
handleSessionOpened(session) {
|
|
51
|
+
log.debug('Session opened', [session]);
|
|
52
|
+
this.setState({
|
|
53
|
+
session
|
|
54
|
+
});
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
// eslint-disable-next-line class-methods-use-this
|
|
58
|
+
handleSessionClosed(session) {
|
|
59
|
+
log.debug('Session closed', session);
|
|
60
|
+
// Keep the session reference in state unchanged until the session is re-connected
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
updateDimensions() {
|
|
64
|
+
if (this.logView) {
|
|
65
|
+
this.logView.updateDimensions();
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
render() {
|
|
69
|
+
var {
|
|
70
|
+
glContainer,
|
|
71
|
+
glEventHub
|
|
72
|
+
} = this.props;
|
|
73
|
+
var {
|
|
74
|
+
session
|
|
75
|
+
} = this.state;
|
|
76
|
+
return /*#__PURE__*/React.createElement(Panel, {
|
|
77
|
+
componentPanel: this,
|
|
78
|
+
glContainer: glContainer,
|
|
79
|
+
glEventHub: glEventHub,
|
|
80
|
+
onResize: this.handleResize,
|
|
81
|
+
onHide: this.handleHide,
|
|
82
|
+
onShow: this.handleShow,
|
|
83
|
+
onSessionOpen: this.handleSessionOpened,
|
|
84
|
+
onSessionClose: this.handleSessionClosed
|
|
85
|
+
}, session == null && /*#__PURE__*/React.createElement("div", {
|
|
86
|
+
className: "log-panel-disconnected-message"
|
|
87
|
+
}, "Waiting for session connection"), session != null && /*#__PURE__*/React.createElement(LogView, {
|
|
88
|
+
session: session,
|
|
89
|
+
ref: logView => {
|
|
90
|
+
this.logView = logView;
|
|
91
|
+
}
|
|
92
|
+
}));
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
_defineProperty(LogPanel, "defaultProps", {
|
|
96
|
+
session: null
|
|
97
|
+
});
|
|
98
|
+
_defineProperty(LogPanel, "COMPONENT", 'LogPanel');
|
|
99
|
+
_defineProperty(LogPanel, "TITLE", 'Log');
|
|
100
|
+
var mapStateToProps = (state, ownProps) => {
|
|
101
|
+
var _getDashboardSessionW;
|
|
102
|
+
return {
|
|
103
|
+
session: (_getDashboardSessionW = getDashboardSessionWrapper(state, ownProps.localDashboardId)) === null || _getDashboardSessionW === void 0 ? void 0 : _getDashboardSessionW.session
|
|
104
|
+
};
|
|
105
|
+
};
|
|
106
|
+
var ConnectedLogPanel = connect(mapStateToProps, null, null, {
|
|
107
|
+
forwardRef: true
|
|
108
|
+
})(LogPanel);
|
|
109
|
+
export default ConnectedLogPanel;
|
|
110
|
+
//# sourceMappingURL=LogPanel.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"LogPanel.js","names":["React","PureComponent","connect","LogView","Log","Panel","getDashboardSessionWrapper","log","module","LogPanel","constructor","props","handleResize","bind","handleShow","handleHide","handleSessionOpened","handleSessionClosed","isBottomVisible","logView","session","state","updateDimensions","triggerFindWidget","scrollToBottom","debug","setState","render","glContainer","glEventHub","mapStateToProps","ownProps","localDashboardId","ConnectedLogPanel","forwardRef"],"sources":["../../src/panels/LogPanel.tsx"],"sourcesContent":["// Wrapper for the Console for use in a golden layout container\n// Will probably need to handle window popping out from golden layout here.\nimport React, { PureComponent } from 'react';\nimport { connect } from 'react-redux';\nimport { LogView } from '@deephaven/console';\nimport type { IdeSession } from '@deephaven/jsapi-types';\nimport Log from '@deephaven/log';\nimport type { Container, EventEmitter } from '@deephaven/golden-layout';\nimport { RootState } from '@deephaven/redux';\nimport './LogPanel.scss';\nimport Panel from './Panel';\nimport { getDashboardSessionWrapper } from '../redux';\n\nconst log = Log.module('LogPanel');\n\ninterface LogPanelProps {\n glContainer: Container;\n glEventHub: EventEmitter;\n session: IdeSession;\n}\n\ninterface LogPanelState {\n session: IdeSession;\n}\n\nclass LogPanel extends PureComponent<LogPanelProps, LogPanelState> {\n static defaultProps = {\n session: null,\n };\n\n static COMPONENT = 'LogPanel';\n\n static TITLE = 'Log';\n\n constructor(props: LogPanelProps) {\n super(props);\n\n this.handleResize = this.handleResize.bind(this);\n this.handleShow = this.handleShow.bind(this);\n this.handleHide = this.handleHide.bind(this);\n this.handleSessionOpened = this.handleSessionOpened.bind(this);\n this.handleSessionClosed = this.handleSessionClosed.bind(this);\n\n this.isBottomVisible = true;\n this.logView = null;\n\n const { session } = this.props;\n\n this.state = { session };\n }\n\n isBottomVisible: boolean;\n\n logView: LogView | null;\n\n handleResize() {\n this.updateDimensions();\n }\n\n handleShow() {\n this.updateDimensions();\n if (this.logView) {\n this.logView.triggerFindWidget();\n\n if (this.isBottomVisible) {\n this.logView.scrollToBottom();\n }\n }\n }\n\n handleHide() {\n if (this.logView) {\n this.isBottomVisible = this.logView.isBottomVisible();\n }\n }\n\n handleSessionOpened(session: IdeSession) {\n log.debug('Session opened', [session]);\n this.setState({ session });\n }\n\n // eslint-disable-next-line class-methods-use-this\n handleSessionClosed(session: IdeSession) {\n log.debug('Session closed', session);\n // Keep the session reference in state unchanged until the session is re-connected\n }\n\n updateDimensions() {\n if (this.logView) {\n this.logView.updateDimensions();\n }\n }\n\n render() {\n const { glContainer, glEventHub } = this.props;\n const { session } = this.state;\n return (\n <Panel\n componentPanel={this}\n glContainer={glContainer}\n glEventHub={glEventHub}\n onResize={this.handleResize}\n onHide={this.handleHide}\n onShow={this.handleShow}\n onSessionOpen={this.handleSessionOpened}\n onSessionClose={this.handleSessionClosed}\n >\n {session == null && (\n <div className=\"log-panel-disconnected-message\">\n Waiting for session connection\n </div>\n )}\n {session != null && (\n <LogView\n session={session}\n ref={logView => {\n this.logView = logView;\n }}\n />\n )}\n </Panel>\n );\n }\n}\n\nconst mapStateToProps = (\n state: RootState,\n ownProps: { localDashboardId: string }\n) => ({\n session: getDashboardSessionWrapper(state, ownProps.localDashboardId)\n ?.session,\n});\n\nconst ConnectedLogPanel = connect(mapStateToProps, null, null, {\n forwardRef: true,\n})(LogPanel);\n\nexport default ConnectedLogPanel;\n"],"mappings":"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"}
|
|
@@ -0,0 +1,107 @@
|
|
|
1
|
+
/* stylelint-disable scss/at-import-no-partial-leading-underscore */
|
|
2
|
+
.markdown-notebook {
|
|
3
|
+
width: 100%;
|
|
4
|
+
height: 100%;
|
|
5
|
+
display: flex;
|
|
6
|
+
flex-direction: column;
|
|
7
|
+
}
|
|
8
|
+
.markdown-notebook .markdown-notebook-toolbar {
|
|
9
|
+
display: flex;
|
|
10
|
+
align-items: center;
|
|
11
|
+
padding: 0.25rem;
|
|
12
|
+
width: 100%;
|
|
13
|
+
flex: 0 0 36px;
|
|
14
|
+
border-bottom: 2px solid #1a171a;
|
|
15
|
+
}
|
|
16
|
+
.markdown-notebook .markdown-notebook-toolbar .btn-play-selected-cell {
|
|
17
|
+
color: #9edc6f;
|
|
18
|
+
min-height: 34px;
|
|
19
|
+
}
|
|
20
|
+
.markdown-notebook .markdown-notebook-content {
|
|
21
|
+
flex-grow: 1;
|
|
22
|
+
width: 100%;
|
|
23
|
+
padding: 0 15px;
|
|
24
|
+
overflow: auto;
|
|
25
|
+
position: relative;
|
|
26
|
+
scroll-behavior: smooth;
|
|
27
|
+
}
|
|
28
|
+
.markdown-notebook .markdown-notebook-content h1,
|
|
29
|
+
.markdown-notebook .markdown-notebook-content h2,
|
|
30
|
+
.markdown-notebook .markdown-notebook-content h3 {
|
|
31
|
+
margin-top: 3rem;
|
|
32
|
+
}
|
|
33
|
+
.markdown-notebook blockquote {
|
|
34
|
+
border-left: 0.25em solid #929192;
|
|
35
|
+
padding: 0 1em;
|
|
36
|
+
color: #f0f0ee;
|
|
37
|
+
}
|
|
38
|
+
.markdown-notebook pre {
|
|
39
|
+
overflow: hidden;
|
|
40
|
+
}
|
|
41
|
+
.markdown-notebook pre > code {
|
|
42
|
+
display: block;
|
|
43
|
+
padding: 0.5rem;
|
|
44
|
+
}
|
|
45
|
+
.markdown-notebook a {
|
|
46
|
+
color: #4878ea;
|
|
47
|
+
}
|
|
48
|
+
.markdown-notebook a:visited {
|
|
49
|
+
color: #aa9af4;
|
|
50
|
+
}
|
|
51
|
+
.markdown-notebook .markdown-notebook-code-block {
|
|
52
|
+
position: relative;
|
|
53
|
+
border-radius: 0 4px 4px 0;
|
|
54
|
+
}
|
|
55
|
+
.markdown-notebook .markdown-notebook-code-block .btn-play-block {
|
|
56
|
+
color: #9edc6f;
|
|
57
|
+
opacity: 0;
|
|
58
|
+
position: absolute;
|
|
59
|
+
top: 0;
|
|
60
|
+
right: 0;
|
|
61
|
+
margin: 3px;
|
|
62
|
+
transition: opacity 0.15s ease-out;
|
|
63
|
+
}
|
|
64
|
+
.markdown-notebook .markdown-notebook-code-block code {
|
|
65
|
+
color: #f0f0ee;
|
|
66
|
+
background: #403e41;
|
|
67
|
+
padding: 0.5rem;
|
|
68
|
+
border-radius: 4px;
|
|
69
|
+
border: 1px solid #1a171a;
|
|
70
|
+
overflow: auto;
|
|
71
|
+
display: block;
|
|
72
|
+
}
|
|
73
|
+
.markdown-notebook .markdown-notebook-code-block.is-selected::after {
|
|
74
|
+
position: absolute;
|
|
75
|
+
top: 0;
|
|
76
|
+
left: 0;
|
|
77
|
+
bottom: 0;
|
|
78
|
+
width: 5px;
|
|
79
|
+
margin: 1px 0 1px 0;
|
|
80
|
+
background: #4878ea;
|
|
81
|
+
content: "";
|
|
82
|
+
pointer-events: none;
|
|
83
|
+
border-radius: 4px 0 0 4px;
|
|
84
|
+
}
|
|
85
|
+
.markdown-notebook .markdown-notebook-code-block.is-selected .btn-play-block, .markdown-notebook .markdown-notebook-code-block:hover .btn-play-block {
|
|
86
|
+
opacity: 1;
|
|
87
|
+
}
|
|
88
|
+
.markdown-notebook .flashing {
|
|
89
|
+
animation-duration: 1s;
|
|
90
|
+
animation-name: flash;
|
|
91
|
+
animation-timing-function: ease-in-out;
|
|
92
|
+
animation-iteration-count: infinite;
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
@keyframes flash {
|
|
96
|
+
0% {
|
|
97
|
+
text-shadow: 0 0 5px #2d2a2e, 0 0 20px #2d2a2e;
|
|
98
|
+
}
|
|
99
|
+
50% {
|
|
100
|
+
text-shadow: 0 0 2px rgba(255, 255, 255, 0.5), 0 0 10px #9edc6f;
|
|
101
|
+
}
|
|
102
|
+
100% {
|
|
103
|
+
text-shadow: 0 0 5px #2d2a2e, 0 0 20px #2d2a2e;
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
/*# sourceMappingURL=MarkdownNotebook.css.map */
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sourceRoot":"","sources":["../../../../node_modules/@deephaven/components/scss/custom.scss","../../src/panels/MarkdownNotebook.scss","../../../../node_modules/@deephaven/components/scss/new_variables.scss","../../../../node_modules/@deephaven/components/scss/bootstrap_overrides.scss"],"names":[],"mappings":"AAAA;ACIA;EACE;EACA;EACA;EACA;;AAEA;EACE;EACA;EACA,SCXO;EDYP;EACA;EACA;;AACA;EACE,OEZE;EFaF;;AAIJ;EACE;EACA;EACA;EACA;EACA;EACA;;AAEA;AAAA;AAAA;EAGE;;AAIJ;EACE;EACA;EACA,OE5Ba;;AF+Bf;EACE;;AAGF;EACE;EACA,SC/CO;;ADkDT;EACE,OE1CY;;AF4CZ;EACE,OEjDG;;AFqDP;EACE;EACA;;AAEA;EACE,OE5DE;EF6DF;EACA;EACA;EACA;EACA;EACA;;AAGF;EACE,OE/DW;EFgEX,YErDK;EFsDL,SC3EK;ED4EL,eE0CU;EFzCV;EACA;EACA;;AAIA;EACE;EACA;EACA;EACA;EACA;EACA;EACA,YEjFQ;EFkFR;EACA;EACA;;AAMF;EACE;;AAKN;EACE;EACA;EACA;EACA;;;AAIJ;EACE;IACE;;EAGF;IACE;;EAGF;IACE","file":"MarkdownNotebook.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\n$btn-play-color: $success;\n\n.markdown-notebook {\n width: 100%;\n height: 100%;\n display: flex;\n flex-direction: column;\n\n .markdown-notebook-toolbar {\n display: flex;\n align-items: center;\n padding: $spacer-1;\n width: 100%;\n flex: 0 0 36px;\n border-bottom: 2px solid $black;\n .btn-play-selected-cell {\n color: $btn-play-color;\n min-height: 34px;\n }\n }\n\n .markdown-notebook-content {\n flex-grow: 1;\n width: 100%;\n padding: 0 15px;\n overflow: auto;\n position: relative;\n scroll-behavior: smooth;\n\n h1,\n h2,\n h3 {\n margin-top: 3rem;\n }\n }\n\n blockquote {\n border-left: 0.25em solid $gray-400;\n padding: 0 1em;\n color: $foreground;\n }\n\n pre {\n overflow: hidden;\n }\n\n pre > code {\n display: block;\n padding: $spacer-2;\n }\n\n a {\n color: $primary;\n\n &:visited {\n color: $purple;\n }\n }\n\n .markdown-notebook-code-block {\n position: relative;\n border-radius: 0 $border-radius $border-radius 0;\n\n .btn-play-block {\n color: $btn-play-color;\n opacity: 0;\n position: absolute;\n top: 0;\n right: 0;\n margin: 3px; // 3px so the outline doesn't get cut off\n transition: opacity $transition ease-out;\n }\n\n code {\n color: $foreground;\n background: $gray-700;\n padding: $spacer-2;\n border-radius: $border-radius;\n border: 1px solid $black;\n overflow: auto;\n display: block;\n }\n\n &.is-selected {\n &::after {\n position: absolute;\n top: 0;\n left: 0;\n bottom: 0;\n width: 5px;\n margin: 1px 0 1px 0;\n background: $primary;\n content: '';\n pointer-events: none;\n border-radius: $border-radius 0 0 $border-radius;\n }\n }\n\n &.is-selected,\n &:hover {\n .btn-play-block {\n opacity: 1;\n }\n }\n }\n\n .flashing {\n animation-duration: 1s;\n animation-name: flash;\n animation-timing-function: ease-in-out;\n animation-iteration-count: infinite;\n }\n}\n\n@keyframes flash {\n 0% {\n text-shadow: 0 0 5px $content-bg, 0 0 20px $content-bg;\n }\n\n 50% {\n text-shadow: 0 0 2px rgba(255, 255, 255, 50%), 0 0 10px $success;\n }\n\n 100% {\n text-shadow: 0 0 5px $content-bg, 0 0 20px $content-bg;\n }\n}\n","//Set of spacer variables from the spacer map\n$spacer-0: map-get($spacers, 0); //0\n$spacer-1: map-get($spacers, 1);\n$spacer-2: map-get($spacers, 2);\n$spacer-3: map-get($spacers, 3);\n$spacer-4: map-get($spacers, 4);\n$spacer-5: map-get($spacers, 5);\n\n//Marching Ants for golden layout dropzone and drag and drop\n//top bottom, left right.\n//create 4 background images that are 50% color 1, 50% color 2 using graidents, two veritical, two horizontal\n//size them to ant-size and thickness\n//position those images along the egdes and make top/bottom repeat-x and left/right repeat-y\n//then offest each of those background positions by ant-size in animation to make them march.\n$ant-size: 8px;\n$ant-thickness: 1px;\n\n@mixin ants-base($color-1: black, $color-2: white) {\n background-image: linear-gradient(to right, $color-2 50%, $color-1 50%),\n linear-gradient(to right, $color-2 50%, $color-1 50%),\n linear-gradient(to bottom, $color-2 50%, $color-1 50%),\n linear-gradient(to bottom, $color-2 50%, $color-1 50%);\n background-size: $ant-size $ant-thickness, $ant-size $ant-thickness,\n $ant-thickness $ant-size, $ant-thickness $ant-size;\n background-position: 0 top, 0 bottom, left 0, right 0;\n background-repeat: repeat-x, repeat-x, repeat-y, repeat-y;\n animation: march 0.5s;\n animation-timing-function: linear;\n animation-iteration-count: infinite;\n}\n\n@mixin drag-stack($pseudo-element) {\n &::#{$pseudo-element} {\n content: ' ';\n background: $primary;\n box-shadow: $box-shadow;\n border-radius: $border-radius;\n position: absolute;\n height: 100%;\n width: 100%;\n @content;\n }\n}\n\n$focus-bg-transparency: 0.12;\n$hover-bg-transparency: 0.14;\n$active-bg-transparency: 0.28;\n$exception-transparency: 0.13;\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"]}
|