@deephaven/embed-widget 0.85.25 → 0.85.26

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (30) hide show
  1. package/build/assets/{App-595fd008.js → App-15dffeeb.js} +2 -2
  2. package/build/assets/{App-595fd008.js.map → App-15dffeeb.js.map} +1 -1
  3. package/build/assets/{Chart-22f6a2d3.js → Chart-348ea4c2.js} +2 -2
  4. package/build/assets/{Chart-22f6a2d3.js.map → Chart-348ea4c2.js.map} +1 -1
  5. package/build/assets/{IrisGrid-53f96366.css → IrisGrid-5c3a4e4a.css} +1 -1
  6. package/build/assets/IrisGrid-dafc31d4.js +5 -0
  7. package/build/assets/IrisGrid-dafc31d4.js.map +1 -0
  8. package/build/assets/IrisGridThemeProvider-7428f934.js +11 -0
  9. package/build/assets/IrisGridThemeProvider-7428f934.js.map +1 -0
  10. package/build/assets/{LocalWorkspaceStorage-007009bf.js → LocalWorkspaceStorage-d5564e7b.js} +2 -2
  11. package/build/assets/{LocalWorkspaceStorage-007009bf.js.map → LocalWorkspaceStorage-d5564e7b.js.map} +1 -1
  12. package/build/assets/{LogPanel-86f2f3c5.js → LogPanel-ba91d8fc.js} +2 -2
  13. package/build/assets/{LogPanel-86f2f3c5.js.map → LogPanel-ba91d8fc.js.map} +1 -1
  14. package/build/assets/{MarkdownEditor-387db06b.js → MarkdownEditor-9fd18925.js} +2 -2
  15. package/build/assets/{MarkdownEditor-387db06b.js.map → MarkdownEditor-9fd18925.js.map} +1 -1
  16. package/build/assets/{MarkdownNotebook-a8f89098.js → MarkdownNotebook-c36b4729.js} +2 -2
  17. package/build/assets/{MarkdownNotebook-a8f89098.js.map → MarkdownNotebook-c36b4729.js.map} +1 -1
  18. package/build/assets/{index-690ab305.js → index-0f0df54a.js} +3 -3
  19. package/build/assets/{index-690ab305.js.map → index-0f0df54a.js.map} +1 -1
  20. package/build/assets/{index-23bdd3d2.js → index-576c5f9f.js} +2 -2
  21. package/build/assets/{index-23bdd3d2.js.map → index-576c5f9f.js.map} +1 -1
  22. package/build/assets/{index-817fc456.js → index-da9b1a84.js} +9 -9
  23. package/build/assets/index-da9b1a84.js.map +1 -0
  24. package/build/index.html +2 -2
  25. package/package.json +7 -7
  26. package/build/assets/IrisGrid-4f2fdccc.js +0 -5
  27. package/build/assets/IrisGrid-4f2fdccc.js.map +0 -1
  28. package/build/assets/IrisGridThemeProvider-68adda15.js +0 -11
  29. package/build/assets/IrisGridThemeProvider-68adda15.js.map +0 -1
  30. package/build/assets/index-817fc456.js.map +0 -1
@@ -1,2 +1,2 @@
1
- import{r as t,K as z,L as N,E as u,M as F,D as K}from"./vendor-ef82b474.js";import{L as B,a as q}from"./index-23bdd3d2.js";import{u as J,P as Q,g as X,a as Z,E as ee,b as te,S as se,c as ae,s as oe,d as ne,e as re,f as ie,h as le,i as ce}from"./LogPanel-86f2f3c5.js";import{u as ue,a as de,b as fe,c as ge,s as pe,l as he,d as be,A as me,C as Se,G as Ce,L as x,f as De}from"./LocalWorkspaceStorage-007009bf.js";import"./helpers-de833af9.js";const m=B.module("EmbedWidget.App"),Ee={hasHeaders:!0,defaultComponentConfig:{isClosable:!1}};function Me(){var A;const[f,M]=t.useState(),[s,k]=t.useState(),c=t.useMemo(()=>new URLSearchParams(window.location.search),[]).get("name"),S=J(),d=ue(),C=de(),D=fe(),a=z(),g=ge();t.useEffect(function(){async function o(){try{if(c==null)throw new Error('Missing URL parameter "name"');const e=C.getStorageService(),l=new Ce(e,{}.VITE_STORAGE_PATH_LAYOUTS??""),L=await new x(l).load({isConsoleAvailable:!1}),{data:{settings:U}}=L,{shortcutOverrides:v={}}=U,I=se.isMacPlatform?v.mac??{}:v.windows??{};Object.entries(I).forEach(([V,Y])=>{var P;(P=ae.get(V))==null||P.setKeyState(Y)}),a(oe(S)),a(ne(g)),a(re(D)),a(ie(L)),a(le(x.makeDefaultWorkspaceSettings(g))),m.debug(`Loading widget definition for ${c}...`);const _=await De(d,c);k(_),m.debug(`Widget definition successfully loaded for ${c}`)}catch(e){m.error(`Unable to load widget definition for ${c}`,e),M(`${e}`)}}o()},[S,C,d,a,c,g,D]);const p=s!=null&&f==null,j=s==null&&f==null,E=t.useMemo(()=>s==null?async()=>{throw new Error("Definition is null")}:()=>d.getObject(s),[d,s]),[r,H]=t.useState(null),[h,O]=t.useState("default-embed-widget"),W=t.useCallback(i=>{function o({pluginId:e,data:l}){const n=K();a(ce(n,e,l)),O(n)}H(e=>(e!=null&&pe(e.eventHub,o),he(i.eventHub,o),i))},[a]),[w,R]=t.useState(!1),T=t.useCallback(()=>{r==null||s==null||w||(R(!0),r.eventHub.emit(Q.OPEN,{fetch:E,widget:X(s)}))},[r,s,E,w]),$=N(Z),G=be(),b=((A=$[h])==null?void 0:A.layoutConfig)??ee,y=t.useMemo(()=>{function i(o){if(o.length===0)return 0;let e=0;for(let l=0;l<o.length;l+=1){const n=o[l];n.type==="react-component"||n.type==="component"?e+=1:n.content!=null&&(e+=i(n.content))}return e}return i(b)>1},[b]);return t.useEffect(function(){r!=null&&(y?r.enableHeaders():r.disableHeaders())},[y,r]),u.jsxs("div",{className:"App",children:[p&&u.jsx(te,{children:u.jsx(me,{dashboards:[{id:h,layoutConfig:b,layoutSettings:Ee}],activeDashboard:h,onLayoutInitialized:T,onGoldenLayoutChange:W,plugins:G})}),!p&&u.jsx(q,{isLoaded:p,isLoading:j,errorMessage:f??null}),u.jsx(Se,{}),u.jsx(F,{})]})}export{Me as default};
2
- //# sourceMappingURL=App-595fd008.js.map
1
+ import{r as t,K as z,L as N,E as u,M as F,D as K}from"./vendor-ef82b474.js";import{L as B,a as q}from"./index-576c5f9f.js";import{u as J,P as Q,g as X,a as Z,E as ee,b as te,S as se,c as ae,s as oe,d as ne,e as re,f as ie,h as le,i as ce}from"./LogPanel-ba91d8fc.js";import{u as ue,a as de,b as fe,c as ge,s as pe,l as he,d as be,A as me,C as Se,G as Ce,L as x,f as De}from"./LocalWorkspaceStorage-d5564e7b.js";import"./helpers-de833af9.js";const m=B.module("EmbedWidget.App"),Ee={hasHeaders:!0,defaultComponentConfig:{isClosable:!1}};function Me(){var A;const[f,M]=t.useState(),[s,k]=t.useState(),c=t.useMemo(()=>new URLSearchParams(window.location.search),[]).get("name"),S=J(),d=ue(),C=de(),D=fe(),a=z(),g=ge();t.useEffect(function(){async function o(){try{if(c==null)throw new Error('Missing URL parameter "name"');const e=C.getStorageService(),l=new Ce(e,{}.VITE_STORAGE_PATH_LAYOUTS??""),L=await new x(l).load({isConsoleAvailable:!1}),{data:{settings:U}}=L,{shortcutOverrides:v={}}=U,I=se.isMacPlatform?v.mac??{}:v.windows??{};Object.entries(I).forEach(([V,Y])=>{var P;(P=ae.get(V))==null||P.setKeyState(Y)}),a(oe(S)),a(ne(g)),a(re(D)),a(ie(L)),a(le(x.makeDefaultWorkspaceSettings(g))),m.debug(`Loading widget definition for ${c}...`);const _=await De(d,c);k(_),m.debug(`Widget definition successfully loaded for ${c}`)}catch(e){m.error(`Unable to load widget definition for ${c}`,e),M(`${e}`)}}o()},[S,C,d,a,c,g,D]);const p=s!=null&&f==null,j=s==null&&f==null,E=t.useMemo(()=>s==null?async()=>{throw new Error("Definition is null")}:()=>d.getObject(s),[d,s]),[r,H]=t.useState(null),[h,O]=t.useState("default-embed-widget"),W=t.useCallback(i=>{function o({pluginId:e,data:l}){const n=K();a(ce(n,e,l)),O(n)}H(e=>(e!=null&&pe(e.eventHub,o),he(i.eventHub,o),i))},[a]),[w,R]=t.useState(!1),T=t.useCallback(()=>{r==null||s==null||w||(R(!0),r.eventHub.emit(Q.OPEN,{fetch:E,widget:X(s)}))},[r,s,E,w]),$=N(Z),G=be(),b=((A=$[h])==null?void 0:A.layoutConfig)??ee,y=t.useMemo(()=>{function i(o){if(o.length===0)return 0;let e=0;for(let l=0;l<o.length;l+=1){const n=o[l];n.type==="react-component"||n.type==="component"?e+=1:n.content!=null&&(e+=i(n.content))}return e}return i(b)>1},[b]);return t.useEffect(function(){r!=null&&(y?r.enableHeaders():r.disableHeaders())},[y,r]),u.jsxs("div",{className:"App",children:[p&&u.jsx(te,{children:u.jsx(me,{dashboards:[{id:h,layoutConfig:b,layoutSettings:Ee}],activeDashboard:h,onLayoutInitialized:T,onGoldenLayoutChange:W,plugins:G})}),!p&&u.jsx(q,{isLoaded:p,isLoading:j,errorMessage:f??null}),u.jsx(Se,{}),u.jsx(F,{})]})}export{Me as default};
2
+ //# sourceMappingURL=App-15dffeeb.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"App-595fd008.js","sources":["../../src/App.tsx"],"sourcesContent":["import React, { useCallback, useEffect, useMemo, useState } from 'react';\nimport { useDispatch, useSelector } from 'react-redux';\nimport { nanoid } from 'nanoid';\nimport {\n AppDashboards,\n GrpcLayoutStorage,\n LocalWorkspaceStorage,\n useConnection,\n useServerConfig,\n useUser,\n} from '@deephaven/app-utils';\nimport type GoldenLayout from '@deephaven/golden-layout';\nimport type { ItemConfigType } from '@deephaven/golden-layout';\nimport {\n ContextMenuRoot,\n ErrorBoundary,\n LoadingOverlay,\n Shortcut,\n ShortcutRegistry,\n ToastContainer,\n} from '@deephaven/components'; // Use the loading spinner from the Deephaven components package\nimport type { dh } from '@deephaven/jsapi-types';\nimport { fetchVariableDefinition } from '@deephaven/jsapi-utils';\nimport Log from '@deephaven/log';\nimport { useDashboardPlugins } from '@deephaven/plugin';\nimport {\n PanelEvent,\n getAllDashboardsData,\n listenForCreateDashboard,\n CreateDashboardPayload,\n setDashboardPluginData,\n stopListenForCreateDashboard,\n} from '@deephaven/dashboard';\nimport {\n getVariableDescriptor,\n useApi,\n useClient,\n} from '@deephaven/jsapi-bootstrap';\nimport { EMPTY_ARRAY } from '@deephaven/utils';\nimport {\n setDefaultWorkspaceSettings,\n setWorkspace,\n setApi,\n setUser,\n setServerConfigValues,\n} from '@deephaven/redux';\nimport './App.scss'; // Styles for in this app\n\nconst log = Log.module('EmbedWidget.App');\n\nconst LAYOUT_SETTINGS = {\n hasHeaders: true,\n defaultComponentConfig: { isClosable: false },\n};\n\n/**\n * A functional React component that displays a Deephaven Widget using the @deephaven/plugin package.\n * It will attempt to open and display the widget specified with the `name` parameter, expecting it to be present on the server.\n * E.g. http://localhost:4010/?name=myWidget will attempt to open a widget `myWidget` by emitting a `PanelEvent.OPEN` event.\n * If no query param is provided, it will display an error.\n * By default, tries to connect to the server defined in the VITE_CORE_API_URL variable, which is set to http://localhost:10000/jsapi\n * See Vite docs for how to update these env vars: https://vitejs.dev/guide/env-and-mode.html\n */\nfunction App(): JSX.Element {\n const [error, setError] = useState<string>();\n const [definition, setDefinition] = useState<dh.ide.VariableDefinition>();\n const searchParams = useMemo(\n () => new URLSearchParams(window.location.search),\n []\n );\n // Get the widget name from the query param `name`.\n const name = searchParams.get('name');\n const api = useApi();\n const connection = useConnection();\n const client = useClient();\n const user = useUser();\n const dispatch = useDispatch();\n const serverConfig = useServerConfig();\n\n useEffect(\n function initializeApp() {\n async function initApp(): Promise<void> {\n try {\n if (name == null) {\n throw new Error('Missing URL parameter \"name\"');\n }\n\n const storageService = client.getStorageService();\n const layoutStorage = new GrpcLayoutStorage(\n storageService,\n import.meta.env.VITE_STORAGE_PATH_LAYOUTS ?? ''\n );\n const workspaceStorage = new LocalWorkspaceStorage(layoutStorage);\n const loadedWorkspace = await workspaceStorage.load({\n isConsoleAvailable: false,\n });\n const {\n data: { settings },\n } = loadedWorkspace;\n // Set any shortcuts that user has overridden on this platform\n const { shortcutOverrides = {} } = settings;\n const isMac = Shortcut.isMacPlatform;\n const platformOverrides = isMac\n ? shortcutOverrides.mac ?? {}\n : shortcutOverrides.windows ?? {};\n Object.entries(platformOverrides).forEach(([id, keyState]) => {\n ShortcutRegistry.get(id)?.setKeyState(keyState);\n });\n dispatch(setApi(api));\n dispatch(setServerConfigValues(serverConfig));\n dispatch(setUser(user));\n dispatch(setWorkspace(loadedWorkspace));\n dispatch(\n setDefaultWorkspaceSettings(\n LocalWorkspaceStorage.makeDefaultWorkspaceSettings(serverConfig)\n )\n );\n\n log.debug(`Loading widget definition for ${name}...`);\n\n const newDefinition = await fetchVariableDefinition(connection, name);\n\n setDefinition(newDefinition);\n\n log.debug(`Widget definition successfully loaded for ${name}`);\n } catch (e: unknown) {\n log.error(`Unable to load widget definition for ${name}`, e);\n setError(`${e}`);\n }\n }\n initApp();\n },\n [api, client, connection, dispatch, name, serverConfig, user]\n );\n\n const isLoaded = definition != null && error == null;\n const isLoading = definition == null && error == null;\n\n const fetch = useMemo(() => {\n if (definition == null) {\n return async () => {\n throw new Error('Definition is null');\n };\n }\n return () => connection.getObject(definition);\n }, [connection, definition]);\n\n const [goldenLayout, setGoldenLayout] = useState<GoldenLayout | null>(null);\n const [dashboardId, setDashboardId] = useState('default-embed-widget'); // Can't be DEFAULT_DASHBOARD_ID because its dashboard layout is not stored in dashboardData\n\n const handleGoldenLayoutChange = useCallback(\n (newLayout: GoldenLayout) => {\n function handleCreateDashboard({\n pluginId,\n data,\n }: CreateDashboardPayload) {\n const id = nanoid();\n dispatch(setDashboardPluginData(id, pluginId, data));\n setDashboardId(id);\n }\n\n setGoldenLayout(oldLayout => {\n if (oldLayout != null) {\n stopListenForCreateDashboard(\n oldLayout.eventHub,\n handleCreateDashboard\n );\n }\n listenForCreateDashboard(newLayout.eventHub, handleCreateDashboard);\n return newLayout;\n });\n },\n [dispatch]\n );\n\n const [hasEmittedWidget, setHasEmittedWidget] = useState(false);\n\n const handleDashboardInitialized = useCallback(() => {\n if (goldenLayout == null || definition == null || hasEmittedWidget) {\n return;\n }\n\n setHasEmittedWidget(true);\n goldenLayout.eventHub.emit(PanelEvent.OPEN, {\n fetch,\n widget: getVariableDescriptor(definition),\n });\n }, [goldenLayout, definition, fetch, hasEmittedWidget]);\n\n const allDashboardData = useSelector(getAllDashboardsData);\n\n const dashboardPlugins = useDashboardPlugins();\n\n const layoutConfig = (allDashboardData[dashboardId]?.layoutConfig ??\n EMPTY_ARRAY) as ItemConfigType[];\n\n const hasMultipleComponents = useMemo(() => {\n function getComponentCount(config: ItemConfigType[]) {\n if (config.length === 0) {\n return 0;\n }\n\n let count = 0;\n for (let i = 0; i < config.length; i += 1) {\n const item = config[i];\n if (item.type === 'react-component' || item.type === 'component') {\n count += 1;\n } else if (item.content != null) {\n count += getComponentCount(item.content);\n }\n }\n return count;\n }\n return getComponentCount(layoutConfig) > 1;\n }, [layoutConfig]);\n\n // Do this instead of changing layoutSettings because it will create\n // a new gl instance and can cause some loading failures likely due to\n // some race conditions w/ deephaven UI\n useEffect(\n function togglePanelHeaders() {\n if (goldenLayout != null) {\n if (hasMultipleComponents) {\n goldenLayout.enableHeaders();\n } else {\n goldenLayout.disableHeaders();\n }\n }\n },\n [hasMultipleComponents, goldenLayout]\n );\n\n return (\n <div className=\"App\">\n {isLoaded && (\n <ErrorBoundary>\n <AppDashboards\n dashboards={[\n {\n id: dashboardId,\n layoutConfig,\n layoutSettings: LAYOUT_SETTINGS,\n },\n ]}\n activeDashboard={dashboardId}\n onLayoutInitialized={handleDashboardInitialized}\n onGoldenLayoutChange={handleGoldenLayoutChange}\n plugins={dashboardPlugins}\n />\n </ErrorBoundary>\n )}\n {!isLoaded && (\n <LoadingOverlay\n isLoaded={isLoaded}\n isLoading={isLoading}\n errorMessage={error ?? null}\n />\n )}\n <ContextMenuRoot />\n <ToastContainer />\n </div>\n );\n}\n\nexport default App;\n"],"names":["log","Log","LAYOUT_SETTINGS","App","error","setError","useState","definition","setDefinition","name","useMemo","api","useApi","connection","useConnection","client","useClient","user","useUser","dispatch","useDispatch","serverConfig","useServerConfig","useEffect","initApp","storageService","layoutStorage","GrpcLayoutStorage","loadedWorkspace","LocalWorkspaceStorage","settings","shortcutOverrides","platformOverrides","Shortcut","id","keyState","_a","ShortcutRegistry","setApi","setServerConfigValues","setUser","setWorkspace","setDefaultWorkspaceSettings","newDefinition","fetchVariableDefinition","isLoaded","isLoading","fetch","goldenLayout","setGoldenLayout","dashboardId","setDashboardId","handleGoldenLayoutChange","useCallback","newLayout","handleCreateDashboard","pluginId","data","nanoid","setDashboardPluginData","oldLayout","stopListenForCreateDashboard","listenForCreateDashboard","hasEmittedWidget","setHasEmittedWidget","handleDashboardInitialized","PanelEvent","getVariableDescriptor","allDashboardData","useSelector","getAllDashboardsData","dashboardPlugins","useDashboardPlugins","layoutConfig","EMPTY_ARRAY","hasMultipleComponents","getComponentCount","config","count","i","item","jsxs","ErrorBoundary","jsx","AppDashboards","LoadingOverlay","ContextMenuRoot","ToastContainer"],"mappings":"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"}
1
+ {"version":3,"file":"App-15dffeeb.js","sources":["../../src/App.tsx"],"sourcesContent":["import React, { useCallback, useEffect, useMemo, useState } from 'react';\nimport { useDispatch, useSelector } from 'react-redux';\nimport { nanoid } from 'nanoid';\nimport {\n AppDashboards,\n GrpcLayoutStorage,\n LocalWorkspaceStorage,\n useConnection,\n useServerConfig,\n useUser,\n} from '@deephaven/app-utils';\nimport type GoldenLayout from '@deephaven/golden-layout';\nimport type { ItemConfigType } from '@deephaven/golden-layout';\nimport {\n ContextMenuRoot,\n ErrorBoundary,\n LoadingOverlay,\n Shortcut,\n ShortcutRegistry,\n ToastContainer,\n} from '@deephaven/components'; // Use the loading spinner from the Deephaven components package\nimport type { dh } from '@deephaven/jsapi-types';\nimport { fetchVariableDefinition } from '@deephaven/jsapi-utils';\nimport Log from '@deephaven/log';\nimport { useDashboardPlugins } from '@deephaven/plugin';\nimport {\n PanelEvent,\n getAllDashboardsData,\n listenForCreateDashboard,\n CreateDashboardPayload,\n setDashboardPluginData,\n stopListenForCreateDashboard,\n} from '@deephaven/dashboard';\nimport {\n getVariableDescriptor,\n useApi,\n useClient,\n} from '@deephaven/jsapi-bootstrap';\nimport { EMPTY_ARRAY } from '@deephaven/utils';\nimport {\n setDefaultWorkspaceSettings,\n setWorkspace,\n setApi,\n setUser,\n setServerConfigValues,\n} from '@deephaven/redux';\nimport './App.scss'; // Styles for in this app\n\nconst log = Log.module('EmbedWidget.App');\n\nconst LAYOUT_SETTINGS = {\n hasHeaders: true,\n defaultComponentConfig: { isClosable: false },\n};\n\n/**\n * A functional React component that displays a Deephaven Widget using the @deephaven/plugin package.\n * It will attempt to open and display the widget specified with the `name` parameter, expecting it to be present on the server.\n * E.g. http://localhost:4010/?name=myWidget will attempt to open a widget `myWidget` by emitting a `PanelEvent.OPEN` event.\n * If no query param is provided, it will display an error.\n * By default, tries to connect to the server defined in the VITE_CORE_API_URL variable, which is set to http://localhost:10000/jsapi\n * See Vite docs for how to update these env vars: https://vitejs.dev/guide/env-and-mode.html\n */\nfunction App(): JSX.Element {\n const [error, setError] = useState<string>();\n const [definition, setDefinition] = useState<dh.ide.VariableDefinition>();\n const searchParams = useMemo(\n () => new URLSearchParams(window.location.search),\n []\n );\n // Get the widget name from the query param `name`.\n const name = searchParams.get('name');\n const api = useApi();\n const connection = useConnection();\n const client = useClient();\n const user = useUser();\n const dispatch = useDispatch();\n const serverConfig = useServerConfig();\n\n useEffect(\n function initializeApp() {\n async function initApp(): Promise<void> {\n try {\n if (name == null) {\n throw new Error('Missing URL parameter \"name\"');\n }\n\n const storageService = client.getStorageService();\n const layoutStorage = new GrpcLayoutStorage(\n storageService,\n import.meta.env.VITE_STORAGE_PATH_LAYOUTS ?? ''\n );\n const workspaceStorage = new LocalWorkspaceStorage(layoutStorage);\n const loadedWorkspace = await workspaceStorage.load({\n isConsoleAvailable: false,\n });\n const {\n data: { settings },\n } = loadedWorkspace;\n // Set any shortcuts that user has overridden on this platform\n const { shortcutOverrides = {} } = settings;\n const isMac = Shortcut.isMacPlatform;\n const platformOverrides = isMac\n ? shortcutOverrides.mac ?? {}\n : shortcutOverrides.windows ?? {};\n Object.entries(platformOverrides).forEach(([id, keyState]) => {\n ShortcutRegistry.get(id)?.setKeyState(keyState);\n });\n dispatch(setApi(api));\n dispatch(setServerConfigValues(serverConfig));\n dispatch(setUser(user));\n dispatch(setWorkspace(loadedWorkspace));\n dispatch(\n setDefaultWorkspaceSettings(\n LocalWorkspaceStorage.makeDefaultWorkspaceSettings(serverConfig)\n )\n );\n\n log.debug(`Loading widget definition for ${name}...`);\n\n const newDefinition = await fetchVariableDefinition(connection, name);\n\n setDefinition(newDefinition);\n\n log.debug(`Widget definition successfully loaded for ${name}`);\n } catch (e: unknown) {\n log.error(`Unable to load widget definition for ${name}`, e);\n setError(`${e}`);\n }\n }\n initApp();\n },\n [api, client, connection, dispatch, name, serverConfig, user]\n );\n\n const isLoaded = definition != null && error == null;\n const isLoading = definition == null && error == null;\n\n const fetch = useMemo(() => {\n if (definition == null) {\n return async () => {\n throw new Error('Definition is null');\n };\n }\n return () => connection.getObject(definition);\n }, [connection, definition]);\n\n const [goldenLayout, setGoldenLayout] = useState<GoldenLayout | null>(null);\n const [dashboardId, setDashboardId] = useState('default-embed-widget'); // Can't be DEFAULT_DASHBOARD_ID because its dashboard layout is not stored in dashboardData\n\n const handleGoldenLayoutChange = useCallback(\n (newLayout: GoldenLayout) => {\n function handleCreateDashboard({\n pluginId,\n data,\n }: CreateDashboardPayload) {\n const id = nanoid();\n dispatch(setDashboardPluginData(id, pluginId, data));\n setDashboardId(id);\n }\n\n setGoldenLayout(oldLayout => {\n if (oldLayout != null) {\n stopListenForCreateDashboard(\n oldLayout.eventHub,\n handleCreateDashboard\n );\n }\n listenForCreateDashboard(newLayout.eventHub, handleCreateDashboard);\n return newLayout;\n });\n },\n [dispatch]\n );\n\n const [hasEmittedWidget, setHasEmittedWidget] = useState(false);\n\n const handleDashboardInitialized = useCallback(() => {\n if (goldenLayout == null || definition == null || hasEmittedWidget) {\n return;\n }\n\n setHasEmittedWidget(true);\n goldenLayout.eventHub.emit(PanelEvent.OPEN, {\n fetch,\n widget: getVariableDescriptor(definition),\n });\n }, [goldenLayout, definition, fetch, hasEmittedWidget]);\n\n const allDashboardData = useSelector(getAllDashboardsData);\n\n const dashboardPlugins = useDashboardPlugins();\n\n const layoutConfig = (allDashboardData[dashboardId]?.layoutConfig ??\n EMPTY_ARRAY) as ItemConfigType[];\n\n const hasMultipleComponents = useMemo(() => {\n function getComponentCount(config: ItemConfigType[]) {\n if (config.length === 0) {\n return 0;\n }\n\n let count = 0;\n for (let i = 0; i < config.length; i += 1) {\n const item = config[i];\n if (item.type === 'react-component' || item.type === 'component') {\n count += 1;\n } else if (item.content != null) {\n count += getComponentCount(item.content);\n }\n }\n return count;\n }\n return getComponentCount(layoutConfig) > 1;\n }, [layoutConfig]);\n\n // Do this instead of changing layoutSettings because it will create\n // a new gl instance and can cause some loading failures likely due to\n // some race conditions w/ deephaven UI\n useEffect(\n function togglePanelHeaders() {\n if (goldenLayout != null) {\n if (hasMultipleComponents) {\n goldenLayout.enableHeaders();\n } else {\n goldenLayout.disableHeaders();\n }\n }\n },\n [hasMultipleComponents, goldenLayout]\n );\n\n return (\n <div className=\"App\">\n {isLoaded && (\n <ErrorBoundary>\n <AppDashboards\n dashboards={[\n {\n id: dashboardId,\n layoutConfig,\n layoutSettings: LAYOUT_SETTINGS,\n },\n ]}\n activeDashboard={dashboardId}\n onLayoutInitialized={handleDashboardInitialized}\n onGoldenLayoutChange={handleGoldenLayoutChange}\n plugins={dashboardPlugins}\n />\n </ErrorBoundary>\n )}\n {!isLoaded && (\n <LoadingOverlay\n isLoaded={isLoaded}\n isLoading={isLoading}\n errorMessage={error ?? null}\n />\n )}\n <ContextMenuRoot />\n <ToastContainer />\n </div>\n );\n}\n\nexport default App;\n"],"names":["log","Log","LAYOUT_SETTINGS","App","error","setError","useState","definition","setDefinition","name","useMemo","api","useApi","connection","useConnection","client","useClient","user","useUser","dispatch","useDispatch","serverConfig","useServerConfig","useEffect","initApp","storageService","layoutStorage","GrpcLayoutStorage","loadedWorkspace","LocalWorkspaceStorage","settings","shortcutOverrides","platformOverrides","Shortcut","id","keyState","_a","ShortcutRegistry","setApi","setServerConfigValues","setUser","setWorkspace","setDefaultWorkspaceSettings","newDefinition","fetchVariableDefinition","isLoaded","isLoading","fetch","goldenLayout","setGoldenLayout","dashboardId","setDashboardId","handleGoldenLayoutChange","useCallback","newLayout","handleCreateDashboard","pluginId","data","nanoid","setDashboardPluginData","oldLayout","stopListenForCreateDashboard","listenForCreateDashboard","hasEmittedWidget","setHasEmittedWidget","handleDashboardInitialized","PanelEvent","getVariableDescriptor","allDashboardData","useSelector","getAllDashboardsData","dashboardPlugins","useDashboardPlugins","layoutConfig","EMPTY_ARRAY","hasMultipleComponents","getComponentCount","config","count","i","item","jsxs","ErrorBoundary","jsx","AppDashboards","LoadingOverlay","ContextMenuRoot","ToastContainer"],"mappings":"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"}
@@ -1,2 +1,2 @@
1
- import{E as n,r as A,br as L,J as k,bs as F}from"./vendor-ef82b474.js";import{L as x,aL as N,b6 as B,b7 as U}from"./index-23bdd3d2.js";import{c as I}from"./Plotly-d4959fc8.js";import{C as W,aa as _,A as h,E as j,e as T,d as z,D as V}from"./index-817fc456.js";import{z as P,as as K}from"./LogPanel-86f2f3c5.js";import{D as $}from"./DownsamplingError-8e6bdb73.js";import{m as H}from"./useMergeRef-c282321f.js";import{P as Y}from"./plotly-c256dde6.js";import"./helpers-de833af9.js";function R(i){var{errorMessage:e,onDiscard:t,onConfirm:r,onCancel:s,"data-testid":a}=i,l=a!=null?"".concat(a,"-message"):void 0;return n.jsx("div",{className:"chart-panel-overlay chart-error-overlay",children:n.jsxs("div",{className:"chart-panel-overlay-content chart-error-overlay-content",children:[n.jsxs("div",{className:"info-message","data-testid":l,children:[e,n.jsx(W,{copy:e,style:{margin:"0"}})]}),n.jsxs("div",{children:[s&&n.jsx(P,{onClick:s,kind:"secondary",children:"Cancel"}),t&&n.jsx(P,{onClick:t,kind:"secondary",children:"Dismiss"}),r&&n.jsx(P,{onClick:r,kind:"primary",children:"Continue"})]})]})})}function M(i,e){var t=Object.keys(i);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(i);e&&(r=r.filter(function(s){return Object.getOwnPropertyDescriptor(i,s).enumerable})),t.push.apply(t,r)}return t}function g(i){for(var e=1;e<arguments.length;e++){var t=arguments[e]!=null?arguments[e]:{};e%2?M(Object(t),!0).forEach(function(r){o(i,r,t[r])}):Object.getOwnPropertyDescriptors?Object.defineProperties(i,Object.getOwnPropertyDescriptors(t)):M(Object(t)).forEach(function(r){Object.defineProperty(i,r,Object.getOwnPropertyDescriptor(t,r))})}return i}function o(i,e,t){return e=Z(e),e in i?Object.defineProperty(i,e,{value:t,enumerable:!0,configurable:!0,writable:!0}):i[e]=t,i}function Z(i){var e=q(i,"string");return typeof e=="symbol"?e:String(e)}function q(i,e){if(typeof i!="object"||i===null)return i;var t=i[Symbol.toPrimitive];if(t!==void 0){var r=t.call(i,e||"default");if(typeof r!="object")return r;throw new TypeError("@@toPrimitive must return a primitive value.")}return(e==="string"?String:Number)(i)}var f=x.module("Chart");class b extends A.Component{static convertIcon(e){var[t,,,,r]=e.icon,s="".concat(r);return{width:t,path:s,ascent:t,descent:0,transform:"matrix(1, 0, 0, 1, 0, 0)"}}static downsampleButtonTitle(e,t){return e?"Downsampling in progress...":t?"Downsampling disabled, click to enable":"Downsampling enabled, click to disable"}static downsampleButtonAttr(e,t){return e?"animation-spin":t?void 0:"fill-active"}constructor(e){super(e),o(this,"currentSeries",void 0),o(this,"PlotComponent",void 0),o(this,"plot",void 0),o(this,"plotWrapper",void 0),o(this,"plotWrapperMerged",void 0),o(this,"columnFormats",void 0),o(this,"dateTimeFormatterOptions",void 0),o(this,"decimalFormatOptions",void 0),o(this,"integerFormatOptions",void 0),o(this,"webgl",void 0),o(this,"rect",void 0),o(this,"ranges",void 0),o(this,"isSubscribed",void 0),o(this,"isLoadedFired",void 0),o(this,"resizeObserver",void 0),o(this,"getCachedConfig",L((t,r,s,a,l,u)=>{var d=[],c=!!t;c&&d.push({name:"Downsampling failed: ".concat(t),title:"Downsampling failed",click:()=>{this.toggleErrorMessage("".concat(t))},icon:b.convertIcon(N),attr:"fill-warning"});var m=!!u;if(m&&d.push({name:"Error: ".concat(u),title:"Error",click:()=>{this.toggleErrorMessage("".concat(u))},icon:b.convertIcon(N),attr:"fill-warning"}),r||s||a||c){var v=b.downsampleButtonTitle(s,a),D=b.downsampleButtonAttr(s,a),E=s?B:U;d.push({name:v,title:"Downsampling status",icon:b.convertIcon(E),click:this.handleDownsampleClick,attr:D})}var y=l.some(S=>{var{type:C}=S;return C!=null&&!C.includes("3d")}),p=l.some(S=>{var{type:C}=S;return C!=null&&C.includes("3d")}),w=["zoomIn2d","zoomOut2d","autoScale2d","resetScale2d"],O=["orbitRotation","tableRotation","resetCameraDefault3d"];return{displaylogo:!1,responsive:!0,displayModeBar:s||c||m?!0:"hover",modeBarButtons:[d,["toImage"],["zoom2d","pan2d"],[...y?w:[],...p?O:[]]]}})),_(this),this.PlotComponent=I(e.Plotly),this.plot=k.createRef(),this.plotWrapper=k.createRef(),this.plotWrapperMerged=H(this.plotWrapper,e.containerRef),this.columnFormats=[],this.dateTimeFormatterOptions={},this.decimalFormatOptions={},this.integerFormatOptions={},this.isSubscribed=!1,this.isLoadedFired=!1,this.currentSeries=0,this.resizeObserver=new window.ResizeObserver(this.handleResize),this.state={data:null,downsamplingError:null,isDownsampleFinished:!1,isDownsampleInProgress:!1,isDownsamplingDisabled:!1,error:null,shownError:null,layout:{datarevision:0},revision:0,shownBlocker:null}}componentDidMount(){this.updateDimensions(),this.updateModelDimensions(),this.initData(),this.initFormatter();var{isActive:e,model:t}=this.props;e&&this.subscribe(t),this.plotWrapper.current!=null&&this.resizeObserver.observe(this.plotWrapper.current),this.handleThemeChange()}componentDidUpdate(e){var{isActive:t,model:r,settings:s,theme:a}=this.props;this.updateFormatterSettings(s),r!==e.model&&(this.unsubscribe(e.model),this.subscribe(r)),t!==e.isActive&&(t?(this.updateDimensions(),this.subscribe(r)):this.unsubscribe(r)),a!==e.theme&&this.handleThemeChange()}componentWillUnmount(){var{model:e}=this.props;this.unsubscribe(e),this.resizeObserver.disconnect()}getPlotRect(){var e,t;return(e=(t=this.plotWrapper.current)===null||t===void 0?void 0:t.getBoundingClientRect())!==null&&e!==void 0?e:null}initData(){var{model:e}=this.props;this.setState(t=>{var{layout:r}=t;return{data:e.getData(),layout:g(g({},r),e.getLayout())}})}subscribe(e){if(!this.isSubscribed){if(!this.rect||this.rect.width===0||this.rect.height===0){f.debug2("Delaying subscription until model dimensions are set");return}e.subscribe(this.handleModelEvent),this.isSubscribed=!0}}unsubscribe(e){this.isSubscribed&&(e.unsubscribe(this.handleModelEvent),this.isSubscribed=!1)}handleAfterPlot(){this.plot.current!=null}handleDownsampleClick(){this.setState(e=>{var{isDownsamplingDisabled:t}=e;return{downsamplingError:null,isDownsampleInProgress:!1,isDownsampleFinished:!1,isDownsamplingDisabled:!t}},()=>{var{model:e}=this.props,{isDownsamplingDisabled:t}=this.state;e.setDownsamplingDisabled(t)})}handleErrorClose(){this.setState({shownError:null})}handleDownsampleErrorClose(){this.setState({downsamplingError:null})}handleModelEvent(e){var{type:t,detail:r}=e;switch(f.debug2("Received data update",t,r),t){case h.EVENT_UPDATED:{this.currentSeries+=1,this.setState(p=>{var{layout:w,revision:O}=p;return typeof w.datarevision=="number"&&(w.datarevision+=1),{data:r,layout:w,revision:O+1}});var{onUpdate:s}=this.props;s({isLoading:!this.isLoadedFired});break}case h.EVENT_LOADFINISHED:{var{onUpdate:a}=this.props;this.isLoadedFired=!0,a({isLoading:!1});break}case h.EVENT_DISCONNECT:{var{onDisconnect:l}=this.props;l();break}case h.EVENT_RECONNECT:{var{onReconnect:u}=this.props;u();break}case h.EVENT_DOWNSAMPLESTARTED:{this.setState({isDownsampleFinished:!1,isDownsampleInProgress:!0,downsamplingError:null});break}case h.EVENT_DOWNSAMPLEFINISHED:{this.setState({isDownsampleFinished:!0,isDownsampleInProgress:!1,downsamplingError:null});break}case h.EVENT_DOWNSAMPLENEEDED:case h.EVENT_DOWNSAMPLEFAILED:{var d,c=(d=r.message)!==null&&d!==void 0?d:r;this.setState({isDownsampleFinished:!1,isDownsampleInProgress:!1,isDownsamplingDisabled:!1,downsamplingError:c});var{onError:m}=this.props;m(new $(c));break}case h.EVENT_ERROR:{var v="".concat(r);this.setState({error:v});var{onError:D}=this.props;D(new Error(v));break}case h.EVENT_BLOCKER:{var E="".concat(r);this.setState({shownBlocker:E});break}case h.EVENT_BLOCKER_CLEAR:{this.setState({shownBlocker:null});break}case h.EVENT_LAYOUT_UPDATED:{var y=r;this.setState(p=>{var{layout:w,revision:O}=p;return{layout:g(g({},w),y),revision:O+1}});break}default:f.debug("Unknown event type",t,e)}}handlePlotUpdate(e){var{layout:t}=e,r=j.getLayoutRanges(t),s=!F(r,this.ranges);s&&(this.ranges=r,this.updateModelDimensions(!0))}handleRelayout(e){if(f.debug("handleRelayout",e),e.hiddenlabels!=null){var{onSettingsChanged:t}=this.props,r=[...e.hiddenlabels];t({hiddenSeries:r})}this.updateModelDimensions()}handleResize(){this.updateDimensions()}handleRestyle(e){var[t,r]=e;if(f.debug("handleRestyle",t,r),Object.keys(t).includes("visible")){var{data:s}=this.state,{onSettingsChanged:a}=this.props;if(s!=null){var l=s.reduce((u,d)=>{var{name:c,visible:m}=d;return c!=null&&m==="legendonly"?[...u,c]:u},[]);a({hiddenSeries:l})}}}handleThemeChange(){var{theme:e,model:t}=this.props,{dh:r}=t,s=new j(r);this.setState(a=>{var{layout:l}=a;return{layout:g(g({},l),{},{template:s.makeDefaultTemplate(e)})}})}toggleErrorMessage(e){this.setState(t=>{var{shownError:r}=t;return{shownError:r===e?null:e}})}updateModelDimensions(){var e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:!1,t=this.getPlotRect();if(!t){f.warn("Unable to get plotting rect");return}var r=!this.rect||this.rect.width!==t.width||this.rect.height!==t.height;if(r||e){this.rect=t;var{isActive:s,model:a}=this.props;a.setDimensions(t),s&&this.subscribe(a)}}initFormatter(){var{settings:e}=this.props;this.updateFormatterSettings(e)}updateFormatterSettings(e){var t=T.getColumnFormats(e),r=T.getDateTimeFormatterOptions(e),{decimalFormatOptions:s={},integerFormatOptions:a={}}=e;(!F(this.columnFormats,t)||!F(this.dateTimeFormatterOptions,r)||!F(this.decimalFormatOptions,s)||!F(this.integerFormatOptions,a))&&(this.columnFormats=T.getColumnFormats(e),this.dateTimeFormatterOptions=r,this.decimalFormatOptions=s,this.integerFormatOptions=a,this.updateFormatter()),this.webgl!==e.webgl&&(this.webgl=e.webgl,this.updateRenderOptions())}updateFormatter(){var{model:e}=this.props,t=new z(e.dh,this.columnFormats,this.dateTimeFormatterOptions,this.decimalFormatOptions,this.integerFormatOptions);e.setFormatter(t)}updateRenderOptions(){var{model:e}=this.props,t={webgl:this.webgl};e.setRenderOptions(t)}updateDimensions(){var e=this.getPlotRect(),{Plotly:t}=this.props;this.plot.current!=null&&e!=null&&e.width>0&&e.height>0&&t.relayout(this.plot.current.el,{autosize:!0}).catch(r=>{f.debug("Unable to resize, promise rejected",r)})}render(){var{PlotComponent:e}=this,{data:t,downsamplingError:r,isDownsampleFinished:s,isDownsampleInProgress:a,isDownsamplingDisabled:l,error:u,shownError:d,layout:c,revision:m,shownBlocker:v}=this.state,D=this.getCachedConfig(r,s,a,l,t??[],u),{model:E}=this.props,y=t!=null&&v==null,p=null;return v!=null?p=n.jsx(R,{errorMessage:"".concat(v),onConfirm:()=>{E.fireBlockerClear()}}):d!=null?p=n.jsx(R,{errorMessage:"".concat(r),onDiscard:()=>{this.handleDownsampleErrorClose()},onConfirm:()=>{this.handleDownsampleErrorClose(),this.handleDownsampleClick()}}):r!=null&&(p=n.jsx(R,{errorMessage:"".concat(r),onDiscard:()=>{this.handleDownsampleErrorClose()},onConfirm:()=>{this.handleDownsampleErrorClose(),this.handleDownsampleClick()}})),n.jsxs("div",{className:"h-100 w-100 chart-wrapper",ref:this.plotWrapperMerged,children:[y&&n.jsx(e,{ref:this.plot,data:t,layout:c,revision:m,config:D,onAfterPlot:this.handleAfterPlot,onError:f.error,onRelayout:this.handleRelayout,onUpdate:this.handlePlotUpdate,onRestyle:this.handleRestyle,style:{height:"100%",width:"100%"}}),p]})}}o(b,"defaultProps",{isActive:!0,settings:{timeZone:"America/New_York",defaultDateTimeFormat:V.FULL_DATE_FORMAT,showTimeZone:!1,showTSeparator:!0,formatter:[],webgl:!0},Plotly:Y,onDisconnect:()=>{},onReconnect:()=>{},onUpdate:()=>{},onError:()=>{},onSettingsChanged:()=>{}});function ae(i){var e=K();return n.jsx(b,g(g({},i),{},{theme:e}))}export{ae as default};
2
- //# sourceMappingURL=Chart-22f6a2d3.js.map
1
+ import{E as n,r as A,br as L,J as k,bs as F}from"./vendor-ef82b474.js";import{L as x,aL as N,b6 as B,b7 as U}from"./index-576c5f9f.js";import{c as I}from"./Plotly-d4959fc8.js";import{C as W,aa as _,A as h,E as j,e as T,d as z,D as V}from"./index-da9b1a84.js";import{z as P,as as K}from"./LogPanel-ba91d8fc.js";import{D as $}from"./DownsamplingError-8e6bdb73.js";import{m as H}from"./useMergeRef-c282321f.js";import{P as Y}from"./plotly-c256dde6.js";import"./helpers-de833af9.js";function R(i){var{errorMessage:e,onDiscard:t,onConfirm:r,onCancel:s,"data-testid":a}=i,l=a!=null?"".concat(a,"-message"):void 0;return n.jsx("div",{className:"chart-panel-overlay chart-error-overlay",children:n.jsxs("div",{className:"chart-panel-overlay-content chart-error-overlay-content",children:[n.jsxs("div",{className:"info-message","data-testid":l,children:[e,n.jsx(W,{copy:e,style:{margin:"0"}})]}),n.jsxs("div",{children:[s&&n.jsx(P,{onClick:s,kind:"secondary",children:"Cancel"}),t&&n.jsx(P,{onClick:t,kind:"secondary",children:"Dismiss"}),r&&n.jsx(P,{onClick:r,kind:"primary",children:"Continue"})]})]})})}function M(i,e){var t=Object.keys(i);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(i);e&&(r=r.filter(function(s){return Object.getOwnPropertyDescriptor(i,s).enumerable})),t.push.apply(t,r)}return t}function g(i){for(var e=1;e<arguments.length;e++){var t=arguments[e]!=null?arguments[e]:{};e%2?M(Object(t),!0).forEach(function(r){o(i,r,t[r])}):Object.getOwnPropertyDescriptors?Object.defineProperties(i,Object.getOwnPropertyDescriptors(t)):M(Object(t)).forEach(function(r){Object.defineProperty(i,r,Object.getOwnPropertyDescriptor(t,r))})}return i}function o(i,e,t){return e=Z(e),e in i?Object.defineProperty(i,e,{value:t,enumerable:!0,configurable:!0,writable:!0}):i[e]=t,i}function Z(i){var e=q(i,"string");return typeof e=="symbol"?e:String(e)}function q(i,e){if(typeof i!="object"||i===null)return i;var t=i[Symbol.toPrimitive];if(t!==void 0){var r=t.call(i,e||"default");if(typeof r!="object")return r;throw new TypeError("@@toPrimitive must return a primitive value.")}return(e==="string"?String:Number)(i)}var f=x.module("Chart");class b extends A.Component{static convertIcon(e){var[t,,,,r]=e.icon,s="".concat(r);return{width:t,path:s,ascent:t,descent:0,transform:"matrix(1, 0, 0, 1, 0, 0)"}}static downsampleButtonTitle(e,t){return e?"Downsampling in progress...":t?"Downsampling disabled, click to enable":"Downsampling enabled, click to disable"}static downsampleButtonAttr(e,t){return e?"animation-spin":t?void 0:"fill-active"}constructor(e){super(e),o(this,"currentSeries",void 0),o(this,"PlotComponent",void 0),o(this,"plot",void 0),o(this,"plotWrapper",void 0),o(this,"plotWrapperMerged",void 0),o(this,"columnFormats",void 0),o(this,"dateTimeFormatterOptions",void 0),o(this,"decimalFormatOptions",void 0),o(this,"integerFormatOptions",void 0),o(this,"webgl",void 0),o(this,"rect",void 0),o(this,"ranges",void 0),o(this,"isSubscribed",void 0),o(this,"isLoadedFired",void 0),o(this,"resizeObserver",void 0),o(this,"getCachedConfig",L((t,r,s,a,l,u)=>{var d=[],c=!!t;c&&d.push({name:"Downsampling failed: ".concat(t),title:"Downsampling failed",click:()=>{this.toggleErrorMessage("".concat(t))},icon:b.convertIcon(N),attr:"fill-warning"});var m=!!u;if(m&&d.push({name:"Error: ".concat(u),title:"Error",click:()=>{this.toggleErrorMessage("".concat(u))},icon:b.convertIcon(N),attr:"fill-warning"}),r||s||a||c){var v=b.downsampleButtonTitle(s,a),D=b.downsampleButtonAttr(s,a),E=s?B:U;d.push({name:v,title:"Downsampling status",icon:b.convertIcon(E),click:this.handleDownsampleClick,attr:D})}var y=l.some(S=>{var{type:C}=S;return C!=null&&!C.includes("3d")}),p=l.some(S=>{var{type:C}=S;return C!=null&&C.includes("3d")}),w=["zoomIn2d","zoomOut2d","autoScale2d","resetScale2d"],O=["orbitRotation","tableRotation","resetCameraDefault3d"];return{displaylogo:!1,responsive:!0,displayModeBar:s||c||m?!0:"hover",modeBarButtons:[d,["toImage"],["zoom2d","pan2d"],[...y?w:[],...p?O:[]]]}})),_(this),this.PlotComponent=I(e.Plotly),this.plot=k.createRef(),this.plotWrapper=k.createRef(),this.plotWrapperMerged=H(this.plotWrapper,e.containerRef),this.columnFormats=[],this.dateTimeFormatterOptions={},this.decimalFormatOptions={},this.integerFormatOptions={},this.isSubscribed=!1,this.isLoadedFired=!1,this.currentSeries=0,this.resizeObserver=new window.ResizeObserver(this.handleResize),this.state={data:null,downsamplingError:null,isDownsampleFinished:!1,isDownsampleInProgress:!1,isDownsamplingDisabled:!1,error:null,shownError:null,layout:{datarevision:0},revision:0,shownBlocker:null}}componentDidMount(){this.updateDimensions(),this.updateModelDimensions(),this.initData(),this.initFormatter();var{isActive:e,model:t}=this.props;e&&this.subscribe(t),this.plotWrapper.current!=null&&this.resizeObserver.observe(this.plotWrapper.current),this.handleThemeChange()}componentDidUpdate(e){var{isActive:t,model:r,settings:s,theme:a}=this.props;this.updateFormatterSettings(s),r!==e.model&&(this.unsubscribe(e.model),this.subscribe(r)),t!==e.isActive&&(t?(this.updateDimensions(),this.subscribe(r)):this.unsubscribe(r)),a!==e.theme&&this.handleThemeChange()}componentWillUnmount(){var{model:e}=this.props;this.unsubscribe(e),this.resizeObserver.disconnect()}getPlotRect(){var e,t;return(e=(t=this.plotWrapper.current)===null||t===void 0?void 0:t.getBoundingClientRect())!==null&&e!==void 0?e:null}initData(){var{model:e}=this.props;this.setState(t=>{var{layout:r}=t;return{data:e.getData(),layout:g(g({},r),e.getLayout())}})}subscribe(e){if(!this.isSubscribed){if(!this.rect||this.rect.width===0||this.rect.height===0){f.debug2("Delaying subscription until model dimensions are set");return}e.subscribe(this.handleModelEvent),this.isSubscribed=!0}}unsubscribe(e){this.isSubscribed&&(e.unsubscribe(this.handleModelEvent),this.isSubscribed=!1)}handleAfterPlot(){this.plot.current!=null}handleDownsampleClick(){this.setState(e=>{var{isDownsamplingDisabled:t}=e;return{downsamplingError:null,isDownsampleInProgress:!1,isDownsampleFinished:!1,isDownsamplingDisabled:!t}},()=>{var{model:e}=this.props,{isDownsamplingDisabled:t}=this.state;e.setDownsamplingDisabled(t)})}handleErrorClose(){this.setState({shownError:null})}handleDownsampleErrorClose(){this.setState({downsamplingError:null})}handleModelEvent(e){var{type:t,detail:r}=e;switch(f.debug2("Received data update",t,r),t){case h.EVENT_UPDATED:{this.currentSeries+=1,this.setState(p=>{var{layout:w,revision:O}=p;return typeof w.datarevision=="number"&&(w.datarevision+=1),{data:r,layout:w,revision:O+1}});var{onUpdate:s}=this.props;s({isLoading:!this.isLoadedFired});break}case h.EVENT_LOADFINISHED:{var{onUpdate:a}=this.props;this.isLoadedFired=!0,a({isLoading:!1});break}case h.EVENT_DISCONNECT:{var{onDisconnect:l}=this.props;l();break}case h.EVENT_RECONNECT:{var{onReconnect:u}=this.props;u();break}case h.EVENT_DOWNSAMPLESTARTED:{this.setState({isDownsampleFinished:!1,isDownsampleInProgress:!0,downsamplingError:null});break}case h.EVENT_DOWNSAMPLEFINISHED:{this.setState({isDownsampleFinished:!0,isDownsampleInProgress:!1,downsamplingError:null});break}case h.EVENT_DOWNSAMPLENEEDED:case h.EVENT_DOWNSAMPLEFAILED:{var d,c=(d=r.message)!==null&&d!==void 0?d:r;this.setState({isDownsampleFinished:!1,isDownsampleInProgress:!1,isDownsamplingDisabled:!1,downsamplingError:c});var{onError:m}=this.props;m(new $(c));break}case h.EVENT_ERROR:{var v="".concat(r);this.setState({error:v});var{onError:D}=this.props;D(new Error(v));break}case h.EVENT_BLOCKER:{var E="".concat(r);this.setState({shownBlocker:E});break}case h.EVENT_BLOCKER_CLEAR:{this.setState({shownBlocker:null});break}case h.EVENT_LAYOUT_UPDATED:{var y=r;this.setState(p=>{var{layout:w,revision:O}=p;return{layout:g(g({},w),y),revision:O+1}});break}default:f.debug("Unknown event type",t,e)}}handlePlotUpdate(e){var{layout:t}=e,r=j.getLayoutRanges(t),s=!F(r,this.ranges);s&&(this.ranges=r,this.updateModelDimensions(!0))}handleRelayout(e){if(f.debug("handleRelayout",e),e.hiddenlabels!=null){var{onSettingsChanged:t}=this.props,r=[...e.hiddenlabels];t({hiddenSeries:r})}this.updateModelDimensions()}handleResize(){this.updateDimensions()}handleRestyle(e){var[t,r]=e;if(f.debug("handleRestyle",t,r),Object.keys(t).includes("visible")){var{data:s}=this.state,{onSettingsChanged:a}=this.props;if(s!=null){var l=s.reduce((u,d)=>{var{name:c,visible:m}=d;return c!=null&&m==="legendonly"?[...u,c]:u},[]);a({hiddenSeries:l})}}}handleThemeChange(){var{theme:e,model:t}=this.props,{dh:r}=t,s=new j(r);this.setState(a=>{var{layout:l}=a;return{layout:g(g({},l),{},{template:s.makeDefaultTemplate(e)})}})}toggleErrorMessage(e){this.setState(t=>{var{shownError:r}=t;return{shownError:r===e?null:e}})}updateModelDimensions(){var e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:!1,t=this.getPlotRect();if(!t){f.warn("Unable to get plotting rect");return}var r=!this.rect||this.rect.width!==t.width||this.rect.height!==t.height;if(r||e){this.rect=t;var{isActive:s,model:a}=this.props;a.setDimensions(t),s&&this.subscribe(a)}}initFormatter(){var{settings:e}=this.props;this.updateFormatterSettings(e)}updateFormatterSettings(e){var t=T.getColumnFormats(e),r=T.getDateTimeFormatterOptions(e),{decimalFormatOptions:s={},integerFormatOptions:a={}}=e;(!F(this.columnFormats,t)||!F(this.dateTimeFormatterOptions,r)||!F(this.decimalFormatOptions,s)||!F(this.integerFormatOptions,a))&&(this.columnFormats=T.getColumnFormats(e),this.dateTimeFormatterOptions=r,this.decimalFormatOptions=s,this.integerFormatOptions=a,this.updateFormatter()),this.webgl!==e.webgl&&(this.webgl=e.webgl,this.updateRenderOptions())}updateFormatter(){var{model:e}=this.props,t=new z(e.dh,this.columnFormats,this.dateTimeFormatterOptions,this.decimalFormatOptions,this.integerFormatOptions);e.setFormatter(t)}updateRenderOptions(){var{model:e}=this.props,t={webgl:this.webgl};e.setRenderOptions(t)}updateDimensions(){var e=this.getPlotRect(),{Plotly:t}=this.props;this.plot.current!=null&&e!=null&&e.width>0&&e.height>0&&t.relayout(this.plot.current.el,{autosize:!0}).catch(r=>{f.debug("Unable to resize, promise rejected",r)})}render(){var{PlotComponent:e}=this,{data:t,downsamplingError:r,isDownsampleFinished:s,isDownsampleInProgress:a,isDownsamplingDisabled:l,error:u,shownError:d,layout:c,revision:m,shownBlocker:v}=this.state,D=this.getCachedConfig(r,s,a,l,t??[],u),{model:E}=this.props,y=t!=null&&v==null,p=null;return v!=null?p=n.jsx(R,{errorMessage:"".concat(v),onConfirm:()=>{E.fireBlockerClear()}}):d!=null?p=n.jsx(R,{errorMessage:"".concat(r),onDiscard:()=>{this.handleDownsampleErrorClose()},onConfirm:()=>{this.handleDownsampleErrorClose(),this.handleDownsampleClick()}}):r!=null&&(p=n.jsx(R,{errorMessage:"".concat(r),onDiscard:()=>{this.handleDownsampleErrorClose()},onConfirm:()=>{this.handleDownsampleErrorClose(),this.handleDownsampleClick()}})),n.jsxs("div",{className:"h-100 w-100 chart-wrapper",ref:this.plotWrapperMerged,children:[y&&n.jsx(e,{ref:this.plot,data:t,layout:c,revision:m,config:D,onAfterPlot:this.handleAfterPlot,onError:f.error,onRelayout:this.handleRelayout,onUpdate:this.handlePlotUpdate,onRestyle:this.handleRestyle,style:{height:"100%",width:"100%"}}),p]})}}o(b,"defaultProps",{isActive:!0,settings:{timeZone:"America/New_York",defaultDateTimeFormat:V.FULL_DATE_FORMAT,showTimeZone:!1,showTSeparator:!0,formatter:[],webgl:!0},Plotly:Y,onDisconnect:()=>{},onReconnect:()=>{},onUpdate:()=>{},onError:()=>{},onSettingsChanged:()=>{}});function ae(i){var e=K();return n.jsx(b,g(g({},i),{},{theme:e}))}export{ae as default};
2
+ //# sourceMappingURL=Chart-348ea4c2.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"Chart-22f6a2d3.js","sources":["../../../chart/dist/ChartErrorOverlay.js","../../../chart/dist/Chart.js"],"sourcesContent":["import { CopyButton, Button } from '@deephaven/components';\nimport \"./ChartErrorOverlay.css\";\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nimport { jsxs as _jsxs } from \"react/jsx-runtime\";\nfunction ChartErrorOverlay(_ref) {\n var {\n errorMessage,\n onDiscard,\n onConfirm,\n onCancel,\n 'data-testid': dataTestId\n } = _ref;\n var messageTestId = dataTestId != null ? \"\".concat(dataTestId, \"-message\") : undefined;\n return /*#__PURE__*/_jsx(\"div\", {\n className: \"chart-panel-overlay chart-error-overlay\",\n children: /*#__PURE__*/_jsxs(\"div\", {\n className: \"chart-panel-overlay-content chart-error-overlay-content\",\n children: [/*#__PURE__*/_jsxs(\"div\", {\n className: \"info-message\",\n \"data-testid\": messageTestId,\n children: [errorMessage, /*#__PURE__*/_jsx(CopyButton, {\n copy: errorMessage,\n style: {\n margin: '0'\n }\n })]\n }), /*#__PURE__*/_jsxs(\"div\", {\n children: [onCancel && /*#__PURE__*/_jsx(Button, {\n onClick: onCancel,\n kind: \"secondary\",\n children: \"Cancel\"\n }), onDiscard && /*#__PURE__*/_jsx(Button, {\n onClick: onDiscard,\n kind: \"secondary\",\n children: \"Dismiss\"\n }), onConfirm && /*#__PURE__*/_jsx(Button, {\n onClick: onConfirm,\n kind: \"primary\",\n children: \"Continue\"\n })]\n })]\n })\n });\n}\nexport default ChartErrorOverlay;\n//# sourceMappingURL=ChartErrorOverlay.js.map","function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\nfunction _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; }\nfunction _toPropertyKey(arg) { var key = _toPrimitive(arg, \"string\"); return typeof key === \"symbol\" ? key : String(key); }\nfunction _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); }\nimport React, { Component } from 'react';\nimport deepEqual from 'fast-deep-equal';\nimport memoize from 'memoize-one';\nimport { vsLoading, dhGraphLineDown, dhWarningFilled } from '@deephaven/icons';\nimport { Formatter, FormatterUtils, DateUtils } from '@deephaven/jsapi-utils';\nimport Log from '@deephaven/log';\nimport { mergeRefs } from '@deephaven/react-hooks';\nimport { bindAllMethods } from '@deephaven/utils';\nimport createPlotlyComponent from \"./plotly/createPlotlyComponent.js\";\nimport Plotly from \"./plotly/Plotly.js\";\nimport ChartModel from \"./ChartModel.js\";\nimport ChartErrorOverlay from \"./ChartErrorOverlay.js\";\nimport ChartUtils from \"./ChartUtils.js\";\nimport \"./Chart.css\";\nimport DownsamplingError from \"./DownsamplingError.js\";\nimport useChartTheme from \"./useChartTheme.js\";\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nimport { jsxs as _jsxs } from \"react/jsx-runtime\";\nvar log = Log.module('Chart');\n\n// All of the ChartProps have default values except for model in the Chart\n// component, hence the Partial here.\nclass Chart extends Component {\n /**\n * Convert a font awesome icon definition to a plotly icon definition\n * @param faIcon The icon to convert\n */\n static convertIcon(faIcon) {\n var [width,,,, path] = faIcon.icon;\n // By default the icons are flipped upside down, so we need to add our own transform\n // https://github.com/plotly/plotly.js/issues/1335\n var stringPath = \"\".concat(path);\n return {\n width,\n path: stringPath,\n ascent: width,\n descent: 0,\n transform: \"matrix(1, 0, 0, 1, 0, 0)\"\n };\n }\n static downsampleButtonTitle(isDownsampleInProgress, isDownsamplingDisabled) {\n if (isDownsampleInProgress) {\n return 'Downsampling in progress...';\n }\n return isDownsamplingDisabled ? 'Downsampling disabled, click to enable' : 'Downsampling enabled, click to disable';\n }\n static downsampleButtonAttr(isDownsampleInProgress, isDownsamplingDisabled) {\n if (isDownsampleInProgress) {\n return 'animation-spin';\n }\n return isDownsamplingDisabled ? undefined : 'fill-active';\n }\n constructor(props) {\n super(props);\n _defineProperty(this, \"currentSeries\", void 0);\n _defineProperty(this, \"PlotComponent\", void 0);\n _defineProperty(this, \"plot\", void 0);\n _defineProperty(this, \"plotWrapper\", void 0);\n _defineProperty(this, \"plotWrapperMerged\", void 0);\n _defineProperty(this, \"columnFormats\", void 0);\n _defineProperty(this, \"dateTimeFormatterOptions\", void 0);\n _defineProperty(this, \"decimalFormatOptions\", void 0);\n _defineProperty(this, \"integerFormatOptions\", void 0);\n _defineProperty(this, \"webgl\", void 0);\n _defineProperty(this, \"rect\", void 0);\n _defineProperty(this, \"ranges\", void 0);\n _defineProperty(this, \"isSubscribed\", void 0);\n _defineProperty(this, \"isLoadedFired\", void 0);\n _defineProperty(this, \"resizeObserver\", void 0);\n _defineProperty(this, \"getCachedConfig\", memoize((downsamplingError, isDownsampleFinished, isDownsampleInProgress, isDownsamplingDisabled, data, error) => {\n var customButtons = [];\n var hasDownsampleError = Boolean(downsamplingError);\n if (hasDownsampleError) {\n customButtons.push({\n name: \"Downsampling failed: \".concat(downsamplingError),\n title: 'Downsampling failed',\n click: () => {\n this.toggleErrorMessage(\"\".concat(downsamplingError));\n },\n icon: Chart.convertIcon(dhWarningFilled),\n attr: 'fill-warning'\n });\n }\n var hasError = Boolean(error);\n if (hasError) {\n customButtons.push({\n name: \"Error: \".concat(error),\n title: \"Error\",\n click: () => {\n this.toggleErrorMessage(\"\".concat(error));\n },\n icon: Chart.convertIcon(dhWarningFilled),\n attr: 'fill-warning'\n });\n }\n if (isDownsampleFinished || isDownsampleInProgress || isDownsamplingDisabled || hasDownsampleError) {\n var name = Chart.downsampleButtonTitle(isDownsampleInProgress, isDownsamplingDisabled);\n var attr = Chart.downsampleButtonAttr(isDownsampleInProgress, isDownsamplingDisabled);\n var icon = isDownsampleInProgress ? vsLoading : dhGraphLineDown;\n customButtons.push({\n name,\n title: 'Downsampling status',\n icon: Chart.convertIcon(icon),\n click: this.handleDownsampleClick,\n attr\n });\n }\n var has2D = data.some(_ref => {\n var {\n type\n } = _ref;\n return type != null && !type.includes('3d');\n });\n var has3D = data.some(_ref2 => {\n var {\n type\n } = _ref2;\n return type != null && type.includes('3d');\n });\n var buttons2D = ['zoomIn2d', 'zoomOut2d', 'autoScale2d', 'resetScale2d'];\n var buttons3D = ['orbitRotation', 'tableRotation', 'resetCameraDefault3d'];\n return {\n displaylogo: false,\n // scales the plot to the container size\n // https://github.com/plotly/react-plotly.js/issues/102\n responsive: true,\n // Display the mode bar if there's an error or downsampling so user can see progress\n // Yes, the value is a boolean or the string 'hover': https://github.com/plotly/plotly.js/blob/master/src/plot_api/plot_config.js#L249\n displayModeBar:\n // eslint-disable-next-line @typescript-eslint/strict-boolean-expressions\n isDownsampleInProgress || hasDownsampleError || hasError ? true : 'hover',\n // Each array gets grouped together in the mode bar\n modeBarButtons: [customButtons, ['toImage'], ['zoom2d', 'pan2d'],\n // These work the same for both 2d and 3d\n [...(has2D ? buttons2D : []), ...(has3D ? buttons3D : [])]]\n };\n }));\n bindAllMethods(this);\n this.PlotComponent = createPlotlyComponent(props.Plotly);\n this.plot = /*#__PURE__*/React.createRef();\n this.plotWrapper = /*#__PURE__*/React.createRef();\n this.plotWrapperMerged = mergeRefs(this.plotWrapper, props.containerRef);\n this.columnFormats = [];\n this.dateTimeFormatterOptions = {};\n this.decimalFormatOptions = {};\n this.integerFormatOptions = {};\n this.isSubscribed = false;\n this.isLoadedFired = false;\n this.currentSeries = 0;\n this.resizeObserver = new window.ResizeObserver(this.handleResize);\n this.state = {\n data: null,\n downsamplingError: null,\n isDownsampleFinished: false,\n isDownsampleInProgress: false,\n isDownsamplingDisabled: false,\n error: null,\n shownError: null,\n layout: {\n datarevision: 0\n },\n revision: 0,\n shownBlocker: null\n };\n }\n componentDidMount() {\n // Need to make sure the model dimensions are up to date before initializing the data\n this.updateDimensions();\n this.updateModelDimensions();\n this.initData();\n this.initFormatter();\n var {\n isActive,\n model\n } = this.props;\n if (isActive) {\n this.subscribe(model);\n }\n if (this.plotWrapper.current != null) {\n this.resizeObserver.observe(this.plotWrapper.current);\n }\n this.handleThemeChange();\n }\n componentDidUpdate(prevProps) {\n var {\n isActive,\n model,\n settings,\n theme\n } = this.props;\n this.updateFormatterSettings(settings);\n if (model !== prevProps.model) {\n this.unsubscribe(prevProps.model);\n this.subscribe(model);\n }\n if (isActive !== prevProps.isActive) {\n if (isActive) {\n this.updateDimensions();\n this.subscribe(model);\n } else {\n this.unsubscribe(model);\n }\n }\n if (theme !== prevProps.theme) {\n this.handleThemeChange();\n }\n }\n componentWillUnmount() {\n var {\n model\n } = this.props;\n this.unsubscribe(model);\n this.resizeObserver.disconnect();\n }\n\n // Listen for resizing of the element and update the canvas appropriately\n\n getPlotRect() {\n var _this$plotWrapper$cur, _this$plotWrapper$cur2;\n return (_this$plotWrapper$cur = (_this$plotWrapper$cur2 = this.plotWrapper.current) === null || _this$plotWrapper$cur2 === void 0 ? void 0 : _this$plotWrapper$cur2.getBoundingClientRect()) !== null && _this$plotWrapper$cur !== void 0 ? _this$plotWrapper$cur : null;\n }\n initData() {\n var {\n model\n } = this.props;\n this.setState(_ref3 => {\n var {\n layout\n } = _ref3;\n return {\n data: model.getData(),\n layout: _objectSpread(_objectSpread({}, layout), model.getLayout())\n };\n });\n }\n subscribe(model) {\n if (this.isSubscribed) {\n return;\n }\n if (!this.rect || this.rect.width === 0 || this.rect.height === 0) {\n log.debug2('Delaying subscription until model dimensions are set');\n return;\n }\n model.subscribe(this.handleModelEvent);\n this.isSubscribed = true;\n }\n unsubscribe(model) {\n if (!this.isSubscribed) {\n return;\n }\n model.unsubscribe(this.handleModelEvent);\n this.isSubscribed = false;\n }\n handleAfterPlot() {\n if (this.plot.current != null) {\n // TODO: Translate whatever Don was doing in plotting.js in the afterplot here so that area graphs show up properly\n }\n }\n handleDownsampleClick() {\n this.setState(_ref4 => {\n var {\n isDownsamplingDisabled\n } = _ref4;\n return {\n downsamplingError: null,\n isDownsampleInProgress: false,\n isDownsampleFinished: false,\n isDownsamplingDisabled: !isDownsamplingDisabled\n };\n }, () => {\n var {\n model\n } = this.props;\n var {\n isDownsamplingDisabled\n } = this.state;\n model.setDownsamplingDisabled(isDownsamplingDisabled);\n });\n }\n handleErrorClose() {\n this.setState({\n shownError: null\n });\n }\n handleDownsampleErrorClose() {\n this.setState({\n downsamplingError: null\n });\n }\n handleModelEvent(event) {\n var {\n type,\n detail\n } = event;\n log.debug2('Received data update', type, detail);\n switch (type) {\n case ChartModel.EVENT_UPDATED:\n {\n this.currentSeries += 1;\n this.setState(state => {\n var {\n layout,\n revision\n } = state;\n if (typeof layout.datarevision === 'number') {\n layout.datarevision += 1;\n }\n return {\n data: detail,\n layout,\n revision: revision + 1\n };\n });\n var {\n onUpdate\n } = this.props;\n onUpdate({\n isLoading: !this.isLoadedFired\n });\n break;\n }\n case ChartModel.EVENT_LOADFINISHED:\n {\n var {\n onUpdate: _onUpdate\n } = this.props;\n this.isLoadedFired = true;\n _onUpdate({\n isLoading: false\n });\n break;\n }\n case ChartModel.EVENT_DISCONNECT:\n {\n var {\n onDisconnect\n } = this.props;\n onDisconnect();\n break;\n }\n case ChartModel.EVENT_RECONNECT:\n {\n var {\n onReconnect\n } = this.props;\n onReconnect();\n break;\n }\n case ChartModel.EVENT_DOWNSAMPLESTARTED:\n {\n this.setState({\n isDownsampleFinished: false,\n isDownsampleInProgress: true,\n downsamplingError: null\n });\n break;\n }\n case ChartModel.EVENT_DOWNSAMPLEFINISHED:\n {\n this.setState({\n isDownsampleFinished: true,\n isDownsampleInProgress: false,\n downsamplingError: null\n });\n break;\n }\n case ChartModel.EVENT_DOWNSAMPLENEEDED:\n case ChartModel.EVENT_DOWNSAMPLEFAILED:\n {\n var _detail$message;\n var downsamplingError = (_detail$message = detail.message) !== null && _detail$message !== void 0 ? _detail$message : detail;\n this.setState({\n isDownsampleFinished: false,\n isDownsampleInProgress: false,\n isDownsamplingDisabled: false,\n downsamplingError\n });\n var {\n onError\n } = this.props;\n onError(new DownsamplingError(downsamplingError));\n break;\n }\n case ChartModel.EVENT_ERROR:\n {\n var _error = \"\".concat(detail);\n this.setState({\n error: _error\n });\n var {\n onError: _onError\n } = this.props;\n _onError(new Error(_error));\n break;\n }\n case ChartModel.EVENT_BLOCKER:\n {\n var blocker = \"\".concat(detail);\n this.setState({\n shownBlocker: blocker\n });\n break;\n }\n case ChartModel.EVENT_BLOCKER_CLEAR:\n {\n this.setState({\n shownBlocker: null\n });\n break;\n }\n case ChartModel.EVENT_LAYOUT_UPDATED:\n {\n var newLayout = detail;\n this.setState(_ref5 => {\n var {\n layout,\n revision\n } = _ref5;\n return {\n layout: _objectSpread(_objectSpread({}, layout), newLayout),\n revision: revision + 1\n };\n });\n break;\n }\n default:\n log.debug('Unknown event type', type, event);\n }\n }\n handlePlotUpdate(figure) {\n // User could have modified zoom/pan here, update the model dimensions\n // We don't need to update the datarevision, as we don't have any data changes\n // until an update comes back from the server anyway\n var {\n layout\n } = figure;\n var ranges = ChartUtils.getLayoutRanges(layout);\n var isRangesChanged = !deepEqual(ranges, this.ranges);\n if (isRangesChanged) {\n this.ranges = ranges;\n this.updateModelDimensions(true);\n }\n }\n handleRelayout(changes) {\n log.debug('handleRelayout', changes);\n if (changes.hiddenlabels != null) {\n var {\n onSettingsChanged\n } = this.props;\n // Pie charts store series visibility in layout.hiddenlabels and trigger relayout on changes\n // Series visibility for other types of charts is handled in handleRestyle\n var hiddenSeries = [...changes.hiddenlabels];\n onSettingsChanged({\n hiddenSeries\n });\n }\n this.updateModelDimensions();\n }\n handleResize() {\n this.updateDimensions();\n }\n handleRestyle(_ref6) {\n var [changes, seriesIndexes] = _ref6;\n log.debug('handleRestyle', changes, seriesIndexes);\n if (Object.keys(changes).includes('visible')) {\n var {\n data\n } = this.state;\n var {\n onSettingsChanged\n } = this.props;\n if (data != null) {\n var hiddenSeries = data.reduce((acc, _ref7) => {\n var {\n name,\n visible\n } = _ref7;\n return name != null && visible === 'legendonly' ? [...acc, name] : acc;\n }, []);\n onSettingsChanged({\n hiddenSeries\n });\n }\n }\n }\n handleThemeChange() {\n var {\n theme,\n model\n } = this.props;\n var {\n dh\n } = model;\n var chartUtils = new ChartUtils(dh);\n this.setState(_ref8 => {\n var {\n layout\n } = _ref8;\n return {\n layout: _objectSpread(_objectSpread({}, layout), {}, {\n template: chartUtils.makeDefaultTemplate(theme)\n })\n };\n });\n }\n\n /**\n * Toggle the error message. If it is already being displayed, then hide it.\n */\n toggleErrorMessage(error) {\n this.setState(_ref9 => {\n var {\n shownError\n } = _ref9;\n return {\n shownError: shownError === error ? null : error\n };\n });\n }\n\n /**\n * Update the models dimensions and ranges.\n * Note that this will update it all whether the plot size changes OR the range\n * the user is looking at has changed (eg. panning/zooming).\n * Could update each independently, but doing them at the same time keeps the\n * ChartModel API a bit cleaner.\n * @param force Force a change even if the chart dimensions haven't changed (eg. after pan/zoom)\n */\n updateModelDimensions() {\n var force = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;\n var rect = this.getPlotRect();\n if (!rect) {\n log.warn('Unable to get plotting rect');\n return;\n }\n var isRectChanged = !this.rect || this.rect.width !== rect.width || this.rect.height !== rect.height;\n if (isRectChanged || force) {\n this.rect = rect;\n var {\n isActive,\n model\n } = this.props;\n model.setDimensions(rect);\n // We may need to resubscribe if dimensions were too small before\n if (isActive) {\n this.subscribe(model);\n }\n }\n }\n initFormatter() {\n var {\n settings\n } = this.props;\n this.updateFormatterSettings(settings);\n }\n updateFormatterSettings(settings) {\n var columnFormats = FormatterUtils.getColumnFormats(settings);\n var dateTimeFormatterOptions = FormatterUtils.getDateTimeFormatterOptions(settings);\n var {\n decimalFormatOptions = {},\n integerFormatOptions = {}\n } = settings;\n if (!deepEqual(this.columnFormats, columnFormats) || !deepEqual(this.dateTimeFormatterOptions, dateTimeFormatterOptions) || !deepEqual(this.decimalFormatOptions, decimalFormatOptions) || !deepEqual(this.integerFormatOptions, integerFormatOptions)) {\n this.columnFormats = FormatterUtils.getColumnFormats(settings);\n this.dateTimeFormatterOptions = dateTimeFormatterOptions;\n this.decimalFormatOptions = decimalFormatOptions;\n this.integerFormatOptions = integerFormatOptions;\n this.updateFormatter();\n }\n if (this.webgl !== settings.webgl) {\n this.webgl = settings.webgl;\n this.updateRenderOptions();\n }\n }\n updateFormatter() {\n var {\n model\n } = this.props;\n var formatter = new Formatter(model.dh, this.columnFormats, this.dateTimeFormatterOptions, this.decimalFormatOptions, this.integerFormatOptions);\n model.setFormatter(formatter);\n }\n updateRenderOptions() {\n var {\n model\n } = this.props;\n var renderOptions = {\n webgl: this.webgl\n };\n model.setRenderOptions(renderOptions);\n }\n updateDimensions() {\n var rect = this.getPlotRect();\n var {\n Plotly: PlotlyProp\n } = this.props;\n if (this.plot.current != null && rect != null && rect.width > 0 && rect.height > 0) {\n // Call relayout to resize avoiding the debouncing plotly does\n // https://github.com/plotly/plotly.js/issues/2769#issuecomment-402099552\n PlotlyProp.relayout(this.plot.current.el, {\n autosize: true\n }).catch(e => {\n log.debug('Unable to resize, promise rejected', e);\n });\n }\n }\n render() {\n var {\n PlotComponent\n } = this;\n var {\n data,\n downsamplingError,\n isDownsampleFinished,\n isDownsampleInProgress,\n isDownsamplingDisabled,\n error,\n shownError,\n layout,\n revision,\n shownBlocker\n } = this.state;\n var config = this.getCachedConfig(downsamplingError, isDownsampleFinished, isDownsampleInProgress, isDownsamplingDisabled, data !== null && data !== void 0 ? data : [], error);\n var {\n model\n } = this.props;\n var isPlotShown = data != null && shownBlocker == null;\n var errorOverlay = null;\n if (shownBlocker != null) {\n errorOverlay = /*#__PURE__*/_jsx(ChartErrorOverlay, {\n errorMessage: \"\".concat(shownBlocker),\n onConfirm: () => {\n model.fireBlockerClear();\n }\n });\n } else if (shownError != null) {\n errorOverlay = /*#__PURE__*/_jsx(ChartErrorOverlay, {\n errorMessage: \"\".concat(downsamplingError),\n onDiscard: () => {\n this.handleDownsampleErrorClose();\n },\n onConfirm: () => {\n this.handleDownsampleErrorClose();\n this.handleDownsampleClick();\n }\n });\n } else if (downsamplingError != null) {\n errorOverlay = /*#__PURE__*/_jsx(ChartErrorOverlay, {\n errorMessage: \"\".concat(downsamplingError),\n onDiscard: () => {\n this.handleDownsampleErrorClose();\n },\n onConfirm: () => {\n this.handleDownsampleErrorClose();\n this.handleDownsampleClick();\n }\n });\n }\n return /*#__PURE__*/_jsxs(\"div\", {\n className: \"h-100 w-100 chart-wrapper\",\n ref: this.plotWrapperMerged,\n children: [isPlotShown && /*#__PURE__*/_jsx(PlotComponent\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n , {\n ref: this.plot,\n data: data,\n layout: layout,\n revision: revision,\n config: config,\n onAfterPlot: this.handleAfterPlot,\n onError: log.error,\n onRelayout: this.handleRelayout,\n onUpdate: this.handlePlotUpdate,\n onRestyle: this.handleRestyle,\n style: {\n height: '100%',\n width: '100%'\n }\n }), errorOverlay]\n });\n }\n}\n_defineProperty(Chart, \"defaultProps\", {\n isActive: true,\n settings: {\n timeZone: 'America/New_York',\n defaultDateTimeFormat: DateUtils.FULL_DATE_FORMAT,\n showTimeZone: false,\n showTSeparator: true,\n formatter: [],\n webgl: true\n },\n Plotly,\n onDisconnect: () => undefined,\n onReconnect: () => undefined,\n onUpdate: () => undefined,\n onError: () => undefined,\n onSettingsChanged: () => undefined\n});\nexport default function ChartContainer(props) {\n var chartTheme = useChartTheme();\n // eslint-disable-next-line react/jsx-props-no-spreading\n return /*#__PURE__*/_jsx(Chart, _objectSpread(_objectSpread({}, props), {}, {\n theme: chartTheme\n }));\n}\n//# sourceMappingURL=Chart.js.map"],"names":["ChartErrorOverlay","_ref","errorMessage","onDiscard","onConfirm","onCancel","dataTestId","messageTestId","_jsx","_jsxs","CopyButton","Button","ownKeys","object","enumerableOnly","keys","symbols","sym","_objectSpread","target","i","source","key","_defineProperty","obj","value","_toPropertyKey","arg","_toPrimitive","input","hint","prim","res","log","Log","Chart","Component","faIcon","width","path","stringPath","isDownsampleInProgress","isDownsamplingDisabled","props","memoize","downsamplingError","isDownsampleFinished","data","error","customButtons","hasDownsampleError","dhWarningFilled","hasError","name","attr","icon","vsLoading","dhGraphLineDown","has2D","type","has3D","_ref2","buttons2D","buttons3D","bindAllMethods","createPlotlyComponent","React","mergeRefs","isActive","model","prevProps","settings","theme","_this$plotWrapper$cur","_this$plotWrapper$cur2","_ref3","layout","_ref4","event","detail","ChartModel","state","revision","onUpdate","_onUpdate","onDisconnect","onReconnect","_detail$message","onError","DownsamplingError","_error","_onError","blocker","newLayout","_ref5","figure","ranges","ChartUtils","isRangesChanged","deepEqual","changes","onSettingsChanged","hiddenSeries","_ref6","seriesIndexes","acc","_ref7","visible","dh","chartUtils","_ref8","_ref9","shownError","force","rect","isRectChanged","columnFormats","FormatterUtils","dateTimeFormatterOptions","decimalFormatOptions","integerFormatOptions","formatter","Formatter","renderOptions","PlotlyProp","e","PlotComponent","shownBlocker","config","isPlotShown","errorOverlay","DateUtils","Plotly","ChartContainer","chartTheme","useChartTheme"],"mappings":"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"}
1
+ {"version":3,"file":"Chart-348ea4c2.js","sources":["../../../chart/dist/ChartErrorOverlay.js","../../../chart/dist/Chart.js"],"sourcesContent":["import { CopyButton, Button } from '@deephaven/components';\nimport \"./ChartErrorOverlay.css\";\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nimport { jsxs as _jsxs } from \"react/jsx-runtime\";\nfunction ChartErrorOverlay(_ref) {\n var {\n errorMessage,\n onDiscard,\n onConfirm,\n onCancel,\n 'data-testid': dataTestId\n } = _ref;\n var messageTestId = dataTestId != null ? \"\".concat(dataTestId, \"-message\") : undefined;\n return /*#__PURE__*/_jsx(\"div\", {\n className: \"chart-panel-overlay chart-error-overlay\",\n children: /*#__PURE__*/_jsxs(\"div\", {\n className: \"chart-panel-overlay-content chart-error-overlay-content\",\n children: [/*#__PURE__*/_jsxs(\"div\", {\n className: \"info-message\",\n \"data-testid\": messageTestId,\n children: [errorMessage, /*#__PURE__*/_jsx(CopyButton, {\n copy: errorMessage,\n style: {\n margin: '0'\n }\n })]\n }), /*#__PURE__*/_jsxs(\"div\", {\n children: [onCancel && /*#__PURE__*/_jsx(Button, {\n onClick: onCancel,\n kind: \"secondary\",\n children: \"Cancel\"\n }), onDiscard && /*#__PURE__*/_jsx(Button, {\n onClick: onDiscard,\n kind: \"secondary\",\n children: \"Dismiss\"\n }), onConfirm && /*#__PURE__*/_jsx(Button, {\n onClick: onConfirm,\n kind: \"primary\",\n children: \"Continue\"\n })]\n })]\n })\n });\n}\nexport default ChartErrorOverlay;\n//# sourceMappingURL=ChartErrorOverlay.js.map","function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\nfunction _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; }\nfunction _toPropertyKey(arg) { var key = _toPrimitive(arg, \"string\"); return typeof key === \"symbol\" ? key : String(key); }\nfunction _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); }\nimport React, { Component } from 'react';\nimport deepEqual from 'fast-deep-equal';\nimport memoize from 'memoize-one';\nimport { vsLoading, dhGraphLineDown, dhWarningFilled } from '@deephaven/icons';\nimport { Formatter, FormatterUtils, DateUtils } from '@deephaven/jsapi-utils';\nimport Log from '@deephaven/log';\nimport { mergeRefs } from '@deephaven/react-hooks';\nimport { bindAllMethods } from '@deephaven/utils';\nimport createPlotlyComponent from \"./plotly/createPlotlyComponent.js\";\nimport Plotly from \"./plotly/Plotly.js\";\nimport ChartModel from \"./ChartModel.js\";\nimport ChartErrorOverlay from \"./ChartErrorOverlay.js\";\nimport ChartUtils from \"./ChartUtils.js\";\nimport \"./Chart.css\";\nimport DownsamplingError from \"./DownsamplingError.js\";\nimport useChartTheme from \"./useChartTheme.js\";\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nimport { jsxs as _jsxs } from \"react/jsx-runtime\";\nvar log = Log.module('Chart');\n\n// All of the ChartProps have default values except for model in the Chart\n// component, hence the Partial here.\nclass Chart extends Component {\n /**\n * Convert a font awesome icon definition to a plotly icon definition\n * @param faIcon The icon to convert\n */\n static convertIcon(faIcon) {\n var [width,,,, path] = faIcon.icon;\n // By default the icons are flipped upside down, so we need to add our own transform\n // https://github.com/plotly/plotly.js/issues/1335\n var stringPath = \"\".concat(path);\n return {\n width,\n path: stringPath,\n ascent: width,\n descent: 0,\n transform: \"matrix(1, 0, 0, 1, 0, 0)\"\n };\n }\n static downsampleButtonTitle(isDownsampleInProgress, isDownsamplingDisabled) {\n if (isDownsampleInProgress) {\n return 'Downsampling in progress...';\n }\n return isDownsamplingDisabled ? 'Downsampling disabled, click to enable' : 'Downsampling enabled, click to disable';\n }\n static downsampleButtonAttr(isDownsampleInProgress, isDownsamplingDisabled) {\n if (isDownsampleInProgress) {\n return 'animation-spin';\n }\n return isDownsamplingDisabled ? undefined : 'fill-active';\n }\n constructor(props) {\n super(props);\n _defineProperty(this, \"currentSeries\", void 0);\n _defineProperty(this, \"PlotComponent\", void 0);\n _defineProperty(this, \"plot\", void 0);\n _defineProperty(this, \"plotWrapper\", void 0);\n _defineProperty(this, \"plotWrapperMerged\", void 0);\n _defineProperty(this, \"columnFormats\", void 0);\n _defineProperty(this, \"dateTimeFormatterOptions\", void 0);\n _defineProperty(this, \"decimalFormatOptions\", void 0);\n _defineProperty(this, \"integerFormatOptions\", void 0);\n _defineProperty(this, \"webgl\", void 0);\n _defineProperty(this, \"rect\", void 0);\n _defineProperty(this, \"ranges\", void 0);\n _defineProperty(this, \"isSubscribed\", void 0);\n _defineProperty(this, \"isLoadedFired\", void 0);\n _defineProperty(this, \"resizeObserver\", void 0);\n _defineProperty(this, \"getCachedConfig\", memoize((downsamplingError, isDownsampleFinished, isDownsampleInProgress, isDownsamplingDisabled, data, error) => {\n var customButtons = [];\n var hasDownsampleError = Boolean(downsamplingError);\n if (hasDownsampleError) {\n customButtons.push({\n name: \"Downsampling failed: \".concat(downsamplingError),\n title: 'Downsampling failed',\n click: () => {\n this.toggleErrorMessage(\"\".concat(downsamplingError));\n },\n icon: Chart.convertIcon(dhWarningFilled),\n attr: 'fill-warning'\n });\n }\n var hasError = Boolean(error);\n if (hasError) {\n customButtons.push({\n name: \"Error: \".concat(error),\n title: \"Error\",\n click: () => {\n this.toggleErrorMessage(\"\".concat(error));\n },\n icon: Chart.convertIcon(dhWarningFilled),\n attr: 'fill-warning'\n });\n }\n if (isDownsampleFinished || isDownsampleInProgress || isDownsamplingDisabled || hasDownsampleError) {\n var name = Chart.downsampleButtonTitle(isDownsampleInProgress, isDownsamplingDisabled);\n var attr = Chart.downsampleButtonAttr(isDownsampleInProgress, isDownsamplingDisabled);\n var icon = isDownsampleInProgress ? vsLoading : dhGraphLineDown;\n customButtons.push({\n name,\n title: 'Downsampling status',\n icon: Chart.convertIcon(icon),\n click: this.handleDownsampleClick,\n attr\n });\n }\n var has2D = data.some(_ref => {\n var {\n type\n } = _ref;\n return type != null && !type.includes('3d');\n });\n var has3D = data.some(_ref2 => {\n var {\n type\n } = _ref2;\n return type != null && type.includes('3d');\n });\n var buttons2D = ['zoomIn2d', 'zoomOut2d', 'autoScale2d', 'resetScale2d'];\n var buttons3D = ['orbitRotation', 'tableRotation', 'resetCameraDefault3d'];\n return {\n displaylogo: false,\n // scales the plot to the container size\n // https://github.com/plotly/react-plotly.js/issues/102\n responsive: true,\n // Display the mode bar if there's an error or downsampling so user can see progress\n // Yes, the value is a boolean or the string 'hover': https://github.com/plotly/plotly.js/blob/master/src/plot_api/plot_config.js#L249\n displayModeBar:\n // eslint-disable-next-line @typescript-eslint/strict-boolean-expressions\n isDownsampleInProgress || hasDownsampleError || hasError ? true : 'hover',\n // Each array gets grouped together in the mode bar\n modeBarButtons: [customButtons, ['toImage'], ['zoom2d', 'pan2d'],\n // These work the same for both 2d and 3d\n [...(has2D ? buttons2D : []), ...(has3D ? buttons3D : [])]]\n };\n }));\n bindAllMethods(this);\n this.PlotComponent = createPlotlyComponent(props.Plotly);\n this.plot = /*#__PURE__*/React.createRef();\n this.plotWrapper = /*#__PURE__*/React.createRef();\n this.plotWrapperMerged = mergeRefs(this.plotWrapper, props.containerRef);\n this.columnFormats = [];\n this.dateTimeFormatterOptions = {};\n this.decimalFormatOptions = {};\n this.integerFormatOptions = {};\n this.isSubscribed = false;\n this.isLoadedFired = false;\n this.currentSeries = 0;\n this.resizeObserver = new window.ResizeObserver(this.handleResize);\n this.state = {\n data: null,\n downsamplingError: null,\n isDownsampleFinished: false,\n isDownsampleInProgress: false,\n isDownsamplingDisabled: false,\n error: null,\n shownError: null,\n layout: {\n datarevision: 0\n },\n revision: 0,\n shownBlocker: null\n };\n }\n componentDidMount() {\n // Need to make sure the model dimensions are up to date before initializing the data\n this.updateDimensions();\n this.updateModelDimensions();\n this.initData();\n this.initFormatter();\n var {\n isActive,\n model\n } = this.props;\n if (isActive) {\n this.subscribe(model);\n }\n if (this.plotWrapper.current != null) {\n this.resizeObserver.observe(this.plotWrapper.current);\n }\n this.handleThemeChange();\n }\n componentDidUpdate(prevProps) {\n var {\n isActive,\n model,\n settings,\n theme\n } = this.props;\n this.updateFormatterSettings(settings);\n if (model !== prevProps.model) {\n this.unsubscribe(prevProps.model);\n this.subscribe(model);\n }\n if (isActive !== prevProps.isActive) {\n if (isActive) {\n this.updateDimensions();\n this.subscribe(model);\n } else {\n this.unsubscribe(model);\n }\n }\n if (theme !== prevProps.theme) {\n this.handleThemeChange();\n }\n }\n componentWillUnmount() {\n var {\n model\n } = this.props;\n this.unsubscribe(model);\n this.resizeObserver.disconnect();\n }\n\n // Listen for resizing of the element and update the canvas appropriately\n\n getPlotRect() {\n var _this$plotWrapper$cur, _this$plotWrapper$cur2;\n return (_this$plotWrapper$cur = (_this$plotWrapper$cur2 = this.plotWrapper.current) === null || _this$plotWrapper$cur2 === void 0 ? void 0 : _this$plotWrapper$cur2.getBoundingClientRect()) !== null && _this$plotWrapper$cur !== void 0 ? _this$plotWrapper$cur : null;\n }\n initData() {\n var {\n model\n } = this.props;\n this.setState(_ref3 => {\n var {\n layout\n } = _ref3;\n return {\n data: model.getData(),\n layout: _objectSpread(_objectSpread({}, layout), model.getLayout())\n };\n });\n }\n subscribe(model) {\n if (this.isSubscribed) {\n return;\n }\n if (!this.rect || this.rect.width === 0 || this.rect.height === 0) {\n log.debug2('Delaying subscription until model dimensions are set');\n return;\n }\n model.subscribe(this.handleModelEvent);\n this.isSubscribed = true;\n }\n unsubscribe(model) {\n if (!this.isSubscribed) {\n return;\n }\n model.unsubscribe(this.handleModelEvent);\n this.isSubscribed = false;\n }\n handleAfterPlot() {\n if (this.plot.current != null) {\n // TODO: Translate whatever Don was doing in plotting.js in the afterplot here so that area graphs show up properly\n }\n }\n handleDownsampleClick() {\n this.setState(_ref4 => {\n var {\n isDownsamplingDisabled\n } = _ref4;\n return {\n downsamplingError: null,\n isDownsampleInProgress: false,\n isDownsampleFinished: false,\n isDownsamplingDisabled: !isDownsamplingDisabled\n };\n }, () => {\n var {\n model\n } = this.props;\n var {\n isDownsamplingDisabled\n } = this.state;\n model.setDownsamplingDisabled(isDownsamplingDisabled);\n });\n }\n handleErrorClose() {\n this.setState({\n shownError: null\n });\n }\n handleDownsampleErrorClose() {\n this.setState({\n downsamplingError: null\n });\n }\n handleModelEvent(event) {\n var {\n type,\n detail\n } = event;\n log.debug2('Received data update', type, detail);\n switch (type) {\n case ChartModel.EVENT_UPDATED:\n {\n this.currentSeries += 1;\n this.setState(state => {\n var {\n layout,\n revision\n } = state;\n if (typeof layout.datarevision === 'number') {\n layout.datarevision += 1;\n }\n return {\n data: detail,\n layout,\n revision: revision + 1\n };\n });\n var {\n onUpdate\n } = this.props;\n onUpdate({\n isLoading: !this.isLoadedFired\n });\n break;\n }\n case ChartModel.EVENT_LOADFINISHED:\n {\n var {\n onUpdate: _onUpdate\n } = this.props;\n this.isLoadedFired = true;\n _onUpdate({\n isLoading: false\n });\n break;\n }\n case ChartModel.EVENT_DISCONNECT:\n {\n var {\n onDisconnect\n } = this.props;\n onDisconnect();\n break;\n }\n case ChartModel.EVENT_RECONNECT:\n {\n var {\n onReconnect\n } = this.props;\n onReconnect();\n break;\n }\n case ChartModel.EVENT_DOWNSAMPLESTARTED:\n {\n this.setState({\n isDownsampleFinished: false,\n isDownsampleInProgress: true,\n downsamplingError: null\n });\n break;\n }\n case ChartModel.EVENT_DOWNSAMPLEFINISHED:\n {\n this.setState({\n isDownsampleFinished: true,\n isDownsampleInProgress: false,\n downsamplingError: null\n });\n break;\n }\n case ChartModel.EVENT_DOWNSAMPLENEEDED:\n case ChartModel.EVENT_DOWNSAMPLEFAILED:\n {\n var _detail$message;\n var downsamplingError = (_detail$message = detail.message) !== null && _detail$message !== void 0 ? _detail$message : detail;\n this.setState({\n isDownsampleFinished: false,\n isDownsampleInProgress: false,\n isDownsamplingDisabled: false,\n downsamplingError\n });\n var {\n onError\n } = this.props;\n onError(new DownsamplingError(downsamplingError));\n break;\n }\n case ChartModel.EVENT_ERROR:\n {\n var _error = \"\".concat(detail);\n this.setState({\n error: _error\n });\n var {\n onError: _onError\n } = this.props;\n _onError(new Error(_error));\n break;\n }\n case ChartModel.EVENT_BLOCKER:\n {\n var blocker = \"\".concat(detail);\n this.setState({\n shownBlocker: blocker\n });\n break;\n }\n case ChartModel.EVENT_BLOCKER_CLEAR:\n {\n this.setState({\n shownBlocker: null\n });\n break;\n }\n case ChartModel.EVENT_LAYOUT_UPDATED:\n {\n var newLayout = detail;\n this.setState(_ref5 => {\n var {\n layout,\n revision\n } = _ref5;\n return {\n layout: _objectSpread(_objectSpread({}, layout), newLayout),\n revision: revision + 1\n };\n });\n break;\n }\n default:\n log.debug('Unknown event type', type, event);\n }\n }\n handlePlotUpdate(figure) {\n // User could have modified zoom/pan here, update the model dimensions\n // We don't need to update the datarevision, as we don't have any data changes\n // until an update comes back from the server anyway\n var {\n layout\n } = figure;\n var ranges = ChartUtils.getLayoutRanges(layout);\n var isRangesChanged = !deepEqual(ranges, this.ranges);\n if (isRangesChanged) {\n this.ranges = ranges;\n this.updateModelDimensions(true);\n }\n }\n handleRelayout(changes) {\n log.debug('handleRelayout', changes);\n if (changes.hiddenlabels != null) {\n var {\n onSettingsChanged\n } = this.props;\n // Pie charts store series visibility in layout.hiddenlabels and trigger relayout on changes\n // Series visibility for other types of charts is handled in handleRestyle\n var hiddenSeries = [...changes.hiddenlabels];\n onSettingsChanged({\n hiddenSeries\n });\n }\n this.updateModelDimensions();\n }\n handleResize() {\n this.updateDimensions();\n }\n handleRestyle(_ref6) {\n var [changes, seriesIndexes] = _ref6;\n log.debug('handleRestyle', changes, seriesIndexes);\n if (Object.keys(changes).includes('visible')) {\n var {\n data\n } = this.state;\n var {\n onSettingsChanged\n } = this.props;\n if (data != null) {\n var hiddenSeries = data.reduce((acc, _ref7) => {\n var {\n name,\n visible\n } = _ref7;\n return name != null && visible === 'legendonly' ? [...acc, name] : acc;\n }, []);\n onSettingsChanged({\n hiddenSeries\n });\n }\n }\n }\n handleThemeChange() {\n var {\n theme,\n model\n } = this.props;\n var {\n dh\n } = model;\n var chartUtils = new ChartUtils(dh);\n this.setState(_ref8 => {\n var {\n layout\n } = _ref8;\n return {\n layout: _objectSpread(_objectSpread({}, layout), {}, {\n template: chartUtils.makeDefaultTemplate(theme)\n })\n };\n });\n }\n\n /**\n * Toggle the error message. If it is already being displayed, then hide it.\n */\n toggleErrorMessage(error) {\n this.setState(_ref9 => {\n var {\n shownError\n } = _ref9;\n return {\n shownError: shownError === error ? null : error\n };\n });\n }\n\n /**\n * Update the models dimensions and ranges.\n * Note that this will update it all whether the plot size changes OR the range\n * the user is looking at has changed (eg. panning/zooming).\n * Could update each independently, but doing them at the same time keeps the\n * ChartModel API a bit cleaner.\n * @param force Force a change even if the chart dimensions haven't changed (eg. after pan/zoom)\n */\n updateModelDimensions() {\n var force = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;\n var rect = this.getPlotRect();\n if (!rect) {\n log.warn('Unable to get plotting rect');\n return;\n }\n var isRectChanged = !this.rect || this.rect.width !== rect.width || this.rect.height !== rect.height;\n if (isRectChanged || force) {\n this.rect = rect;\n var {\n isActive,\n model\n } = this.props;\n model.setDimensions(rect);\n // We may need to resubscribe if dimensions were too small before\n if (isActive) {\n this.subscribe(model);\n }\n }\n }\n initFormatter() {\n var {\n settings\n } = this.props;\n this.updateFormatterSettings(settings);\n }\n updateFormatterSettings(settings) {\n var columnFormats = FormatterUtils.getColumnFormats(settings);\n var dateTimeFormatterOptions = FormatterUtils.getDateTimeFormatterOptions(settings);\n var {\n decimalFormatOptions = {},\n integerFormatOptions = {}\n } = settings;\n if (!deepEqual(this.columnFormats, columnFormats) || !deepEqual(this.dateTimeFormatterOptions, dateTimeFormatterOptions) || !deepEqual(this.decimalFormatOptions, decimalFormatOptions) || !deepEqual(this.integerFormatOptions, integerFormatOptions)) {\n this.columnFormats = FormatterUtils.getColumnFormats(settings);\n this.dateTimeFormatterOptions = dateTimeFormatterOptions;\n this.decimalFormatOptions = decimalFormatOptions;\n this.integerFormatOptions = integerFormatOptions;\n this.updateFormatter();\n }\n if (this.webgl !== settings.webgl) {\n this.webgl = settings.webgl;\n this.updateRenderOptions();\n }\n }\n updateFormatter() {\n var {\n model\n } = this.props;\n var formatter = new Formatter(model.dh, this.columnFormats, this.dateTimeFormatterOptions, this.decimalFormatOptions, this.integerFormatOptions);\n model.setFormatter(formatter);\n }\n updateRenderOptions() {\n var {\n model\n } = this.props;\n var renderOptions = {\n webgl: this.webgl\n };\n model.setRenderOptions(renderOptions);\n }\n updateDimensions() {\n var rect = this.getPlotRect();\n var {\n Plotly: PlotlyProp\n } = this.props;\n if (this.plot.current != null && rect != null && rect.width > 0 && rect.height > 0) {\n // Call relayout to resize avoiding the debouncing plotly does\n // https://github.com/plotly/plotly.js/issues/2769#issuecomment-402099552\n PlotlyProp.relayout(this.plot.current.el, {\n autosize: true\n }).catch(e => {\n log.debug('Unable to resize, promise rejected', e);\n });\n }\n }\n render() {\n var {\n PlotComponent\n } = this;\n var {\n data,\n downsamplingError,\n isDownsampleFinished,\n isDownsampleInProgress,\n isDownsamplingDisabled,\n error,\n shownError,\n layout,\n revision,\n shownBlocker\n } = this.state;\n var config = this.getCachedConfig(downsamplingError, isDownsampleFinished, isDownsampleInProgress, isDownsamplingDisabled, data !== null && data !== void 0 ? data : [], error);\n var {\n model\n } = this.props;\n var isPlotShown = data != null && shownBlocker == null;\n var errorOverlay = null;\n if (shownBlocker != null) {\n errorOverlay = /*#__PURE__*/_jsx(ChartErrorOverlay, {\n errorMessage: \"\".concat(shownBlocker),\n onConfirm: () => {\n model.fireBlockerClear();\n }\n });\n } else if (shownError != null) {\n errorOverlay = /*#__PURE__*/_jsx(ChartErrorOverlay, {\n errorMessage: \"\".concat(downsamplingError),\n onDiscard: () => {\n this.handleDownsampleErrorClose();\n },\n onConfirm: () => {\n this.handleDownsampleErrorClose();\n this.handleDownsampleClick();\n }\n });\n } else if (downsamplingError != null) {\n errorOverlay = /*#__PURE__*/_jsx(ChartErrorOverlay, {\n errorMessage: \"\".concat(downsamplingError),\n onDiscard: () => {\n this.handleDownsampleErrorClose();\n },\n onConfirm: () => {\n this.handleDownsampleErrorClose();\n this.handleDownsampleClick();\n }\n });\n }\n return /*#__PURE__*/_jsxs(\"div\", {\n className: \"h-100 w-100 chart-wrapper\",\n ref: this.plotWrapperMerged,\n children: [isPlotShown && /*#__PURE__*/_jsx(PlotComponent\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n , {\n ref: this.plot,\n data: data,\n layout: layout,\n revision: revision,\n config: config,\n onAfterPlot: this.handleAfterPlot,\n onError: log.error,\n onRelayout: this.handleRelayout,\n onUpdate: this.handlePlotUpdate,\n onRestyle: this.handleRestyle,\n style: {\n height: '100%',\n width: '100%'\n }\n }), errorOverlay]\n });\n }\n}\n_defineProperty(Chart, \"defaultProps\", {\n isActive: true,\n settings: {\n timeZone: 'America/New_York',\n defaultDateTimeFormat: DateUtils.FULL_DATE_FORMAT,\n showTimeZone: false,\n showTSeparator: true,\n formatter: [],\n webgl: true\n },\n Plotly,\n onDisconnect: () => undefined,\n onReconnect: () => undefined,\n onUpdate: () => undefined,\n onError: () => undefined,\n onSettingsChanged: () => undefined\n});\nexport default function ChartContainer(props) {\n var chartTheme = useChartTheme();\n // eslint-disable-next-line react/jsx-props-no-spreading\n return /*#__PURE__*/_jsx(Chart, _objectSpread(_objectSpread({}, props), {}, {\n theme: chartTheme\n }));\n}\n//# sourceMappingURL=Chart.js.map"],"names":["ChartErrorOverlay","_ref","errorMessage","onDiscard","onConfirm","onCancel","dataTestId","messageTestId","_jsx","_jsxs","CopyButton","Button","ownKeys","object","enumerableOnly","keys","symbols","sym","_objectSpread","target","i","source","key","_defineProperty","obj","value","_toPropertyKey","arg","_toPrimitive","input","hint","prim","res","log","Log","Chart","Component","faIcon","width","path","stringPath","isDownsampleInProgress","isDownsamplingDisabled","props","memoize","downsamplingError","isDownsampleFinished","data","error","customButtons","hasDownsampleError","dhWarningFilled","hasError","name","attr","icon","vsLoading","dhGraphLineDown","has2D","type","has3D","_ref2","buttons2D","buttons3D","bindAllMethods","createPlotlyComponent","React","mergeRefs","isActive","model","prevProps","settings","theme","_this$plotWrapper$cur","_this$plotWrapper$cur2","_ref3","layout","_ref4","event","detail","ChartModel","state","revision","onUpdate","_onUpdate","onDisconnect","onReconnect","_detail$message","onError","DownsamplingError","_error","_onError","blocker","newLayout","_ref5","figure","ranges","ChartUtils","isRangesChanged","deepEqual","changes","onSettingsChanged","hiddenSeries","_ref6","seriesIndexes","acc","_ref7","visible","dh","chartUtils","_ref8","_ref9","shownError","force","rect","isRectChanged","columnFormats","FormatterUtils","dateTimeFormatterOptions","decimalFormatOptions","integerFormatOptions","formatter","Formatter","renderOptions","PlotlyProp","e","PlotComponent","shownBlocker","config","isPlotShown","errorOverlay","DateUtils","Plotly","ChartContainer","chartTheme","useChartTheme"],"mappings":"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"}
@@ -1 +1 @@
1
- .grid-wrapper{flex:1 1 0;max-width:100%;max-height:100%;min-width:0;min-height:0;position:relative;font-family:sans-serif;font-feature-settings:"tnum"}.grid-canvas{display:block}.grid-canvas:focus{outline:none}.grid-cursor-default{cursor:default}.grid-cursor-move{cursor:grabbing}.grid-cursor-not-allowed{cursor:not-allowed}.grid-cursor-s-resize{cursor:s-resize}.grid-cursor-row-resize{cursor:row-resize}.grid-cursor-e-resize{cursor:e-resize}.grid-cursor-col-resize{cursor:col-resize}.grid-cursor-pointer{cursor:pointer}.grid-block-events{pointer-events:none}.grid-cell-input-field{color:#e5e5e5;background:#393939;border:none;width:100%;height:100%;padding:2px 5px 3px;border-radius:2px;resize:none}.grid-cell-input-field:focus{outline:none;border:none;box-shadow:0 0 0 2px #00f}.grid-cell-input-field.error{color:red}.grid-cell-input-field.error:focus{box-shadow:0 0 0 2px red}.advanced-filter-creator-filter-item input.error{color:var(--dh-color-negative-bg)}.advanced-filter-creator-filter-item input.error:focus{box-shadow:inset 0 0 0 2px var(--dh-color-negative-bg),0 0 0 .2rem color-mix(in srgb,var(--dh-color-accent) 35%,transparent)}.advanced-filter-creator-select-value .select-value-list-scroll-pane{min-height:120px;height:120px;max-height:120px;overflow-x:auto}.advanced-filter-creator-select-value .advanced-filter-creator-select-meta-row{display:flex;flex-wrap:wrap;justify-content:space-between;padding-top:.25rem}.advanced-filter-creator-select-value .row-count-info{padding-top:calc(.25rem + 2px);padding-bottom:calc(.25rem + 2px);color:var(--dh-color-gray-600);-webkit-user-select:none;user-select:none}.advanced-filter-creator-select-value .btn-link{color:var(--dh-color-fg, #f0f0ee);text-decoration:underline}.advanced-filter-creator-select-value .btn-link:hover{color:var(--dh-color-accent-bg)}.advanced-filter-creator-select-value .select-value-list-wrapper{position:relative;display:flex;background:var(--dh-color-input-bg)}.advanced-filter-creator-select-value .select-value-list-wrapper .value-list-item label{white-space:nowrap}.advanced-filter-creator-select-value .select-value-list-wrapper .loading-list{position:absolute;top:0;bottom:0;left:0;right:0;display:flex;flex-direction:column;justify-content:center;align-content:center}.advanced-filter-creator-select-value .select-value-list-wrapper .loading-list .fa-layers{margin:auto}.advanced-filter-creator{padding:.5rem .75rem}.advanced-filter-creator .btn-link{padding-left:.25rem;padding-right:.25rem}.advanced-filter-creator hr{margin:.5rem -.75rem;background:var(--dh-color-gray-300)}.advanced-filter-creator .form-row.justify-content-end{margin-right:0}.advanced-filter-creator .advanced-filter-column-name{padding-bottom:.5rem}.advanced-filter-creator .advanced-filter-column-name .column-type{font-style:italic;color:var(--dh-color-gray-600);font-weight:400;text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.advanced-filter-creator .title-bar{display:flex;align-items:baseline;-webkit-user-select:none;user-select:none}.advanced-filter-creator .title-bar .advanced-filter-title{flex-grow:1}.advanced-filter-creator .advanced-filter-menu-buttons .sort-operator.btn{font-size:14px;color:var(--dh-color-gray-600);text-decoration:none;padding-top:0;padding-bottom:0;margin-left:.5rem}.advanced-filter-creator .advanced-filter-menu-buttons .sort-operator.active{color:var(--dh-color-fg, #f0f0ee)}.advanced-filter-creator .add-filter-item,.advanced-filter-creator .advanced-filter-creator-filter-operator{-webkit-user-select:none;user-select:none;padding-right:25px;padding-top:2px;padding-bottom:2px;margin-top:-1rem;transition:.15s opacity}.advanced-filter-creator .add-filter-item span,.advanced-filter-creator .advanced-filter-creator-filter-operator span{font-size:14px;padding-top:4px;padding-right:.25rem;color:var(--dh-color-gray-700)}.advanced-filter-creator .add-filter-item .btn-link.filter-operator,.advanced-filter-creator .add-filter-item .btn-link.btn-filter-item,.advanced-filter-creator .advanced-filter-creator-filter-operator .btn-link.filter-operator,.advanced-filter-creator .advanced-filter-creator-filter-operator .btn-link.btn-filter-item{font-size:12px;color:var(--dh-color-fg, #f0f0ee);text-decoration:underline;margin-right:0}.advanced-filter-creator .add-filter-item .btn-link.filter-operator:hover,.advanced-filter-creator .add-filter-item .btn-link.btn-filter-item:hover,.advanced-filter-creator .advanced-filter-creator-filter-operator .btn-link.filter-operator:hover,.advanced-filter-creator .advanced-filter-creator-filter-operator .btn-link.btn-filter-item:hover{color:var(--dh-color-accent-bg);text-decoration:underline}.advanced-filter-creator .add-filter-item.hidden{transition:none;opacity:0;pointer-events:none}.advanced-filter-creator .advanced-filter-creator-filter-operator .filter-operator:not(.active){color:var(--dh-color-gray-600)}.advanced-filter-creator .advanced-filter-creator-filter-operator .filter-operator.btn-link{text-decoration:none}.advanced-filter-creator .advanced-filter-creator-filter-operator .filter-operator.btn-link.active{color:var(--dh-color-fg, #f0f0ee)}.advanced-filter-creator .advanced-filter-creator-filter-operator .filter-operator.btn-link.active:hover{color:var(--dh-color-fg, #f0f0ee);cursor:default}.advanced-filter-creator .advanced-filter-creator-filter-operator .filter-operator.btn-link:hover{color:var(--dh-color-accent-bg)}.advanced-filter-creator .advanced-filter-creator-filter-operator .filter-operator.btn-link:focus{text-decoration:underline}.iris-grid-bottom-bar{position:absolute;bottom:-50px;left:0;right:0;height:100px;background-color:var(--dh-color-surface-bg);display:flex;flex-direction:row;align-content:center;padding-left:1em;padding-right:1em;padding-bottom:50px}.iris-grid-bottom-bar .status-message,.iris-grid-bottom-bar .error-message{flex-grow:1;flex-shrink:1;font-weight:600;margin-right:1em;overflow:hidden;display:flex;flex-direction:row;align-items:center;margin-top:-4px;-webkit-user-select:none;user-select:none}.iris-grid-bottom-bar .status-message span,.iris-grid-bottom-bar .error-message span{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.iris-grid-bottom-bar .status-message .svg-inline--fa,.iris-grid-bottom-bar .error-message .svg-inline--fa{margin-right:.5rem}.iris-grid-bottom-bar .error-message{color:var(--dh-color-negative-bg)}.iris-grid-bottom-bar .buttons-container{flex-grow:0;display:flex;flex-direction:row;align-items:center}.iris-grid-bottom-bar .buttons-container .btn{min-width:10rem}.iris-grid-bottom-bar .buttons-container .btn .svg-inline--fa,.iris-grid-bottom-bar .buttons-container .btn .loading-spinner{margin:0 .25rem 0 0}.iris-grid-bottom-bar .buttons-container .btn:not(:last-child){margin-right:.5em}.iris-grid-bottom-bar-slide-up-enter{transform:translate3d(0,100%,0)}.iris-grid-bottom-bar-slide-up-enter-active{transform:initial;transition:transform .3s cubic-bezier(.175,.885,.32,1.275)}.iris-grid-bottom-bar-slide-up-enter-done{position:relative;bottom:0;padding-bottom:0;height:50px;transition:transform .3s cubic-bezier(.175,.885,.32,1.275)}.iris-grid-bottom-bar-slide-up-exit{transform:initial}.iris-grid-bottom-bar-slide-up-exit-active{transform:translate3d(0,100%,0);transition:transform .3s cubic-bezier(.175,.885,.32,1.275)}.pending-data-bottom-bar{background-color:var(--dh-color-surface-bg)}.iris-grid-copy-handler{position:absolute;bottom:-50px;left:0;right:0;height:100px;background-color:var(--dh-color-surface-bg);display:flex;flex-direction:row;align-content:center;padding-left:1em;padding-right:1em;padding-bottom:50px}.iris-grid-copy-handler .status-message{flex-grow:1;font-weight:600;margin-right:1em;text-overflow:ellipsis;display:flex;flex-direction:row;align-items:center;margin-top:-4px;-webkit-user-select:none;user-select:none}.iris-grid-copy-handler .buttons-container{flex-grow:0;display:flex;flex-direction:row;align-items:center}.iris-grid-copy-handler .buttons-container .btn{min-width:10rem}.iris-grid-copy-handler .buttons-container .btn-cancel{color:var(--dh-color-gray-900, #fcfcfa);border-color:var(--dh-color-gray-900, #fcfcfa);margin-right:.5em}.iris-grid-copy-handler .buttons-container .btn-copy:disabled{opacity:1}.copy-slide-up-enter{transform:translateY(50px)}.copy-slide-up-enter-active{transform:initial;transition:transform .3s cubic-bezier(.175,.885,.32,1.275)}.copy-slide-up-exit{transform:initial}.copy-slide-up-exit-active{transform:translateY(50px);transition:transform .3s cubic-bezier(.175,.885,.32,1.275)}.iris-grid .grid-cursor-copy{cursor:url(./cursor-copy-6c703498.svg) 8 8,copy}.iris-grid .grid-cursor-linker{cursor:url(./cursor-linker-07cb7513.svg) 8 8,crosshair}.iris-grid .grid-cursor-linker-not-allowed{cursor:url(./cursor-linker-not-allowed-7a84bf1f.svg) 8 8,not-allowed}.iris-grid-input-autosized-wrapper{position:absolute;display:inline-grid;height:100%;align-items:center;z-index:1}.iris-grid-input-autosized-wrapper .advanced-filter-button{position:absolute;top:2px;right:.25rem;height:23px;margin:0}.iris-grid-input-autosized-wrapper:after{content:attr(data-value) " ";width:auto;height:100%;border:1px solid;padding:3px 2px 3px 3px;margin-right:24px;overflow:hidden;visibility:hidden;white-space:nowrap;grid-area:1/1;font:12px fira sans,sans-serif;font-feature-settings:"tnum"}@-moz-document url-prefix(""){.iris-grid-input-autosized-wrapper:after{font-feature-settings:normal}}.iris-grid-input-autosized-wrapper .iris-grid-input-field{position:absolute;color:var(--dh-color-text);background:var(--dh-color-grid-filter-bar-expanded-bg);border:1px solid var(--dh-color-input-border);width:100%;height:100%;padding:3px 2px 3px 3px;border-radius:1px;font:12px fira sans,sans-serif;font-feature-settings:"tnum"}@-moz-document url-prefix(""){.iris-grid-input-autosized-wrapper .iris-grid-input-field{font-feature-settings:normal}}.iris-grid-input-autosized-wrapper .iris-grid-input-field.iris-grid-has-filter{background:linear-gradient(var(--dh-color-grid-filter-bar-expanded-active-bg) 100%,var(--dh-color-grid-filter-bar-expanded-active-bg)),linear-gradient(var(--dh-color-grid-bg) 100%,var(--dh-color-grid-bg))}.iris-grid-input-autosized-wrapper .iris-grid-input-field.active{background:linear-gradient(var(--dh-color-grid-filter-bar-expanded-active-cell-bg) 100%,var(--dh-color-grid-filter-bar-expanded-active-cell-bg)),linear-gradient(var(--dh-color-grid-filter-bar-expanded-active-bg) 100%,var(--dh-color-grid-filter-bar-expanded-active-bg)),linear-gradient(var(--dh-color-grid-bg) 100%,var(--dh-color-grid-bg))}.iris-grid-input-autosized-wrapper .iris-grid-input-field:focus{outline:0;border:1px solid var(--dh-color-input-focus-border);box-shadow:0 0 0 .2rem color-mix(in srgb,var(--dh-color-accent) 35%,transparent)}.iris-grid-input-autosized-wrapper .iris-grid-input-field.error{color:var(--dh-color-negative-bg)}.iris-grid-input-autosized-wrapper .iris-grid-input-field.error:focus{box-shadow:inset 0 0 0 2px var(--dh-color-negative-bg),0 0 0 .2rem color-mix(in srgb,var(--dh-color-accent) 35%,transparent)}.column-statistics{min-width:175px;max-width:350px;color:var(--dh-color-fg, #f0f0ee);text-align:left;font-size:small;font-weight:300}.column-statistics-title{padding-top:.25rem;font-weight:500;word-break:break-all}.column-statistics-title .column-statistics-copy{margin-left:2px;margin-top:-2px}.column-statistics-type{font-style:italic;color:var(--dh-color-gray-600);font-weight:400;-webkit-user-select:none;user-select:none;white-space:nowrap}.column-statistics-status{margin:.25rem 0 .25rem -1px}.column-statistics-grid{display:grid;grid-template-columns:auto auto;row-gap:.25rem;padding-top:.25rem}.column-statistics-grid>div{border-bottom:1px solid var(--dh-color-gray-500)}.column-statistics-grid>div:last-child,.column-statistics-grid>div:nth-last-child(2){border-bottom:none}.column-statistics-grid .column-statistics-unique-value{margin-left:1rem}.column-statistics-grid .column-statistic-operation{flex-grow:0;padding-right:1rem;text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.column-statistics-grid .column-statistic-value{font-feature-settings:"tnum";text-align:right;text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.column-statistics .btn-link{text-decoration:underline;padding-top:0;padding-bottom:0}.column-statistics-loading,.column-statistics-loading .loading{padding-bottom:2px;display:inline-block;color:var(--dh-color-gray-600)}.column-statistics-loading .loading-spinner{margin-right:5px}:export{grid-bg:var(--dh-color-grid-bg);font:12px Fira Sans,sans-serif;white:var(--dh-color-white);black:var(--dh-color-black);header-bg:var(--dh-color-grid-header-bg);header-color:var(--dh-color-grid-header-text);header-height:30px;header-separator-color:var(--dh-color-grid-header-separator);header-separator-hover-color:var(--dh-color-grid-header-separator-hover);header-hidden-separator-hover-color:var(--dh-color-grid-header-separator-hidden-hover);header-sort-bar-color:var(--dh-color-grid-header-sort-bar);header-reverse-bar-color:var(--dh-color-grid-header-reverse-bar);header-bar-casing-color:var(--dh-color-grid-header-bar-casing);header-font:600 12px Fira Sans,sans-serif;row-height:19px;row-background-colors:var(--dh-color-grid-row-0-bg) var(--dh-color-grid-row-1-bg);active-cell-selection-border-width:2px;selection-color:var(--dh-color-grid-selection);selection-outline-color:var(--dh-color-grid-selection-outline);selection-outline-casing-color:var(--dh-color-grid-selection-outline-casing);row-hover-bg:var(--dh-color-grid-row-hover-bg);row-shadow-alpha:var(--dh-color-grid-row-shadow-alpha);selected-row-hover-bg:var(--dh-color-grid-row-hover-bg-selected);scroll-bar-active-selection-tick-color:var(--dh-color-grid-scroll-bar-active-selection-tick);scroll-bar-bg:var(--dh-color-grid-scroll-bar-bg);scroll-bar-hover-bg:var(--dh-color-grid-scroll-bar-hover-bg);scroll-bar-casing-color:var(--dh-color-grid-scroll-bar-casing);scroll-bar-corner-color:var(--dh-color-grid-scroll-bar-corner);scroll-bar-color:var(--dh-color-grid-scroll-bar);scroll-bar-hover-color:var(--dh-color-grid-scroll-bar-hover);scroll-bar-active-color:var(--dh-color-grid-scroll-bar-active);text-color:var(--dh-color-grid-text);hyperlink-color:var(--dh-color-grid-text-hyperlink);positive-number-color:var(--dh-color-grid-number-positive);negative-number-color:var(--dh-color-grid-number-negative);zero-number-color:var(--dh-color-grid-number-zero);date-color:var(--dh-color-grid-date);pending-text-color:var(--dh-color-grid-text-pending);error-text-color:var(--dh-color-grid-text-error);null-string-color:var(--dh-color-grid-string-null);filter-bar-active-bg:var(--dh-color-grid-filter-bar-active-bg);filter-bar-active-color:var(--dh-color-grid-filter-bar-active);filter-bar-expanded-bg:var(--dh-color-grid-filter-bar-expanded-bg);filter-bar-expanded-active-bg:var(--dh-color-grid-filter-bar-expanded-active-bg);filter-bar-expanded-active-cell-bg:var(--dh-color-grid-filter-bar-expanded-active-cell-bg);filter-bar-separator-color:var(--dh-color-grid-filter-bar-separator);filter-bar-error-color:var(--dh-color-grid-filter-bar-error);filter-icon-color:var(--dh-color-grid-filter-icon);scrim-color:var(--dh-color-grid-scrim);context-menu-sort-icon-color:var(--dh-color-grid-context-menu-sort-icon);context-menu-reverse-icon-color:var(--dh-color-grid-context-menu-reverse-icon);linker-column-hover-bg:var(--dh-color-grid-column-linker-hover-bg);tree-line-color:var(--dh-color-grid-tree-line);tree-marker-color:var(--dh-color-grid-tree-marker);tree-marker-hover-color:var(--dh-color-grid-tree-marker-hover);grouped-column-divider-color:var(--dh-color-grid-column-grouped-divider);floating-grid-row-color:var(--dh-color-grid-floating-row);floating-row-background-colors:var(--dh-color-grid-floating-row-bg);floating-divider-inner-color:var(--dh-color-grid-floating-divider-inner);floating-divider-outer-color:var(--dh-color-grid-floating-divider-outer);overflow-button-color:var(--dh-color-grid-overflow-button);overflow-button-hover-color:var(--dh-color-grid-overflow-button-hover);zero-line-color:var(--dh-color-grid-data-bar-zero-line);positive-bar-color:var(--dh-color-grid-data-bar-positive);negative-bar-color:var(--dh-color-grid-data-bar-negative);marker-bar-color:var(--dh-color-grid-data-bar-marker)}.iris-grid{--table-sidebar-bg: var(--dh-color-surface-bg);--dh-color-hr: var(--dh-color-gray-500);width:100%;height:100%;position:relative;display:flex;flex-direction:row;overflow:hidden}.iris-grid .iris-grid-column{flex:1 1;min-width:0;transition:all .2s;display:flex;flex-direction:column;position:relative}.iris-grid .grid-cursor-copy{cursor:url(./cursor-copy-6c703498.svg) 8 8,copy}.iris-grid .grid-cursor-linker{cursor:url(./cursor-linker-07cb7513.svg) 8 8,crosshair}.iris-grid .grid-cursor-linker-not-allowed{cursor:url(./cursor-linker-not-allowed-7a84bf1f.svg) 8 8,not-allowed}.iris-grid .table-sidebar{height:100%;flex:0 0 320px;width:320px;max-width:320px;background:var(--table-sidebar-bg);box-shadow:0 0 6px var(--dh-color-dropshadow);z-index:1;position:absolute;right:0}.iris-grid .table-sidebar .pushing-view,.iris-grid .table-sidebar .popping-view,.iris-grid .table-sidebar .main-view{background:var(--table-sidebar-bg)}.iris-grid .table-sidebar.slide-left-enter-done{position:relative}.iris-grid .table-sidebar .navigation-content{overflow-y:auto}.iris-grid .section-title{padding:1rem 0;font-weight:500;text-align:left}.iris-grid .section-footer{flex-grow:2;display:flex;justify-content:flex-end;margin-bottom:1rem}.iris-grid .grid-wrapper{font:12px fira sans,sans-serif;font-feature-settings:"tnum";transition:all .2s}.iris-grid .grid-wrapper .grid-settings-button{position:absolute;top:0;right:0;height:30px;width:30px;background-color:var(--dh-color-grid-header-bg);border-bottom:1px solid var(--dh-color-grid-header-separator);transition:transform .2s ease-out,opacity .2s ease-out}.iris-grid .grid-wrapper .grid-settings-button .btn{height:100%;width:100%}.iris-grid .grid-wrapper .grid-settings-button .btn:after{border-radius:0}.iris-grid .grid-wrapper .grid-settings-button .btn:focus:after{box-shadow:none}.iris-grid .grid-wrapper .grid-settings-button.is-menu-shown{opacity:0}.iris-grid .grid-wrapper .grid-cell-input-field{color:var(--dh-color-input-fg);background:var(--dh-color-input-bg)}.iris-grid .grid-wrapper .grid-cell-input-field:focus{box-shadow:0 0 0 2px var(--dh-color-grid-selection-outline),0 0 0 5px color-mix(in srgb,var(--dh-color-accent) 25%,transparent)}.iris-grid .grid-wrapper .grid-cell-input-field.error{color:var(--dh-color-negative-bg)}.iris-grid .grid-wrapper .grid-cell-input-field.error:focus{box-shadow:0 0 0 2px var(--dh-color-negative),0 0 0 5px color-mix(in srgb,var(--dh-color-negative) 25%,transparent)}.iris-grid-loading{position:absolute;bottom:0;left:0;right:0;display:flex;flex-direction:column;justify-content:center;align-content:center}.iris-grid-loading-status{display:flex;position:absolute;bottom:0;left:0;z-index:30;min-width:min(320px,100%)}.iris-grid-loading-status .iris-grid-loading-status-bar{position:relative;padding:5px;background:var(--dh-color-content-bg, #2d2a2e);color:var(--dh-color-gray-700);border-top:1px solid var(--dh-color-gray-500);border-right:1px solid var(--dh-color-gray-500);overflow:hidden;word-wrap:break-word;z-index:2;flex-grow:1}.iris-grid-loading-status .iris-grid-loading-status-bar:after{content:"";position:absolute;bottom:0;left:0;width:100%;height:2px;z-index:-1;background:var(--dh-color-accent-bg);transform-origin:0% 50%;opacity:0}.iris-grid-loading-status .iris-grid-loading-status-bar.show:after{opacity:1;animation:1.5s indeterminateAnimation infinite linear}@keyframes indeterminateAnimation{0%{transform:translate(-50%) scaleX(.5)}50%{transform:translate(0) scaleX(.5)}to{transform:translate(100%) scaleX(.2)}}.iris-grid-loading-status .iris-grid-btn-cancel{z-index:1;opacity:0;border:1px solid var(--dh-color-gray-500);border-left:0;border-bottom:0;padding:0 7px 2px 4px;background:var(--dh-color-content-bg, #2d2a2e);color:var(--dh-color-gray-700);transform:translate(-100%);transition:all .1s ease-out 0s;white-space:nowrap;outline-offset:-1px;outline:var(--dh-color-accent-bg)}.iris-grid-loading-status .iris-grid-btn-cancel:hover{color:var(--dh-color-fg, #f0f0ee);background:var(--dh-color-negative-bg)}.iris-grid-loading-status .iris-grid-btn-cancel:focus{outline:1px solid var(--dh-color-accent-bg)}.iris-grid-loading-status .iris-grid-btn-cancel:active{background:var(--dh-color-negative-hover-bg)}.iris-grid-loading-status .iris-grid-btn-cancel:active:focus{outline-color:var(--dh-color-negative-bg)}.iris-grid-loading-status .iris-grid-btn-cancel.show{opacity:1;transform:translate(0);transition:all .25s ease-out .1s}.advanced-filter-button-container{background:none}.advanced-filter-button-container .advanced-filter-button{height:23px;margin:0}.advanced-filter-button-container .advanced-filter-button .filter-solid{opacity:0;transition:.15s opacity}.advanced-filter-button-container .advanced-filter-button .filter-light{opacity:1;transition:.15s opacity}.advanced-filter-button-container .advanced-filter-button.filter-set .filter-solid,.advanced-filter-button-container .advanced-filter-button:hover .filter-solid{opacity:1}.advanced-filter-button-container .advanced-filter-button.filter-set .filter-light,.advanced-filter-button-container .advanced-filter-button:hover .filter-light{opacity:0}.advanced-filter-button-container .advanced-filter-button:hover{color:var(--dh-color-gray-400)}.advanced-filter-button-container .advanced-filter-button:hover .filter-solid{color:var(--dh-color-accent-bg)}.advanced-filter-menu-popper{background:var(--dh-color-gray-400)}.advanced-filter-menu-popper .popper-content .advanced-filter-creator{max-height:550px;overflow-y:auto;background:var(--dh-color-gray-400);width:320px;box-shadow:none}.advanced-filter-menu-popper .popper-content .popper-arrow{border-color:var(--dh-color-gray-400)}.advanced-filter-menu-container{pointer-events:none;visibility:hidden}.iris-grid-bar{overflow:hidden;flex:0 0 auto}.iris-grid-bar.iris-grid-bar-horizontal-enter{max-height:0}.iris-grid-bar.iris-grid-bar-horizontal-enter-active{transition:background-color 1s ease-in,max-height .15s ease-in;max-height:250px}.iris-grid-bar.iris-grid-bar-horizontal-enter-done{max-height:250px}.iris-grid-bar.iris-grid-bar-horizontal-exit{max-height:250px;transition:max-height .15s ease-out}.iris-grid-bar.iris-grid-bar-horizontal-exit-active,.iris-grid-bar.iris-grid-bar-horizontal-exit-done{max-height:0}.iris-grid-bar.iris-grid-bar-vertical-enter{max-width:0}.iris-grid-bar.iris-grid-bar-vertical-enter-active{transition:background-color 1s ease-in,max-width .15s ease-in;max-width:320px}.iris-grid-bar.iris-grid-bar-vertical-enter-done{max-width:320px}.iris-grid-bar.iris-grid-bar-vertical-exit{max-width:320px;transition:max-width .15s ease-out}.iris-grid-bar.iris-grid-bar-vertical-exit-active,.iris-grid-bar.iris-grid-bar-vertical-exit-done{max-width:0}.iris-grid-bar-primary{background-color:var(--dh-color-accent-down-bg)}.iris-grid-bar-primary.iris-grid-bar-horizontal-enter,.iris-grid-bar-primary.iris-grid-bar-vertical-enter{background-color:var(--dh-color-accent-bg)}.link-hover-tooltip{text-align:left;max-width:500px;overflow-wrap:break-word}.cross-column-container{display:flex;flex-direction:row;margin:.25rem;align-items:stretch;flex:0 1 auto}.cross-column-container .cross-column-search{flex:1;margin-right:.25rem}.cross-column-popup{padding:.5rem 1rem .1rem}.cross-column-popup .cross-column-scroll{display:grid;grid-template-columns:max-content auto;grid-column-gap:.5rem;grid-row-gap:0;overflow-y:auto;max-height:15rem;padding:.2rem .5rem;border:1px solid var(--dh-color-input-border)}.cross-column-button-bar{display:flex}.cross-column-button-bar :last-child{margin-left:auto}.iris-grid-partition-selector{display:flex;flex-wrap:wrap;background:var(--dh-color-surface-bg);align-items:center;padding:.5rem;gap:.5rem}.iris-grid-partition-selector .column-selector{display:flex;align-items:center;gap:.5rem}.iris-grid-partition-selector .column-selector .custom-select{min-width:4rem}.iris-grid-partition-selector .partition-button-group{display:flex;border:1px var(--dh-color-hr);border-style:none solid;padding:0 .5rem;gap:.5rem}.select-distinct-builder-container{width:100%;height:100%;padding:0;overflow:auto;display:flex;justify-content:space-between;flex-flow:column}.select-distinct-builder-container .select-distinct-title{padding:1rem;font-weight:500;text-align:left}.select-distinct-builder-container .select-distinct-input-container{padding:1rem}.select-distinct-builder-container .select-distinct-builder-footer{margin:1rem;margin-bottom:auto;display:flex;flex-direction:column;padding-bottom:1rem}.select-distinct-builder-container .select-distinct-builder-hint{color:var(--dh-color-gray-600);font-size:smaller}.select-distinct-builder-container .select-distinct-builder-hint .inline-code-snippet{display:inline;color:var(--dh-color-visual-yellow);font-family:Fira Mono,menlo,monaco,consolas,Liberation Mono,Courier New,monospace}.select-distinct-builder-container hr{background:var(--dh-color-gray-300);margin:0;width:100%}.conditional-formatting-rules{padding:.25rem}.conditional-formatting-list-item{display:flex;flex-direction:row;margin-bottom:2px;padding:0 .25rem}.conditional-formatting-list-item:first-child{padding-top:.25rem}.conditional-formatting-list-item .formatting-item{border-radius:4px;display:flex;padding:.25rem;flex-grow:1;align-items:center;-webkit-user-select:none;user-select:none;transition:color .12s ease-in-out,background-color .12s ease-in-out,border-color .12s ease-in-out,box-shadow .12s ease-in-out;border:1px solid transparent;line-height:1.3;cursor:pointer}.conditional-formatting-list-item .formatting-item .btn-drag-handle{cursor:grab}.conditional-formatting-list-item .formatting-item .rule-icon{padding-right:.5rem}.conditional-formatting-list-item .formatting-item .rule-icon-bg{min-width:2rem;height:2rem;display:flex;font-size:x-small;justify-content:center;align-items:center}.conditional-formatting-list-item .formatting-item .rule-title{overflow-x:hidden;text-overflow:ellipsis;padding-right:2px;display:flex;flex-grow:1}.conditional-formatting-list-item .formatting-item:focus{outline:0;border:1px solid var(--dh-color-input-focus-border);box-shadow:0 0 0 .2rem color-mix(in srgb,var(--dh-color-accent) 35%,transparent)}.conditional-formatting-list-item .formatting-item:hover{background:var(--dh-color-item-list-hover-bg)}.dragging>.conditional-formatting-list-item .formatting-item{background:var(--dh-color-accent-bg);box-shadow:0 .1rem 1rem var(--dh-color-dropshadow);color:var(--dh-color-accent-contrast)}.dragging>.conditional-formatting-list-item .formatting-item .btn{color:var(--dh-color-accent-contrast)}.style-editor .cs-dropdown{display:flex;text-align:left;padding-left:.5rem;width:100%;justify-content:space-between;border-radius:4px;border:1px solid var(--dh-color-input-border);min-width:14rem;background-position:right .75rem center;background-size:10px 6px;background-repeat:no-repeat}.style-editor .cs-dropdown:focus{border-color:var(--dh-color-input-focus-border)}.style-editor .cs-dropdown.btn-inline:active{background:var(--dh-svg-icon-select-indicator) right .75rem center/10px 6px no-repeat,var(--dh-color-action-down-bg)}.style-dropdown-menu{border-radius:4px}.style-dropdown-menu .style-options{max-height:400px;overflow:auto}.style-dropdown-menu .style-option-btn{border:none;border-radius:0;width:100%;padding:.42145rem .75rem;white-space:nowrap;text-decoration:none;background-color:transparent;text-align:left;cursor:pointer;-webkit-user-select:none;user-select:none;display:block}.style-dropdown-menu .style-option-btn:hover{opacity:.8}.style-dropdown-menu .style-option-btn:focus{outline:none;box-shadow:none}.style-dropdown-menu .style-option-btn:first-child{border-top-left-radius:4px;border-top-right-radius:4px}.style-dropdown-menu .style-option-btn:last-child{border-bottom-left-radius:4px;border-bottom-right-radius:4px}.conditional-format-editor{padding:1rem}.conditional-format-editor .formatter-list{display:flex;justify-content:flex-start;padding-top:.5rem}.conditional-format-editor .formatter-type{margin:0 1rem 0 0;display:flex}.conditional-format-editor .btn-formatter-type{font-size:smaller;width:100%}.conditional-format-editor .color-select{padding:0 2em 0 .25em}.conditional-format-editor .dh-combobox{width:100%}.cell-overflow-modal .modal-title{width:100%;display:flex;align-items:center;gap:.5rem}.cell-overflow-modal .modal-title .overflow-modal-title{margin:0;flex-grow:1}.cell-overflow-modal .modal-body{max-height:80vh;flex-shrink:1}.iris-grid-bottom-bar.goto-row{height:auto}.goto-row{background-color:var(--dh-color-content-bg, #2d2a2e);border-top:1px solid var(--dh-color-black, #1a171a);display:block}.goto-row .goto-row-row{display:flex;padding:.5rem;justify-content:space-between;align-items:flex-start;gap:.5rem}.goto-row .goto-row-wrapper{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.goto-row .goto-row-text{min-width:10ch;margin:0;font-size:14px}.goto-row .goto-row-close{display:flex}.goto-row input{max-width:calc(1.5rem + 12ch)}.goto-row select{max-width:calc(1.5rem + 25ch)}.goto-row .is-inactive{color:var(--dh-color-gray-600)}.goto-row .goto-value-date-time-input{min-width:30ch}
1
+ .grid-wrapper{flex:1 1 0;max-width:100%;max-height:100%;min-width:0;min-height:0;position:relative;font-family:sans-serif;font-feature-settings:"tnum"}.grid-canvas{display:block}.grid-canvas:focus{outline:none}.grid-cursor-default{cursor:default}.grid-cursor-move{cursor:grabbing}.grid-cursor-not-allowed{cursor:not-allowed}.grid-cursor-s-resize{cursor:s-resize}.grid-cursor-row-resize{cursor:row-resize}.grid-cursor-e-resize{cursor:e-resize}.grid-cursor-col-resize{cursor:col-resize}.grid-cursor-pointer{cursor:pointer}.grid-block-events{pointer-events:none}.grid-cell-input-field{color:#e5e5e5;background:#393939;border:none;width:100%;height:100%;padding:2px 5px 3px;border-radius:2px;resize:none}.grid-cell-input-field:focus{outline:none;border:none;box-shadow:0 0 0 2px #00f}.grid-cell-input-field.error{color:red}.grid-cell-input-field.error:focus{box-shadow:0 0 0 2px red}.advanced-filter-creator-filter-item input.error{color:var(--dh-color-negative-bg)}.advanced-filter-creator-filter-item input.error:focus{box-shadow:inset 0 0 0 2px var(--dh-color-negative-bg),0 0 0 .2rem color-mix(in srgb,var(--dh-color-accent) 35%,transparent)}.advanced-filter-creator-select-value .select-value-list-scroll-pane{min-height:120px;height:120px;max-height:120px;overflow-x:auto}.advanced-filter-creator-select-value .advanced-filter-creator-select-meta-row{display:flex;flex-wrap:wrap;justify-content:space-between;padding-top:.25rem}.advanced-filter-creator-select-value .row-count-info{padding-top:calc(.25rem + 2px);padding-bottom:calc(.25rem + 2px);color:var(--dh-color-gray-600);-webkit-user-select:none;user-select:none}.advanced-filter-creator-select-value .btn-link{color:var(--dh-color-fg, #f0f0ee);text-decoration:underline}.advanced-filter-creator-select-value .btn-link:hover{color:var(--dh-color-accent-bg)}.advanced-filter-creator-select-value .select-value-list-wrapper{position:relative;display:flex;background:var(--dh-color-input-bg)}.advanced-filter-creator-select-value .select-value-list-wrapper .value-list-item label{white-space:nowrap}.advanced-filter-creator-select-value .select-value-list-wrapper .loading-list{position:absolute;top:0;bottom:0;left:0;right:0;display:flex;flex-direction:column;justify-content:center;align-content:center}.advanced-filter-creator-select-value .select-value-list-wrapper .loading-list .fa-layers{margin:auto}.advanced-filter-creator{padding:.5rem .75rem}.advanced-filter-creator .btn-link{padding-left:.25rem;padding-right:.25rem}.advanced-filter-creator hr{margin:.5rem -.75rem;background:var(--dh-color-gray-300)}.advanced-filter-creator .form-row.justify-content-end{margin-right:0}.advanced-filter-creator .advanced-filter-column-name{padding-bottom:.5rem}.advanced-filter-creator .advanced-filter-column-name .column-type{font-style:italic;color:var(--dh-color-gray-600);font-weight:400;text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.advanced-filter-creator .title-bar{display:flex;align-items:baseline;-webkit-user-select:none;user-select:none}.advanced-filter-creator .title-bar .advanced-filter-title{flex-grow:1}.advanced-filter-creator .advanced-filter-menu-buttons .sort-operator.btn{font-size:14px;color:var(--dh-color-gray-600);text-decoration:none;padding-top:0;padding-bottom:0;margin-left:.5rem}.advanced-filter-creator .advanced-filter-menu-buttons .sort-operator.active{color:var(--dh-color-fg, #f0f0ee)}.advanced-filter-creator .add-filter-item,.advanced-filter-creator .advanced-filter-creator-filter-operator{-webkit-user-select:none;user-select:none;padding-right:25px;padding-top:2px;padding-bottom:2px;margin-top:-1rem;transition:.15s opacity}.advanced-filter-creator .add-filter-item span,.advanced-filter-creator .advanced-filter-creator-filter-operator span{font-size:14px;padding-top:4px;padding-right:.25rem;color:var(--dh-color-gray-700)}.advanced-filter-creator .add-filter-item .btn-link.filter-operator,.advanced-filter-creator .add-filter-item .btn-link.btn-filter-item,.advanced-filter-creator .advanced-filter-creator-filter-operator .btn-link.filter-operator,.advanced-filter-creator .advanced-filter-creator-filter-operator .btn-link.btn-filter-item{font-size:12px;color:var(--dh-color-fg, #f0f0ee);text-decoration:underline;margin-right:0}.advanced-filter-creator .add-filter-item .btn-link.filter-operator:hover,.advanced-filter-creator .add-filter-item .btn-link.btn-filter-item:hover,.advanced-filter-creator .advanced-filter-creator-filter-operator .btn-link.filter-operator:hover,.advanced-filter-creator .advanced-filter-creator-filter-operator .btn-link.btn-filter-item:hover{color:var(--dh-color-accent-bg);text-decoration:underline}.advanced-filter-creator .add-filter-item.hidden{transition:none;opacity:0;pointer-events:none}.advanced-filter-creator .advanced-filter-creator-filter-operator .filter-operator:not(.active){color:var(--dh-color-gray-600)}.advanced-filter-creator .advanced-filter-creator-filter-operator .filter-operator.btn-link{text-decoration:none}.advanced-filter-creator .advanced-filter-creator-filter-operator .filter-operator.btn-link.active{color:var(--dh-color-fg, #f0f0ee)}.advanced-filter-creator .advanced-filter-creator-filter-operator .filter-operator.btn-link.active:hover{color:var(--dh-color-fg, #f0f0ee);cursor:default}.advanced-filter-creator .advanced-filter-creator-filter-operator .filter-operator.btn-link:hover{color:var(--dh-color-accent-bg)}.advanced-filter-creator .advanced-filter-creator-filter-operator .filter-operator.btn-link:focus{text-decoration:underline}.iris-grid-bottom-bar{position:absolute;bottom:-50px;left:0;right:0;height:100px;background-color:var(--dh-color-surface-bg);display:flex;flex-direction:row;align-content:center;padding-left:1em;padding-right:1em;padding-bottom:50px}.iris-grid-bottom-bar .status-message,.iris-grid-bottom-bar .error-message{flex-grow:1;flex-shrink:1;font-weight:600;margin-right:1em;overflow:hidden;display:flex;flex-direction:row;align-items:center;margin-top:-4px;-webkit-user-select:none;user-select:none}.iris-grid-bottom-bar .status-message span,.iris-grid-bottom-bar .error-message span{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.iris-grid-bottom-bar .status-message .svg-inline--fa,.iris-grid-bottom-bar .error-message .svg-inline--fa{margin-right:.5rem}.iris-grid-bottom-bar .error-message{color:var(--dh-color-negative-bg)}.iris-grid-bottom-bar .buttons-container{flex-grow:0;display:flex;flex-direction:row;align-items:center}.iris-grid-bottom-bar .buttons-container .btn{min-width:10rem}.iris-grid-bottom-bar .buttons-container .btn .svg-inline--fa,.iris-grid-bottom-bar .buttons-container .btn .loading-spinner{margin:0 .25rem 0 0}.iris-grid-bottom-bar .buttons-container .btn:not(:last-child){margin-right:.5em}.iris-grid-bottom-bar-slide-up-enter{transform:translate3d(0,100%,0)}.iris-grid-bottom-bar-slide-up-enter-active{transform:initial;transition:transform .3s cubic-bezier(.175,.885,.32,1.275)}.iris-grid-bottom-bar-slide-up-enter-done{position:relative;bottom:0;padding-bottom:0;height:50px;transition:transform .3s cubic-bezier(.175,.885,.32,1.275)}.iris-grid-bottom-bar-slide-up-exit{transform:initial}.iris-grid-bottom-bar-slide-up-exit-active{transform:translate3d(0,100%,0);transition:transform .3s cubic-bezier(.175,.885,.32,1.275)}.pending-data-bottom-bar{background-color:var(--dh-color-surface-bg)}.iris-grid-copy-handler{position:absolute;bottom:-50px;left:0;right:0;height:100px;background-color:var(--dh-color-surface-bg);display:flex;flex-direction:row;align-content:center;padding-left:1em;padding-right:1em;padding-bottom:50px}.iris-grid-copy-handler .status-message{flex-grow:1;font-weight:600;margin-right:1em;text-overflow:ellipsis;display:flex;flex-direction:row;align-items:center;margin-top:-4px;-webkit-user-select:none;user-select:none}.iris-grid-copy-handler .buttons-container{flex-grow:0;display:flex;flex-direction:row;align-items:center}.iris-grid-copy-handler .buttons-container .btn{min-width:10rem}.iris-grid-copy-handler .buttons-container .btn-cancel{color:var(--dh-color-gray-900, #fcfcfa);border-color:var(--dh-color-gray-900, #fcfcfa);margin-right:.5em}.iris-grid-copy-handler .buttons-container .btn-copy:disabled{opacity:1}.copy-slide-up-enter{transform:translateY(50px)}.copy-slide-up-enter-active{transform:initial;transition:transform .3s cubic-bezier(.175,.885,.32,1.275)}.copy-slide-up-exit{transform:initial}.copy-slide-up-exit-active{transform:translateY(50px);transition:transform .3s cubic-bezier(.175,.885,.32,1.275)}.iris-grid .grid-cursor-copy{cursor:url(./cursor-copy-6c703498.svg) 8 8,copy}.iris-grid .grid-cursor-linker{cursor:url(./cursor-linker-07cb7513.svg) 8 8,crosshair}.iris-grid .grid-cursor-linker-not-allowed{cursor:url(./cursor-linker-not-allowed-7a84bf1f.svg) 8 8,not-allowed}.iris-grid-input-autosized-wrapper{position:absolute;display:inline-grid;height:100%;align-items:center;z-index:1}.iris-grid-input-autosized-wrapper .advanced-filter-button{position:absolute;top:2px;right:.25rem;height:23px;margin:0}.iris-grid-input-autosized-wrapper:after{content:attr(data-value) " ";width:auto;height:100%;border:1px solid;padding:3px 2px 3px 3px;margin-right:24px;overflow:hidden;visibility:hidden;white-space:nowrap;grid-area:1/1;font:12px fira sans,sans-serif;font-feature-settings:"tnum"}@-moz-document url-prefix(""){.iris-grid-input-autosized-wrapper:after{font-feature-settings:normal}}.iris-grid-input-autosized-wrapper .iris-grid-input-field{position:absolute;color:var(--dh-color-text);background:var(--dh-color-grid-filter-bar-expanded-bg);border:1px solid var(--dh-color-input-border);width:100%;height:100%;padding:3px 2px 3px 3px;border-radius:1px;font:12px fira sans,sans-serif;font-feature-settings:"tnum"}@-moz-document url-prefix(""){.iris-grid-input-autosized-wrapper .iris-grid-input-field{font-feature-settings:normal}}.iris-grid-input-autosized-wrapper .iris-grid-input-field.iris-grid-has-filter{background:linear-gradient(var(--dh-color-grid-filter-bar-expanded-active-bg) 100%,var(--dh-color-grid-filter-bar-expanded-active-bg)),linear-gradient(var(--dh-color-grid-bg) 100%,var(--dh-color-grid-bg))}.iris-grid-input-autosized-wrapper .iris-grid-input-field.active{background:linear-gradient(var(--dh-color-grid-filter-bar-expanded-active-cell-bg) 100%,var(--dh-color-grid-filter-bar-expanded-active-cell-bg)),linear-gradient(var(--dh-color-grid-filter-bar-expanded-active-bg) 100%,var(--dh-color-grid-filter-bar-expanded-active-bg)),linear-gradient(var(--dh-color-grid-bg) 100%,var(--dh-color-grid-bg))}.iris-grid-input-autosized-wrapper .iris-grid-input-field:focus{outline:0;border:1px solid var(--dh-color-input-focus-border);box-shadow:0 0 0 .2rem color-mix(in srgb,var(--dh-color-accent) 35%,transparent)}.iris-grid-input-autosized-wrapper .iris-grid-input-field.error{color:var(--dh-color-negative-bg)}.iris-grid-input-autosized-wrapper .iris-grid-input-field.error:focus{box-shadow:inset 0 0 0 2px var(--dh-color-negative-bg),0 0 0 .2rem color-mix(in srgb,var(--dh-color-accent) 35%,transparent)}.column-statistics{min-width:175px;max-width:350px;color:var(--dh-color-fg, #f0f0ee);text-align:left;font-size:small;font-weight:300}.column-statistics-title{padding-top:.25rem;font-weight:500;word-break:break-all}.column-statistics-title .column-statistics-copy{margin-left:2px;margin-top:-2px}.column-statistics-type{font-style:italic;color:var(--dh-color-gray-600);font-weight:400;-webkit-user-select:none;user-select:none;white-space:nowrap}.column-statistics-status{margin:.25rem 0 .25rem -1px}.column-statistics-grid{display:grid;grid-template-columns:auto auto;row-gap:.25rem;padding-top:.25rem}.column-statistics-grid>div{border-bottom:1px solid var(--dh-color-gray-500)}.column-statistics-grid>div:last-child,.column-statistics-grid>div:nth-last-child(2){border-bottom:none}.column-statistics-grid .column-statistics-unique-value{margin-left:1rem}.column-statistics-grid .column-statistic-operation{flex-grow:0;padding-right:1rem;text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.column-statistics-grid .column-statistic-value{font-feature-settings:"tnum";text-align:right;text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.column-statistics .btn-link{text-decoration:underline;padding-top:0;padding-bottom:0}.column-statistics-loading,.column-statistics-loading .loading{padding-bottom:2px;display:inline-block;color:var(--dh-color-gray-600)}.column-statistics-loading .loading-spinner{margin-right:5px}:export{grid-bg:var(--dh-color-grid-bg);font:12px Fira Sans,sans-serif;white:var(--dh-color-white);black:var(--dh-color-black);header-bg:var(--dh-color-grid-header-bg);header-color:var(--dh-color-grid-header-text);header-height:30px;header-separator-color:var(--dh-color-grid-header-separator);header-separator-hover-color:var(--dh-color-grid-header-separator-hover);header-hidden-separator-hover-color:var(--dh-color-grid-header-separator-hidden-hover);header-sort-bar-color:var(--dh-color-grid-header-sort-bar);header-reverse-bar-color:var(--dh-color-grid-header-reverse-bar);header-bar-casing-color:var(--dh-color-grid-header-bar-casing);header-font:600 12px Fira Sans,sans-serif;row-height:19px;row-background-colors:var(--dh-color-grid-row-0-bg) var(--dh-color-grid-row-1-bg);active-cell-selection-border-width:2px;selection-color:var(--dh-color-grid-selection);selection-outline-color:var(--dh-color-grid-selection-outline);selection-outline-casing-color:var(--dh-color-grid-selection-outline-casing);row-hover-bg:var(--dh-color-grid-row-hover-bg);row-shadow-alpha:var(--dh-color-grid-row-shadow-alpha);selected-row-hover-bg:var(--dh-color-grid-row-hover-bg-selected);scroll-bar-active-selection-tick-color:var(--dh-color-grid-scroll-bar-active-selection-tick);scroll-bar-bg:var(--dh-color-grid-scroll-bar-bg);scroll-bar-hover-bg:var(--dh-color-grid-scroll-bar-hover-bg);scroll-bar-casing-color:var(--dh-color-grid-scroll-bar-casing);scroll-bar-corner-color:var(--dh-color-grid-scroll-bar-corner);scroll-bar-color:var(--dh-color-grid-scroll-bar);scroll-bar-hover-color:var(--dh-color-grid-scroll-bar-hover);scroll-bar-active-color:var(--dh-color-grid-scroll-bar-active);text-color:var(--dh-color-grid-text);hyperlink-color:var(--dh-color-grid-text-hyperlink);positive-number-color:var(--dh-color-grid-number-positive);negative-number-color:var(--dh-color-grid-number-negative);zero-number-color:var(--dh-color-grid-number-zero);date-color:var(--dh-color-grid-date);pending-text-color:var(--dh-color-grid-text-pending);error-text-color:var(--dh-color-grid-text-error);null-string-color:var(--dh-color-grid-string-null);filter-bar-active-bg:var(--dh-color-grid-filter-bar-active-bg);filter-bar-active-color:var(--dh-color-grid-filter-bar-active);filter-bar-expanded-bg:var(--dh-color-grid-filter-bar-expanded-bg);filter-bar-expanded-active-bg:var(--dh-color-grid-filter-bar-expanded-active-bg);filter-bar-expanded-active-cell-bg:var(--dh-color-grid-filter-bar-expanded-active-cell-bg);filter-bar-separator-color:var(--dh-color-grid-filter-bar-separator);filter-bar-error-color:var(--dh-color-grid-filter-bar-error);filter-icon-color:var(--dh-color-grid-filter-icon);scrim-color:var(--dh-color-grid-scrim);context-menu-sort-icon-color:var(--dh-color-grid-context-menu-sort-icon);context-menu-reverse-icon-color:var(--dh-color-grid-context-menu-reverse-icon);linker-column-hover-bg:var(--dh-color-grid-column-linker-hover-bg);tree-line-color:var(--dh-color-grid-tree-line);tree-marker-color:var(--dh-color-grid-tree-marker);tree-marker-hover-color:var(--dh-color-grid-tree-marker-hover);grouped-column-divider-color:var(--dh-color-grid-column-grouped-divider);floating-grid-row-color:var(--dh-color-grid-floating-row);floating-row-background-colors:var(--dh-color-grid-floating-row-bg);floating-divider-inner-color:var(--dh-color-grid-floating-divider-inner);floating-divider-outer-color:var(--dh-color-grid-floating-divider-outer);overflow-button-color:var(--dh-color-grid-overflow-button);overflow-button-hover-color:var(--dh-color-grid-overflow-button-hover);zero-line-color:var(--dh-color-grid-data-bar-zero-line);positive-bar-color:var(--dh-color-grid-data-bar-positive);negative-bar-color:var(--dh-color-grid-data-bar-negative);marker-bar-color:var(--dh-color-grid-data-bar-marker)}.iris-grid{--table-sidebar-bg: var(--dh-color-surface-bg);--dh-color-hr: var(--dh-color-gray-500);width:100%;height:100%;position:relative;display:flex;flex-direction:row;overflow:hidden}.iris-grid .iris-grid-column{flex:1 1;min-width:0;transition:all .2s;display:flex;flex-direction:column;position:relative}.iris-grid .grid-cursor-copy{cursor:url(./cursor-copy-6c703498.svg) 8 8,copy}.iris-grid .grid-cursor-linker{cursor:url(./cursor-linker-07cb7513.svg) 8 8,crosshair}.iris-grid .grid-cursor-linker-not-allowed{cursor:url(./cursor-linker-not-allowed-7a84bf1f.svg) 8 8,not-allowed}.iris-grid .table-sidebar{height:100%;flex:0 0 320px;width:320px;max-width:320px;background:var(--table-sidebar-bg);box-shadow:0 0 6px var(--dh-color-dropshadow);z-index:1;position:absolute;right:0}.iris-grid .table-sidebar .pushing-view,.iris-grid .table-sidebar .popping-view,.iris-grid .table-sidebar .main-view{background:var(--table-sidebar-bg)}.iris-grid .table-sidebar.slide-left-enter-done{position:relative}.iris-grid .table-sidebar .navigation-content{overflow-y:auto}.iris-grid .section-title{padding:1rem 0;font-weight:500;text-align:left}.iris-grid .section-footer{flex-grow:2;display:flex;justify-content:flex-end;margin-bottom:1rem}.iris-grid .grid-wrapper{font:12px fira sans,sans-serif;font-feature-settings:"tnum";transition:all .2s}.iris-grid .grid-wrapper .grid-settings-button{position:absolute;top:0;right:0;height:30px;width:30px;background-color:var(--dh-color-grid-header-bg);border-bottom:1px solid var(--dh-color-grid-header-separator);transition:transform .2s ease-out,opacity .2s ease-out}.iris-grid .grid-wrapper .grid-settings-button .btn{height:100%;width:100%}.iris-grid .grid-wrapper .grid-settings-button .btn:after{border-radius:0}.iris-grid .grid-wrapper .grid-settings-button .btn:focus:after{box-shadow:none}.iris-grid .grid-wrapper .grid-settings-button.is-menu-shown{opacity:0}.iris-grid .grid-wrapper .grid-cell-input-field{color:var(--dh-color-input-fg);background:var(--dh-color-input-bg)}.iris-grid .grid-wrapper .grid-cell-input-field:focus{box-shadow:0 0 0 2px var(--dh-color-grid-selection-outline),0 0 0 5px color-mix(in srgb,var(--dh-color-accent) 25%,transparent)}.iris-grid .grid-wrapper .grid-cell-input-field.error{color:var(--dh-color-negative-bg)}.iris-grid .grid-wrapper .grid-cell-input-field.error:focus{box-shadow:0 0 0 2px var(--dh-color-negative),0 0 0 5px color-mix(in srgb,var(--dh-color-negative) 25%,transparent)}.iris-grid-loading{position:absolute;bottom:0;left:0;right:0;display:flex;flex-direction:column;justify-content:center;align-content:center}.iris-grid-loading-status{display:flex;position:absolute;bottom:0;left:0;z-index:30;min-width:min(320px,100%)}.iris-grid-loading-status .iris-grid-loading-status-bar{position:relative;padding:5px;background:var(--dh-color-content-bg, #2d2a2e);color:var(--dh-color-gray-700);border-top:1px solid var(--dh-color-gray-500);border-right:1px solid var(--dh-color-gray-500);overflow:hidden;word-wrap:break-word;z-index:2;flex-grow:1}.iris-grid-loading-status .iris-grid-loading-status-bar:after{content:"";position:absolute;bottom:0;left:0;width:100%;height:2px;z-index:-1;background:var(--dh-color-accent-bg);transform-origin:0% 50%;opacity:0}.iris-grid-loading-status .iris-grid-loading-status-bar.show:after{opacity:1;animation:1.5s indeterminateAnimation infinite linear}@keyframes indeterminateAnimation{0%{transform:translate(-50%) scaleX(.5)}50%{transform:translate(0) scaleX(.5)}to{transform:translate(100%) scaleX(.2)}}.iris-grid-loading-status .iris-grid-btn-cancel{z-index:1;opacity:0;border:1px solid var(--dh-color-gray-500);border-left:0;border-bottom:0;padding:0 7px 2px 4px;background:var(--dh-color-content-bg, #2d2a2e);color:var(--dh-color-gray-700);transform:translate(-100%);transition:all .1s ease-out 0s;white-space:nowrap;outline-offset:-1px;outline:var(--dh-color-accent-bg)}.iris-grid-loading-status .iris-grid-btn-cancel:hover{color:var(--dh-color-fg, #f0f0ee);background:var(--dh-color-negative-bg)}.iris-grid-loading-status .iris-grid-btn-cancel:focus{outline:1px solid var(--dh-color-accent-bg)}.iris-grid-loading-status .iris-grid-btn-cancel:active{background:var(--dh-color-negative-hover-bg)}.iris-grid-loading-status .iris-grid-btn-cancel:active:focus{outline-color:var(--dh-color-negative-bg)}.iris-grid-loading-status .iris-grid-btn-cancel.show{opacity:1;transform:translate(0);transition:all .25s ease-out .1s}.advanced-filter-button-container{background:none}.advanced-filter-button-container .advanced-filter-button{height:23px;margin:0}.advanced-filter-button-container .advanced-filter-button .filter-solid{opacity:0;transition:.15s opacity}.advanced-filter-button-container .advanced-filter-button .filter-light{opacity:1;transition:.15s opacity}.advanced-filter-button-container .advanced-filter-button.filter-set .filter-solid,.advanced-filter-button-container .advanced-filter-button:hover .filter-solid{opacity:1}.advanced-filter-button-container .advanced-filter-button.filter-set .filter-light,.advanced-filter-button-container .advanced-filter-button:hover .filter-light{opacity:0}.advanced-filter-button-container .advanced-filter-button:hover{color:var(--dh-color-gray-400)}.advanced-filter-button-container .advanced-filter-button:hover .filter-solid{color:var(--dh-color-accent-bg)}.advanced-filter-menu-popper{background:var(--dh-color-gray-400)}.advanced-filter-menu-popper .popper-content .advanced-filter-creator{max-height:550px;overflow-y:auto;background:var(--dh-color-gray-400);width:320px;box-shadow:none}.advanced-filter-menu-popper .popper-content .popper-arrow{border-color:var(--dh-color-gray-400)}.advanced-filter-menu-container{pointer-events:none;visibility:hidden}.iris-grid-bar{overflow:hidden;flex:0 0 auto}.iris-grid-bar.iris-grid-bar-horizontal-enter{max-height:0}.iris-grid-bar.iris-grid-bar-horizontal-enter-active{transition:background-color 1s ease-in,max-height .15s ease-in;max-height:250px}.iris-grid-bar.iris-grid-bar-horizontal-enter-done{max-height:250px}.iris-grid-bar.iris-grid-bar-horizontal-exit{max-height:250px;transition:max-height .15s ease-out}.iris-grid-bar.iris-grid-bar-horizontal-exit-active,.iris-grid-bar.iris-grid-bar-horizontal-exit-done{max-height:0}.iris-grid-bar.iris-grid-bar-vertical-enter{max-width:0}.iris-grid-bar.iris-grid-bar-vertical-enter-active{transition:background-color 1s ease-in,max-width .15s ease-in;max-width:320px}.iris-grid-bar.iris-grid-bar-vertical-enter-done{max-width:320px}.iris-grid-bar.iris-grid-bar-vertical-exit{max-width:320px;transition:max-width .15s ease-out}.iris-grid-bar.iris-grid-bar-vertical-exit-active,.iris-grid-bar.iris-grid-bar-vertical-exit-done{max-width:0}.iris-grid-bar-primary{background-color:var(--dh-color-accent-down-bg)}.iris-grid-bar-primary.iris-grid-bar-horizontal-enter,.iris-grid-bar-primary.iris-grid-bar-vertical-enter{background-color:var(--dh-color-accent-bg)}.link-hover-tooltip{text-align:left;max-width:500px;overflow-wrap:break-word}.cross-column-container{display:flex;flex-direction:row;margin:.25rem;align-items:stretch;flex:0 1 auto}.cross-column-container .cross-column-search{flex:1;margin-right:.25rem}.cross-column-popup{padding:.5rem 1rem .1rem}.cross-column-popup .cross-column-scroll{display:grid;grid-template-columns:max-content auto;grid-column-gap:.5rem;grid-row-gap:0;overflow-y:auto;max-height:15rem;padding:.2rem .5rem;border:1px solid var(--dh-color-input-border)}.cross-column-button-bar{display:flex}.cross-column-button-bar :last-child{margin-left:auto}.iris-grid-partition-selector{display:flex;flex-wrap:wrap;background:var(--dh-color-surface-bg);align-items:center;padding:.5rem;gap:.5rem}.iris-grid-partition-selector .column-selector{display:flex;align-items:center;gap:.5rem}.iris-grid-partition-selector .column-selector .custom-select{min-width:4rem}.iris-grid-partition-selector .partition-button-group{display:flex;border-right:1px solid var(--dh-color-hr);padding:0 .5rem;gap:.5rem}.select-distinct-builder-container{width:100%;height:100%;padding:0;overflow:auto;display:flex;justify-content:space-between;flex-flow:column}.select-distinct-builder-container .select-distinct-title{padding:1rem;font-weight:500;text-align:left}.select-distinct-builder-container .select-distinct-input-container{padding:1rem}.select-distinct-builder-container .select-distinct-builder-footer{margin:1rem;margin-bottom:auto;display:flex;flex-direction:column;padding-bottom:1rem}.select-distinct-builder-container .select-distinct-builder-hint{color:var(--dh-color-gray-600);font-size:smaller}.select-distinct-builder-container .select-distinct-builder-hint .inline-code-snippet{display:inline;color:var(--dh-color-visual-yellow);font-family:Fira Mono,menlo,monaco,consolas,Liberation Mono,Courier New,monospace}.select-distinct-builder-container hr{background:var(--dh-color-gray-300);margin:0;width:100%}.conditional-formatting-rules{padding:.25rem}.conditional-formatting-list-item{display:flex;flex-direction:row;margin-bottom:2px;padding:0 .25rem}.conditional-formatting-list-item:first-child{padding-top:.25rem}.conditional-formatting-list-item .formatting-item{border-radius:4px;display:flex;padding:.25rem;flex-grow:1;align-items:center;-webkit-user-select:none;user-select:none;transition:color .12s ease-in-out,background-color .12s ease-in-out,border-color .12s ease-in-out,box-shadow .12s ease-in-out;border:1px solid transparent;line-height:1.3;cursor:pointer}.conditional-formatting-list-item .formatting-item .btn-drag-handle{cursor:grab}.conditional-formatting-list-item .formatting-item .rule-icon{padding-right:.5rem}.conditional-formatting-list-item .formatting-item .rule-icon-bg{min-width:2rem;height:2rem;display:flex;font-size:x-small;justify-content:center;align-items:center}.conditional-formatting-list-item .formatting-item .rule-title{overflow-x:hidden;text-overflow:ellipsis;padding-right:2px;display:flex;flex-grow:1}.conditional-formatting-list-item .formatting-item:focus{outline:0;border:1px solid var(--dh-color-input-focus-border);box-shadow:0 0 0 .2rem color-mix(in srgb,var(--dh-color-accent) 35%,transparent)}.conditional-formatting-list-item .formatting-item:hover{background:var(--dh-color-item-list-hover-bg)}.dragging>.conditional-formatting-list-item .formatting-item{background:var(--dh-color-accent-bg);box-shadow:0 .1rem 1rem var(--dh-color-dropshadow);color:var(--dh-color-accent-contrast)}.dragging>.conditional-formatting-list-item .formatting-item .btn{color:var(--dh-color-accent-contrast)}.style-editor .cs-dropdown{display:flex;text-align:left;padding-left:.5rem;width:100%;justify-content:space-between;border-radius:4px;border:1px solid var(--dh-color-input-border);min-width:14rem;background-position:right .75rem center;background-size:10px 6px;background-repeat:no-repeat}.style-editor .cs-dropdown:focus{border-color:var(--dh-color-input-focus-border)}.style-editor .cs-dropdown.btn-inline:active{background:var(--dh-svg-icon-select-indicator) right .75rem center/10px 6px no-repeat,var(--dh-color-action-down-bg)}.style-dropdown-menu{border-radius:4px}.style-dropdown-menu .style-options{max-height:400px;overflow:auto}.style-dropdown-menu .style-option-btn{border:none;border-radius:0;width:100%;padding:.42145rem .75rem;white-space:nowrap;text-decoration:none;background-color:transparent;text-align:left;cursor:pointer;-webkit-user-select:none;user-select:none;display:block}.style-dropdown-menu .style-option-btn:hover{opacity:.8}.style-dropdown-menu .style-option-btn:focus{outline:none;box-shadow:none}.style-dropdown-menu .style-option-btn:first-child{border-top-left-radius:4px;border-top-right-radius:4px}.style-dropdown-menu .style-option-btn:last-child{border-bottom-left-radius:4px;border-bottom-right-radius:4px}.conditional-format-editor{padding:1rem}.conditional-format-editor .formatter-list{display:flex;justify-content:flex-start;padding-top:.5rem}.conditional-format-editor .formatter-type{margin:0 1rem 0 0;display:flex}.conditional-format-editor .btn-formatter-type{font-size:smaller;width:100%}.conditional-format-editor .color-select{padding:0 2em 0 .25em}.conditional-format-editor .dh-combobox{width:100%}.cell-overflow-modal .modal-title{width:100%;display:flex;align-items:center;gap:.5rem}.cell-overflow-modal .modal-title .overflow-modal-title{margin:0;flex-grow:1}.cell-overflow-modal .modal-body{max-height:80vh;flex-shrink:1}.iris-grid-bottom-bar.goto-row{height:auto}.goto-row{background-color:var(--dh-color-content-bg, #2d2a2e);border-top:1px solid var(--dh-color-black, #1a171a);display:block}.goto-row .goto-row-row{display:flex;padding:.5rem;justify-content:space-between;align-items:flex-start;gap:.5rem}.goto-row .goto-row-wrapper{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.goto-row .goto-row-text{min-width:10ch;margin:0;font-size:14px}.goto-row .goto-row-close{display:flex}.goto-row input{max-width:calc(1.5rem + 12ch)}.goto-row select{max-width:calc(1.5rem + 25ch)}.goto-row .is-inactive{color:var(--dh-color-gray-600)}.goto-row .goto-value-date-time-input{min-width:30ch}