diff --git a/package.json b/package.json
index f872c28904..ad7c33006a 100644
--- a/package.json
+++ b/package.json
@@ -31,6 +31,7 @@
"build:profile": "lerna run build --stream --profile",
"build:necessary": "lerna run build --scope=@deephaven/icons",
"analyze": "lerna run analyze",
+ "lint:packages": "eslint \"packages/*/src/**/*.{ts,tsx,js,jsx}\"",
"preview": "lerna run --scope=@deephaven/{code-studio,embed-widget} preview --stream",
"preview:app": "lerna run --scope=@deephaven/code-studio preview --stream",
"prestart": "npm run build:necessary",
diff --git a/packages/app-utils/src/components/AppBootstrap.test.tsx b/packages/app-utils/src/components/AppBootstrap.test.tsx
index 538fbae2a0..835c48c11c 100644
--- a/packages/app-utils/src/components/AppBootstrap.test.tsx
+++ b/packages/app-utils/src/components/AppBootstrap.test.tsx
@@ -2,7 +2,7 @@ import React, { useContext } from 'react';
import { act, render, screen } from '@testing-library/react';
import { AUTH_HANDLER_TYPE_ANONYMOUS } from '@deephaven/auth-plugins';
import { ApiContext } from '@deephaven/jsapi-bootstrap';
-import { PluginModuleMap, PluginsContext } from '@deephaven/plugin';
+import { type PluginModuleMap, PluginsContext } from '@deephaven/plugin';
import { BROADCAST_LOGIN_MESSAGE } from '@deephaven/jsapi-utils';
import type {
CoreClient,
diff --git a/packages/app-utils/src/components/AppDashboards.tsx b/packages/app-utils/src/components/AppDashboards.tsx
index 3c59bdfb9d..18d91e8029 100644
--- a/packages/app-utils/src/components/AppDashboards.tsx
+++ b/packages/app-utils/src/components/AppDashboards.tsx
@@ -2,14 +2,15 @@ import React, { useCallback } from 'react';
import classNames from 'classnames';
import {
DashboardUtils,
- DehydratedDashboardPanelProps,
+ type DehydratedDashboardPanelProps,
LazyDashboard,
} from '@deephaven/dashboard';
import { useObjectFetcher } from '@deephaven/jsapi-bootstrap';
-import LayoutManager, {
- ItemConfig,
- Settings as LayoutSettings,
+import {
+ type ItemConfig,
+ type Settings as LayoutSettings,
} from '@deephaven/golden-layout';
+import type LayoutManager from '@deephaven/golden-layout';
import { LoadingOverlay } from '@deephaven/components';
interface AppDashboardsProps {
diff --git a/packages/app-utils/src/components/AuthBootstrap.tsx b/packages/app-utils/src/components/AuthBootstrap.tsx
index 38c9ce769f..2fd03942ea 100644
--- a/packages/app-utils/src/components/AuthBootstrap.tsx
+++ b/packages/app-utils/src/components/AuthBootstrap.tsx
@@ -1,6 +1,6 @@
import React, { useContext, useEffect, useMemo, useState } from 'react';
import {
- AuthConfigMap,
+ type AuthConfigMap,
AuthPluginAnonymous,
AuthPluginParent,
AuthPluginPsk,
diff --git a/packages/app-utils/src/components/ConnectionBootstrap.tsx b/packages/app-utils/src/components/ConnectionBootstrap.tsx
index cc320e99a5..c0e8a55b94 100644
--- a/packages/app-utils/src/components/ConnectionBootstrap.tsx
+++ b/packages/app-utils/src/components/ConnectionBootstrap.tsx
@@ -8,7 +8,7 @@ import {
} from '@deephaven/components';
import {
ObjectFetcherContext,
- ObjectFetchManager,
+ type ObjectFetchManager,
ObjectFetchManagerContext,
sanitizeVariableDescriptor,
useApi,
diff --git a/packages/app-utils/src/plugins/PluginUtils.test.ts b/packages/app-utils/src/plugins/PluginUtils.test.ts
index f21a2ebeb6..15d805c515 100644
--- a/packages/app-utils/src/plugins/PluginUtils.test.ts
+++ b/packages/app-utils/src/plugins/PluginUtils.test.ts
@@ -1,4 +1,4 @@
-import { LegacyPlugin, Plugin, PluginType } from '@deephaven/plugin';
+import { type LegacyPlugin, type Plugin, PluginType } from '@deephaven/plugin';
import { getPluginModuleValue } from './PluginUtils';
describe('getPluginModuleValue', () => {
diff --git a/packages/app-utils/src/plugins/PluginUtils.tsx b/packages/app-utils/src/plugins/PluginUtils.tsx
index 4ae7ee4086..0e88c5a7fc 100644
--- a/packages/app-utils/src/plugins/PluginUtils.tsx
+++ b/packages/app-utils/src/plugins/PluginUtils.tsx
@@ -4,13 +4,13 @@ import {
type AuthPlugin,
type AuthPluginComponent,
isAuthPlugin,
- LegacyAuthPlugin,
- LegacyPlugin,
- Plugin,
+ type LegacyAuthPlugin,
+ type LegacyPlugin,
+ type Plugin,
PluginType,
isLegacyAuthPlugin,
isLegacyPlugin,
- PluginModule,
+ type PluginModule,
isPlugin,
} from '@deephaven/plugin';
import loadRemoteModule from './loadRemoteModule';
diff --git a/packages/app-utils/src/storage/LayoutStorage.ts b/packages/app-utils/src/storage/LayoutStorage.ts
index 406269640b..b2f2a50c64 100644
--- a/packages/app-utils/src/storage/LayoutStorage.ts
+++ b/packages/app-utils/src/storage/LayoutStorage.ts
@@ -1,6 +1,6 @@
import type { ItemConfig } from '@deephaven/golden-layout';
-import { FilterSet, Link } from '@deephaven/dashboard-core-plugins';
-import { PluginDataMap } from '@deephaven/redux';
+import { type FilterSet, type Link } from '@deephaven/dashboard-core-plugins';
+import { type PluginDataMap } from '@deephaven/redux';
/**
* Have a different version to support legacy layout exports
diff --git a/packages/app-utils/src/storage/LocalWorkspaceStorage.ts b/packages/app-utils/src/storage/LocalWorkspaceStorage.ts
index 1c0bb82460..bb09511c6a 100644
--- a/packages/app-utils/src/storage/LocalWorkspaceStorage.ts
+++ b/packages/app-utils/src/storage/LocalWorkspaceStorage.ts
@@ -1,11 +1,11 @@
import Log from '@deephaven/log';
import {
- WorkspaceStorage,
- WorkspaceStorageLoadOptions,
- CustomizableWorkspaceData,
- CustomizableWorkspace,
- WorkspaceSettings,
- ServerConfigValues,
+ type WorkspaceStorage,
+ type WorkspaceStorageLoadOptions,
+ type CustomizableWorkspaceData,
+ type CustomizableWorkspace,
+ type WorkspaceSettings,
+ type ServerConfigValues,
} from '@deephaven/redux';
import {
DateTimeColumnFormatter,
@@ -13,7 +13,7 @@ import {
IntegerColumnFormatter,
} from '@deephaven/jsapi-utils';
import UserLayoutUtils from './UserLayoutUtils';
-import LayoutStorage from './LayoutStorage';
+import type LayoutStorage from './LayoutStorage';
const log = Log.module('LocalWorkspaceStorage');
diff --git a/packages/app-utils/src/storage/UserLayoutUtils.test.ts b/packages/app-utils/src/storage/UserLayoutUtils.test.ts
index 7b8041e3a7..362b0bdbfc 100644
--- a/packages/app-utils/src/storage/UserLayoutUtils.test.ts
+++ b/packages/app-utils/src/storage/UserLayoutUtils.test.ts
@@ -1,10 +1,11 @@
-import { FilterSet, Link } from '@deephaven/dashboard-core-plugins';
+import { type FilterSet, type Link } from '@deephaven/dashboard-core-plugins';
import type { ItemConfig } from '@deephaven/golden-layout';
-import LayoutStorage, {
- ExportedLayout,
- ExportedLayoutV1,
- ExportedLayoutV2,
+import {
+ type ExportedLayout,
+ type ExportedLayoutV1,
+ type ExportedLayoutV2,
} from './LayoutStorage';
+import type LayoutStorage from './LayoutStorage';
import UserLayoutUtils, {
DEFAULT_LAYOUT_CONFIG,
DEFAULT_LAYOUT_CONFIG_NO_CONSOLE,
diff --git a/packages/app-utils/src/storage/UserLayoutUtils.ts b/packages/app-utils/src/storage/UserLayoutUtils.ts
index ece3351a62..9fbf1502be 100644
--- a/packages/app-utils/src/storage/UserLayoutUtils.ts
+++ b/packages/app-utils/src/storage/UserLayoutUtils.ts
@@ -5,13 +5,14 @@ import {
LogPanel,
} from '@deephaven/dashboard-core-plugins';
import Log from '@deephaven/log';
-import { CustomizableWorkspaceData } from '@deephaven/redux';
-import LayoutStorage, {
- ExportedLayout,
- ExportedLayoutV2,
+import { type CustomizableWorkspaceData } from '@deephaven/redux';
+import {
+ type ExportedLayout,
+ type ExportedLayoutV2,
isLayoutV1,
isLayoutV2,
} from './LayoutStorage';
+import type LayoutStorage from './LayoutStorage';
const log = Log.module('UserLayoutUtils');
diff --git a/packages/app-utils/src/storage/grpc/GrpcFileStorage.ts b/packages/app-utils/src/storage/grpc/GrpcFileStorage.ts
index 9eee39be2e..fb331b832f 100644
--- a/packages/app-utils/src/storage/grpc/GrpcFileStorage.ts
+++ b/packages/app-utils/src/storage/grpc/GrpcFileStorage.ts
@@ -1,10 +1,10 @@
import throttle from 'lodash.throttle';
import {
FileNotFoundError,
- FileStorage,
- File,
- FileStorageItem,
- FileStorageTable,
+ type FileStorage,
+ type File,
+ type FileStorageItem,
+ type FileStorageTable,
FileUtils,
isFileType,
} from '@deephaven/file-explorer';
diff --git a/packages/app-utils/src/storage/grpc/GrpcFileStorageTable.ts b/packages/app-utils/src/storage/grpc/GrpcFileStorageTable.ts
index ef56f52ea2..d4b8214e55 100644
--- a/packages/app-utils/src/storage/grpc/GrpcFileStorageTable.ts
+++ b/packages/app-utils/src/storage/grpc/GrpcFileStorageTable.ts
@@ -2,21 +2,21 @@
import Log from '@deephaven/log';
import {
- StorageTableViewport,
- StorageListenerRemover,
- ViewportUpdateCallback,
- ViewportData,
- IndexRange,
- StorageSnapshot,
+ type StorageTableViewport,
+ type StorageListenerRemover,
+ type ViewportUpdateCallback,
+ type ViewportData,
+ type IndexRange,
+ type StorageSnapshot,
} from '@deephaven/storage';
import {
- CancelablePromise,
+ type CancelablePromise,
CanceledPromiseError,
PromiseUtils,
} from '@deephaven/utils';
import {
- FileStorageItem,
- FileStorageTable,
+ type FileStorageItem,
+ type FileStorageTable,
FileUtils,
} from '@deephaven/file-explorer';
import type { dh } from '@deephaven/jsapi-types';
diff --git a/packages/app-utils/src/storage/grpc/GrpcLayoutStorage.ts b/packages/app-utils/src/storage/grpc/GrpcLayoutStorage.ts
index 049488271b..1b9961c02e 100644
--- a/packages/app-utils/src/storage/grpc/GrpcLayoutStorage.ts
+++ b/packages/app-utils/src/storage/grpc/GrpcLayoutStorage.ts
@@ -1,5 +1,6 @@
import type { dh } from '@deephaven/jsapi-types';
-import LayoutStorage, { ExportedLayout } from '../LayoutStorage';
+import { type ExportedLayout } from '../LayoutStorage';
+import type LayoutStorage from '../LayoutStorage';
export class GrpcLayoutStorage implements LayoutStorage {
readonly storageService: dh.storage.StorageService;
diff --git a/packages/auth-plugins/src/AuthPlugin.ts b/packages/auth-plugins/src/AuthPlugin.ts
index 44f6f25f6c..c82057b62c 100644
--- a/packages/auth-plugins/src/AuthPlugin.ts
+++ b/packages/auth-plugins/src/AuthPlugin.ts
@@ -1,4 +1,4 @@
-import React from 'react';
+import type React from 'react';
/**
* Map from auth config keys to their values
diff --git a/packages/auth-plugins/src/AuthPluginAnonymous.test.tsx b/packages/auth-plugins/src/AuthPluginAnonymous.test.tsx
index a4f5e44876..26cd5762f7 100644
--- a/packages/auth-plugins/src/AuthPluginAnonymous.test.tsx
+++ b/packages/auth-plugins/src/AuthPluginAnonymous.test.tsx
@@ -5,7 +5,7 @@ import { dh } from '@deephaven/jsapi-shim';
import type { CoreClient } from '@deephaven/jsapi-types';
import AuthPluginAnonymous from './AuthPluginAnonymous';
import { AUTH_HANDLER_TYPE_ANONYMOUS as AUTH_TYPE } from './AuthHandlerTypes';
-import { AuthConfigMap } from './AuthPlugin';
+import { type AuthConfigMap } from './AuthPlugin';
const mockChildText = 'Mock Auth Anonymous Child';
const mockChild =
{mockChildText}
;
diff --git a/packages/auth-plugins/src/AuthPluginAnonymous.tsx b/packages/auth-plugins/src/AuthPluginAnonymous.tsx
index d3c4fa6d07..69db57380a 100644
--- a/packages/auth-plugins/src/AuthPluginAnonymous.tsx
+++ b/packages/auth-plugins/src/AuthPluginAnonymous.tsx
@@ -1,10 +1,10 @@
import React, { useCallback } from 'react';
import { useApi } from '@deephaven/jsapi-bootstrap';
import { AUTH_HANDLER_TYPE_ANONYMOUS } from './AuthHandlerTypes';
-import { AuthPlugin, AuthPluginProps } from './AuthPlugin';
+import { type AuthPlugin, type AuthPluginProps } from './AuthPlugin';
import AuthPluginBase from './AuthPluginBase';
import {
- UserPermissionsOverride,
+ type UserPermissionsOverride,
UserPermissionsOverrideContext,
} from './UserContexts';
diff --git a/packages/auth-plugins/src/AuthPluginParent.test.tsx b/packages/auth-plugins/src/AuthPluginParent.test.tsx
index 5a30ba33fe..9415cc261c 100644
--- a/packages/auth-plugins/src/AuthPluginParent.test.tsx
+++ b/packages/auth-plugins/src/AuthPluginParent.test.tsx
@@ -5,7 +5,7 @@ import { dh } from '@deephaven/jsapi-shim';
import type { CoreClient, LoginOptions } from '@deephaven/jsapi-types';
import { TestUtils } from '@deephaven/test-utils';
import AuthPluginParent from './AuthPluginParent';
-import { AuthConfigMap } from './AuthPlugin';
+import { type AuthConfigMap } from './AuthPlugin';
let mockParentResponse: Promise;
jest.mock('@deephaven/jsapi-utils', () => ({
diff --git a/packages/auth-plugins/src/AuthPluginParent.tsx b/packages/auth-plugins/src/AuthPluginParent.tsx
index dc121711b7..d8f01e3e2e 100644
--- a/packages/auth-plugins/src/AuthPluginParent.tsx
+++ b/packages/auth-plugins/src/AuthPluginParent.tsx
@@ -6,10 +6,10 @@ import {
requestParentResponse,
} from '@deephaven/jsapi-utils';
import Log from '@deephaven/log';
-import { AuthPlugin, AuthPluginProps } from './AuthPlugin';
+import { type AuthPlugin, type AuthPluginProps } from './AuthPlugin';
import AuthPluginBase from './AuthPluginBase';
import {
- UserPermissionsOverride,
+ type UserPermissionsOverride,
UserPermissionsOverrideContext,
} from './UserContexts';
diff --git a/packages/auth-plugins/src/AuthPluginPsk.test.tsx b/packages/auth-plugins/src/AuthPluginPsk.test.tsx
index f0dc97ba76..f6affb60db 100644
--- a/packages/auth-plugins/src/AuthPluginPsk.test.tsx
+++ b/packages/auth-plugins/src/AuthPluginPsk.test.tsx
@@ -1,4 +1,4 @@
-import React, { ReactNode } from 'react';
+import React, { type ReactNode } from 'react';
import Cookies from 'js-cookie';
import { act, render, screen } from '@testing-library/react';
import userEvent from '@testing-library/user-event';
@@ -8,7 +8,7 @@ import { dh } from '@deephaven/jsapi-shim';
import type { CoreClient } from '@deephaven/jsapi-types';
import AuthPluginPsk from './AuthPluginPsk';
import { AUTH_HANDLER_TYPE_PSK as AUTH_TYPE } from './AuthHandlerTypes';
-import { AuthConfigMap } from './AuthPlugin';
+import { type AuthConfigMap } from './AuthPlugin';
let mockOnBroadcastLogin = jest.fn();
let mockOnBroadcastLogout = jest.fn();
diff --git a/packages/auth-plugins/src/AuthPluginPsk.tsx b/packages/auth-plugins/src/AuthPluginPsk.tsx
index b11ef5ebc5..71638e05bf 100644
--- a/packages/auth-plugins/src/AuthPluginPsk.tsx
+++ b/packages/auth-plugins/src/AuthPluginPsk.tsx
@@ -5,7 +5,7 @@ import { useBroadcastLoginListener } from '@deephaven/jsapi-components';
import Log from '@deephaven/log';
import { getErrorMessage } from '@deephaven/utils';
import Cookies from 'js-cookie';
-import { AuthPlugin, AuthPluginProps } from './AuthPlugin';
+import { type AuthPlugin, type AuthPluginProps } from './AuthPlugin';
import LoginForm from './LoginForm';
import Login from './Login';
import AuthenticationError from './AuthenticationError';
diff --git a/packages/auth-plugins/src/LoginForm.tsx b/packages/auth-plugins/src/LoginForm.tsx
index cd2a68f971..ba88268656 100644
--- a/packages/auth-plugins/src/LoginForm.tsx
+++ b/packages/auth-plugins/src/LoginForm.tsx
@@ -1,6 +1,6 @@
import { LoadingSpinner } from '@deephaven/components';
import classNames from 'classnames';
-import React, { FormEventHandler } from 'react';
+import React, { type FormEventHandler } from 'react';
import './LoginForm.scss';
export interface LoginFormProps {
diff --git a/packages/auth-plugins/src/UserContexts.ts b/packages/auth-plugins/src/UserContexts.ts
index 9276c5ca72..e3bcf2f31e 100644
--- a/packages/auth-plugins/src/UserContexts.ts
+++ b/packages/auth-plugins/src/UserContexts.ts
@@ -1,5 +1,5 @@
import { createContext } from 'react';
-import { User, UserPermissions } from '@deephaven/redux';
+import { type User, type UserPermissions } from '@deephaven/redux';
export type UserOverride = Partial>;
diff --git a/packages/auth-plugins/src/UserUtils.ts b/packages/auth-plugins/src/UserUtils.ts
index a79d5d1df8..2d6cd908cd 100644
--- a/packages/auth-plugins/src/UserUtils.ts
+++ b/packages/auth-plugins/src/UserUtils.ts
@@ -1,4 +1,4 @@
-import { User, UserPermissions } from '@deephaven/redux';
+import { type User, type UserPermissions } from '@deephaven/redux';
import Log from '@deephaven/log';
const log = Log.module('UserUtils');
diff --git a/packages/chart/src/Chart.tsx b/packages/chart/src/Chart.tsx
index 2b389233ed..e8db80b798 100644
--- a/packages/chart/src/Chart.tsx
+++ b/packages/chart/src/Chart.tsx
@@ -1,31 +1,31 @@
-import React, { Component, ReactElement, RefObject } from 'react';
+import React, { Component, type ReactElement, type RefObject } from 'react';
import deepEqual from 'fast-deep-equal';
import memoize from 'memoize-one';
import {
vsLoading,
dhGraphLineDown,
dhWarningFilled,
- IconDefinition,
+ type IconDefinition,
} from '@deephaven/icons';
import {
Formatter,
FormatterUtils,
DateUtils,
- DateTimeColumnFormatterOptions,
- DecimalColumnFormatterOptions,
- IntegerColumnFormatterOptions,
- FormattingRule,
- ColumnFormatSettings,
- DateTimeFormatSettings,
+ type DateTimeColumnFormatterOptions,
+ type DecimalColumnFormatterOptions,
+ type IntegerColumnFormatterOptions,
+ type FormattingRule,
+ type ColumnFormatSettings,
+ type DateTimeFormatSettings,
} from '@deephaven/jsapi-utils';
import Log from '@deephaven/log';
import {
- Config as PlotlyConfig,
- Layout,
- Icon,
- Data,
- PlotData,
- ModeBarButtonAny,
+ type Config as PlotlyConfig,
+ type Layout,
+ type Icon,
+ type Data,
+ type PlotData,
+ type ModeBarButtonAny,
} from 'plotly.js';
import type { PlotParams } from 'react-plotly.js';
import { mergeRefs } from '@deephaven/react-hooks';
@@ -34,8 +34,8 @@ import createPlotlyComponent from './plotly/createPlotlyComponent';
import Plotly from './plotly/Plotly';
import ChartModel from './ChartModel';
import ChartErrorOverlay from './ChartErrorOverlay';
-import { ChartTheme } from './ChartTheme';
-import ChartUtils, { ChartModelSettings } from './ChartUtils';
+import { type ChartTheme } from './ChartTheme';
+import ChartUtils, { type ChartModelSettings } from './ChartUtils';
import './Chart.scss';
import DownsamplingError from './DownsamplingError';
import useChartTheme from './useChartTheme';
diff --git a/packages/chart/src/ChartErrorOverlay.tsx b/packages/chart/src/ChartErrorOverlay.tsx
index 4a5693dfc1..36c22cd42a 100644
--- a/packages/chart/src/ChartErrorOverlay.tsx
+++ b/packages/chart/src/ChartErrorOverlay.tsx
@@ -1,4 +1,4 @@
-import { ReactElement } from 'react';
+import { type ReactElement } from 'react';
import { CopyButton, Button } from '@deephaven/components';
import './ChartErrorOverlay.scss';
diff --git a/packages/chart/src/ChartModel.ts b/packages/chart/src/ChartModel.ts
index 0cf03815af..f1cce72b8a 100644
--- a/packages/chart/src/ChartModel.ts
+++ b/packages/chart/src/ChartModel.ts
@@ -2,9 +2,9 @@
/* eslint no-unused-vars: "off" */
import type { dh as DhType } from '@deephaven/jsapi-types';
-import { Formatter } from '@deephaven/jsapi-utils';
+import { type Formatter } from '@deephaven/jsapi-utils';
import type { Layout, Data } from 'plotly.js';
-import { FilterColumnMap, FilterMap } from './ChartUtils';
+import { type FilterColumnMap, type FilterMap } from './ChartUtils';
export type ChartEvent = CustomEvent;
diff --git a/packages/chart/src/ChartModelFactory.ts b/packages/chart/src/ChartModelFactory.ts
index 34606f5a80..65d158bf4b 100644
--- a/packages/chart/src/ChartModelFactory.ts
+++ b/packages/chart/src/ChartModelFactory.ts
@@ -1,7 +1,7 @@
import type { dh as DhType } from '@deephaven/jsapi-types';
-import ChartUtils, { ChartModelSettings } from './ChartUtils';
+import ChartUtils, { type ChartModelSettings } from './ChartUtils';
import FigureChartModel from './FigureChartModel';
-import ChartModel from './ChartModel';
+import type ChartModel from './ChartModel';
class ChartModelFactory {
/**
diff --git a/packages/chart/src/ChartThemeProvider.tsx b/packages/chart/src/ChartThemeProvider.tsx
index 0cd0eeabf5..4a41a608bd 100644
--- a/packages/chart/src/ChartThemeProvider.tsx
+++ b/packages/chart/src/ChartThemeProvider.tsx
@@ -1,6 +1,6 @@
-import { createContext, ReactNode, useMemo } from 'react';
+import { createContext, type ReactNode, useMemo } from 'react';
import { useTheme } from '@deephaven/components';
-import defaultChartTheme, { ChartTheme } from './ChartTheme';
+import defaultChartTheme, { type ChartTheme } from './ChartTheme';
export type ChartThemeContextValue = ChartTheme;
diff --git a/packages/chart/src/ChartUtils.test.ts b/packages/chart/src/ChartUtils.test.ts
index 67c41a4f51..38a3fb8dd4 100644
--- a/packages/chart/src/ChartUtils.test.ts
+++ b/packages/chart/src/ChartUtils.test.ts
@@ -1,6 +1,6 @@
import dh from '@deephaven/jsapi-shim';
import { Formatter } from '@deephaven/jsapi-utils';
-import { Layout } from 'plotly.js';
+import { type Layout } from 'plotly.js';
import ChartUtils from './ChartUtils';
import ChartTestUtils from './ChartTestUtils';
import type { ChartTheme } from './ChartTheme';
diff --git a/packages/chart/src/ChartUtils.ts b/packages/chart/src/ChartUtils.ts
index ce66ae77ee..efb0f78cbe 100644
--- a/packages/chart/src/ChartUtils.ts
+++ b/packages/chart/src/ChartUtils.ts
@@ -1,8 +1,8 @@
import Log from '@deephaven/log';
import {
- DateTimeColumnFormatter,
- Formatter,
- TableColumnFormatter,
+ type DateTimeColumnFormatter,
+ type Formatter,
+ type TableColumnFormatter,
TableUtils,
} from '@deephaven/jsapi-utils';
import type { dh as DhType } from '@deephaven/jsapi-types';
@@ -18,8 +18,8 @@ import type {
MarkerSymbol,
Template,
} from 'plotly.js';
-import { assertNotNull, bindAllMethods, Range } from '@deephaven/utils';
-import { ChartTheme } from './ChartTheme';
+import { assertNotNull, bindAllMethods, type Range } from '@deephaven/utils';
+import { type ChartTheme } from './ChartTheme';
export type FilterColumnMap = Map<
string,
diff --git a/packages/chart/src/FigureChartModel.test.ts b/packages/chart/src/FigureChartModel.test.ts
index 4cb6b1689e..af3df563f4 100644
--- a/packages/chart/src/FigureChartModel.test.ts
+++ b/packages/chart/src/FigureChartModel.test.ts
@@ -1,5 +1,5 @@
import dh from '@deephaven/jsapi-shim';
-import { Data } from 'plotly.js';
+import { type Data } from 'plotly.js';
import ChartTestUtils from './ChartTestUtils';
import FigureChartModel from './FigureChartModel';
diff --git a/packages/chart/src/FigureChartModel.ts b/packages/chart/src/FigureChartModel.ts
index a96cf03def..95c4531f2d 100644
--- a/packages/chart/src/FigureChartModel.ts
+++ b/packages/chart/src/FigureChartModel.ts
@@ -4,7 +4,7 @@ import debounce from 'lodash.debounce';
import set from 'lodash.set';
import type { dh as DhType } from '@deephaven/jsapi-types';
import Log from '@deephaven/log';
-import { Range } from '@deephaven/utils';
+import { type Range } from '@deephaven/utils';
import type {
Annotations,
Layout,
@@ -17,12 +17,12 @@ import type {
DateTimeColumnFormatter,
Formatter,
} from '@deephaven/jsapi-utils';
-import ChartModel, { ChartEvent, RenderOptions } from './ChartModel';
+import ChartModel, { type ChartEvent, type RenderOptions } from './ChartModel';
import ChartUtils, {
- AxisTypeMap,
- ChartModelSettings,
- FilterColumnMap,
- FilterMap,
+ type AxisTypeMap,
+ type ChartModelSettings,
+ type FilterColumnMap,
+ type FilterMap,
} from './ChartUtils';
const log = Log.module('FigureChartModel');
diff --git a/packages/chart/src/MockChartModel.ts b/packages/chart/src/MockChartModel.ts
index 0cf67434cb..5ea18ce2fb 100644
--- a/packages/chart/src/MockChartModel.ts
+++ b/packages/chart/src/MockChartModel.ts
@@ -4,7 +4,7 @@
import type { dh as DhType } from '@deephaven/jsapi-types';
import type { Datum, Layout, PlotData } from 'plotly.js';
import ChartModel from './ChartModel';
-import { ChartTheme, defaultChartTheme } from './ChartTheme';
+import { type ChartTheme, defaultChartTheme } from './ChartTheme';
import ChartUtils from './ChartUtils';
interface Series {
diff --git a/packages/chart/src/isFigureChartModel.ts b/packages/chart/src/isFigureChartModel.ts
index 208535fc07..e7bd2a9c35 100644
--- a/packages/chart/src/isFigureChartModel.ts
+++ b/packages/chart/src/isFigureChartModel.ts
@@ -1,5 +1,5 @@
-import ChartModel from './ChartModel';
-import FigureChartModel from './FigureChartModel';
+import type ChartModel from './ChartModel';
+import type FigureChartModel from './FigureChartModel';
export default function isFigureChartModel(
model: ChartModel
diff --git a/packages/chart/src/useChartTheme.tsx b/packages/chart/src/useChartTheme.tsx
index c3a6eb0004..cd115e39f1 100644
--- a/packages/chart/src/useChartTheme.tsx
+++ b/packages/chart/src/useChartTheme.tsx
@@ -2,7 +2,7 @@ import { useContextOrThrow } from '@deephaven/react-hooks';
import {
ChartThemeContext,
- ChartThemeContextValue,
+ type ChartThemeContextValue,
} from './ChartThemeProvider';
/**
diff --git a/packages/code-studio/src/components/DateInput.tsx b/packages/code-studio/src/components/DateInput.tsx
index 3e88abb72f..7f12dc7af5 100644
--- a/packages/code-studio/src/components/DateInput.tsx
+++ b/packages/code-studio/src/components/DateInput.tsx
@@ -1,8 +1,8 @@
-import React, { useState, ReactElement } from 'react';
+import React, { useState, type ReactElement } from 'react';
import dh from '@deephaven/jsapi-shim';
import type { dh as DhType } from '@deephaven/jsapi-types';
import Log from '@deephaven/log';
-import { MaskedInput, SelectionSegment } from '@deephaven/components';
+import { MaskedInput, type SelectionSegment } from '@deephaven/components';
const log = Log.module('DateInput');
diff --git a/packages/code-studio/src/log/LogInit.ts b/packages/code-studio/src/log/LogInit.ts
index 6e2d6decf6..7779de1dd2 100644
--- a/packages/code-studio/src/log/LogInit.ts
+++ b/packages/code-studio/src/log/LogInit.ts
@@ -1,4 +1,4 @@
-import { LogProxy, LogHistory, Logger, Log } from '@deephaven/log';
+import { LogProxy, LogHistory, type Logger, Log } from '@deephaven/log';
declare global {
interface Window {
diff --git a/packages/code-studio/src/main/App.tsx b/packages/code-studio/src/main/App.tsx
index c9a717d0b4..027e837ad7 100644
--- a/packages/code-studio/src/main/App.tsx
+++ b/packages/code-studio/src/main/App.tsx
@@ -1,4 +1,4 @@
-import React, { ReactElement } from 'react';
+import React, { type ReactElement } from 'react';
import { ContextMenuRoot } from '@deephaven/components';
import AppMainContainer from './AppMainContainer';
diff --git a/packages/code-studio/src/main/AppControlsMenu.tsx b/packages/code-studio/src/main/AppControlsMenu.tsx
index 17d7355ea8..914ba38796 100644
--- a/packages/code-studio/src/main/AppControlsMenu.tsx
+++ b/packages/code-studio/src/main/AppControlsMenu.tsx
@@ -4,12 +4,12 @@ import React, {
useCallback,
useState,
useMemo,
- ReactNode,
- ReactElement,
+ type ReactNode,
+ type ReactElement,
} from 'react';
import classNames from 'classnames';
import {
- DropdownAction,
+ type DropdownAction,
DropdownMenu,
GLOBAL_SHORTCUTS,
} from '@deephaven/components';
diff --git a/packages/code-studio/src/main/AppInit.tsx b/packages/code-studio/src/main/AppInit.tsx
index b785e88f6c..6a5662e595 100644
--- a/packages/code-studio/src/main/AppInit.tsx
+++ b/packages/code-studio/src/main/AppInit.tsx
@@ -17,7 +17,7 @@ import Log from '@deephaven/log';
import { PouchCommandHistoryStorage } from '@deephaven/pouch-storage';
import {
getWorkspace,
- RootState,
+ type RootState,
setActiveTool,
setApi,
setCommandHistoryStorage,
diff --git a/packages/code-studio/src/main/AppMainContainer.test.tsx b/packages/code-studio/src/main/AppMainContainer.test.tsx
index 6f99090981..b48dd74e97 100644
--- a/packages/code-studio/src/main/AppMainContainer.test.tsx
+++ b/packages/code-studio/src/main/AppMainContainer.test.tsx
@@ -5,12 +5,12 @@ import { act, render, screen } from '@testing-library/react';
import {
ConnectionContext,
LocalWorkspaceStorage,
- LayoutStorage,
+ type LayoutStorage,
} from '@deephaven/app-utils';
import { ToolType } from '@deephaven/dashboard-core-plugins';
import {
ApiContext,
- ObjectFetcher,
+ type ObjectFetcher,
ObjectFetcherContext,
} from '@deephaven/jsapi-bootstrap';
import dh from '@deephaven/jsapi-shim';
@@ -20,7 +20,7 @@ import type {
VariableChanges,
} from '@deephaven/jsapi-types';
import { TestUtils } from '@deephaven/test-utils';
-import { Workspace, createMockStore } from '@deephaven/redux';
+import { type Workspace, createMockStore } from '@deephaven/redux';
import userEvent from '@testing-library/user-event';
import { DEFAULT_DASHBOARD_ID } from '@deephaven/dashboard';
import { AppMainContainer } from './AppMainContainer';
diff --git a/packages/code-studio/src/main/AppMainContainer.tsx b/packages/code-studio/src/main/AppMainContainer.tsx
index fd2c6000bb..d80063a935 100644
--- a/packages/code-studio/src/main/AppMainContainer.tsx
+++ b/packages/code-studio/src/main/AppMainContainer.tsx
@@ -1,21 +1,21 @@
import React, {
- ClipboardEvent,
- ChangeEvent,
+ type ClipboardEvent,
+ type ChangeEvent,
Component,
- ReactElement,
- RefObject,
+ type ReactElement,
+ type RefObject,
} from 'react';
import classNames from 'classnames';
import memoize from 'memoize-one';
import { connect } from 'react-redux';
-import { RouteComponentProps, withRouter } from 'react-router-dom';
+import { type RouteComponentProps, withRouter } from 'react-router-dom';
import { nanoid } from 'nanoid';
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
import {
ContextActions,
GLOBAL_SHORTCUTS,
Popper,
- ContextAction,
+ type ContextAction,
Button,
Logo,
BasicModal,
@@ -26,10 +26,10 @@ import {
} from '@deephaven/components';
import { SHORTCUTS as IRIS_GRID_SHORTCUTS } from '@deephaven/iris-grid';
import {
- CreateDashboardPayload,
+ type CreateDashboardPayload,
DashboardUtils,
DEFAULT_DASHBOARD_ID,
- DehydratedDashboardPanelProps,
+ type DehydratedDashboardPanelProps,
emitPanelOpen,
getAllDashboardsData,
getDashboardData,
@@ -55,7 +55,7 @@ import { vsGear, dhShapes, dhPanels, vsTerminal } from '@deephaven/icons';
import { getVariableDescriptor } from '@deephaven/jsapi-bootstrap';
import dh from '@deephaven/jsapi-shim';
import type { dh as DhType } from '@deephaven/jsapi-types';
-import { SessionConfig } from '@deephaven/jsapi-utils';
+import { type SessionConfig } from '@deephaven/jsapi-utils';
import Log from '@deephaven/log';
import {
getActiveTool,
@@ -64,12 +64,12 @@ import {
setActiveTool as setActiveToolAction,
updateWorkspaceData as updateWorkspaceDataAction,
getPlugins,
- WorkspaceData,
- RootState,
- User,
- ServerConfigValues,
- CustomizableWorkspace,
- DashboardData,
+ type WorkspaceData,
+ type RootState,
+ type User,
+ type ServerConfigValues,
+ type CustomizableWorkspace,
+ type DashboardData,
} from '@deephaven/redux';
import {
bindAllMethods,
@@ -78,12 +78,12 @@ import {
EMPTY_ARRAY,
assertNotNull,
} from '@deephaven/utils';
-import GoldenLayout, { EventHub } from '@deephaven/golden-layout';
-import type { ItemConfig } from '@deephaven/golden-layout';
+import type GoldenLayout from '@deephaven/golden-layout';
+import type { ItemConfig, EventHub } from '@deephaven/golden-layout';
import { type PluginModuleMap, getDashboardPlugins } from '@deephaven/plugin';
import {
AppDashboards,
- LayoutStorage,
+ type LayoutStorage,
UserLayoutUtils,
} from '@deephaven/app-utils';
import JSZip from 'jszip';
@@ -91,7 +91,7 @@ import SettingsMenu from '../settings/SettingsMenu';
import AppControlsMenu from './AppControlsMenu';
import { getLayoutStorage, getServerConfigValues } from '../redux';
import './AppMainContainer.scss';
-import WidgetList, { WindowMouseEvent } from './WidgetList';
+import WidgetList, { type WindowMouseEvent } from './WidgetList';
import { getFormattedVersionInfo } from '../settings/SettingsUtils';
import EmptyDashboard from './EmptyDashboard';
diff --git a/packages/code-studio/src/main/AppRouter.tsx b/packages/code-studio/src/main/AppRouter.tsx
index a5b0e9730f..cb053ab0f6 100644
--- a/packages/code-studio/src/main/AppRouter.tsx
+++ b/packages/code-studio/src/main/AppRouter.tsx
@@ -1,4 +1,4 @@
-import React, { ReactElement } from 'react';
+import React, { type ReactElement } from 'react';
import {
BrowserRouter as Router,
Route,
diff --git a/packages/code-studio/src/main/WidgetList.tsx b/packages/code-studio/src/main/WidgetList.tsx
index 243b0e95d6..4a444a4a10 100644
--- a/packages/code-studio/src/main/WidgetList.tsx
+++ b/packages/code-studio/src/main/WidgetList.tsx
@@ -1,6 +1,6 @@
import React, {
- ChangeEvent,
- MouseEvent,
+ type ChangeEvent,
+ type MouseEvent,
useCallback,
useMemo,
useRef,
diff --git a/packages/code-studio/src/redux/selectors.ts b/packages/code-studio/src/redux/selectors.ts
index 68bce68cec..ef9b187ea4 100644
--- a/packages/code-studio/src/redux/selectors.ts
+++ b/packages/code-studio/src/redux/selectors.ts
@@ -1,4 +1,4 @@
-import { RootState } from '@deephaven/redux';
+import { type RootState } from '@deephaven/redux';
import type { LayoutStorage } from '@deephaven/app-utils';
/**
diff --git a/packages/code-studio/src/settings/ColumnSpecificSectionContent.test.tsx b/packages/code-studio/src/settings/ColumnSpecificSectionContent.test.tsx
index 614bf3cca8..c08822a3c1 100644
--- a/packages/code-studio/src/settings/ColumnSpecificSectionContent.test.tsx
+++ b/packages/code-studio/src/settings/ColumnSpecificSectionContent.test.tsx
@@ -3,7 +3,7 @@ import {
render,
waitForElementToBeRemoved,
} from '@testing-library/react';
-import { WorkspaceSettings } from '@deephaven/redux';
+import { type WorkspaceSettings } from '@deephaven/redux';
import userEvent from '@testing-library/user-event';
import React from 'react';
import { Formatter } from '@deephaven/jsapi-utils';
@@ -12,7 +12,7 @@ import dh from '@deephaven/jsapi-shim';
import { TestUtils } from '@deephaven/test-utils';
import {
ColumnSpecificSectionContent,
- ColumnSpecificSectionContentProps,
+ type ColumnSpecificSectionContentProps,
} from './ColumnSpecificSectionContent';
const DEFAULT_DECIMAL_STRING = '###,#00.00';
diff --git a/packages/code-studio/src/settings/ColumnSpecificSectionContent.tsx b/packages/code-studio/src/settings/ColumnSpecificSectionContent.tsx
index b011425475..a39bc625c6 100644
--- a/packages/code-studio/src/settings/ColumnSpecificSectionContent.tsx
+++ b/packages/code-studio/src/settings/ColumnSpecificSectionContent.tsx
@@ -1,8 +1,8 @@
import React, {
- ChangeEvent,
+ type ChangeEvent,
PureComponent,
- ReactElement,
- RefObject,
+ type ReactElement,
+ type RefObject,
} from 'react';
import { connect } from 'react-redux';
import { dhNewCircleLargeFilled, vsTrash } from '@deephaven/icons';
@@ -16,8 +16,8 @@ import {
IntegerColumnFormatter,
DecimalColumnFormatter,
TableUtils,
- TableColumnFormat,
- FormattingRule,
+ type TableColumnFormat,
+ type FormattingRule,
} from '@deephaven/jsapi-utils';
import type { dh as DhType } from '@deephaven/jsapi-types';
import {
@@ -29,8 +29,8 @@ import {
getShowTimeZone,
getShowTSeparator,
updateSettings as updateSettingsAction,
- RootState,
- WorkspaceSettings,
+ type RootState,
+ type WorkspaceSettings,
} from '@deephaven/redux';
import { assertNotNull } from '@deephaven/utils';
import './FormattingSectionContent.scss';
@@ -41,7 +41,7 @@ import {
isValidFormat,
removeFormatRuleExtraProps,
isFormatRuleValidForSave,
- ValidFormatterItem,
+ type ValidFormatterItem,
} from './SettingsUtils';
import type { FormatterItem, FormatOption } from './SettingsUtils';
import ColumnTypeOptions from './ColumnTypeOptions';
diff --git a/packages/code-studio/src/settings/ColumnTypeOptions.tsx b/packages/code-studio/src/settings/ColumnTypeOptions.tsx
index 26cc34a63d..96d525e86f 100644
--- a/packages/code-studio/src/settings/ColumnTypeOptions.tsx
+++ b/packages/code-studio/src/settings/ColumnTypeOptions.tsx
@@ -1,4 +1,4 @@
-import React, { ReactElement } from 'react';
+import React, { type ReactElement } from 'react';
import { TableUtils } from '@deephaven/jsapi-utils';
const columnTypesArray = [
diff --git a/packages/code-studio/src/settings/DateTimeOptions.tsx b/packages/code-studio/src/settings/DateTimeOptions.tsx
index e797a3572c..223ba7754d 100644
--- a/packages/code-studio/src/settings/DateTimeOptions.tsx
+++ b/packages/code-studio/src/settings/DateTimeOptions.tsx
@@ -1,4 +1,4 @@
-import React, { ReactElement, useMemo } from 'react';
+import React, { type ReactElement, useMemo } from 'react';
import {
Formatter,
DateTimeColumnFormatter,
diff --git a/packages/code-studio/src/settings/FormattingSectionContent.test.tsx b/packages/code-studio/src/settings/FormattingSectionContent.test.tsx
index 86b92c1f30..09a2ab6019 100644
--- a/packages/code-studio/src/settings/FormattingSectionContent.test.tsx
+++ b/packages/code-studio/src/settings/FormattingSectionContent.test.tsx
@@ -4,7 +4,7 @@ import userEvent from '@testing-library/user-event';
import { ApiContext } from '@deephaven/jsapi-bootstrap';
import dh from '@deephaven/jsapi-shim';
import { DateTimeColumnFormatter } from '@deephaven/jsapi-utils';
-import { WorkspaceSettings } from '@deephaven/redux';
+import { type WorkspaceSettings } from '@deephaven/redux';
import { assertNotNull } from '@deephaven/utils';
import { FormattingSectionContent } from './FormattingSectionContent';
diff --git a/packages/code-studio/src/settings/FormattingSectionContent.tsx b/packages/code-studio/src/settings/FormattingSectionContent.tsx
index 0f2bcfcd27..18a0775168 100644
--- a/packages/code-studio/src/settings/FormattingSectionContent.tsx
+++ b/packages/code-studio/src/settings/FormattingSectionContent.tsx
@@ -1,8 +1,8 @@
import React, {
- ChangeEvent,
+ type ChangeEvent,
PureComponent,
- ReactElement,
- RefObject,
+ type ReactElement,
+ type RefObject,
} from 'react';
import { connect } from 'react-redux';
import { vsRefresh } from '@deephaven/icons';
@@ -30,8 +30,8 @@ import {
getShowNullStrings,
getShowExtraGroupColumn,
updateSettings as updateSettingsAction,
- RootState,
- WorkspaceSettings,
+ type RootState,
+ type WorkspaceSettings,
getDefaultSettings,
} from '@deephaven/redux';
import './FormattingSectionContent.scss';
diff --git a/packages/code-studio/src/settings/LegalNotice.tsx b/packages/code-studio/src/settings/LegalNotice.tsx
index 6fc01041ce..14cbd99475 100644
--- a/packages/code-studio/src/settings/LegalNotice.tsx
+++ b/packages/code-studio/src/settings/LegalNotice.tsx
@@ -1,4 +1,4 @@
-import React, { ReactElement, useState } from 'react';
+import React, { type ReactElement, useState } from 'react';
import { Button, Modal, ModalBody, ModalHeader } from '@deephaven/components';
import { vsLaw } from '@deephaven/icons';
diff --git a/packages/code-studio/src/settings/SettingsMenu.tsx b/packages/code-studio/src/settings/SettingsMenu.tsx
index 72567e42c2..1980e7a9ab 100644
--- a/packages/code-studio/src/settings/SettingsMenu.tsx
+++ b/packages/code-studio/src/settings/SettingsMenu.tsx
@@ -1,4 +1,9 @@
-import React, { Component, Fragment, ReactElement, RefObject } from 'react';
+import React, {
+ Component,
+ Fragment,
+ type ReactElement,
+ type RefObject,
+} from 'react';
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
import {
vsClose,
@@ -18,13 +23,13 @@ import {
Logo,
Tooltip,
} from '@deephaven/components';
-import { ServerConfigValues, User } from '@deephaven/redux';
+import { type ServerConfigValues, type User } from '@deephaven/redux';
import {
BROADCAST_CHANNEL_NAME,
BROADCAST_LOGOUT_MESSAGE,
makeMessage,
} from '@deephaven/jsapi-utils';
-import { PluginModuleMap } from '@deephaven/plugin';
+import { type PluginModuleMap } from '@deephaven/plugin';
import FormattingSectionContent from './FormattingSectionContent';
import LegalNotice from './LegalNotice';
import SettingsMenuSection from './SettingsMenuSection';
diff --git a/packages/code-studio/src/settings/SettingsMenuSection.tsx b/packages/code-studio/src/settings/SettingsMenuSection.tsx
index 1909b4b4b2..d1b8b7d256 100644
--- a/packages/code-studio/src/settings/SettingsMenuSection.tsx
+++ b/packages/code-studio/src/settings/SettingsMenuSection.tsx
@@ -1,4 +1,4 @@
-import React, { ReactElement, ReactNode } from 'react';
+import React, { type ReactElement, type ReactNode } from 'react';
import PropTypes from 'prop-types';
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
import { Button, Collapse } from '@deephaven/components';
diff --git a/packages/code-studio/src/settings/SettingsUtils.tsx b/packages/code-studio/src/settings/SettingsUtils.tsx
index 653f82d204..a05da35448 100644
--- a/packages/code-studio/src/settings/SettingsUtils.tsx
+++ b/packages/code-studio/src/settings/SettingsUtils.tsx
@@ -3,14 +3,14 @@ import {
DateTimeColumnFormatter,
IntegerColumnFormatter,
DecimalColumnFormatter,
- TableColumnFormat,
- FormattingRule,
+ type TableColumnFormat,
+ type FormattingRule,
} from '@deephaven/jsapi-utils';
import type { dh as DhType } from '@deephaven/jsapi-types';
import Log from '@deephaven/log';
import type { ServerConfigValues } from '@deephaven/redux';
import Bowser from 'bowser';
-import { PluginModuleMap } from '@deephaven/plugin';
+import { type PluginModuleMap } from '@deephaven/plugin';
const log = Log.module('SettingsUtils');
diff --git a/packages/code-studio/src/settings/ShortcutsSectionContent.tsx b/packages/code-studio/src/settings/ShortcutsSectionContent.tsx
index 2b8cc5ec30..1de5667aa2 100644
--- a/packages/code-studio/src/settings/ShortcutsSectionContent.tsx
+++ b/packages/code-studio/src/settings/ShortcutsSectionContent.tsx
@@ -3,9 +3,9 @@ import { connect } from 'react-redux';
import { Shortcut, ShortcutRegistry } from '@deephaven/components';
import {
getShortcutOverrides,
- RootState,
+ type RootState,
updateSettings as updateSettingsAction,
- WorkspaceSettings,
+ type WorkspaceSettings,
} from '@deephaven/redux';
import ShortcutItem from './ShortcutItem';
diff --git a/packages/code-studio/src/settings/ThemeSectionContent.tsx b/packages/code-studio/src/settings/ThemeSectionContent.tsx
index 0293c3497b..ed7fdbcc35 100644
--- a/packages/code-studio/src/settings/ThemeSectionContent.tsx
+++ b/packages/code-studio/src/settings/ThemeSectionContent.tsx
@@ -1,7 +1,7 @@
import React, { useCallback } from 'react';
import {
Item,
- ItemKey,
+ type ItemKey,
Picker,
ThemePicker,
useTheme,
diff --git a/packages/code-studio/src/styleguide/Buttons.tsx b/packages/code-studio/src/styleguide/Buttons.tsx
index c02a27f4c3..6fb3c5c9ed 100644
--- a/packages/code-studio/src/styleguide/Buttons.tsx
+++ b/packages/code-studio/src/styleguide/Buttons.tsx
@@ -1,4 +1,4 @@
-import React, { Component, ReactElement } from 'react';
+import React, { Component, type ReactElement } from 'react';
import {
Button,
SocketedButton,
diff --git a/packages/code-studio/src/styleguide/Charts.tsx b/packages/code-studio/src/styleguide/Charts.tsx
index 86a02d4b17..289e1bd0f2 100644
--- a/packages/code-studio/src/styleguide/Charts.tsx
+++ b/packages/code-studio/src/styleguide/Charts.tsx
@@ -1,5 +1,5 @@
-import React, { ReactElement, useState } from 'react';
-import { Chart, ChartModel, MockChartModel } from '@deephaven/chart';
+import React, { type ReactElement, useState } from 'react';
+import { Chart, type ChartModel, MockChartModel } from '@deephaven/chart';
import { useApi } from '@deephaven/jsapi-bootstrap';
import { useSeededRandomNumberCallback } from './utils';
import SampleSection from './SampleSection';
diff --git a/packages/code-studio/src/styleguide/ContextMenus.tsx b/packages/code-studio/src/styleguide/ContextMenus.tsx
index f8b75f263a..4918079edf 100644
--- a/packages/code-studio/src/styleguide/ContextMenus.tsx
+++ b/packages/code-studio/src/styleguide/ContextMenus.tsx
@@ -6,14 +6,14 @@ import {
ContextActions,
KEY,
MODIFIER,
- ResolvableContextAction,
+ type ResolvableContextAction,
Shortcut,
} from '@deephaven/components';
import {
vsBell,
dhFilePrint,
vsQuestion,
- IconDefinition,
+ type IconDefinition,
} from '@deephaven/icons';
import SampleSection from './SampleSection';
diff --git a/packages/code-studio/src/styleguide/Dialog.tsx b/packages/code-studio/src/styleguide/Dialog.tsx
index c456f93bc8..8ed0fdc17f 100644
--- a/packages/code-studio/src/styleguide/Dialog.tsx
+++ b/packages/code-studio/src/styleguide/Dialog.tsx
@@ -4,7 +4,7 @@ import React, { Component } from 'react';
import {
HierarchicalCheckboxMenu,
Popper,
- HierarchicalCheckboxValueMap,
+ type HierarchicalCheckboxValueMap,
Button,
} from '@deephaven/components';
import SampleSection from './SampleSection';
diff --git a/packages/code-studio/src/styleguide/DraggableListInput.tsx b/packages/code-studio/src/styleguide/DraggableListInput.tsx
index b3f4ff5278..cb467c8d73 100644
--- a/packages/code-studio/src/styleguide/DraggableListInput.tsx
+++ b/packages/code-studio/src/styleguide/DraggableListInput.tsx
@@ -1,9 +1,9 @@
/* eslint no-console: "off" */
import React, { PureComponent } from 'react';
-import PropTypes from 'prop-types';
+import type PropTypes from 'prop-types';
import memoize from 'memoize-one';
import { DraggableItemList } from '@deephaven/components';
-import { Range } from '@deephaven/utils';
+import { type Range } from '@deephaven/utils';
interface DraggableListInputProps {
draggablePrefix: string;
diff --git a/packages/code-studio/src/styleguide/DraggableLists.tsx b/packages/code-studio/src/styleguide/DraggableLists.tsx
index a1be4ec299..9ef488da77 100644
--- a/packages/code-studio/src/styleguide/DraggableLists.tsx
+++ b/packages/code-studio/src/styleguide/DraggableLists.tsx
@@ -2,12 +2,16 @@
import React, { Component } from 'react';
import {
DragDropContext,
- DragStart,
- DragUpdate,
- DropResult,
+ type DragStart,
+ type DragUpdate,
+ type DropResult,
} from 'react-beautiful-dnd';
import memoize from 'memoizee';
-import { DragUtils, DraggableItemList, Range } from '@deephaven/components';
+import {
+ DragUtils,
+ DraggableItemList,
+ type Range,
+} from '@deephaven/components';
import DraggableListInput from './DraggableListInput';
import SampleSection from './SampleSection';
diff --git a/packages/code-studio/src/styleguide/DropdownMenus.tsx b/packages/code-studio/src/styleguide/DropdownMenus.tsx
index b82be5af36..df3801bc6d 100644
--- a/packages/code-studio/src/styleguide/DropdownMenus.tsx
+++ b/packages/code-studio/src/styleguide/DropdownMenus.tsx
@@ -8,7 +8,7 @@ import {
KEY,
MODIFIER,
Shortcut,
- DropdownAction,
+ type DropdownAction,
Button,
} from '@deephaven/components';
import {
diff --git a/packages/code-studio/src/styleguide/ErrorViews.tsx b/packages/code-studio/src/styleguide/ErrorViews.tsx
index 46f95e4a5d..a26f068e46 100644
--- a/packages/code-studio/src/styleguide/ErrorViews.tsx
+++ b/packages/code-studio/src/styleguide/ErrorViews.tsx
@@ -1,5 +1,5 @@
/* eslint no-alert: "off" */
-import React, { CSSProperties } from 'react';
+import React, { type CSSProperties } from 'react';
import { ErrorView } from '@deephaven/components';
import SampleSection from './SampleSection';
diff --git a/packages/code-studio/src/styleguide/Grids.tsx b/packages/code-studio/src/styleguide/Grids.tsx
index 348197cdd5..9afe147726 100644
--- a/packages/code-studio/src/styleguide/Grids.tsx
+++ b/packages/code-studio/src/styleguide/Grids.tsx
@@ -1,7 +1,7 @@
-import React, { ReactElement, useState } from 'react';
+import React, { type ReactElement, useState } from 'react';
import {
Grid,
- GridThemeType,
+ type GridThemeType,
MockGridModel,
MockTreeGridModel,
ThemeContext,
diff --git a/packages/code-studio/src/styleguide/Icons.tsx b/packages/code-studio/src/styleguide/Icons.tsx
index 27e982845b..1fec8de746 100644
--- a/packages/code-studio/src/styleguide/Icons.tsx
+++ b/packages/code-studio/src/styleguide/Icons.tsx
@@ -1,7 +1,7 @@
import React, { useState, useEffect } from 'react';
import {
dh,
- IconDefinition,
+ type IconDefinition,
vsOrganization,
dhSquareFilled,
dhAddSmall,
diff --git a/packages/code-studio/src/styleguide/ItemListInput.tsx b/packages/code-studio/src/styleguide/ItemListInput.tsx
index a757eb55f4..36cc47f923 100644
--- a/packages/code-studio/src/styleguide/ItemListInput.tsx
+++ b/packages/code-studio/src/styleguide/ItemListInput.tsx
@@ -1,6 +1,6 @@
/* eslint no-console: "off" */
import React, { PureComponent } from 'react';
-import PropTypes from 'prop-types';
+import type PropTypes from 'prop-types';
import { ItemList } from '@deephaven/components';
interface ItemListInput {
diff --git a/packages/code-studio/src/styleguide/ListViews.tsx b/packages/code-studio/src/styleguide/ListViews.tsx
index fc97ced5ca..a463b29fa5 100644
--- a/packages/code-studio/src/styleguide/ListViews.tsx
+++ b/packages/code-studio/src/styleguide/ListViews.tsx
@@ -1,4 +1,4 @@
-import React, { ReactNode, useCallback, useState } from 'react';
+import React, { type ReactNode, useCallback, useState } from 'react';
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
import type { BoxAlignmentStyleProps, StyleProps } from '@react-types/shared';
import {
@@ -8,11 +8,11 @@ import {
LIST_VIEW_ROW_HEIGHTS,
ListView,
ListViewNormalized,
- ItemKey,
+ type ItemKey,
Text,
Flex,
Checkbox,
- ListViewProps,
+ type ListViewProps,
RadioGroup,
Radio,
useSpectrumThemeProvider,
diff --git a/packages/code-studio/src/styleguide/MockIrisGridTreeModel.ts b/packages/code-studio/src/styleguide/MockIrisGridTreeModel.ts
index 83cd317927..3284f120c6 100644
--- a/packages/code-studio/src/styleguide/MockIrisGridTreeModel.ts
+++ b/packages/code-studio/src/styleguide/MockIrisGridTreeModel.ts
@@ -1,25 +1,25 @@
/* eslint class-methods-use-this: "off" */
/* eslint no-unused-vars: "off" */
/* eslint no-empty-function: "off" */
-import { EventTarget, Event } from 'event-target-shim';
+import { type EventTarget, type Event } from 'event-target-shim';
import memoize from 'memoize-one';
import {
- EditableGridModel,
- EditOperation,
- ExpandableGridModel,
+ type EditableGridModel,
+ type EditOperation,
+ type ExpandableGridModel,
GridRange,
MockTreeGridModel,
- ModelIndex,
- MoveOperation,
+ type ModelIndex,
+ type MoveOperation,
} from '@deephaven/grid';
import {
IrisGridModel,
- PendingDataMap,
- UITreeRow,
- ColumnHeaderGroup,
+ type PendingDataMap,
+ type UITreeRow,
+ type ColumnHeaderGroup,
} from '@deephaven/iris-grid';
import type { dh as DhType } from '@deephaven/jsapi-types';
-import { Formatter } from '@deephaven/jsapi-utils';
+import { type Formatter } from '@deephaven/jsapi-utils';
// We need to cast our CustomEvent so it's happy with event-target-shim
type CustomEventType = EventTarget.EventData<
diff --git a/packages/code-studio/src/styleguide/Navigations.tsx b/packages/code-studio/src/styleguide/Navigations.tsx
index 96e5bfb53c..a73172e97e 100644
--- a/packages/code-studio/src/styleguide/Navigations.tsx
+++ b/packages/code-studio/src/styleguide/Navigations.tsx
@@ -1,6 +1,6 @@
import React, { useCallback, useEffect, useMemo, useState } from 'react';
import { vsFile, dhTruck, vsListUnordered } from '@deephaven/icons';
-import { IconProp } from '@fortawesome/fontawesome-svg-core';
+import { type IconProp } from '@fortawesome/fontawesome-svg-core';
import {
Menu,
NavTabList,
diff --git a/packages/code-studio/src/styleguide/Pickers.tsx b/packages/code-studio/src/styleguide/Pickers.tsx
index 40838ab50c..3161241abb 100644
--- a/packages/code-studio/src/styleguide/Pickers.tsx
+++ b/packages/code-studio/src/styleguide/Pickers.tsx
@@ -6,7 +6,7 @@ import {
Flex,
Icon,
Item,
- ItemKey,
+ type ItemKey,
PICKER_ITEM_HEIGHTS,
PICKER_TOP_OFFSET,
Picker,
diff --git a/packages/code-studio/src/styleguide/SampleSection.tsx b/packages/code-studio/src/styleguide/SampleSection.tsx
index 05617cc2b9..f0b843267d 100644
--- a/packages/code-studio/src/styleguide/SampleSection.tsx
+++ b/packages/code-studio/src/styleguide/SampleSection.tsx
@@ -1,6 +1,6 @@
-import { Flex, Grid, View } from '@deephaven/components';
+import { type Flex, type Grid, type View } from '@deephaven/components';
import type { StyleProps } from '@react-types/shared';
-import React, { CSSProperties, ReactNode } from 'react';
+import React, { type CSSProperties, type ReactNode } from 'react';
import {
getSectionIdFromName,
sampleSectionIdAndClasses,
diff --git a/packages/code-studio/src/styleguide/SamplesMenu.tsx b/packages/code-studio/src/styleguide/SamplesMenu.tsx
index 3f6bcdd701..8e97d026a2 100644
--- a/packages/code-studio/src/styleguide/SamplesMenu.tsx
+++ b/packages/code-studio/src/styleguide/SamplesMenu.tsx
@@ -1,4 +1,4 @@
-import React, { Key, useCallback, useEffect, useState } from 'react';
+import React, { type Key, useCallback, useEffect, useState } from 'react';
// eslint-disable-next-line no-restricted-imports
import {
ActionButton,
diff --git a/packages/code-studio/src/styleguide/SpectrumComparison.tsx b/packages/code-studio/src/styleguide/SpectrumComparison.tsx
index 97778a6fb2..95ab5d5d53 100644
--- a/packages/code-studio/src/styleguide/SpectrumComparison.tsx
+++ b/packages/code-studio/src/styleguide/SpectrumComparison.tsx
@@ -10,7 +10,7 @@ import {
Icon,
Item,
Picker,
- SpectrumButtonProps,
+ type SpectrumButtonProps,
TextField,
} from '@adobe/react-spectrum';
import {
diff --git a/packages/code-studio/src/styleguide/StyleGuide.test.tsx b/packages/code-studio/src/styleguide/StyleGuide.test.tsx
index 28355f2637..7fb563ad2a 100644
--- a/packages/code-studio/src/styleguide/StyleGuide.test.tsx
+++ b/packages/code-studio/src/styleguide/StyleGuide.test.tsx
@@ -1,7 +1,7 @@
import React from 'react';
import { render } from '@testing-library/react';
import { ChartThemeProvider } from '@deephaven/chart';
-import { ThemeData, ThemeProvider } from '@deephaven/components';
+import { type ThemeData, ThemeProvider } from '@deephaven/components';
import { dh } from '@deephaven/jsapi-shim';
import { ApiContext } from '@deephaven/jsapi-bootstrap';
import StyleGuide from './StyleGuide';
diff --git a/packages/code-studio/src/styleguide/StyleGuideInit.tsx b/packages/code-studio/src/styleguide/StyleGuideInit.tsx
index 34ae9809a3..2b367d389d 100644
--- a/packages/code-studio/src/styleguide/StyleGuideInit.tsx
+++ b/packages/code-studio/src/styleguide/StyleGuideInit.tsx
@@ -2,10 +2,10 @@ import React, { useEffect } from 'react';
import PropTypes from 'prop-types';
import { connect } from 'react-redux';
import {
- CustomizableWorkspace,
+ type CustomizableWorkspace,
getWorkspace,
- PayloadActionCreator,
- RootState,
+ type PayloadActionCreator,
+ type RootState,
setWorkspace as setWorkspaceAction,
} from '@deephaven/redux';
import {
diff --git a/packages/code-studio/src/styleguide/Swatch.tsx b/packages/code-studio/src/styleguide/Swatch.tsx
index abfef13c27..415d2c32fe 100644
--- a/packages/code-studio/src/styleguide/Swatch.tsx
+++ b/packages/code-studio/src/styleguide/Swatch.tsx
@@ -1,4 +1,4 @@
-import React, { ReactNode, useMemo } from 'react';
+import React, { type ReactNode, useMemo } from 'react';
import { Tooltip } from '@deephaven/components';
import { INVALID_COLOR_BORDER_STYLE } from './colorUtils';
import { useContrastFgColorRef, useDhColorFromPseudoContent } from './hooks';
diff --git a/packages/code-studio/src/styleguide/grid-examples/AsyncExample.tsx b/packages/code-studio/src/styleguide/grid-examples/AsyncExample.tsx
index 5aa264d25a..a44c5835b8 100644
--- a/packages/code-studio/src/styleguide/grid-examples/AsyncExample.tsx
+++ b/packages/code-studio/src/styleguide/grid-examples/AsyncExample.tsx
@@ -1,5 +1,5 @@
import React, { useCallback, useEffect, useRef, useState } from 'react';
-import { Grid, GridMetrics, ViewportDataGridModel } from '@deephaven/grid';
+import { Grid, type GridMetrics, ViewportDataGridModel } from '@deephaven/grid';
/**
* An example showing data loading asnychronously for a grid.
diff --git a/packages/code-studio/src/styleguide/utils.ts b/packages/code-studio/src/styleguide/utils.ts
index baf676f44d..aa2afb8579 100644
--- a/packages/code-studio/src/styleguide/utils.ts
+++ b/packages/code-studio/src/styleguide/utils.ts
@@ -1,6 +1,10 @@
import { createElement, useCallback, useEffect, useState } from 'react';
import cl from 'classnames';
-import { Item, ItemElement, NormalizedItem } from '@deephaven/components';
+import {
+ Item,
+ type ItemElement,
+ type NormalizedItem,
+} from '@deephaven/components';
import { dh as dhIcons } from '@deephaven/icons';
export const ISOLATED_SECTION_QUERY_CLASS = 'isolated-section-query';
diff --git a/packages/components/src/AutoCompleteInput.tsx b/packages/components/src/AutoCompleteInput.tsx
index e44a1a1ef7..8379f1c999 100644
--- a/packages/components/src/AutoCompleteInput.tsx
+++ b/packages/components/src/AutoCompleteInput.tsx
@@ -21,7 +21,7 @@ import PropTypes from 'prop-types';
import memoize from 'memoizee';
import classNames from 'classnames';
import debounce from 'lodash.debounce';
-import { PopperOptions } from 'popper.js';
+import { type PopperOptions } from 'popper.js';
import { Popper } from './popper';
import './AutoCompleteInput.scss';
diff --git a/packages/components/src/BasicModal.test.tsx b/packages/components/src/BasicModal.test.tsx
index 419dfd5730..b58c4bb336 100644
--- a/packages/components/src/BasicModal.test.tsx
+++ b/packages/components/src/BasicModal.test.tsx
@@ -1,7 +1,7 @@
import React from 'react';
import userEvent from '@testing-library/user-event';
import { render } from '@testing-library/react';
-import BasicModal, { BasicModalProps } from './BasicModal';
+import BasicModal, { type BasicModalProps } from './BasicModal';
const DEFAULT_BODY_TEXT = 'DEFAULT_TEXT';
const DEFAULT_TEST_ID = 'DEFAULT_TEST_ID';
diff --git a/packages/components/src/Button.tsx b/packages/components/src/Button.tsx
index a516ed59a2..57e5014d10 100644
--- a/packages/components/src/Button.tsx
+++ b/packages/components/src/Button.tsx
@@ -3,7 +3,7 @@ import { useSlotProps } from '@react-spectrum/utils';
import PropTypes from 'prop-types';
import classNames from 'classnames';
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
-import { IconDefinition } from '@fortawesome/fontawesome-svg-core';
+import { type IconDefinition } from '@fortawesome/fontawesome-svg-core';
import { Tooltip } from './popper';
const BUTTON_KINDS = [
diff --git a/packages/components/src/CardFlip.tsx b/packages/components/src/CardFlip.tsx
index c1d7ec1348..d2537d8ed3 100644
--- a/packages/components/src/CardFlip.tsx
+++ b/packages/components/src/CardFlip.tsx
@@ -1,4 +1,4 @@
-import React, { ReactNode, useCallback, useEffect, useRef } from 'react';
+import React, { type ReactNode, useCallback, useEffect, useRef } from 'react';
import classNames from 'classnames';
import './CardFlip.scss';
diff --git a/packages/components/src/ComponentUtils.test.tsx b/packages/components/src/ComponentUtils.test.tsx
index bd347b81ad..c16dcc942e 100644
--- a/packages/components/src/ComponentUtils.test.tsx
+++ b/packages/components/src/ComponentUtils.test.tsx
@@ -1,4 +1,4 @@
-import React, { PropsWithChildren } from 'react';
+import React, { type PropsWithChildren } from 'react';
// We only use react-redux from tests in @deephaven/components, so it is only added as a devDependency
import { connect } from 'react-redux';
import {
diff --git a/packages/components/src/ComponentUtils.ts b/packages/components/src/ComponentUtils.ts
index c63e663725..3de334fded 100644
--- a/packages/components/src/ComponentUtils.ts
+++ b/packages/components/src/ComponentUtils.ts
@@ -1,8 +1,9 @@
-import React, {
- ComponentType,
- ForwardRefExoticComponent,
- RefAttributes,
+import {
+ type ComponentType,
+ type ForwardRefExoticComponent,
+ type RefAttributes,
} from 'react';
+import type React from 'react';
import { ForwardRef } from 'react-is';
export type Props = Record | RefAttributes;
diff --git a/packages/components/src/CopyButton.tsx b/packages/components/src/CopyButton.tsx
index b3ffedd1c3..c6b34ea4ce 100644
--- a/packages/components/src/CopyButton.tsx
+++ b/packages/components/src/CopyButton.tsx
@@ -1,7 +1,7 @@
import React from 'react';
import { vsPassFilled, vsCopy } from '@deephaven/icons';
import { useCopyToClipboard } from '@deephaven/react-hooks';
-import Button, { ButtonKind } from './Button';
+import Button, { type ButtonKind } from './Button';
type CopyButtonProps = {
/** The value to copy when clicked, accepts string or function returning a string. */
diff --git a/packages/components/src/CustomTimeSelect.tsx b/packages/components/src/CustomTimeSelect.tsx
index 3dacf2490a..b932b1276c 100644
--- a/packages/components/src/CustomTimeSelect.tsx
+++ b/packages/components/src/CustomTimeSelect.tsx
@@ -1,10 +1,10 @@
import React, { Component } from 'react';
-import { PopperOptions } from 'popper.js';
+import { type PopperOptions } from 'popper.js';
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
-import { vsCheck, IconDefinition } from '@deephaven/icons';
+import { vsCheck, type IconDefinition } from '@deephaven/icons';
import { TimeUtils } from '@deephaven/utils';
import classNames from 'classnames';
-import TimeInput, { TimeInputElement } from './TimeInput';
+import TimeInput, { type TimeInputElement } from './TimeInput';
import DropdownMenu from './menu-actions/DropdownMenu';
import './CustomTimeSelect.scss';
diff --git a/packages/components/src/DateInput.tsx b/packages/components/src/DateInput.tsx
index e3bdad97a7..2da4791d33 100644
--- a/packages/components/src/DateInput.tsx
+++ b/packages/components/src/DateInput.tsx
@@ -1,7 +1,7 @@
import React, { useCallback, useState } from 'react';
import classNames from 'classnames';
import Log from '@deephaven/log';
-import MaskedInput, { SelectionSegment } from './MaskedInput';
+import MaskedInput, { type SelectionSegment } from './MaskedInput';
import { getNextSegmentValue } from './DateInputUtils';
const log = Log.module('DateInput');
diff --git a/packages/components/src/DateInputUtils.ts b/packages/components/src/DateInputUtils.ts
index d941f3b425..900c0d0a23 100644
--- a/packages/components/src/DateInputUtils.ts
+++ b/packages/components/src/DateInputUtils.ts
@@ -1,4 +1,4 @@
-import { SelectionSegment } from './MaskedInput';
+import { type SelectionSegment } from './MaskedInput';
export function getNextNumberSegmentValue(
delta: number,
diff --git a/packages/components/src/DateTimeInput.tsx b/packages/components/src/DateTimeInput.tsx
index 9a0f31288c..0acb02d558 100644
--- a/packages/components/src/DateTimeInput.tsx
+++ b/packages/components/src/DateTimeInput.tsx
@@ -1,7 +1,7 @@
-import React, { KeyboardEvent, useCallback, useState } from 'react';
+import React, { type KeyboardEvent, useCallback, useState } from 'react';
import classNames from 'classnames';
import Log from '@deephaven/log';
-import MaskedInput, { SelectionSegment } from './MaskedInput';
+import MaskedInput, { type SelectionSegment } from './MaskedInput';
import { getNextSegmentValue } from './DateInputUtils';
import { addSeparators } from './DateTimeInputUtils';
diff --git a/packages/components/src/DraggableItemList.tsx b/packages/components/src/DraggableItemList.tsx
index 41e8581395..816a2d0455 100644
--- a/packages/components/src/DraggableItemList.tsx
+++ b/packages/components/src/DraggableItemList.tsx
@@ -1,14 +1,18 @@
import React, { PureComponent } from 'react';
import classNames from 'classnames';
import memoize from 'memoizee';
-import { Draggable, Droppable, DraggableChildrenFn } from 'react-beautiful-dnd';
+import {
+ Draggable,
+ Droppable,
+ type DraggableChildrenFn,
+} from 'react-beautiful-dnd';
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
import { vsGripper } from '@deephaven/icons';
-import { RangeUtils, Range } from '@deephaven/utils';
+import { RangeUtils, type Range } from '@deephaven/utils';
import ItemList, {
- RenderItemProps,
- DefaultListItem,
- ItemListProps,
+ type RenderItemProps,
+ type DefaultListItem,
+ type ItemListProps,
} from './ItemList';
import { Tooltip } from './popper';
import './DraggableItemList.scss';
diff --git a/packages/components/src/EditableItemList.test.tsx b/packages/components/src/EditableItemList.test.tsx
index 8436aab806..d3b3da5602 100644
--- a/packages/components/src/EditableItemList.test.tsx
+++ b/packages/components/src/EditableItemList.test.tsx
@@ -1,7 +1,9 @@
import React from 'react';
import { fireEvent, render, screen } from '@testing-library/react';
import userEvent from '@testing-library/user-event';
-import EditableItemList, { EditableItemListProps } from './EditableItemList';
+import EditableItemList, {
+ type EditableItemListProps,
+} from './EditableItemList';
const INVALID_INPUT_CLASS = 'is-invalid';
diff --git a/packages/components/src/EditableItemList.tsx b/packages/components/src/EditableItemList.tsx
index 1c6f448d7c..3a847078a2 100644
--- a/packages/components/src/EditableItemList.tsx
+++ b/packages/components/src/EditableItemList.tsx
@@ -1,6 +1,6 @@
import React, {
- ChangeEvent,
- KeyboardEvent,
+ type ChangeEvent,
+ type KeyboardEvent,
useCallback,
useMemo,
useState,
@@ -8,7 +8,7 @@ import React, {
import classNames from 'classnames';
import clamp from 'lodash.clamp';
import { vsAdd, vsTrash } from '@deephaven/icons';
-import { Range, RangeUtils } from '@deephaven/utils';
+import { type Range, RangeUtils } from '@deephaven/utils';
import Button from './Button';
import ItemList from './ItemList';
diff --git a/packages/components/src/ErrorBoundary.test.tsx b/packages/components/src/ErrorBoundary.test.tsx
index 0c03ef7def..5d6015e6f6 100644
--- a/packages/components/src/ErrorBoundary.test.tsx
+++ b/packages/components/src/ErrorBoundary.test.tsx
@@ -1,7 +1,7 @@
import React from 'react';
import { render } from '@testing-library/react';
import { TestUtils } from '@deephaven/test-utils';
-import ErrorBoundary, { ErrorBoundaryProps } from './ErrorBoundary';
+import ErrorBoundary, { type ErrorBoundaryProps } from './ErrorBoundary';
function ThrowComponent(): JSX.Element {
throw new Error('Test error');
diff --git a/packages/components/src/ErrorBoundary.tsx b/packages/components/src/ErrorBoundary.tsx
index cbf803cf08..1053dc084c 100644
--- a/packages/components/src/ErrorBoundary.tsx
+++ b/packages/components/src/ErrorBoundary.tsx
@@ -1,5 +1,5 @@
import Log from '@deephaven/log';
-import React, { Component, ReactNode } from 'react';
+import React, { Component, type ReactNode } from 'react';
import LoadingOverlay from './LoadingOverlay';
const log = Log.module('ErrorBoundary');
diff --git a/packages/components/src/HierarchicalCheckboxMenu.tsx b/packages/components/src/HierarchicalCheckboxMenu.tsx
index 5327e3c7a5..0fbcd04857 100644
--- a/packages/components/src/HierarchicalCheckboxMenu.tsx
+++ b/packages/components/src/HierarchicalCheckboxMenu.tsx
@@ -1,6 +1,6 @@
import React, { Component } from 'react';
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
-import { IconDefinition } from '@deephaven/icons';
+import { type IconDefinition } from '@deephaven/icons';
import classNames from 'classnames';
import Checkbox from './Checkbox';
import Popper from './popper/Popper';
diff --git a/packages/components/src/ItemList.test.tsx b/packages/components/src/ItemList.test.tsx
index a520f9d77b..35259c6afa 100644
--- a/packages/components/src/ItemList.test.tsx
+++ b/packages/components/src/ItemList.test.tsx
@@ -1,6 +1,6 @@
import React from 'react';
-import { Range } from '@deephaven/utils';
-import { ClickOptions, TestUtils } from '@deephaven/test-utils';
+import { type Range } from '@deephaven/utils';
+import { type ClickOptions, TestUtils } from '@deephaven/test-utils';
import { render, screen } from '@testing-library/react';
import userEvent from '@testing-library/user-event';
import ItemList from './ItemList';
diff --git a/packages/components/src/ItemList.tsx b/packages/components/src/ItemList.tsx
index ed4364d2d9..1859e36499 100644
--- a/packages/components/src/ItemList.tsx
+++ b/packages/components/src/ItemList.tsx
@@ -3,12 +3,12 @@ import React, { PureComponent } from 'react';
import memoize from 'memoizee';
import {
FixedSizeList as List,
- ListOnItemsRenderedProps,
- ListOnScrollProps,
+ type ListOnItemsRenderedProps,
+ type ListOnScrollProps,
} from 'react-window';
-import AutoSizer, { Size } from 'react-virtualized-auto-sizer';
+import AutoSizer, { type Size } from 'react-virtualized-auto-sizer';
import Log from '@deephaven/log';
-import { RangeUtils, Range } from '@deephaven/utils';
+import { RangeUtils, type Range } from '@deephaven/utils';
import ItemListItem from './ItemListItem';
import { ContextActionUtils } from './context-actions';
import './ItemList.scss';
diff --git a/packages/components/src/MaskedInput.tsx b/packages/components/src/MaskedInput.tsx
index e5ffb4475f..8d2f7e213e 100644
--- a/packages/components/src/MaskedInput.tsx
+++ b/packages/components/src/MaskedInput.tsx
@@ -1,4 +1,9 @@
-import React, { useMemo, useEffect, useCallback, KeyboardEvent } from 'react';
+import React, {
+ useMemo,
+ useEffect,
+ useCallback,
+ type KeyboardEvent,
+} from 'react';
import classNames from 'classnames';
import Log from '@deephaven/log';
import { useForwardedRef } from '@deephaven/react-hooks';
diff --git a/packages/components/src/Option.tsx b/packages/components/src/Option.tsx
index 0d85d7048f..e7a8f9b158 100644
--- a/packages/components/src/Option.tsx
+++ b/packages/components/src/Option.tsx
@@ -1,4 +1,4 @@
-import React, { OptionHTMLAttributes } from 'react';
+import React, { type OptionHTMLAttributes } from 'react';
export type OptionProps = OptionHTMLAttributes & {
children: React.ReactNode;
diff --git a/packages/components/src/SearchableCombobox.tsx b/packages/components/src/SearchableCombobox.tsx
index ddb5f23b19..7f74c8818b 100644
--- a/packages/components/src/SearchableCombobox.tsx
+++ b/packages/components/src/SearchableCombobox.tsx
@@ -1,7 +1,7 @@
/* eslint-disable react/jsx-props-no-spreading */
-import { Key, useCallback } from 'react';
+import { type Key, useCallback } from 'react';
import type { DOMRefValue, FocusableRef } from '@react-types/shared';
-import { SpectrumComboBox, Item, SpectrumComboBoxProps } from './spectrum';
+import { SpectrumComboBox, Item, type SpectrumComboBoxProps } from './spectrum';
import TextWithTooltip from './TextWithTooltip';
export interface SearchableComboboxProps
diff --git a/packages/components/src/TextWithTooltip.tsx b/packages/components/src/TextWithTooltip.tsx
index ef83d7af06..399615bed7 100644
--- a/packages/components/src/TextWithTooltip.tsx
+++ b/packages/components/src/TextWithTooltip.tsx
@@ -1,7 +1,7 @@
import { useMemo } from 'react';
import { Text } from './spectrum';
import stylesCommon from './SpectrumComponent.module.scss';
-import { PopperOptions, Tooltip } from './popper';
+import { type PopperOptions, Tooltip } from './popper';
export interface TextWithTooltipProps {
text?: string | null;
diff --git a/packages/components/src/TimeInput.test.tsx b/packages/components/src/TimeInput.test.tsx
index 6926e0bce2..1e1e2e6df1 100644
--- a/packages/components/src/TimeInput.test.tsx
+++ b/packages/components/src/TimeInput.test.tsx
@@ -3,7 +3,7 @@ import { render, screen } from '@testing-library/react';
import userEvent from '@testing-library/user-event';
import { TimeUtils } from '@deephaven/utils';
import type { SelectionSegment } from './MaskedInput';
-import TimeInput, { TimeInputElement } from './TimeInput';
+import TimeInput, { type TimeInputElement } from './TimeInput';
type SelectionDirection = SelectionSegment['selectionDirection'];
diff --git a/packages/components/src/TimeInput.tsx b/packages/components/src/TimeInput.tsx
index 3176c72519..12c5671dae 100644
--- a/packages/components/src/TimeInput.tsx
+++ b/packages/components/src/TimeInput.tsx
@@ -7,7 +7,7 @@ import React, {
} from 'react';
import Log from '@deephaven/log';
import { TimeUtils } from '@deephaven/utils';
-import MaskedInput, { SelectionSegment } from './MaskedInput';
+import MaskedInput, { type SelectionSegment } from './MaskedInput';
import { DEFAULT_GET_PREFERRED_REPLACEMENT_STRING } from './MaskedInputUtils';
export type { SelectionSegment } from './MaskedInput';
diff --git a/packages/components/src/TimeSlider.tsx b/packages/components/src/TimeSlider.tsx
index 3979471386..76232d4b9b 100644
--- a/packages/components/src/TimeSlider.tsx
+++ b/packages/components/src/TimeSlider.tsx
@@ -9,7 +9,10 @@ import React, {
useEffect,
} from 'react';
import classNames from 'classnames';
-import TimeInput, { SelectionSegment, TimeInputElement } from './TimeInput';
+import TimeInput, {
+ type SelectionSegment,
+ type TimeInputElement,
+} from './TimeInput';
import StyleExports from './TimeSlider.module.scss';
import './TimeSlider.scss';
diff --git a/packages/components/src/UISwitch.test.tsx b/packages/components/src/UISwitch.test.tsx
index 6be0b9180c..d3aa6ae49f 100644
--- a/packages/components/src/UISwitch.test.tsx
+++ b/packages/components/src/UISwitch.test.tsx
@@ -1,7 +1,7 @@
import React from 'react';
import { render } from '@testing-library/react';
import userEvent from '@testing-library/user-event';
-import UISwitch, { UISwitchProps } from './UISwitch';
+import UISwitch, { type UISwitchProps } from './UISwitch';
function makeUISwitch({
'data-testid': dataTestId = 'TestUISwitch',
diff --git a/packages/components/src/XComponent.tsx b/packages/components/src/XComponent.tsx
index 0f1c9c0cb6..9fb84c1e50 100644
--- a/packages/components/src/XComponent.tsx
+++ b/packages/components/src/XComponent.tsx
@@ -1,6 +1,6 @@
-import React, { ComponentType, forwardRef } from 'react';
+import React, { type ComponentType, forwardRef } from 'react';
import { canHaveRef } from './ComponentUtils';
-import { useXComponent, XComponentType } from './XComponentMap';
+import { useXComponent, type XComponentType } from './XComponentMap';
/**
* Helper function that will wrap the provided component, and return an ExtendableComponent type.
diff --git a/packages/components/src/actions/ConfirmActionButton.tsx b/packages/components/src/actions/ConfirmActionButton.tsx
index 4c096ad33a..c8d7c6dcf2 100644
--- a/packages/components/src/actions/ConfirmActionButton.tsx
+++ b/packages/components/src/actions/ConfirmActionButton.tsx
@@ -1,4 +1,4 @@
-import { ReactElement, ReactNode, useCallback } from 'react';
+import { type ReactElement, type ReactNode, useCallback } from 'react';
import type { SpectrumLabelableProps } from '@react-types/shared';
import { vsTrash } from '@deephaven/icons';
import { ActionButtonDialogTrigger, ConfirmationDialog } from '../dialogs';
diff --git a/packages/components/src/actions/IconActionButton.tsx b/packages/components/src/actions/IconActionButton.tsx
index 43ae0fbd57..6d8353c46f 100644
--- a/packages/components/src/actions/IconActionButton.tsx
+++ b/packages/components/src/actions/IconActionButton.tsx
@@ -1,7 +1,7 @@
/* eslint-disable react/jsx-props-no-spreading */
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
import type { IconProp } from '@fortawesome/fontawesome-svg-core';
-import { ActionButton, Icon, ActionButtonProps } from '../spectrum';
+import { ActionButton, Icon, type ActionButtonProps } from '../spectrum';
import { Tooltip } from '../popper';
import { ACTION_ICON_HEIGHT } from '../UIConstants';
diff --git a/packages/components/src/context-actions/ContextActionUtils.ts b/packages/components/src/context-actions/ContextActionUtils.ts
index 06f9b70fd4..1e802bfe3b 100644
--- a/packages/components/src/context-actions/ContextActionUtils.ts
+++ b/packages/components/src/context-actions/ContextActionUtils.ts
@@ -1,5 +1,5 @@
-import { IconDefinition } from '@deephaven/icons';
-import React from 'react';
+import { type IconDefinition } from '@deephaven/icons';
+import type React from 'react';
import type { Shortcut } from '../shortcuts';
export type ResolvableContextAction =
diff --git a/packages/components/src/context-actions/ContextActions.tsx b/packages/components/src/context-actions/ContextActions.tsx
index ab45275490..bfabf54f34 100644
--- a/packages/components/src/context-actions/ContextActions.tsx
+++ b/packages/components/src/context-actions/ContextActions.tsx
@@ -4,7 +4,7 @@
import React, { Component } from 'react';
import Log from '@deephaven/log';
import ContextActionUtils, {
- ResolvableContextAction,
+ type ResolvableContextAction,
isPromise,
} from './ContextActionUtils';
import type { ContextAction, ContextActionEvent } from './ContextActionUtils';
diff --git a/packages/components/src/context-actions/ContextMenu.tsx b/packages/components/src/context-actions/ContextMenu.tsx
index b3276a78fa..0d756638ae 100644
--- a/packages/components/src/context-actions/ContextMenu.tsx
+++ b/packages/components/src/context-actions/ContextMenu.tsx
@@ -1,10 +1,10 @@
import React, { PureComponent } from 'react';
import classNames from 'classnames';
import Log from '@deephaven/log';
-import { PromiseUtils, CancelablePromise } from '@deephaven/utils';
+import { PromiseUtils, type CancelablePromise } from '@deephaven/utils';
import ContextActionUtils, {
- ContextAction,
- ResolvableContextAction,
+ type ContextAction,
+ type ResolvableContextAction,
} from './ContextActionUtils';
import ContextMenuItem from './ContextMenuItem';
import LoadingSpinner from '../LoadingSpinner';
diff --git a/packages/components/src/context-actions/ContextMenuItem.tsx b/packages/components/src/context-actions/ContextMenuItem.tsx
index 9af75cfef3..7e51efa054 100644
--- a/packages/components/src/context-actions/ContextMenuItem.tsx
+++ b/packages/components/src/context-actions/ContextMenuItem.tsx
@@ -1,7 +1,7 @@
import React from 'react';
import classNames from 'classnames';
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
-import { vsChevronRight, IconDefinition } from '@deephaven/icons';
+import { vsChevronRight, type IconDefinition } from '@deephaven/icons';
import type { ContextAction } from './ContextActionUtils';
interface ContextMenuItemProps {
diff --git a/packages/components/src/context-actions/ContextMenuRoot.tsx b/packages/components/src/context-actions/ContextMenuRoot.tsx
index 93d3f54c94..c754220e17 100644
--- a/packages/components/src/context-actions/ContextMenuRoot.tsx
+++ b/packages/components/src/context-actions/ContextMenuRoot.tsx
@@ -1,7 +1,7 @@
import React, { Component } from 'react';
import classNames from 'classnames';
import ContextMenu from './ContextMenu';
-import ContextActionUtils, { MenuItem } from './ContextActionUtils';
+import ContextActionUtils, { type MenuItem } from './ContextActionUtils';
type ContextMenuRootProps = Record & {
'data-testid'?: string;
diff --git a/packages/components/src/dialogs/ActionButtonDialogTrigger.tsx b/packages/components/src/dialogs/ActionButtonDialogTrigger.tsx
index 130d3f0208..97c706c638 100644
--- a/packages/components/src/dialogs/ActionButtonDialogTrigger.tsx
+++ b/packages/components/src/dialogs/ActionButtonDialogTrigger.tsx
@@ -1,4 +1,4 @@
-import { ReactElement } from 'react';
+import { type ReactElement } from 'react';
import type { SpectrumDialogClose } from '@react-types/dialog';
import type { StyleProps } from '@react-types/shared';
import type { IconDefinition } from '@fortawesome/fontawesome-common-types';
diff --git a/packages/components/src/dialogs/ConfirmationDialog.tsx b/packages/components/src/dialogs/ConfirmationDialog.tsx
index e5e0bcba42..356485f2a7 100644
--- a/packages/components/src/dialogs/ConfirmationDialog.tsx
+++ b/packages/components/src/dialogs/ConfirmationDialog.tsx
@@ -1,5 +1,5 @@
/* eslint-disable react/jsx-props-no-spreading */
-import { ReactElement, ReactNode } from 'react';
+import { type ReactElement, type ReactNode } from 'react';
import type { SpectrumLabelableProps } from '@react-types/shared';
import { useFormWithDetachedSubmitButton } from '@deephaven/react-hooks';
import {
diff --git a/packages/components/src/menu-actions/DropdownMenu.tsx b/packages/components/src/menu-actions/DropdownMenu.tsx
index fc7586981d..e7b0b4af2b 100644
--- a/packages/components/src/menu-actions/DropdownMenu.tsx
+++ b/packages/components/src/menu-actions/DropdownMenu.tsx
@@ -30,10 +30,10 @@
*/
import React, { PureComponent } from 'react';
import classNames from 'classnames';
-import { PopperOptions } from 'popper.js';
+import { type PopperOptions } from 'popper.js';
import { Popper } from '../popper';
-import Menu, { MenuOptions } from './Menu';
-import { ContextAction } from '../context-actions/ContextActionUtils';
+import Menu, { type MenuOptions } from './Menu';
+import { type ContextAction } from '../context-actions/ContextActionUtils';
import './DropdownMenu.scss';
export type DropdownAction = ContextAction & { actions?: never };
diff --git a/packages/components/src/menu-actions/Menu.tsx b/packages/components/src/menu-actions/Menu.tsx
index c2af839d2b..bf3e2c9039 100644
--- a/packages/components/src/menu-actions/Menu.tsx
+++ b/packages/components/src/menu-actions/Menu.tsx
@@ -1,6 +1,6 @@
import React, { PureComponent } from 'react';
import ContextActionUtils, {
- ContextAction,
+ type ContextAction,
} from '../context-actions/ContextActionUtils';
import ContextMenuItem from '../context-actions/ContextMenuItem';
diff --git a/packages/components/src/modal/InfoModal.tsx b/packages/components/src/modal/InfoModal.tsx
index 9259fae40a..05fbaa40d8 100644
--- a/packages/components/src/modal/InfoModal.tsx
+++ b/packages/components/src/modal/InfoModal.tsx
@@ -1,6 +1,6 @@
import React from 'react';
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
-import { IconProp } from '@fortawesome/fontawesome-svg-core';
+import { type IconProp } from '@fortawesome/fontawesome-svg-core';
import Modal from './Modal';
import ModalBody from './ModalBody';
import './InfoModal.scss';
diff --git a/packages/components/src/modal/Modal.tsx b/packages/components/src/modal/Modal.tsx
index 5385821be9..de5dcddaf8 100644
--- a/packages/components/src/modal/Modal.tsx
+++ b/packages/components/src/modal/Modal.tsx
@@ -1,6 +1,6 @@
import classNames from 'classnames';
import React, {
- ReactNode,
+ type ReactNode,
useCallback,
useEffect,
useRef,
diff --git a/packages/components/src/modal/ModalBody.tsx b/packages/components/src/modal/ModalBody.tsx
index 9a531acea2..499761dc33 100644
--- a/packages/components/src/modal/ModalBody.tsx
+++ b/packages/components/src/modal/ModalBody.tsx
@@ -1,4 +1,8 @@
-import React, { CSSProperties, ReactElement, ReactNode } from 'react';
+import React, {
+ type CSSProperties,
+ type ReactElement,
+ type ReactNode,
+} from 'react';
import classNames from 'classnames';
interface ModalBodyProps {
diff --git a/packages/components/src/modal/ModalFooter.tsx b/packages/components/src/modal/ModalFooter.tsx
index 8a20be419c..6c97b77e19 100644
--- a/packages/components/src/modal/ModalFooter.tsx
+++ b/packages/components/src/modal/ModalFooter.tsx
@@ -1,4 +1,4 @@
-import React, { ReactElement, ReactNode } from 'react';
+import React, { type ReactElement, type ReactNode } from 'react';
import classNames from 'classnames';
interface ModalFooterProps {
diff --git a/packages/components/src/modal/ModalHeader.tsx b/packages/components/src/modal/ModalHeader.tsx
index 0e8b5602d2..ce0439120e 100644
--- a/packages/components/src/modal/ModalHeader.tsx
+++ b/packages/components/src/modal/ModalHeader.tsx
@@ -1,4 +1,8 @@
-import React, { CSSProperties, ReactElement, ReactNode } from 'react';
+import React, {
+ type CSSProperties,
+ type ReactElement,
+ type ReactNode,
+} from 'react';
import classNames from 'classnames';
interface ModalHeaderProps {
diff --git a/packages/components/src/navigation/Menu.tsx b/packages/components/src/navigation/Menu.tsx
index 4a8249a460..c140dfea74 100644
--- a/packages/components/src/navigation/Menu.tsx
+++ b/packages/components/src/navigation/Menu.tsx
@@ -1,5 +1,5 @@
import React from 'react';
-import MenuItem, { MenuItemDef } from './MenuItem';
+import MenuItem, { type MenuItemDef } from './MenuItem';
import './Menu.scss';
export type MenuSelectCallback = (itemIndex: number) => void;
diff --git a/packages/components/src/navigation/MenuItem.tsx b/packages/components/src/navigation/MenuItem.tsx
index 7529a6393e..ff66f83b64 100644
--- a/packages/components/src/navigation/MenuItem.tsx
+++ b/packages/components/src/navigation/MenuItem.tsx
@@ -1,5 +1,5 @@
import React, { useMemo } from 'react';
-import { IconProp } from '@fortawesome/fontawesome-svg-core';
+import { type IconProp } from '@fortawesome/fontawesome-svg-core';
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
import { vsChevronRight } from '@deephaven/icons';
import './MenuItem.scss';
diff --git a/packages/components/src/navigation/NavTab.test.tsx b/packages/components/src/navigation/NavTab.test.tsx
index c327b6b1cc..992d29abe0 100644
--- a/packages/components/src/navigation/NavTab.test.tsx
+++ b/packages/components/src/navigation/NavTab.test.tsx
@@ -3,9 +3,9 @@ import { render, screen } from '@testing-library/react';
import userEvent from '@testing-library/user-event';
import {
DragDropContext,
- DropResult,
+ type DropResult,
Droppable,
- ResponderProvided,
+ type ResponderProvided,
} from 'react-beautiful-dnd';
import NavTab from './NavTab';
diff --git a/packages/components/src/navigation/NavTab.tsx b/packages/components/src/navigation/NavTab.tsx
index 69bf8456f1..67804ecf42 100644
--- a/packages/components/src/navigation/NavTab.tsx
+++ b/packages/components/src/navigation/NavTab.tsx
@@ -1,12 +1,12 @@
import React, { memo } from 'react';
import classNames from 'classnames';
import { Draggable } from 'react-beautiful-dnd';
-import { IconDefinition, vsClose } from '@deephaven/icons';
+import { type IconDefinition, vsClose } from '@deephaven/icons';
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
import type { NavTabItem } from './NavTabList';
import Button from '../Button';
import ContextActions from '../context-actions/ContextActions';
-import { ResolvableContextAction } from '../context-actions';
+import { type ResolvableContextAction } from '../context-actions';
interface NavTabProps {
tab: NavTabItem;
diff --git a/packages/components/src/navigation/NavTabList.tsx b/packages/components/src/navigation/NavTabList.tsx
index e6847207e5..5baaf22150 100644
--- a/packages/components/src/navigation/NavTabList.tsx
+++ b/packages/components/src/navigation/NavTabList.tsx
@@ -10,17 +10,20 @@ import clamp from 'lodash.clamp';
import {
DragDropContext,
Droppable,
- OnDragEndResponder,
+ type OnDragEndResponder,
} from 'react-beautiful-dnd';
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
-import { IconDefinition } from '@fortawesome/fontawesome-svg-core';
+import { type IconDefinition } from '@fortawesome/fontawesome-svg-core';
import { vsChevronRight, vsChevronLeft } from '@deephaven/icons';
import { useResizeObserver } from '@deephaven/react-hooks';
import DragUtils from '../DragUtils';
import Button from '../Button';
import NavTab from './NavTab';
import './NavTabList.scss';
-import { ContextAction, ResolvableContextAction } from '../context-actions';
+import {
+ type ContextAction,
+ type ResolvableContextAction,
+} from '../context-actions';
// mouse hold timeout to act as hold instead of click
const CLICK_TIMEOUT = 500;
diff --git a/packages/components/src/popper/Popper.tsx b/packages/components/src/popper/Popper.tsx
index 56331abbcd..6c94c7fdfe 100644
--- a/packages/components/src/popper/Popper.tsx
+++ b/packages/components/src/popper/Popper.tsx
@@ -19,7 +19,7 @@ import React, { Component } from 'react';
import ReactDOM from 'react-dom';
import classNames from 'classnames';
import { CSSTransition } from 'react-transition-group';
-import PopperJs, { PopperOptions, ReferenceObject } from 'popper.js';
+import PopperJs, { type PopperOptions, type ReferenceObject } from 'popper.js';
import PropTypes from 'prop-types';
import ThemeExport from '../ThemeExport';
import './Popper.scss';
diff --git a/packages/components/src/popper/Tooltip.tsx b/packages/components/src/popper/Tooltip.tsx
index 02d8e3d4b3..cd84ec6b8d 100644
--- a/packages/components/src/popper/Tooltip.tsx
+++ b/packages/components/src/popper/Tooltip.tsx
@@ -1,7 +1,7 @@
import React, { Component } from 'react';
import classNames from 'classnames';
import Log from '@deephaven/log';
-import Popper, { PopperOptions, ReferenceObject } from './Popper';
+import Popper, { type PopperOptions, type ReferenceObject } from './Popper';
const log = Log.module('Tooltip');
diff --git a/packages/components/src/shortcuts/Shortcut.ts b/packages/components/src/shortcuts/Shortcut.ts
index 57618a9608..5492029632 100644
--- a/packages/components/src/shortcuts/Shortcut.ts
+++ b/packages/components/src/shortcuts/Shortcut.ts
@@ -1,8 +1,8 @@
/* eslint-disable no-underscore-dangle */
import { EventTarget } from 'event-target-shim';
-import React from 'react';
+import type React from 'react';
import { Log } from '@deephaven/log';
-import { CustomEventMap, EventShimCustomEvent } from '@deephaven/utils';
+import { type CustomEventMap, EventShimCustomEvent } from '@deephaven/utils';
import { ContextActionUtils } from '../context-actions';
const log = Log.module('Shortcut');
diff --git a/packages/components/src/shortcuts/ShortcutRegistry.ts b/packages/components/src/shortcuts/ShortcutRegistry.ts
index 3a9e39d20f..2ec72854c0 100644
--- a/packages/components/src/shortcuts/ShortcutRegistry.ts
+++ b/packages/components/src/shortcuts/ShortcutRegistry.ts
@@ -1,8 +1,8 @@
/* eslint-disable max-classes-per-file */
import { EventTarget } from 'event-target-shim';
import { Log } from '@deephaven/log';
-import { CustomEventMap, EventShimCustomEvent } from '@deephaven/utils';
-import Shortcut, { KeyState } from './Shortcut';
+import { type CustomEventMap, EventShimCustomEvent } from '@deephaven/utils';
+import Shortcut, { type KeyState } from './Shortcut';
const log = Log.module('ShortcutRegistry');
diff --git a/packages/components/src/spectrum/ActionGroup.tsx b/packages/components/src/spectrum/ActionGroup.tsx
index 456b87769a..5e17722851 100644
--- a/packages/components/src/spectrum/ActionGroup.tsx
+++ b/packages/components/src/spectrum/ActionGroup.tsx
@@ -1,11 +1,11 @@
import { useMemo } from 'react';
import {
ActionGroup as SpectrumActionGroup,
- SpectrumActionGroupProps,
+ type SpectrumActionGroupProps,
} from '@adobe/react-spectrum';
import cl from 'classnames';
-import { ItemsOrPrimitiveChildren } from './shared';
-import { MultipleItemSelectionProps, wrapItemChildren } from './utils';
+import { type ItemsOrPrimitiveChildren } from './shared';
+import { type MultipleItemSelectionProps, wrapItemChildren } from './utils';
export type ActionGroupProps = Omit<
SpectrumActionGroupProps,
diff --git a/packages/components/src/spectrum/ActionMenu.tsx b/packages/components/src/spectrum/ActionMenu.tsx
index b629a0de13..9c6885f6fa 100644
--- a/packages/components/src/spectrum/ActionMenu.tsx
+++ b/packages/components/src/spectrum/ActionMenu.tsx
@@ -1,11 +1,11 @@
import { useMemo } from 'react';
import {
ActionMenu as SpectrumActionMenu,
- SpectrumActionMenuProps,
+ type SpectrumActionMenuProps,
} from '@adobe/react-spectrum';
import cl from 'classnames';
-import { ItemsOrPrimitiveChildren } from './shared';
-import { ItemKey, wrapItemChildren } from './utils';
+import { type ItemsOrPrimitiveChildren } from './shared';
+import { type ItemKey, wrapItemChildren } from './utils';
export type ActionMenuProps = Omit<
SpectrumActionMenuProps,
diff --git a/packages/components/src/spectrum/ItemContent.tsx b/packages/components/src/spectrum/ItemContent.tsx
index f11e6c9638..e8fc039564 100644
--- a/packages/components/src/spectrum/ItemContent.tsx
+++ b/packages/components/src/spectrum/ItemContent.tsx
@@ -2,14 +2,14 @@ import {
Children,
cloneElement,
isValidElement,
- ReactNode,
+ type ReactNode,
useState,
} from 'react';
import cl from 'classnames';
import { isElementOfType, useCheckOverflow } from '@deephaven/react-hooks';
import { NON_BREAKING_SPACE } from '@deephaven/utils';
import { Text } from './Text';
-import { TooltipOptions } from './utils';
+import { type TooltipOptions } from './utils';
import ItemTooltip from './ItemTooltip';
import stylesCommon from '../SpectrumComponent.module.scss';
diff --git a/packages/components/src/spectrum/ItemTooltip.tsx b/packages/components/src/spectrum/ItemTooltip.tsx
index a86588d2ff..454daaa9be 100644
--- a/packages/components/src/spectrum/ItemTooltip.tsx
+++ b/packages/components/src/spectrum/ItemTooltip.tsx
@@ -1,6 +1,6 @@
-import { ReactNode } from 'react';
+import { type ReactNode } from 'react';
import { isElementOfType } from '@deephaven/react-hooks';
-import { TooltipOptions } from './utils';
+import { type TooltipOptions } from './utils';
import { Tooltip } from '../popper';
import { Flex } from './layout';
import { Text } from './Text';
diff --git a/packages/components/src/spectrum/ListActionGroup.tsx b/packages/components/src/spectrum/ListActionGroup.tsx
index d1882ad56e..612d548bd9 100644
--- a/packages/components/src/spectrum/ListActionGroup.tsx
+++ b/packages/components/src/spectrum/ListActionGroup.tsx
@@ -1,5 +1,5 @@
-import { ActionGroupProps } from './ActionGroup';
-import { ItemKey, ItemSelection } from './utils';
+import { type ActionGroupProps } from './ActionGroup';
+import { type ItemKey, type ItemSelection } from './utils';
export interface ListActionGroupProps
extends Omit<
diff --git a/packages/components/src/spectrum/ListActionMenu.tsx b/packages/components/src/spectrum/ListActionMenu.tsx
index c5ebfa4191..7bbe46f014 100644
--- a/packages/components/src/spectrum/ListActionMenu.tsx
+++ b/packages/components/src/spectrum/ListActionMenu.tsx
@@ -1,5 +1,5 @@
-import { ActionMenuProps } from './ActionMenu';
-import { ItemKey } from './utils';
+import { type ActionMenuProps } from './ActionMenu';
+import { type ItemKey } from './utils';
export interface ListActionMenuProps
extends Omit, 'onAction' | 'onOpenChange'> {
diff --git a/packages/components/src/spectrum/View.tsx b/packages/components/src/spectrum/View.tsx
index 7ab0633d9c..1e5eee99ea 100644
--- a/packages/components/src/spectrum/View.tsx
+++ b/packages/components/src/spectrum/View.tsx
@@ -1,5 +1,5 @@
/* eslint-disable react/jsx-props-no-spreading */
-import { CSSProperties, forwardRef, useMemo } from 'react';
+import { type CSSProperties, forwardRef, useMemo } from 'react';
import {
useLocale,
View as SpectrumView,
diff --git a/packages/components/src/spectrum/comboBox/ComboBox.tsx b/packages/components/src/spectrum/comboBox/ComboBox.tsx
index 3681174ee9..3898d65743 100644
--- a/packages/components/src/spectrum/comboBox/ComboBox.tsx
+++ b/packages/components/src/spectrum/comboBox/ComboBox.tsx
@@ -1,13 +1,13 @@
import React from 'react';
import {
ComboBox as SpectrumComboBox,
- SpectrumComboBoxProps,
+ type SpectrumComboBoxProps,
} from '@adobe/react-spectrum';
import type { DOMRef } from '@react-types/shared';
import cl from 'classnames';
import { useMergeRef } from '@deephaven/react-hooks';
import type { NormalizedItem } from '../utils';
-import { PickerPropsT, usePickerProps } from '../picker';
+import { type PickerPropsT, usePickerProps } from '../picker';
export type ComboBoxProps = PickerPropsT>;
diff --git a/packages/components/src/spectrum/comboBox/ComboBoxNormalized.tsx b/packages/components/src/spectrum/comboBox/ComboBoxNormalized.tsx
index b963803a47..1b18908542 100644
--- a/packages/components/src/spectrum/comboBox/ComboBoxNormalized.tsx
+++ b/packages/components/src/spectrum/comboBox/ComboBoxNormalized.tsx
@@ -1,8 +1,11 @@
import { ComboBox as SpectrumComboBox } from '@adobe/react-spectrum';
-import { FocusableRef } from '@react-types/shared';
+import { type FocusableRef } from '@react-types/shared';
import cl from 'classnames';
-import { PickerNormalizedPropsT, usePickerNormalizedProps } from '../picker';
-import { ComboBoxProps } from './ComboBox';
+import {
+ type PickerNormalizedPropsT,
+ usePickerNormalizedProps,
+} from '../picker';
+import { type ComboBoxProps } from './ComboBox';
export type ComboBoxNormalizedProps = PickerNormalizedPropsT;
diff --git a/packages/components/src/spectrum/dateAndTime.ts b/packages/components/src/spectrum/dateAndTime.ts
index 4e4c164be7..858f8c53b5 100644
--- a/packages/components/src/spectrum/dateAndTime.ts
+++ b/packages/components/src/spectrum/dateAndTime.ts
@@ -1,7 +1,7 @@
import {
- CalendarDate,
- CalendarDateTime,
- ZonedDateTime,
+ type CalendarDate,
+ type CalendarDateTime,
+ type ZonedDateTime,
} from '@internationalized/date';
export {
diff --git a/packages/components/src/spectrum/listView/ListView.tsx b/packages/components/src/spectrum/listView/ListView.tsx
index 21b68c752e..5f5796e920 100644
--- a/packages/components/src/spectrum/listView/ListView.tsx
+++ b/packages/components/src/spectrum/listView/ListView.tsx
@@ -1,16 +1,16 @@
import { useMemo } from 'react';
-import { SpectrumListViewProps } from '@adobe/react-spectrum';
+import { type SpectrumListViewProps } from '@adobe/react-spectrum';
import cl from 'classnames';
import { EMPTY_FUNCTION } from '@deephaven/utils';
import {
- MultipleItemSelectionProps,
- NormalizedItem,
+ type MultipleItemSelectionProps,
+ type NormalizedItem,
normalizeTooltipOptions,
- TooltipOptions,
+ type TooltipOptions,
wrapItemChildren,
} from '../utils';
-import { ListViewWrapper, ListViewWrapperProps } from './ListViewWrapper';
-import { ItemElementOrPrimitive } from '../shared';
+import { ListViewWrapper, type ListViewWrapperProps } from './ListViewWrapper';
+import { type ItemElementOrPrimitive } from '../shared';
export type ListViewProps = MultipleItemSelectionProps & {
children: ItemElementOrPrimitive | ItemElementOrPrimitive[];
diff --git a/packages/components/src/spectrum/listView/ListViewNormalized.tsx b/packages/components/src/spectrum/listView/ListViewNormalized.tsx
index e5301bccb6..ee47e89400 100644
--- a/packages/components/src/spectrum/listView/ListViewNormalized.tsx
+++ b/packages/components/src/spectrum/listView/ListViewNormalized.tsx
@@ -1,8 +1,8 @@
import { useMemo } from 'react';
import cl from 'classnames';
import {
- ListActions,
- NormalizedItem,
+ type ListActions,
+ type NormalizedItem,
normalizeTooltipOptions,
useRenderNormalizedItem,
useStringifiedMultiSelection,
diff --git a/packages/components/src/spectrum/listView/ListViewWrapper.tsx b/packages/components/src/spectrum/listView/ListViewWrapper.tsx
index b08f98e87d..e14c3d5b3a 100644
--- a/packages/components/src/spectrum/listView/ListViewWrapper.tsx
+++ b/packages/components/src/spectrum/listView/ListViewWrapper.tsx
@@ -1,6 +1,6 @@
import {
ListView as SpectrumListView,
- SpectrumListViewProps,
+ type SpectrumListViewProps,
} from '@adobe/react-spectrum';
import {
extractSpectrumHTMLElement,
diff --git a/packages/components/src/spectrum/picker/Picker.tsx b/packages/components/src/spectrum/picker/Picker.tsx
index f449b169f6..521e30da5f 100644
--- a/packages/components/src/spectrum/picker/Picker.tsx
+++ b/packages/components/src/spectrum/picker/Picker.tsx
@@ -1,6 +1,6 @@
import {
Picker as SpectrumPicker,
- SpectrumPickerProps,
+ type SpectrumPickerProps,
} from '@adobe/react-spectrum';
import type { DOMRef } from '@react-types/shared';
import cl from 'classnames';
diff --git a/packages/components/src/spectrum/picker/usePickerNormalizedProps.tsx b/packages/components/src/spectrum/picker/usePickerNormalizedProps.tsx
index 01c2d7938e..fc36eccf6e 100644
--- a/packages/components/src/spectrum/picker/usePickerNormalizedProps.tsx
+++ b/packages/components/src/spectrum/picker/usePickerNormalizedProps.tsx
@@ -1,16 +1,16 @@
-import { Key, useCallback, useMemo } from 'react';
+import { type Key, useCallback, useMemo } from 'react';
import { EMPTY_FUNCTION } from '@deephaven/utils';
import type { DOMRef } from '@react-types/shared';
import {
getItemKey,
isNormalizedSection,
- NormalizedItem,
- NormalizedSection,
+ type NormalizedItem,
+ type NormalizedSection,
normalizeTooltipOptions,
useRenderNormalizedItem,
useStringifiedSelection,
} from '../utils';
-import { PickerNormalizedPropsT } from './PickerProps';
+import { type PickerNormalizedPropsT } from './PickerProps';
import { usePickerScrollOnOpen } from './usePickerScrollOnOpen';
import { Section } from '../shared';
diff --git a/packages/components/src/spectrum/picker/usePickerProps.ts b/packages/components/src/spectrum/picker/usePickerProps.ts
index ba6eef1b50..ec34c06d1b 100644
--- a/packages/components/src/spectrum/picker/usePickerProps.ts
+++ b/packages/components/src/spectrum/picker/usePickerProps.ts
@@ -1,5 +1,5 @@
import { EMPTY_FUNCTION, ensureArray } from '@deephaven/utils';
-import { DOMRef } from '@react-types/shared';
+import { type DOMRef } from '@react-types/shared';
import { useMemo } from 'react';
import { PICKER_TOP_OFFSET } from '../../UIConstants';
import {
@@ -7,9 +7,9 @@ import {
wrapItemChildren,
useOnChangeTrackUncontrolled,
useStaticItemInitialScrollPosition,
- ItemKey,
- SectionElement,
- ItemElement,
+ type ItemKey,
+ type SectionElement,
+ type ItemElement,
} from '../utils';
import type { PickerPropsT } from './PickerProps';
import usePickerItemScale from './usePickerItemScale';
diff --git a/packages/components/src/spectrum/picker/usePickerScrollOnOpen.test.ts b/packages/components/src/spectrum/picker/usePickerScrollOnOpen.test.ts
index 77f48d09cf..e09cef195f 100644
--- a/packages/components/src/spectrum/picker/usePickerScrollOnOpen.test.ts
+++ b/packages/components/src/spectrum/picker/usePickerScrollOnOpen.test.ts
@@ -3,7 +3,7 @@ import { TestUtils } from '@deephaven/test-utils';
import {
findSpectrumPickerScrollArea,
usePopoverOnScrollRef,
- UsePopoverOnScrollRefResult,
+ type UsePopoverOnScrollRefResult,
} from '@deephaven/react-hooks';
import { usePickerScrollOnOpen } from './usePickerScrollOnOpen';
diff --git a/packages/components/src/spectrum/utils/itemUtils.test.tsx b/packages/components/src/spectrum/utils/itemUtils.test.tsx
index a09c8fc02d..3705954a09 100644
--- a/packages/components/src/spectrum/utils/itemUtils.test.tsx
+++ b/packages/components/src/spectrum/utils/itemUtils.test.tsx
@@ -6,18 +6,18 @@ import {
isNormalizedSection,
isItemOrSection,
isSectionElement,
- NormalizedItem,
- NormalizedSection,
+ type NormalizedItem,
+ type NormalizedSection,
normalizeTooltipOptions,
- ItemOrSection,
- SectionElement,
+ type ItemOrSection,
+ type SectionElement,
itemSelectionToStringSet,
getPositionOfSelectedItemElement,
isItemElementWithDescription,
getItemTextValue,
ITEM_EMPTY_STRING_TEXT_VALUE,
} from './itemUtils';
-import { Item, ItemElementOrPrimitive, Section } from '../shared';
+import { Item, type ItemElementOrPrimitive, Section } from '../shared';
import { Text } from '../Text';
import ItemContent from '../ItemContent';
diff --git a/packages/components/src/spectrum/utils/itemUtils.ts b/packages/components/src/spectrum/utils/itemUtils.ts
index 7a8d674db8..880e78aa1b 100644
--- a/packages/components/src/spectrum/utils/itemUtils.ts
+++ b/packages/components/src/spectrum/utils/itemUtils.ts
@@ -1,15 +1,15 @@
-import { Key, ReactElement, ReactNode } from 'react';
+import { type Key, type ReactElement, type ReactNode } from 'react';
import type { ItemRenderer } from '@react-types/shared';
import { isElementOfType } from '@deephaven/react-hooks';
-import { ensureArray, KeyedItem, SelectionT } from '@deephaven/utils';
+import { ensureArray, type KeyedItem, type SelectionT } from '@deephaven/utils';
import {
Item,
- ItemElementOrPrimitive,
- ItemProps,
+ type ItemElementOrPrimitive,
+ type ItemProps,
Section,
- SectionProps,
+ type SectionProps,
} from '../shared';
-import { PopperOptions } from '../../popper';
+import { type PopperOptions } from '../../popper';
import { Text } from '../Text';
import ItemContent from '../ItemContent';
diff --git a/packages/components/src/spectrum/utils/itemWrapperUtils.tsx b/packages/components/src/spectrum/utils/itemWrapperUtils.tsx
index 0435f06501..31816a2eee 100644
--- a/packages/components/src/spectrum/utils/itemWrapperUtils.tsx
+++ b/packages/components/src/spectrum/utils/itemWrapperUtils.tsx
@@ -1,4 +1,4 @@
-import { cloneElement, ReactNode } from 'react';
+import { cloneElement, type ReactNode } from 'react';
import { Item } from '@adobe/react-spectrum';
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
import { dh as dhIcons } from '@deephaven/icons';
@@ -8,12 +8,12 @@ import {
getItemTextValue,
isItemElement,
isSectionElement,
- ItemElement,
- ItemIconSlot,
- ItemOrSection,
+ type ItemElement,
+ type ItemIconSlot,
+ type ItemOrSection,
ITEM_EMPTY_STRING_TEXT_VALUE,
- SectionElement,
- TooltipOptions,
+ type SectionElement,
+ type TooltipOptions,
} from './itemUtils';
import { ItemContent } from '../ItemContent';
import { Icon } from '../icons';
diff --git a/packages/components/src/spectrum/utils/propUtils.test.ts b/packages/components/src/spectrum/utils/propUtils.test.ts
index 356bc1f8bc..9ce7b0f748 100644
--- a/packages/components/src/spectrum/utils/propUtils.test.ts
+++ b/packages/components/src/spectrum/utils/propUtils.test.ts
@@ -1,4 +1,4 @@
-import { AriaLabelingProps, StyleProps } from '@react-types/shared';
+import { type AriaLabelingProps, type StyleProps } from '@react-types/shared';
import { separateSpectrumProps } from './propsUtils';
describe('separateSpectrumProps', () => {
diff --git a/packages/components/src/spectrum/utils/useOnChangeTrackUncontrolled.test.ts b/packages/components/src/spectrum/utils/useOnChangeTrackUncontrolled.test.ts
index 5815e201d3..0bb0336b74 100644
--- a/packages/components/src/spectrum/utils/useOnChangeTrackUncontrolled.test.ts
+++ b/packages/components/src/spectrum/utils/useOnChangeTrackUncontrolled.test.ts
@@ -1,8 +1,8 @@
import { act, renderHook } from '@testing-library/react-hooks';
-import { ItemKey } from './itemUtils';
+import { type ItemKey } from './itemUtils';
import {
useOnChangeTrackUncontrolled,
- UseOnChangeTrackUncontrolledOptions,
+ type UseOnChangeTrackUncontrolledOptions,
} from './useOnChangeTrackUncontrolled';
beforeEach(() => {
diff --git a/packages/components/src/spectrum/utils/useOnChangeTrackUncontrolled.ts b/packages/components/src/spectrum/utils/useOnChangeTrackUncontrolled.ts
index 9cf62ec6bd..9c2169cb83 100644
--- a/packages/components/src/spectrum/utils/useOnChangeTrackUncontrolled.ts
+++ b/packages/components/src/spectrum/utils/useOnChangeTrackUncontrolled.ts
@@ -1,5 +1,5 @@
import { useCallback, useState } from 'react';
-import { ItemKey } from './itemUtils';
+import { type ItemKey } from './itemUtils';
export interface UseOnChangeTrackUncontrolledOptions {
defaultSelectedKey?: ItemKey;
diff --git a/packages/components/src/spectrum/utils/useRenderNormalizedItem.test.tsx b/packages/components/src/spectrum/utils/useRenderNormalizedItem.test.tsx
index e5e2dc46ba..db55293326 100644
--- a/packages/components/src/spectrum/utils/useRenderNormalizedItem.test.tsx
+++ b/packages/components/src/spectrum/utils/useRenderNormalizedItem.test.tsx
@@ -1,11 +1,11 @@
-import React, { Key } from 'react';
+import React, { type Key } from 'react';
import { Item } from '@adobe/react-spectrum';
import { renderHook } from '@testing-library/react-hooks';
import { isElementOfType } from '@deephaven/react-hooks';
import { TestUtils } from '@deephaven/test-utils';
import { ItemContent } from '../ItemContent';
import { useRenderNormalizedItem } from './useRenderNormalizedItem';
-import { getItemKey, NormalizedItem } from './itemUtils';
+import { getItemKey, type NormalizedItem } from './itemUtils';
import { wrapIcon, wrapPrimitiveWithText } from './itemWrapperUtils';
import { ListActionGroup } from '../ListActionGroup';
import { ActionGroup } from '../ActionGroup';
diff --git a/packages/components/src/spectrum/utils/useRenderNormalizedItem.tsx b/packages/components/src/spectrum/utils/useRenderNormalizedItem.tsx
index 1a14cc6fa6..c7fba27e90 100644
--- a/packages/components/src/spectrum/utils/useRenderNormalizedItem.tsx
+++ b/packages/components/src/spectrum/utils/useRenderNormalizedItem.tsx
@@ -1,17 +1,17 @@
import { isElementOfType } from '@deephaven/react-hooks';
-import { Key, ReactElement, useCallback } from 'react';
+import { type Key, type ReactElement, useCallback } from 'react';
import ActionGroup from '../ActionGroup';
import ActionMenu from '../ActionMenu';
import { ItemContent } from '../ItemContent';
-import { ListActionGroup, ListActionGroupProps } from '../ListActionGroup';
-import { ListActionMenu, ListActionMenuProps } from '../ListActionMenu';
+import { ListActionGroup, type ListActionGroupProps } from '../ListActionGroup';
+import { ListActionMenu, type ListActionMenuProps } from '../ListActionMenu';
import { Item } from '../shared';
import {
getItemKey,
ITEM_EMPTY_STRING_TEXT_VALUE,
- ItemIconSlot,
- NormalizedItem,
- TooltipOptions,
+ type ItemIconSlot,
+ type NormalizedItem,
+ type TooltipOptions,
} from './itemUtils';
import { wrapIcon, wrapPrimitiveWithText } from './itemWrapperUtils';
diff --git a/packages/components/src/spectrum/utils/useStaticItemInitialScrollPosition.test.tsx b/packages/components/src/spectrum/utils/useStaticItemInitialScrollPosition.test.tsx
index dab7444f3d..ee7633f774 100644
--- a/packages/components/src/spectrum/utils/useStaticItemInitialScrollPosition.test.tsx
+++ b/packages/components/src/spectrum/utils/useStaticItemInitialScrollPosition.test.tsx
@@ -1,7 +1,7 @@
import React from 'react';
import { renderHook } from '@testing-library/react-hooks';
import { Item, Section } from '../shared';
-import { ItemElement } from './itemUtils';
+import { type ItemElement } from './itemUtils';
import { useStaticItemInitialScrollPosition } from './useStaticItemInitialScrollPosition';
beforeEach(() => {
diff --git a/packages/components/src/spectrum/utils/useStaticItemInitialScrollPosition.ts b/packages/components/src/spectrum/utils/useStaticItemInitialScrollPosition.ts
index 8f0f390de5..6e94d486cf 100644
--- a/packages/components/src/spectrum/utils/useStaticItemInitialScrollPosition.ts
+++ b/packages/components/src/spectrum/utils/useStaticItemInitialScrollPosition.ts
@@ -3,9 +3,9 @@ import {
getPositionOfSelectedItemElement,
isItemElementWithDescription,
isSectionElement,
- ItemElement,
- ItemKey,
- SectionElement,
+ type ItemElement,
+ type ItemKey,
+ type SectionElement,
} from './itemUtils';
export interface UseStaticItemInitialScrollPositionOptions {
diff --git a/packages/components/src/spectrum/utils/useStringifiedMultiSelection.test.ts b/packages/components/src/spectrum/utils/useStringifiedMultiSelection.test.ts
index 8f5c4e89d4..58e32d0164 100644
--- a/packages/components/src/spectrum/utils/useStringifiedMultiSelection.test.ts
+++ b/packages/components/src/spectrum/utils/useStringifiedMultiSelection.test.ts
@@ -1,5 +1,5 @@
import { renderHook } from '@testing-library/react-hooks';
-import { NormalizedItem } from './itemUtils';
+import { type NormalizedItem } from './itemUtils';
import { useStringifiedMultiSelection } from './useStringifiedMultiSelection';
beforeEach(() => {
diff --git a/packages/components/src/spectrum/utils/useStringifiedMultiSelection.ts b/packages/components/src/spectrum/utils/useStringifiedMultiSelection.ts
index 843d847a92..b3c13d497c 100644
--- a/packages/components/src/spectrum/utils/useStringifiedMultiSelection.ts
+++ b/packages/components/src/spectrum/utils/useStringifiedMultiSelection.ts
@@ -1,10 +1,10 @@
-import { Key, useCallback, useMemo } from 'react';
+import { type Key, useCallback, useMemo } from 'react';
import {
getItemKey,
- ItemKey,
- ItemSelection,
+ type ItemKey,
+ type ItemSelection,
itemSelectionToStringSet,
- NormalizedItem,
+ type NormalizedItem,
} from './itemUtils';
export interface UseStringifiedMultiSelectionOptions {
diff --git a/packages/components/src/spectrum/utils/useStringifiedSelection.test.ts b/packages/components/src/spectrum/utils/useStringifiedSelection.test.ts
index 3d442397bf..ad26804ab7 100644
--- a/packages/components/src/spectrum/utils/useStringifiedSelection.test.ts
+++ b/packages/components/src/spectrum/utils/useStringifiedSelection.test.ts
@@ -1,5 +1,5 @@
import { renderHook } from '@testing-library/react-hooks';
-import { NormalizedItem } from './itemUtils';
+import { type NormalizedItem } from './itemUtils';
import { useStringifiedSelection } from './useStringifiedSelection';
describe('useStringifiedSelection', () => {
diff --git a/packages/components/src/spectrum/utils/useStringifiedSelection.ts b/packages/components/src/spectrum/utils/useStringifiedSelection.ts
index d954760c77..5087a560f9 100644
--- a/packages/components/src/spectrum/utils/useStringifiedSelection.ts
+++ b/packages/components/src/spectrum/utils/useStringifiedSelection.ts
@@ -1,10 +1,10 @@
-import { Key, useCallback, useMemo } from 'react';
+import { type Key, useCallback, useMemo } from 'react';
import {
getItemKey,
- ItemKey,
+ type ItemKey,
itemSelectionToStringSet,
- NormalizedItem,
- NormalizedSection,
+ type NormalizedItem,
+ type NormalizedSection,
} from './itemUtils';
export interface UseStringifiedSelectionOptions {
diff --git a/packages/components/src/theme/SpectrumThemeProvider.tsx b/packages/components/src/theme/SpectrumThemeProvider.tsx
index a127a1cd5d..ff51a9b3a8 100644
--- a/packages/components/src/theme/SpectrumThemeProvider.tsx
+++ b/packages/components/src/theme/SpectrumThemeProvider.tsx
@@ -1,4 +1,4 @@
-import { ReactNode, useState } from 'react';
+import { type ReactNode, useState } from 'react';
import { Provider } from '@adobe/react-spectrum';
import type { Theme } from '@react-types/provider';
import { nanoid } from 'nanoid';
diff --git a/packages/components/src/theme/ThemePicker.tsx b/packages/components/src/theme/ThemePicker.tsx
index 9169752285..87737ecf70 100644
--- a/packages/components/src/theme/ThemePicker.tsx
+++ b/packages/components/src/theme/ThemePicker.tsx
@@ -1,4 +1,4 @@
-import { Key, useCallback } from 'react';
+import { type Key, useCallback } from 'react';
import { Item, Picker } from '@adobe/react-spectrum';
import useTheme from './useTheme';
diff --git a/packages/components/src/theme/ThemeProvider.test.tsx b/packages/components/src/theme/ThemeProvider.test.tsx
index 87e3fef5a5..6a075381bb 100644
--- a/packages/components/src/theme/ThemeProvider.test.tsx
+++ b/packages/components/src/theme/ThemeProvider.test.tsx
@@ -2,8 +2,8 @@ import React from 'react';
import { act, render } from '@testing-library/react';
import { assertNotNull } from '@deephaven/utils';
import { TestUtils } from '@deephaven/test-utils';
-import { ThemeContextValue, ThemeProvider } from './ThemeProvider';
-import { DEFAULT_LIGHT_THEME_KEY, ThemeData } from './ThemeModel';
+import { type ThemeContextValue, ThemeProvider } from './ThemeProvider';
+import { DEFAULT_LIGHT_THEME_KEY, type ThemeData } from './ThemeModel';
import {
calculatePreloadStyleContent,
getActiveThemes,
diff --git a/packages/components/src/theme/ThemeProvider.tsx b/packages/components/src/theme/ThemeProvider.tsx
index 2f687fb78d..e483d16548 100644
--- a/packages/components/src/theme/ThemeProvider.tsx
+++ b/packages/components/src/theme/ThemeProvider.tsx
@@ -1,6 +1,12 @@
-import { createContext, ReactNode, useEffect, useMemo, useState } from 'react';
+import {
+ createContext,
+ type ReactNode,
+ useEffect,
+ useMemo,
+ useState,
+} from 'react';
import Log from '@deephaven/log';
-import { DEFAULT_PRELOAD_DATA_VARIABLES, ThemeData } from './ThemeModel';
+import { DEFAULT_PRELOAD_DATA_VARIABLES, type ThemeData } from './ThemeModel';
import {
calculatePreloadStyleContent,
getActiveThemes,
diff --git a/packages/components/src/theme/ThemeUtils.test.ts b/packages/components/src/theme/ThemeUtils.test.ts
index 281e9b015e..1052cdb514 100644
--- a/packages/components/src/theme/ThemeUtils.test.ts
+++ b/packages/components/src/theme/ThemeUtils.test.ts
@@ -7,9 +7,9 @@ import {
DEFAULT_DARK_THEME_KEY,
DEFAULT_PRELOAD_DATA_VARIABLES,
SVG_ICON_MANUAL_COLOR_MAP,
- ThemeData,
- ThemePreloadColorVariable,
- ThemeRegistrationData,
+ type ThemeData,
+ type ThemePreloadColorVariable,
+ type ThemeRegistrationData,
THEME_CACHE_LOCAL_STORAGE_KEY,
THEME_KEY_OVERRIDE_QUERY_PARAM,
} from './ThemeModel';
diff --git a/packages/components/src/theme/ThemeUtils.ts b/packages/components/src/theme/ThemeUtils.ts
index 659fbf05eb..e40f24b2ae 100644
--- a/packages/components/src/theme/ThemeUtils.ts
+++ b/packages/components/src/theme/ThemeUtils.ts
@@ -6,15 +6,15 @@ import {
DEFAULT_DARK_THEME_KEY,
DEFAULT_LIGHT_THEME_KEY,
DEFAULT_PRELOAD_DATA_VARIABLES,
- ThemeData,
- ThemePreloadData,
- CssVariableStyleContent,
- ThemePreloadColorVariable,
- ThemeRegistrationData,
+ type ThemeData,
+ type ThemePreloadData,
+ type CssVariableStyleContent,
+ type ThemePreloadColorVariable,
+ type ThemeRegistrationData,
THEME_CACHE_LOCAL_STORAGE_KEY,
SVG_ICON_MANUAL_COLOR_MAP,
- ThemeCssVariableName,
- ThemeIconsRequiringManualColorChanges,
+ type ThemeCssVariableName,
+ type ThemeIconsRequiringManualColorChanges,
THEME_KEY_OVERRIDE_QUERY_PARAM,
} from './ThemeModel';
diff --git a/packages/components/src/theme/colorUtils.ts b/packages/components/src/theme/colorUtils.ts
index 9f8f5bbed4..793f302220 100644
--- a/packages/components/src/theme/colorUtils.ts
+++ b/packages/components/src/theme/colorUtils.ts
@@ -1,4 +1,4 @@
-import { CSSProperties } from 'react';
+import { type CSSProperties } from 'react';
/**
* Color values for the DH color palette exposed to end users in spectrum components.
diff --git a/packages/components/src/theme/useTheme.ts b/packages/components/src/theme/useTheme.ts
index aaf96fda06..d1a8a62cd0 100644
--- a/packages/components/src/theme/useTheme.ts
+++ b/packages/components/src/theme/useTheme.ts
@@ -1,5 +1,5 @@
import { useContextOrThrow } from '@deephaven/react-hooks';
-import { ThemeContext, ThemeContextValue } from './ThemeProvider';
+import { ThemeContext, type ThemeContextValue } from './ThemeProvider';
/**
* Hook to get the current `ThemeContextValue`.
diff --git a/packages/console/src/Console.test.tsx b/packages/console/src/Console.test.tsx
index 838c1fbb94..f7d1131641 100644
--- a/packages/console/src/Console.test.tsx
+++ b/packages/console/src/Console.test.tsx
@@ -3,7 +3,7 @@ import dh from '@deephaven/jsapi-shim';
import { render, screen } from '@testing-library/react';
import userEvent from '@testing-library/user-event';
import { Console } from './Console';
-import { CommandHistoryStorage } from './command-history';
+import { type CommandHistoryStorage } from './command-history';
function makeMockCommandHistoryStorage(): CommandHistoryStorage {
return {
diff --git a/packages/console/src/Console.tsx b/packages/console/src/Console.tsx
index 9ccb4ebe5f..940fa54585 100644
--- a/packages/console/src/Console.tsx
+++ b/packages/console/src/Console.tsx
@@ -2,16 +2,16 @@
* Console display for use in the Iris environment.
*/
import React, {
- DragEvent,
+ type DragEvent,
PureComponent,
- ReactElement,
- ReactNode,
- RefObject,
+ type ReactElement,
+ type ReactNode,
+ type RefObject,
} from 'react';
import {
ContextActions,
- DropdownAction,
- ResolvableContextAction,
+ type DropdownAction,
+ type ResolvableContextAction,
} from '@deephaven/components';
import { vsCheck } from '@deephaven/icons';
import classNames from 'classnames';
@@ -22,7 +22,7 @@ import type { dh as DhType } from '@deephaven/jsapi-types';
import Log from '@deephaven/log';
import { assertNotNull, Pending, PromiseUtils } from '@deephaven/utils';
import ConsoleHistory from './console-history/ConsoleHistory';
-import { ConsoleHistoryActionItem } from './console-history/ConsoleHistoryTypes';
+import { type ConsoleHistoryActionItem } from './console-history/ConsoleHistoryTypes';
import SHORTCUTS from './ConsoleShortcuts';
import LogLevel from './log/LogLevel';
import ConsoleInput from './ConsoleInput';
@@ -31,8 +31,8 @@ import CsvInputBar from './csv/CsvInputBar';
import './Console.scss';
import ConsoleStatusBar from './ConsoleStatusBar';
import {
- CommandHistoryStorage,
- CommandHistoryStorageItem,
+ type CommandHistoryStorage,
+ type CommandHistoryStorageItem,
} from './command-history';
import ConsoleObjectsMenu from './ConsoleObjectsMenu';
diff --git a/packages/console/src/ConsoleInput.tsx b/packages/console/src/ConsoleInput.tsx
index ef77ccb29b..96f53308ed 100644
--- a/packages/console/src/ConsoleInput.tsx
+++ b/packages/console/src/ConsoleInput.tsx
@@ -1,18 +1,18 @@
-import React, { PureComponent, ReactElement, RefObject } from 'react';
+import React, { PureComponent, type ReactElement, type RefObject } from 'react';
import classNames from 'classnames';
import * as monaco from 'monaco-editor';
import Log from '@deephaven/log';
import {
assertNotNull,
- CancelablePromise,
+ type CancelablePromise,
PromiseUtils,
} from '@deephaven/utils';
-import { ViewportData } from '@deephaven/storage';
+import { type ViewportData } from '@deephaven/storage';
import type { dh } from '@deephaven/jsapi-types';
import {
- CommandHistoryStorage,
- CommandHistoryStorageItem,
- CommandHistoryTable,
+ type CommandHistoryStorage,
+ type CommandHistoryStorageItem,
+ type CommandHistoryTable,
} from './command-history';
import { MonacoProviders, MonacoTheme, MonacoUtils } from './monaco';
import './ConsoleInput.scss';
diff --git a/packages/console/src/ConsoleObjectsMenu.tsx b/packages/console/src/ConsoleObjectsMenu.tsx
index fa5a124396..faff228047 100644
--- a/packages/console/src/ConsoleObjectsMenu.tsx
+++ b/packages/console/src/ConsoleObjectsMenu.tsx
@@ -1,5 +1,5 @@
import React, {
- ReactElement,
+ type ReactElement,
useCallback,
useMemo,
useRef,
@@ -8,7 +8,7 @@ import React, {
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
import {
Button,
- DropdownActions,
+ type DropdownActions,
DropdownMenu,
SearchInput,
} from '@deephaven/components';
diff --git a/packages/console/src/ConsoleStatusBar.test.tsx b/packages/console/src/ConsoleStatusBar.test.tsx
index 44dfb92efc..90f9a25902 100644
--- a/packages/console/src/ConsoleStatusBar.test.tsx
+++ b/packages/console/src/ConsoleStatusBar.test.tsx
@@ -1,7 +1,7 @@
import React from 'react';
import { render, screen } from '@testing-library/react';
import dh from '@deephaven/jsapi-shim';
-import { ContextActions, DropdownActions } from '@deephaven/components';
+import { ContextActions, type DropdownActions } from '@deephaven/components';
import { vsCheck } from '@deephaven/icons';
import { TestUtils } from '@deephaven/test-utils';
import userEvent from '@testing-library/user-event';
diff --git a/packages/console/src/ConsoleStatusBar.tsx b/packages/console/src/ConsoleStatusBar.tsx
index b95a6ea289..d80942328d 100644
--- a/packages/console/src/ConsoleStatusBar.tsx
+++ b/packages/console/src/ConsoleStatusBar.tsx
@@ -1,6 +1,6 @@
import React, {
- ReactElement,
- ReactNode,
+ type ReactElement,
+ type ReactNode,
useCallback,
useEffect,
useState,
@@ -10,9 +10,9 @@ import { vsKebabVertical } from '@deephaven/icons';
import type { dh as DhType } from '@deephaven/jsapi-types';
import {
Button,
- DropdownActions,
+ type DropdownActions,
DropdownMenu,
- PopperOptions,
+ type PopperOptions,
Tooltip,
} from '@deephaven/components';
import './ConsoleStatusBar.scss';
diff --git a/packages/console/src/HeapUsage.tsx b/packages/console/src/HeapUsage.tsx
index 9883aa2c25..cdb5f98d47 100644
--- a/packages/console/src/HeapUsage.tsx
+++ b/packages/console/src/HeapUsage.tsx
@@ -1,4 +1,4 @@
-import { useState, ReactElement, useRef, useCallback } from 'react';
+import { useState, type ReactElement, useRef, useCallback } from 'react';
import classNames from 'classnames';
import { Tooltip } from '@deephaven/components';
import type { dh } from '@deephaven/jsapi-types';
diff --git a/packages/console/src/command-history/CommandHistory.test.tsx b/packages/console/src/command-history/CommandHistory.test.tsx
index 247585c2f4..762bf5fa92 100644
--- a/packages/console/src/command-history/CommandHistory.test.tsx
+++ b/packages/console/src/command-history/CommandHistory.test.tsx
@@ -2,7 +2,7 @@ import React from 'react';
import { fireEvent, render, screen } from '@testing-library/react';
import userEvent from '@testing-library/user-event';
import CommandHistory from './CommandHistory';
-import { CommandHistoryTable } from './CommandHistoryStorage';
+import { type CommandHistoryTable } from './CommandHistoryStorage';
jest.mock('pouchdb-browser');
diff --git a/packages/console/src/command-history/CommandHistory.tsx b/packages/console/src/command-history/CommandHistory.tsx
index 0d2e0e8256..455d297a19 100644
--- a/packages/console/src/command-history/CommandHistory.tsx
+++ b/packages/console/src/command-history/CommandHistory.tsx
@@ -1,13 +1,18 @@
-import React, { ChangeEvent, Component, ReactElement, RefObject } from 'react';
+import React, {
+ type ChangeEvent,
+ Component,
+ type ReactElement,
+ type RefObject,
+} from 'react';
import debounce from 'lodash.debounce';
import {
ContextActions,
ItemList,
SearchInput,
GLOBAL_SHORTCUTS,
- RenderItemProps,
+ type RenderItemProps,
} from '@deephaven/components';
-import { ViewportData } from '@deephaven/storage';
+import { type ViewportData } from '@deephaven/storage';
import {
vsFileCode,
vsFiles,
@@ -15,7 +20,7 @@ import {
vsPlay,
vsTerminal,
} from '@deephaven/icons';
-import { copyToClipboard, Pending, Range } from '@deephaven/utils';
+import { copyToClipboard, Pending, type Range } from '@deephaven/utils';
import Log from '@deephaven/log';
import CommandHistoryItem from './CommandHistoryItem';
import CommandHistoryActions from './CommandHistoryActions';
@@ -24,11 +29,12 @@ import ConsoleConstants from '../common/ConsoleConstants';
import './CommandHistory.scss';
import CommandHistoryViewportUpdater from './CommandHistoryViewportUpdater';
import SHORTCUTS from '../ConsoleShortcuts';
-import CommandHistoryStorage, {
- CommandHistoryStorageItem,
- CommandHistoryTable,
+import {
+ type CommandHistoryStorageItem,
+ type CommandHistoryTable,
} from './CommandHistoryStorage';
-import { ItemAction, HistoryAction } from './CommandHistoryTypes';
+import type CommandHistoryStorage from './CommandHistoryStorage';
+import { type ItemAction, type HistoryAction } from './CommandHistoryTypes';
const log = Log.module('CommandHistory');
diff --git a/packages/console/src/command-history/CommandHistoryActions.tsx b/packages/console/src/command-history/CommandHistoryActions.tsx
index ebebf07ea3..4c963d0e98 100644
--- a/packages/console/src/command-history/CommandHistoryActions.tsx
+++ b/packages/console/src/command-history/CommandHistoryActions.tsx
@@ -1,10 +1,10 @@
-import React, { Component, ReactElement } from 'react';
+import React, { Component, type ReactElement } from 'react';
import classNames from 'classnames';
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
import { Button } from '@deephaven/components';
import { vsArrowLeft, vsCircleLargeFilled } from '@deephaven/icons';
import './CommandHistoryActions.scss';
-import { HistoryAction } from './CommandHistoryTypes';
+import { type HistoryAction } from './CommandHistoryTypes';
interface CommandHistoryActionsProps {
actions: HistoryAction[];
diff --git a/packages/console/src/command-history/CommandHistoryItem.tsx b/packages/console/src/command-history/CommandHistoryItem.tsx
index 02a88498c6..92bf510e94 100644
--- a/packages/console/src/command-history/CommandHistoryItem.tsx
+++ b/packages/console/src/command-history/CommandHistoryItem.tsx
@@ -1,12 +1,11 @@
-import React, { useRef, useCallback, ReactElement } from 'react';
+import React, { useRef, useCallback, type ReactElement } from 'react';
import classNames from 'classnames';
import { Tooltip } from '@deephaven/components';
import './CommandHistoryItem.scss';
import CommandHistoryItemTooltip from './CommandHistoryItemTooltip';
-import CommandHistoryStorage, {
- CommandHistoryStorageItem,
-} from './CommandHistoryStorage';
+import { type CommandHistoryStorageItem } from './CommandHistoryStorage';
+import type CommandHistoryStorage from './CommandHistoryStorage';
interface CommandHistoryItemProps {
item: CommandHistoryStorageItem;
diff --git a/packages/console/src/command-history/CommandHistoryItemTooltip.test.tsx b/packages/console/src/command-history/CommandHistoryItemTooltip.test.tsx
index 15fcab1c45..5e51318623 100644
--- a/packages/console/src/command-history/CommandHistoryItemTooltip.test.tsx
+++ b/packages/console/src/command-history/CommandHistoryItemTooltip.test.tsx
@@ -1,7 +1,7 @@
import React from 'react';
import { render, screen } from '@testing-library/react';
import { CommandHistoryItemTooltip } from './CommandHistoryItemTooltip';
-import { CommandHistoryStorageItem } from './CommandHistoryStorage';
+import { type CommandHistoryStorageItem } from './CommandHistoryStorage';
jest.mock('../common/Code', () => () => 'Code');
diff --git a/packages/console/src/command-history/CommandHistoryItemTooltip.tsx b/packages/console/src/command-history/CommandHistoryItemTooltip.tsx
index 1e5c66ced7..504c632681 100644
--- a/packages/console/src/command-history/CommandHistoryItemTooltip.tsx
+++ b/packages/console/src/command-history/CommandHistoryItemTooltip.tsx
@@ -1,17 +1,18 @@
-import React, { Component, ReactElement } from 'react';
+import React, { Component, type ReactElement } from 'react';
import debounce from 'lodash.debounce';
import memoize from 'memoizee';
import { LoadingSpinner } from '@deephaven/components';
import { TimeUtils } from '@deephaven/utils';
-import { StorageListenerRemover } from '@deephaven/storage';
+import { type StorageListenerRemover } from '@deephaven/storage';
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
import { vsWarning } from '@deephaven/icons';
import Code from '../common/Code';
import './CommandHistoryItemTooltip.scss';
-import CommandHistoryStorage, {
- CommandHistoryStorageData,
- CommandHistoryStorageItem,
+import {
+ type CommandHistoryStorageData,
+ type CommandHistoryStorageItem,
} from './CommandHistoryStorage';
+import type CommandHistoryStorage from './CommandHistoryStorage';
interface CommandHistoryItemTooltipProps {
item: CommandHistoryStorageItem;
diff --git a/packages/console/src/command-history/CommandHistoryStorage.ts b/packages/console/src/command-history/CommandHistoryStorage.ts
index a956758e20..f2d1231161 100644
--- a/packages/console/src/command-history/CommandHistoryStorage.ts
+++ b/packages/console/src/command-history/CommandHistoryStorage.ts
@@ -1,9 +1,9 @@
import {
- StorageTable,
- StorageItem,
- StorageItemListener,
- StorageListenerRemover,
- StorageErrorListener,
+ type StorageTable,
+ type StorageItem,
+ type StorageItemListener,
+ type StorageListenerRemover,
+ type StorageErrorListener,
} from '@deephaven/storage';
export interface CommandHistoryStorageData {
diff --git a/packages/console/src/command-history/CommandHistoryTypes.tsx b/packages/console/src/command-history/CommandHistoryTypes.tsx
index b9a4b44deb..cc8c8f99cc 100644
--- a/packages/console/src/command-history/CommandHistoryTypes.tsx
+++ b/packages/console/src/command-history/CommandHistoryTypes.tsx
@@ -1,5 +1,5 @@
-import { ContextAction } from '@deephaven/components';
-import { IconDefinition } from '@deephaven/icons';
+import { type ContextAction } from '@deephaven/components';
+import { type IconDefinition } from '@deephaven/icons';
export type ItemAction = ContextAction & {
title: string;
diff --git a/packages/console/src/command-history/CommandHistoryViewportUpdater.tsx b/packages/console/src/command-history/CommandHistoryViewportUpdater.tsx
index 7adcbe1cc3..45879e0b43 100644
--- a/packages/console/src/command-history/CommandHistoryViewportUpdater.tsx
+++ b/packages/console/src/command-history/CommandHistoryViewportUpdater.tsx
@@ -1,14 +1,14 @@
import { useEffect, useMemo } from 'react';
import throttle from 'lodash.throttle';
import {
- StorageTableViewport,
- ViewportData,
- ViewportUpdateCallback,
+ type StorageTableViewport,
+ type ViewportData,
+ type ViewportUpdateCallback,
} from '@deephaven/storage';
import Log from '@deephaven/log';
import {
- CommandHistoryStorageItem,
- CommandHistoryTable,
+ type CommandHistoryStorageItem,
+ type CommandHistoryTable,
} from './CommandHistoryStorage';
export type CommandHistoryViewportUpdaterProps = {
diff --git a/packages/console/src/common/Code.tsx b/packages/console/src/common/Code.tsx
index 373c7de5c4..8786207884 100644
--- a/packages/console/src/common/Code.tsx
+++ b/packages/console/src/common/Code.tsx
@@ -1,4 +1,4 @@
-import React, { useEffect, useState, ReactNode } from 'react';
+import React, { useEffect, useState, type ReactNode } from 'react';
import * as monaco from 'monaco-editor';
import { useTheme } from '@deephaven/components';
diff --git a/packages/console/src/common/ConsoleUtils.ts b/packages/console/src/common/ConsoleUtils.ts
index 7a862b0eaa..2b1da396e0 100644
--- a/packages/console/src/common/ConsoleUtils.ts
+++ b/packages/console/src/common/ConsoleUtils.ts
@@ -1,4 +1,4 @@
-import ShellQuote, { ParseEntry, ControlOperator } from 'shell-quote';
+import ShellQuote, { type ParseEntry, type ControlOperator } from 'shell-quote';
import type { dh as DhType } from '@deephaven/jsapi-types';
class ConsoleUtils {
diff --git a/packages/console/src/console-history/ConsoleHistory.tsx b/packages/console/src/console-history/ConsoleHistory.tsx
index caf2593509..e239fec978 100644
--- a/packages/console/src/console-history/ConsoleHistory.tsx
+++ b/packages/console/src/console-history/ConsoleHistory.tsx
@@ -6,7 +6,7 @@ import type { dh } from '@deephaven/jsapi-types';
import ConsoleHistoryItem from './ConsoleHistoryItem';
import './ConsoleHistory.scss';
-import { ConsoleHistoryActionItem } from './ConsoleHistoryTypes';
+import { type ConsoleHistoryActionItem } from './ConsoleHistoryTypes';
interface ConsoleHistoryProps {
items: ConsoleHistoryActionItem[];
diff --git a/packages/console/src/console-history/ConsoleHistoryItem.tsx b/packages/console/src/console-history/ConsoleHistoryItem.tsx
index 60c0f87100..7718e4572d 100644
--- a/packages/console/src/console-history/ConsoleHistoryItem.tsx
+++ b/packages/console/src/console-history/ConsoleHistoryItem.tsx
@@ -1,7 +1,7 @@
/**
* Console display for use in the Iris environment.
*/
-import React, { PureComponent, ReactElement } from 'react';
+import React, { PureComponent, type ReactElement } from 'react';
import { Button } from '@deephaven/components';
import Log from '@deephaven/log';
import type { dh } from '@deephaven/jsapi-types';
@@ -11,7 +11,7 @@ import ConsoleHistoryItemResult from './ConsoleHistoryItemResult';
import ConsoleHistoryResultInProgress from './ConsoleHistoryResultInProgress';
import ConsoleHistoryResultErrorMessage from './ConsoleHistoryResultErrorMessage';
import './ConsoleHistoryItem.scss';
-import { ConsoleHistoryActionItem } from './ConsoleHistoryTypes';
+import { type ConsoleHistoryActionItem } from './ConsoleHistoryTypes';
const log = Log.module('ConsoleHistoryItem');
diff --git a/packages/console/src/console-history/ConsoleHistoryItemResult.tsx b/packages/console/src/console-history/ConsoleHistoryItemResult.tsx
index 81a0e1b528..d941eec1f3 100644
--- a/packages/console/src/console-history/ConsoleHistoryItemResult.tsx
+++ b/packages/console/src/console-history/ConsoleHistoryItemResult.tsx
@@ -1,7 +1,7 @@
/**
* Console display for use in the Iris environment.
*/
-import React, { ReactElement, ReactNode } from 'react';
+import React, { type ReactElement, type ReactNode } from 'react';
import PropTypes from 'prop-types';
function ConsoleHistoryItemResult({
diff --git a/packages/console/src/console-history/ConsoleHistoryResultErrorMessage.tsx b/packages/console/src/console-history/ConsoleHistoryResultErrorMessage.tsx
index ade57b5553..6167ebe29e 100644
--- a/packages/console/src/console-history/ConsoleHistoryResultErrorMessage.tsx
+++ b/packages/console/src/console-history/ConsoleHistoryResultErrorMessage.tsx
@@ -2,10 +2,10 @@
* Error message that can be expanded
*/
import React, {
- KeyboardEvent,
- MouseEvent,
+ type KeyboardEvent,
+ type MouseEvent,
PureComponent,
- ReactElement,
+ type ReactElement,
} from 'react';
import classNames from 'classnames';
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
diff --git a/packages/console/src/console-history/ConsoleHistoryResultInProgress.tsx b/packages/console/src/console-history/ConsoleHistoryResultInProgress.tsx
index 967979041d..26a219657e 100644
--- a/packages/console/src/console-history/ConsoleHistoryResultInProgress.tsx
+++ b/packages/console/src/console-history/ConsoleHistoryResultInProgress.tsx
@@ -1,4 +1,4 @@
-import React, { Component, ReactElement } from 'react';
+import React, { Component, type ReactElement } from 'react';
import classNames from 'classnames';
import { Button, LoadingSpinner } from '@deephaven/components';
import { vsClose } from '@deephaven/icons';
diff --git a/packages/console/src/console-history/ConsoleHistoryTypes.tsx b/packages/console/src/console-history/ConsoleHistoryTypes.tsx
index a9a883debb..0659e3bd9c 100644
--- a/packages/console/src/console-history/ConsoleHistoryTypes.tsx
+++ b/packages/console/src/console-history/ConsoleHistoryTypes.tsx
@@ -1,4 +1,4 @@
-import { CancelablePromise } from '@deephaven/utils';
+import { type CancelablePromise } from '@deephaven/utils';
import type { dh } from '@deephaven/jsapi-types';
export type ConsoleHistoryError =
diff --git a/packages/console/src/csv/CsvInputBar.tsx b/packages/console/src/csv/CsvInputBar.tsx
index 5bc67eae3a..a7f25fe21a 100644
--- a/packages/console/src/csv/CsvInputBar.tsx
+++ b/packages/console/src/csv/CsvInputBar.tsx
@@ -1,9 +1,9 @@
import React, {
- ChangeEvent,
+ type ChangeEvent,
Component,
- FormEvent,
- ReactElement,
- RefObject,
+ type FormEvent,
+ type ReactElement,
+ type RefObject,
} from 'react';
import classNames from 'classnames';
import type { JSZipObject } from 'jszip';
diff --git a/packages/console/src/csv/CsvOverlay.tsx b/packages/console/src/csv/CsvOverlay.tsx
index ab63104cb4..067c5b5402 100644
--- a/packages/console/src/csv/CsvOverlay.tsx
+++ b/packages/console/src/csv/CsvOverlay.tsx
@@ -1,16 +1,16 @@
import React, {
- ChangeEvent,
+ type ChangeEvent,
Component,
- DragEvent,
- MouseEvent,
- ReactElement,
- RefObject,
+ type DragEvent,
+ type MouseEvent,
+ type ReactElement,
+ type RefObject,
} from 'react';
import memoize from 'memoize-one';
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
import {
Button,
- ContextAction,
+ type ContextAction,
ContextActions,
GLOBAL_SHORTCUTS,
} from '@deephaven/components';
@@ -18,7 +18,7 @@ import {
dhFileCsv,
dhFileDownload,
dhFileSpreadsheet,
- IconDefinition,
+ type IconDefinition,
vsClippy,
vsFileZip,
vsTrash,
diff --git a/packages/console/src/csv/CsvParser.ts b/packages/console/src/csv/CsvParser.ts
index 32bef38b03..1b1e7d0e22 100644
--- a/packages/console/src/csv/CsvParser.ts
+++ b/packages/console/src/csv/CsvParser.ts
@@ -1,10 +1,14 @@
-import Papa, { ParseLocalConfig, Parser, ParseResult } from 'papaparse';
+import Papa, {
+ type ParseLocalConfig,
+ type Parser,
+ type ParseResult,
+} from 'papaparse';
import Log from '@deephaven/log';
import { assertNotNull, DbNameValidator } from '@deephaven/utils';
import type { dh } from '@deephaven/jsapi-types';
import type { JSZipObject } from 'jszip';
import CsvTypeParser from './CsvTypeParser';
-import { CsvTypes } from './CsvFormats';
+import { type CsvTypes } from './CsvFormats';
import makeZipStreamHelper from './ZipStreamHelper';
const log = Log.module('CsvParser');
diff --git a/packages/console/src/csv/CsvTypeParser.ts b/packages/console/src/csv/CsvTypeParser.ts
index b332a80591..4a3e87b3b9 100644
--- a/packages/console/src/csv/CsvTypeParser.ts
+++ b/packages/console/src/csv/CsvTypeParser.ts
@@ -1,6 +1,10 @@
import type { JSZipObject } from 'jszip';
import { assertNotNull } from '@deephaven/utils';
-import Papa, { Parser, ParseResult, ParseLocalConfig } from 'papaparse';
+import Papa, {
+ type Parser,
+ type ParseResult,
+ type ParseLocalConfig,
+} from 'papaparse';
// Intentionally using isNaN rather than Number.isNaN
/* eslint-disable no-restricted-globals */
import NewTableColumnTypes from './NewTableColumnTypes';
diff --git a/packages/console/src/log/LogLevelMenuItem.tsx b/packages/console/src/log/LogLevelMenuItem.tsx
index ce1a4e4289..764dd5565e 100644
--- a/packages/console/src/log/LogLevelMenuItem.tsx
+++ b/packages/console/src/log/LogLevelMenuItem.tsx
@@ -1,5 +1,5 @@
// Port of https://github.com/react-bootstrap/react-bootstrap/blob/master/src/Collapse.js
-import React, { PureComponent, ReactElement } from 'react';
+import React, { PureComponent, type ReactElement } from 'react';
import classNames from 'classnames';
import { UISwitch } from '@deephaven/components';
import './LogLevelMenuItem.scss';
diff --git a/packages/console/src/log/LogView.tsx b/packages/console/src/log/LogView.tsx
index befc394f4b..ee7b79b25e 100644
--- a/packages/console/src/log/LogView.tsx
+++ b/packages/console/src/log/LogView.tsx
@@ -1,9 +1,13 @@
-import React, { PureComponent, ReactElement } from 'react';
-import { Button, DropdownActions, DropdownMenu } from '@deephaven/components';
+import React, { PureComponent, type ReactElement } from 'react';
+import {
+ Button,
+ type DropdownActions,
+ DropdownMenu,
+} from '@deephaven/components';
import { vsGear, dhTrashUndo } from '@deephaven/icons';
import { assertNotNull } from '@deephaven/utils';
import type { dh } from '@deephaven/jsapi-types';
-import { Placement } from 'popper.js';
+import { type Placement } from 'popper.js';
import * as monaco from 'monaco-editor';
import ConsoleUtils from '../common/ConsoleUtils';
import LogLevel from './LogLevel';
diff --git a/packages/console/src/monaco/MonacoThemeProvider.tsx b/packages/console/src/monaco/MonacoThemeProvider.tsx
index 84e5da6296..27c2dd1baf 100644
--- a/packages/console/src/monaco/MonacoThemeProvider.tsx
+++ b/packages/console/src/monaco/MonacoThemeProvider.tsx
@@ -1,4 +1,4 @@
-import { ReactNode, useEffect } from 'react';
+import { type ReactNode, useEffect } from 'react';
import { useTheme } from '@deephaven/components';
import MonacoUtils from './MonacoUtils';
diff --git a/packages/console/src/monaco/MonacoUtils.ts b/packages/console/src/monaco/MonacoUtils.ts
index 99011839e6..ac1c21c32a 100644
--- a/packages/console/src/monaco/MonacoUtils.ts
+++ b/packages/console/src/monaco/MonacoUtils.ts
@@ -3,7 +3,10 @@ import { nanoid } from 'nanoid';
/**
* Exports a function for initializing monaco with the deephaven theme/config
*/
-import { resolveCssVariablesInRecord, Shortcut } from '@deephaven/components';
+import {
+ resolveCssVariablesInRecord,
+ type Shortcut,
+} from '@deephaven/components';
import type { dh } from '@deephaven/jsapi-types';
import { assertNotNull } from '@deephaven/utils';
import { find as linkifyFind } from 'linkifyjs';
@@ -18,7 +21,7 @@ import GroovyLang from './lang/groovy';
import ScalaLang from './lang/scala';
import DbLang from './lang/db';
import LogLang from './lang/log';
-import { Language } from './lang/Language';
+import { type Language } from './lang/Language';
const log = Log.module('MonacoUtils');
diff --git a/packages/console/src/monaco/lang/Language.ts b/packages/console/src/monaco/lang/Language.ts
index 6a7aaea949..ecbf522fa7 100644
--- a/packages/console/src/monaco/lang/Language.ts
+++ b/packages/console/src/monaco/lang/Language.ts
@@ -1,4 +1,4 @@
-import * as monaco from 'monaco-editor';
+import type * as monaco from 'monaco-editor';
export type Language = {
id: string;
diff --git a/packages/console/src/monaco/lang/db.ts b/packages/console/src/monaco/lang/db.ts
index 2b1b898f89..a9f4a29ffa 100644
--- a/packages/console/src/monaco/lang/db.ts
+++ b/packages/console/src/monaco/lang/db.ts
@@ -1,5 +1,5 @@
-import * as monaco from 'monaco-editor';
-import { Language } from './Language';
+import type * as monaco from 'monaco-editor';
+import { type Language } from './Language';
/* eslint no-useless-escape: "off" */
const id = 'deephavenDb';
diff --git a/packages/console/src/monaco/lang/groovy.ts b/packages/console/src/monaco/lang/groovy.ts
index d9c191f139..d2ce72dd44 100644
--- a/packages/console/src/monaco/lang/groovy.ts
+++ b/packages/console/src/monaco/lang/groovy.ts
@@ -1,5 +1,5 @@
-import * as monaco from 'monaco-editor';
-import { Language } from './Language';
+import type * as monaco from 'monaco-editor';
+import { type Language } from './Language';
const id = 'groovy';
diff --git a/packages/console/src/monaco/lang/log.ts b/packages/console/src/monaco/lang/log.ts
index 892fdb70a9..50c04f0b87 100644
--- a/packages/console/src/monaco/lang/log.ts
+++ b/packages/console/src/monaco/lang/log.ts
@@ -1,6 +1,6 @@
/* eslint no-useless-escape: "off" */
-import * as monaco from 'monaco-editor';
-import { Language } from './Language';
+import type * as monaco from 'monaco-editor';
+import { type Language } from './Language';
const id = 'log';
diff --git a/packages/console/src/monaco/lang/python.ts b/packages/console/src/monaco/lang/python.ts
index 2ee3718b87..2463d5e563 100644
--- a/packages/console/src/monaco/lang/python.ts
+++ b/packages/console/src/monaco/lang/python.ts
@@ -1,5 +1,5 @@
-import * as monaco from 'monaco-editor';
-import { Language } from './Language';
+import type * as monaco from 'monaco-editor';
+import { type Language } from './Language';
const id = 'python';
diff --git a/packages/console/src/monaco/lang/scala.ts b/packages/console/src/monaco/lang/scala.ts
index 7e718477bd..eb2b8923ea 100644
--- a/packages/console/src/monaco/lang/scala.ts
+++ b/packages/console/src/monaco/lang/scala.ts
@@ -26,8 +26,8 @@
* - https://github.com/microsoft/monaco-languages/blob/main/src/scala/scala.ts
*--------------------------------------------------------------------------------------------*/
-import * as monaco from 'monaco-editor';
-import { Language } from './Language';
+import type * as monaco from 'monaco-editor';
+import { type Language } from './Language';
const id = 'scala';
diff --git a/packages/console/src/notebook/Editor.tsx b/packages/console/src/notebook/Editor.tsx
index f29f5c4ec0..f3762ccbc4 100644
--- a/packages/console/src/notebook/Editor.tsx
+++ b/packages/console/src/notebook/Editor.tsx
@@ -1,7 +1,7 @@
/**
* Editor editor for large blocks of code
*/
-import React, { Component, ReactElement } from 'react';
+import React, { Component, type ReactElement } from 'react';
import classNames from 'classnames';
import * as monaco from 'monaco-editor';
import { assertNotNull } from '@deephaven/utils';
diff --git a/packages/console/src/notebook/ScriptEditor.tsx b/packages/console/src/notebook/ScriptEditor.tsx
index aea6a44fd4..43cccf2756 100644
--- a/packages/console/src/notebook/ScriptEditor.tsx
+++ b/packages/console/src/notebook/ScriptEditor.tsx
@@ -1,7 +1,7 @@
/**
* Script editor for large blocks of code
*/
-import React, { Component, ReactElement, RefObject } from 'react';
+import React, { Component, type ReactElement, type RefObject } from 'react';
import { LoadingOverlay, ShortcutRegistry } from '@deephaven/components';
import Log from '@deephaven/log';
import type { dh } from '@deephaven/jsapi-types';
diff --git a/packages/dashboard-core-plugins/src/ChartBuilderPlugin.tsx b/packages/dashboard-core-plugins/src/ChartBuilderPlugin.tsx
index 5c61cba7f0..01d4d4d82a 100644
--- a/packages/dashboard-core-plugins/src/ChartBuilderPlugin.tsx
+++ b/packages/dashboard-core-plugins/src/ChartBuilderPlugin.tsx
@@ -1,8 +1,8 @@
import { useCallback } from 'react';
-import { ChartModelSettings, ChartUtils } from '@deephaven/chart';
+import { type ChartModelSettings, ChartUtils } from '@deephaven/chart';
import {
assertIsDashboardPluginProps,
- DashboardPluginComponentProps,
+ type DashboardPluginComponentProps,
LayoutUtils,
useListener,
} from '@deephaven/dashboard';
diff --git a/packages/dashboard-core-plugins/src/ChartBuilderPluginConfig.ts b/packages/dashboard-core-plugins/src/ChartBuilderPluginConfig.ts
index 220a3ac621..09930ffde3 100644
--- a/packages/dashboard-core-plugins/src/ChartBuilderPluginConfig.ts
+++ b/packages/dashboard-core-plugins/src/ChartBuilderPluginConfig.ts
@@ -1,4 +1,4 @@
-import { PluginType, DashboardPlugin } from '@deephaven/plugin';
+import { PluginType, type DashboardPlugin } from '@deephaven/plugin';
import ChartBuilderPlugin from './ChartBuilderPlugin';
const ChartBuilderPluginConfig: DashboardPlugin = {
diff --git a/packages/dashboard-core-plugins/src/ChartPanelPlugin.tsx b/packages/dashboard-core-plugins/src/ChartPanelPlugin.tsx
index c561d24aba..09b6201961 100644
--- a/packages/dashboard-core-plugins/src/ChartPanelPlugin.tsx
+++ b/packages/dashboard-core-plugins/src/ChartPanelPlugin.tsx
@@ -1,14 +1,14 @@
import { forwardRef, useCallback } from 'react';
import { useDeferredApi } from '@deephaven/jsapi-bootstrap';
-import { ChartModel, ChartModelFactory } from '@deephaven/chart';
+import { type ChartModel, ChartModelFactory } from '@deephaven/chart';
import type { dh as DhType } from '@deephaven/jsapi-types';
import { IrisGridUtils } from '@deephaven/iris-grid';
import { getTimeZone, store } from '@deephaven/redux';
-import { WidgetPanelProps } from '@deephaven/plugin';
+import { type WidgetPanelProps } from '@deephaven/plugin';
import { assertNotNull } from '@deephaven/utils';
import {
- ChartPanelMetadata,
- GLChartPanelState,
+ type ChartPanelMetadata,
+ type GLChartPanelState,
isChartPanelDehydratedProps,
isChartPanelTableMetadata,
} from './panels';
diff --git a/packages/dashboard-core-plugins/src/ChartWidgetPlugin.tsx b/packages/dashboard-core-plugins/src/ChartWidgetPlugin.tsx
index 990e7400db..28d9b5707e 100644
--- a/packages/dashboard-core-plugins/src/ChartWidgetPlugin.tsx
+++ b/packages/dashboard-core-plugins/src/ChartWidgetPlugin.tsx
@@ -1,6 +1,6 @@
import { useEffect, useState } from 'react';
import { useApi } from '@deephaven/jsapi-bootstrap';
-import { Chart, ChartModel, ChartModelFactory } from '@deephaven/chart';
+import { Chart, type ChartModel, ChartModelFactory } from '@deephaven/chart';
import type { dh } from '@deephaven/jsapi-types';
import { type WidgetComponentProps } from '@deephaven/plugin';
diff --git a/packages/dashboard-core-plugins/src/ConsolePlugin.tsx b/packages/dashboard-core-plugins/src/ConsolePlugin.tsx
index 0aad73effb..cc594cc3f6 100644
--- a/packages/dashboard-core-plugins/src/ConsolePlugin.tsx
+++ b/packages/dashboard-core-plugins/src/ConsolePlugin.tsx
@@ -1,17 +1,17 @@
-import { ScriptEditor } from '@deephaven/console';
+import { type ScriptEditor } from '@deephaven/console';
import {
assertIsDashboardPluginProps,
- DashboardPluginComponentProps,
+ type DashboardPluginComponentProps,
DashboardUtils,
- DehydratedDashboardPanelProps,
+ type DehydratedDashboardPanelProps,
LayoutUtils,
- PanelComponent,
- PanelHydrateFunction,
+ type PanelComponent,
+ type PanelHydrateFunction,
useListener,
usePanelRegistration,
} from '@deephaven/dashboard';
import { FileUtils } from '@deephaven/file-explorer';
-import { CloseOptions, isComponent } from '@deephaven/golden-layout';
+import { type CloseOptions, isComponent } from '@deephaven/golden-layout';
import Log from '@deephaven/log';
import { useCallback, useRef, useState } from 'react';
import { useDispatch } from 'react-redux';
diff --git a/packages/dashboard-core-plugins/src/FilterPlugin.tsx b/packages/dashboard-core-plugins/src/FilterPlugin.tsx
index 3ee7e29170..0da3469855 100644
--- a/packages/dashboard-core-plugins/src/FilterPlugin.tsx
+++ b/packages/dashboard-core-plugins/src/FilterPlugin.tsx
@@ -1,9 +1,9 @@
-import { Component, useCallback, useEffect, useState } from 'react';
+import { type Component, useCallback, useEffect, useState } from 'react';
import { useDispatch } from 'react-redux';
import { nanoid } from 'nanoid';
import {
assertIsDashboardPluginProps,
- DashboardPluginComponentProps,
+ type DashboardPluginComponentProps,
LayoutUtils,
PanelEvent,
updateDashboardData,
diff --git a/packages/dashboard-core-plugins/src/FilterPluginConfig.ts b/packages/dashboard-core-plugins/src/FilterPluginConfig.ts
index 2eff1ac264..ae6c946edf 100644
--- a/packages/dashboard-core-plugins/src/FilterPluginConfig.ts
+++ b/packages/dashboard-core-plugins/src/FilterPluginConfig.ts
@@ -1,4 +1,4 @@
-import { PluginType, DashboardPlugin } from '@deephaven/plugin';
+import { PluginType, type DashboardPlugin } from '@deephaven/plugin';
import FilterPlugin from './FilterPlugin';
const FilterPluginConfig: DashboardPlugin = {
diff --git a/packages/dashboard-core-plugins/src/GridPanelPlugin.tsx b/packages/dashboard-core-plugins/src/GridPanelPlugin.tsx
index df50cfb3b6..dc70ac9e2b 100644
--- a/packages/dashboard-core-plugins/src/GridPanelPlugin.tsx
+++ b/packages/dashboard-core-plugins/src/GridPanelPlugin.tsx
@@ -1,5 +1,5 @@
import { forwardRef } from 'react';
-import { WidgetPanelProps } from '@deephaven/plugin';
+import { type WidgetPanelProps } from '@deephaven/plugin';
import { type dh } from '@deephaven/jsapi-types';
import useHydrateGrid from './useHydrateGrid';
import ConnectedIrisGridPanel, {
diff --git a/packages/dashboard-core-plugins/src/GridPluginConfig.ts b/packages/dashboard-core-plugins/src/GridPluginConfig.ts
index e57dd35cc8..a1d1dd16da 100644
--- a/packages/dashboard-core-plugins/src/GridPluginConfig.ts
+++ b/packages/dashboard-core-plugins/src/GridPluginConfig.ts
@@ -1,6 +1,6 @@
import { PluginType, type WidgetPlugin } from '@deephaven/plugin';
import { dhTable } from '@deephaven/icons';
-import { dh } from '@deephaven/jsapi-types';
+import { type dh } from '@deephaven/jsapi-types';
import { GridWidgetPlugin } from './GridWidgetPlugin';
import { GridPanelPlugin } from './GridPanelPlugin';
diff --git a/packages/dashboard-core-plugins/src/GridWidgetPlugin.tsx b/packages/dashboard-core-plugins/src/GridWidgetPlugin.tsx
index dd12853d94..d2406d7927 100644
--- a/packages/dashboard-core-plugins/src/GridWidgetPlugin.tsx
+++ b/packages/dashboard-core-plugins/src/GridWidgetPlugin.tsx
@@ -2,7 +2,7 @@ import { type WidgetComponentProps } from '@deephaven/plugin';
import { type dh } from '@deephaven/jsapi-types';
import { IrisGrid } from '@deephaven/iris-grid';
import { useSelector } from 'react-redux';
-import { getSettings, RootState } from '@deephaven/redux';
+import { getSettings, type RootState } from '@deephaven/redux';
import { LoadingOverlay } from '@deephaven/components';
import { getErrorMessage } from '@deephaven/utils';
import { useIrisGridModel } from './useIrisGridModel';
diff --git a/packages/dashboard-core-plugins/src/LinkerPlugin.tsx b/packages/dashboard-core-plugins/src/LinkerPlugin.tsx
index 20a71a402a..94fa40b192 100644
--- a/packages/dashboard-core-plugins/src/LinkerPlugin.tsx
+++ b/packages/dashboard-core-plugins/src/LinkerPlugin.tsx
@@ -1,7 +1,7 @@
import React from 'react';
import {
assertIsDashboardPluginProps,
- DashboardPluginComponentProps,
+ type DashboardPluginComponentProps,
} from '@deephaven/dashboard';
import Linker from './linker/Linker';
diff --git a/packages/dashboard-core-plugins/src/LinkerPluginConfig.ts b/packages/dashboard-core-plugins/src/LinkerPluginConfig.ts
index 8a03840526..c72d31b134 100644
--- a/packages/dashboard-core-plugins/src/LinkerPluginConfig.ts
+++ b/packages/dashboard-core-plugins/src/LinkerPluginConfig.ts
@@ -1,4 +1,4 @@
-import { PluginType, DashboardPlugin } from '@deephaven/plugin';
+import { PluginType, type DashboardPlugin } from '@deephaven/plugin';
import LinkerPlugin from './LinkerPlugin';
const LinkerPluginConfig: DashboardPlugin = {
diff --git a/packages/dashboard-core-plugins/src/MarkdownPlugin.tsx b/packages/dashboard-core-plugins/src/MarkdownPlugin.tsx
index 1da0eebb1e..a99e8c3244 100644
--- a/packages/dashboard-core-plugins/src/MarkdownPlugin.tsx
+++ b/packages/dashboard-core-plugins/src/MarkdownPlugin.tsx
@@ -2,7 +2,7 @@ import { useCallback, useEffect } from 'react';
import { nanoid } from 'nanoid';
import {
assertIsDashboardPluginProps,
- DashboardPluginComponentProps,
+ type DashboardPluginComponentProps,
LayoutUtils,
useListener,
} from '@deephaven/dashboard';
diff --git a/packages/dashboard-core-plugins/src/MarkdownPluginConfig.ts b/packages/dashboard-core-plugins/src/MarkdownPluginConfig.ts
index d1f52354cb..2eef78a363 100644
--- a/packages/dashboard-core-plugins/src/MarkdownPluginConfig.ts
+++ b/packages/dashboard-core-plugins/src/MarkdownPluginConfig.ts
@@ -1,4 +1,4 @@
-import { PluginType, DashboardPlugin } from '@deephaven/plugin';
+import { PluginType, type DashboardPlugin } from '@deephaven/plugin';
import MarkdownPlugin from './MarkdownPlugin';
const MarkdownPluginConfig: DashboardPlugin = {
diff --git a/packages/dashboard-core-plugins/src/PandasPanelPlugin.tsx b/packages/dashboard-core-plugins/src/PandasPanelPlugin.tsx
index 5ffdc3c143..a5b10d10cd 100644
--- a/packages/dashboard-core-plugins/src/PandasPanelPlugin.tsx
+++ b/packages/dashboard-core-plugins/src/PandasPanelPlugin.tsx
@@ -1,5 +1,5 @@
import { forwardRef } from 'react';
-import { WidgetPanelProps } from '@deephaven/plugin';
+import { type WidgetPanelProps } from '@deephaven/plugin';
import { type dh } from '@deephaven/jsapi-types';
import { PandasPanel } from './panels';
import useHydrateGrid from './useHydrateGrid';
diff --git a/packages/dashboard-core-plugins/src/PandasPluginConfig.ts b/packages/dashboard-core-plugins/src/PandasPluginConfig.ts
index a21798fc7e..59a1560837 100644
--- a/packages/dashboard-core-plugins/src/PandasPluginConfig.ts
+++ b/packages/dashboard-core-plugins/src/PandasPluginConfig.ts
@@ -1,4 +1,4 @@
-import { PluginType, WidgetPlugin } from '@deephaven/plugin';
+import { PluginType, type WidgetPlugin } from '@deephaven/plugin';
import { dhPandas } from '@deephaven/icons';
import type { dh } from '@deephaven/jsapi-types';
import { PandasWidgetPlugin } from './PandasWidgetPlugin';
diff --git a/packages/dashboard-core-plugins/src/PandasWidgetPlugin.tsx b/packages/dashboard-core-plugins/src/PandasWidgetPlugin.tsx
index 8b43a0ec43..d7c3c98488 100644
--- a/packages/dashboard-core-plugins/src/PandasWidgetPlugin.tsx
+++ b/packages/dashboard-core-plugins/src/PandasWidgetPlugin.tsx
@@ -1,4 +1,4 @@
-import { WidgetComponentProps } from '@deephaven/plugin';
+import { type WidgetComponentProps } from '@deephaven/plugin';
import { type dh } from '@deephaven/jsapi-types';
import IrisGrid from '@deephaven/iris-grid';
import { LoadingOverlay } from '@deephaven/components';
diff --git a/packages/dashboard-core-plugins/src/WidgetLoaderPlugin.tsx b/packages/dashboard-core-plugins/src/WidgetLoaderPlugin.tsx
index d4e951287a..e846cd7712 100644
--- a/packages/dashboard-core-plugins/src/WidgetLoaderPlugin.tsx
+++ b/packages/dashboard-core-plugins/src/WidgetLoaderPlugin.tsx
@@ -3,11 +3,11 @@ import type { ReactComponentConfig } from '@deephaven/golden-layout';
import { nanoid } from 'nanoid';
import {
assertIsDashboardPluginProps,
- DashboardPluginComponentProps,
- DehydratedDashboardPanelProps,
- PanelOpenEventDetail,
+ type DashboardPluginComponentProps,
+ type DehydratedDashboardPanelProps,
+ type PanelOpenEventDetail,
LayoutUtils,
- PanelProps,
+ type PanelProps,
canHaveRef,
usePanelOpenListener,
} from '@deephaven/dashboard';
@@ -18,7 +18,7 @@ import {
type WidgetPlugin,
} from '@deephaven/plugin';
import { WidgetPanel } from './panels';
-import { WidgetPanelDescriptor } from './panels/WidgetPanelTypes';
+import { type WidgetPanelDescriptor } from './panels/WidgetPanelTypes';
const log = Log.module('WidgetLoaderPlugin');
diff --git a/packages/dashboard-core-plugins/src/WidgetLoaderPluginConfig.ts b/packages/dashboard-core-plugins/src/WidgetLoaderPluginConfig.ts
index 707e396c6b..3c74122cfc 100644
--- a/packages/dashboard-core-plugins/src/WidgetLoaderPluginConfig.ts
+++ b/packages/dashboard-core-plugins/src/WidgetLoaderPluginConfig.ts
@@ -1,4 +1,4 @@
-import { PluginType, DashboardPlugin } from '@deephaven/plugin';
+import { PluginType, type DashboardPlugin } from '@deephaven/plugin';
import WidgetLoaderPlugin from './WidgetLoaderPlugin';
const WidgetLoaderPluginConfig: DashboardPlugin = {
diff --git a/packages/dashboard-core-plugins/src/controls/dropdown-filter/DropdownFilter.test.tsx b/packages/dashboard-core-plugins/src/controls/dropdown-filter/DropdownFilter.test.tsx
index c806cb152e..7bf6dd6717 100644
--- a/packages/dashboard-core-plugins/src/controls/dropdown-filter/DropdownFilter.test.tsx
+++ b/packages/dashboard-core-plugins/src/controls/dropdown-filter/DropdownFilter.test.tsx
@@ -2,8 +2,8 @@ import React from 'react';
import { fireEvent, render, screen } from '@testing-library/react';
import userEvent from '@testing-library/user-event';
import { IrisGridTestUtils } from '@deephaven/iris-grid';
-import DropdownFilter, { DropdownFilterProps } from './DropdownFilter';
-import { LinkPoint } from '../../linker/LinkerUtils';
+import DropdownFilter, { type DropdownFilterProps } from './DropdownFilter';
+import { type LinkPoint } from '../../linker/LinkerUtils';
type MakeContainerProps = Partial & {
ref?: React.RefObject;
diff --git a/packages/dashboard-core-plugins/src/controls/dropdown-filter/DropdownFilter.tsx b/packages/dashboard-core-plugins/src/controls/dropdown-filter/DropdownFilter.tsx
index 1d0e4e00af..034df06756 100644
--- a/packages/dashboard-core-plugins/src/controls/dropdown-filter/DropdownFilter.tsx
+++ b/packages/dashboard-core-plugins/src/controls/dropdown-filter/DropdownFilter.tsx
@@ -4,10 +4,10 @@
import React, {
Component,
- KeyboardEvent,
- MouseEvent,
- ReactElement,
- RefObject,
+ type KeyboardEvent,
+ type MouseEvent,
+ type ReactElement,
+ type RefObject,
} from 'react';
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
import {
@@ -25,7 +25,7 @@ import debounce from 'lodash.debounce';
import { nanoid } from 'nanoid';
import Log from '@deephaven/log';
import './DropdownFilter.scss';
-import { LinkPoint } from '../../linker/LinkerUtils';
+import { type LinkPoint } from '../../linker/LinkerUtils';
const log = Log.module('DropdownFilter');
const UPDATE_DEBOUNCE = 150;
diff --git a/packages/dashboard-core-plugins/src/controls/input-filter/InputFilter.tsx b/packages/dashboard-core-plugins/src/controls/input-filter/InputFilter.tsx
index b92190f141..37a3c67df7 100644
--- a/packages/dashboard-core-plugins/src/controls/input-filter/InputFilter.tsx
+++ b/packages/dashboard-core-plugins/src/controls/input-filter/InputFilter.tsx
@@ -3,12 +3,12 @@
// background click is just a convience method, not an actual a11y issue
import React, {
- ChangeEvent,
+ type ChangeEvent,
Component,
- RefObject,
- MouseEvent,
- KeyboardEvent,
- ReactElement,
+ type RefObject,
+ type MouseEvent,
+ type KeyboardEvent,
+ type ReactElement,
} from 'react';
import { Button, CardFlip, Select } from '@deephaven/components';
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
diff --git a/packages/dashboard-core-plugins/src/controls/markdown/MarkdownContainer.tsx b/packages/dashboard-core-plugins/src/controls/markdown/MarkdownContainer.tsx
index 0f173a6ccc..6db2d3184f 100644
--- a/packages/dashboard-core-plugins/src/controls/markdown/MarkdownContainer.tsx
+++ b/packages/dashboard-core-plugins/src/controls/markdown/MarkdownContainer.tsx
@@ -1,8 +1,8 @@
import React, {
- MouseEventHandler,
+ type MouseEventHandler,
PureComponent,
- ReactElement,
- ReactNode,
+ type ReactElement,
+ type ReactNode,
} from 'react';
import classNames from 'classnames';
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
diff --git a/packages/dashboard-core-plugins/src/controls/markdown/MarkdownEditor.tsx b/packages/dashboard-core-plugins/src/controls/markdown/MarkdownEditor.tsx
index 19c7753540..5dcab749f1 100644
--- a/packages/dashboard-core-plugins/src/controls/markdown/MarkdownEditor.tsx
+++ b/packages/dashboard-core-plugins/src/controls/markdown/MarkdownEditor.tsx
@@ -1,6 +1,6 @@
-import React, { PureComponent, ReactElement } from 'react';
+import React, { PureComponent, type ReactElement } from 'react';
import Markdown from 'react-markdown';
-import { CodeComponent } from 'react-markdown/lib/ast-to-react';
+import { type CodeComponent } from 'react-markdown/lib/ast-to-react';
import remarkMath from 'remark-math';
import rehypeMathjax from 'rehype-mathjax';
import { Code, Editor } from '@deephaven/console';
diff --git a/packages/dashboard-core-plugins/src/controls/markdown/MarkdownStartPage.tsx b/packages/dashboard-core-plugins/src/controls/markdown/MarkdownStartPage.tsx
index 30e4019331..627ac9ce2f 100644
--- a/packages/dashboard-core-plugins/src/controls/markdown/MarkdownStartPage.tsx
+++ b/packages/dashboard-core-plugins/src/controls/markdown/MarkdownStartPage.tsx
@@ -1,8 +1,8 @@
import React, {
- Key,
- MouseEventHandler,
+ type Key,
+ type MouseEventHandler,
PureComponent,
- ReactElement,
+ type ReactElement,
} from 'react';
import {
Button,
diff --git a/packages/dashboard-core-plugins/src/controls/markdown/MarkdownUtils.ts b/packages/dashboard-core-plugins/src/controls/markdown/MarkdownUtils.ts
index 6751dcf9e5..eea3c376d4 100644
--- a/packages/dashboard-core-plugins/src/controls/markdown/MarkdownUtils.ts
+++ b/packages/dashboard-core-plugins/src/controls/markdown/MarkdownUtils.ts
@@ -1,4 +1,4 @@
-import { ClosedPanels } from '@deephaven/dashboard';
+import { type ClosedPanels } from '@deephaven/dashboard';
import memoize from 'memoize-one';
class MarkdownUtils {
diff --git a/packages/dashboard-core-plugins/src/events/IrisGridEvent.ts b/packages/dashboard-core-plugins/src/events/IrisGridEvent.ts
index 36234a2419..05a754d84c 100644
--- a/packages/dashboard-core-plugins/src/events/IrisGridEvent.ts
+++ b/packages/dashboard-core-plugins/src/events/IrisGridEvent.ts
@@ -1,5 +1,5 @@
-import { RowDataMap } from '@deephaven/jsapi-utils';
-import { IrisGridPanel } from '../panels/IrisGridPanel';
+import { type RowDataMap } from '@deephaven/jsapi-utils';
+import { type IrisGridPanel } from '../panels/IrisGridPanel';
export type IrisGridDataSelectedEventCallback = (
panel: IrisGridPanel,
diff --git a/packages/dashboard-core-plugins/src/events/TabEventMap.ts b/packages/dashboard-core-plugins/src/events/TabEventMap.ts
index ce371f55b8..b3fcc94bfc 100644
--- a/packages/dashboard-core-plugins/src/events/TabEventMap.ts
+++ b/packages/dashboard-core-plugins/src/events/TabEventMap.ts
@@ -1,5 +1,5 @@
-import { ValueOf } from '@deephaven/utils';
-import TabEvent from './TabEvent';
+import { type ValueOf } from '@deephaven/utils';
+import type TabEvent from './TabEvent';
export type TabEventType = ValueOf;
diff --git a/packages/dashboard-core-plugins/src/linker/ColumnSelectionValidator.ts b/packages/dashboard-core-plugins/src/linker/ColumnSelectionValidator.ts
index 88dd0d2e4d..0de1c6d58b 100644
--- a/packages/dashboard-core-plugins/src/linker/ColumnSelectionValidator.ts
+++ b/packages/dashboard-core-plugins/src/linker/ColumnSelectionValidator.ts
@@ -1,5 +1,5 @@
-import { PanelComponent } from '@deephaven/dashboard';
-import { LinkColumn } from './LinkerUtils';
+import { type PanelComponent } from '@deephaven/dashboard';
+import { type LinkColumn } from './LinkerUtils';
export type ColumnSelectionValidator = (
panel: PanelComponent,
diff --git a/packages/dashboard-core-plugins/src/linker/Linker.test.tsx b/packages/dashboard-core-plugins/src/linker/Linker.test.tsx
index 27bec46446..e3feae2bc8 100644
--- a/packages/dashboard-core-plugins/src/linker/Linker.test.tsx
+++ b/packages/dashboard-core-plugins/src/linker/Linker.test.tsx
@@ -1,16 +1,16 @@
import React from 'react';
import { render, screen, fireEvent } from '@testing-library/react';
import {
- OpenedPanelMap,
- PanelComponent,
+ type OpenedPanelMap,
+ type PanelComponent,
PanelManager,
} from '@deephaven/dashboard';
-import GoldenLayout, { Config } from '@deephaven/golden-layout';
+import GoldenLayout, { type Config } from '@deephaven/golden-layout';
import dh from '@deephaven/jsapi-shim';
-import { TypeValue as FilterTypeValue } from '@deephaven/filters';
+import { type TypeValue as FilterTypeValue } from '@deephaven/filters';
import ToolType from './ToolType';
import { Linker } from './Linker';
-import { Link, LinkPoint, LinkType } from './LinkerUtils';
+import { type Link, type LinkPoint, type LinkType } from './LinkerUtils';
function makeLayout() {
return new GoldenLayout({} as Config, undefined);
diff --git a/packages/dashboard-core-plugins/src/linker/Linker.tsx b/packages/dashboard-core-plugins/src/linker/Linker.tsx
index a2a1996051..5dea8b455c 100644
--- a/packages/dashboard-core-plugins/src/linker/Linker.tsx
+++ b/packages/dashboard-core-plugins/src/linker/Linker.tsx
@@ -1,19 +1,19 @@
-import React, { Component, ErrorInfo } from 'react';
-import { connect, ConnectedProps } from 'react-redux';
+import React, { Component, type ErrorInfo } from 'react';
+import { connect, type ConnectedProps } from 'react-redux';
import { nanoid } from 'nanoid';
import memoize from 'memoize-one';
import { FadeTransition } from '@deephaven/components';
import {
LayoutUtils,
- PanelComponent,
+ type PanelComponent,
PanelEvent,
- PanelManager,
+ type PanelManager,
} from '@deephaven/dashboard';
import type GoldenLayout from '@deephaven/golden-layout';
import {
DateTimeColumnFormatter,
DateUtils,
- RowDataMap,
+ type RowDataMap,
TableUtils,
} from '@deephaven/jsapi-utils';
import type { dh as DhType } from '@deephaven/jsapi-types';
@@ -24,7 +24,7 @@ import {
getApi,
getTimeZone,
setActiveTool as setActiveToolAction,
- RootState,
+ type RootState,
} from '@deephaven/redux';
import {
getIsolatedLinkerPanelIdForDashboard,
@@ -40,10 +40,10 @@ import { ChartEvent, IrisGridEvent, InputFilterEvent } from '../events';
import LinkerOverlayContent from './LinkerOverlayContent';
import LinkerUtils, {
isLinkablePanel,
- Link,
- LinkColumn,
- LinkFilterMap,
- LinkType,
+ type Link,
+ type LinkColumn,
+ type LinkFilterMap,
+ type LinkType,
isLinkableColumn,
} from './LinkerUtils';
diff --git a/packages/dashboard-core-plugins/src/linker/LinkerLink.tsx b/packages/dashboard-core-plugins/src/linker/LinkerLink.tsx
index 39ccd4ab82..b84aed1bda 100644
--- a/packages/dashboard-core-plugins/src/linker/LinkerLink.tsx
+++ b/packages/dashboard-core-plugins/src/linker/LinkerLink.tsx
@@ -1,12 +1,16 @@
-import React, { Component, MouseEvent } from 'react';
+import React, { Component, type MouseEvent } from 'react';
import memoize from 'memoize-one';
import classNames from 'classnames';
-import { Button, DropdownAction, DropdownMenu } from '@deephaven/components';
+import {
+ Button,
+ type DropdownAction,
+ DropdownMenu,
+} from '@deephaven/components';
import { vsTrash, vsTriangleDown } from '@deephaven/icons';
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
import {
Type as FilterType,
- TypeValue as FilterTypeValue,
+ type TypeValue as FilterTypeValue,
getLabelForNumberFilter,
getLabelForTextFilter,
getLabelForDateFilter,
@@ -14,7 +18,7 @@ import {
import Log from '@deephaven/log';
import { TableUtils } from '@deephaven/jsapi-utils';
import './LinkerLink.scss';
-import { LinkType } from './LinkerUtils';
+import { type LinkType } from './LinkerUtils';
const log = Log.module('LinkerLink');
diff --git a/packages/dashboard-core-plugins/src/linker/LinkerOverlayContent.test.tsx b/packages/dashboard-core-plugins/src/linker/LinkerOverlayContent.test.tsx
index 9c8cd0c392..c12782edaa 100644
--- a/packages/dashboard-core-plugins/src/linker/LinkerOverlayContent.test.tsx
+++ b/packages/dashboard-core-plugins/src/linker/LinkerOverlayContent.test.tsx
@@ -1,11 +1,11 @@
import React from 'react';
import { render, screen, fireEvent } from '@testing-library/react';
import {
- OpenedPanelMap,
- PanelComponent,
+ type OpenedPanelMap,
+ type PanelComponent,
PanelManager,
} from '@deephaven/dashboard';
-import GoldenLayout, { Config } from '@deephaven/golden-layout';
+import GoldenLayout, { type Config } from '@deephaven/golden-layout';
import LinkerOverlayContent from './LinkerOverlayContent';
const LINKER_OVERLAY_MESSAGE = 'TEST_MESSAGE';
diff --git a/packages/dashboard-core-plugins/src/linker/LinkerOverlayContent.tsx b/packages/dashboard-core-plugins/src/linker/LinkerOverlayContent.tsx
index 7ecc550cff..0c0a3e3feb 100644
--- a/packages/dashboard-core-plugins/src/linker/LinkerOverlayContent.tsx
+++ b/packages/dashboard-core-plugins/src/linker/LinkerOverlayContent.tsx
@@ -1,4 +1,4 @@
-import React, { Component, ErrorInfo } from 'react';
+import React, { Component, type ErrorInfo } from 'react';
import classNames from 'classnames';
import {
Button,
@@ -6,18 +6,18 @@ import {
GLOBAL_SHORTCUTS,
Tooltip,
} from '@deephaven/components';
-import { LayoutUtils, PanelManager } from '@deephaven/dashboard';
+import { LayoutUtils, type PanelManager } from '@deephaven/dashboard';
import Log from '@deephaven/log';
import type { Container } from '@deephaven/golden-layout';
import { vsGripper } from '@deephaven/icons';
-import { TypeValue as FilterTypeValue } from '@deephaven/filters';
+import { type TypeValue as FilterTypeValue } from '@deephaven/filters';
import clamp from 'lodash.clamp';
import {
isLinkableFromPanel,
- Link,
- LinkerCoordinate,
- LinkPoint,
- LinkType,
+ type Link,
+ type LinkerCoordinate,
+ type LinkPoint,
+ type LinkType,
} from './LinkerUtils';
import LinkerLink from './LinkerLink';
import './LinkerOverlayContent.scss';
diff --git a/packages/dashboard-core-plugins/src/linker/LinkerUtils.test.tsx b/packages/dashboard-core-plugins/src/linker/LinkerUtils.test.tsx
index 5172347d5f..15ea1b0ee9 100644
--- a/packages/dashboard-core-plugins/src/linker/LinkerUtils.test.tsx
+++ b/packages/dashboard-core-plugins/src/linker/LinkerUtils.test.tsx
@@ -1,10 +1,10 @@
-import { PanelComponent } from '@deephaven/dashboard';
-import { TypeValue as FilterTypeValue } from '@deephaven/filters';
+import { type PanelComponent } from '@deephaven/dashboard';
+import { type TypeValue as FilterTypeValue } from '@deephaven/filters';
import LinkerUtils, {
- Link,
- LinkType,
- LinkPoint,
- LinkColumn,
+ type Link,
+ type LinkType,
+ type LinkPoint,
+ type LinkColumn,
isLinkableColumn,
isLinkableFromPanel,
isLinkablePanel,
diff --git a/packages/dashboard-core-plugins/src/linker/LinkerUtils.ts b/packages/dashboard-core-plugins/src/linker/LinkerUtils.ts
index 770bef84fd..afe379cbb0 100644
--- a/packages/dashboard-core-plugins/src/linker/LinkerUtils.ts
+++ b/packages/dashboard-core-plugins/src/linker/LinkerUtils.ts
@@ -1,7 +1,7 @@
import { nanoid } from 'nanoid';
-import { LayoutUtils, PanelComponent } from '@deephaven/dashboard';
+import { LayoutUtils, type PanelComponent } from '@deephaven/dashboard';
import { TableUtils } from '@deephaven/jsapi-utils';
-import { TypeValue as FilterTypeValue } from '@deephaven/filters';
+import { type TypeValue as FilterTypeValue } from '@deephaven/filters';
import Log from '@deephaven/log';
import { ChartPanel, IrisGridPanel, DropdownFilterPanel } from '../panels';
diff --git a/packages/dashboard-core-plugins/src/panels/ChartColumnSelectorOverlay.tsx b/packages/dashboard-core-plugins/src/panels/ChartColumnSelectorOverlay.tsx
index a94daa3abf..05c5fa6418 100644
--- a/packages/dashboard-core-plugins/src/panels/ChartColumnSelectorOverlay.tsx
+++ b/packages/dashboard-core-plugins/src/panels/ChartColumnSelectorOverlay.tsx
@@ -1,4 +1,4 @@
-import React, { MouseEventHandler, ReactElement } from 'react';
+import React, { type MouseEventHandler, type ReactElement } from 'react';
import classNames from 'classnames';
import { SocketedButton } from '@deephaven/components';
import './ChartColumnSelectorOverlay.scss';
diff --git a/packages/dashboard-core-plugins/src/panels/ChartFilterOverlay.test.tsx b/packages/dashboard-core-plugins/src/panels/ChartFilterOverlay.test.tsx
index 373359ceec..f79eeb7add 100644
--- a/packages/dashboard-core-plugins/src/panels/ChartFilterOverlay.test.tsx
+++ b/packages/dashboard-core-plugins/src/panels/ChartFilterOverlay.test.tsx
@@ -1,7 +1,7 @@
import React from 'react';
import { render, screen } from '@testing-library/react';
-import { InputFilter } from '@deephaven/iris-grid';
-import ChartFilterOverlay, { ColumnMap } from './ChartFilterOverlay';
+import { type InputFilter } from '@deephaven/iris-grid';
+import ChartFilterOverlay, { type ColumnMap } from './ChartFilterOverlay';
const emptyTestMap = new Map([]);
diff --git a/packages/dashboard-core-plugins/src/panels/ChartFilterOverlay.tsx b/packages/dashboard-core-plugins/src/panels/ChartFilterOverlay.tsx
index 259a59cf1a..ac772fd032 100644
--- a/packages/dashboard-core-plugins/src/panels/ChartFilterOverlay.tsx
+++ b/packages/dashboard-core-plugins/src/panels/ChartFilterOverlay.tsx
@@ -1,11 +1,16 @@
-import React, { MouseEvent, ReactElement, useCallback, useMemo } from 'react';
+import React, {
+ type MouseEvent,
+ type ReactElement,
+ useCallback,
+ useMemo,
+} from 'react';
import PropTypes from 'prop-types';
import classNames from 'classnames';
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
import { Button } from '@deephaven/components';
import { vsPass, vsWarning } from '@deephaven/icons';
import { TextUtils } from '@deephaven/utils';
-import { ColumnName, InputFilter } from '@deephaven/iris-grid';
+import { type ColumnName, type InputFilter } from '@deephaven/iris-grid';
import './ChartFilterOverlay.scss';
export type ColumnMap = Map;
diff --git a/packages/dashboard-core-plugins/src/panels/ChartPanel.test.tsx b/packages/dashboard-core-plugins/src/panels/ChartPanel.test.tsx
index dfc828fe9b..06432c1de4 100644
--- a/packages/dashboard-core-plugins/src/panels/ChartPanel.test.tsx
+++ b/packages/dashboard-core-plugins/src/panels/ChartPanel.test.tsx
@@ -5,8 +5,8 @@ import { act, render, screen } from '@testing-library/react';
import dh from '@deephaven/jsapi-shim';
import { MockChartModel } from '@deephaven/chart';
import type { Container } from '@deephaven/golden-layout';
-import { PanelComponent } from '@deephaven/dashboard';
-import { ChartPanel, ChartPanelMetadata } from './ChartPanel';
+import { type PanelComponent } from '@deephaven/dashboard';
+import { ChartPanel, type ChartPanelMetadata } from './ChartPanel';
import ChartColumnSelectorOverlay from './ChartColumnSelectorOverlay';
const DASHBOARD_ID = 'TEST_DASHBOARD_ID';
diff --git a/packages/dashboard-core-plugins/src/panels/ChartPanel.tsx b/packages/dashboard-core-plugins/src/panels/ChartPanel.tsx
index e44514b08e..fe89e881c4 100644
--- a/packages/dashboard-core-plugins/src/panels/ChartPanel.tsx
+++ b/packages/dashboard-core-plugins/src/panels/ChartPanel.tsx
@@ -1,30 +1,30 @@
-import React, { Component, ReactElement, RefObject } from 'react';
+import React, { Component, type ReactElement, type RefObject } from 'react';
import classNames from 'classnames';
import memoize from 'memoize-one';
import { connect } from 'react-redux';
import debounce from 'lodash.debounce';
import {
Chart,
- ChartModel,
+ type ChartModel,
ChartModelFactory,
- ChartModelSettings,
- FilterMap,
+ type ChartModelSettings,
+ type FilterMap,
isFigureChartModel,
} from '@deephaven/chart';
import type PlotlyType from 'plotly.js';
import {
- DashboardPanelProps,
+ type DashboardPanelProps,
getOpenedPanelMapForDashboard,
LayoutUtils,
- PanelComponent,
- PanelMetadata,
- PanelProps,
+ type PanelComponent,
+ type PanelMetadata,
+ type PanelProps,
} from '@deephaven/dashboard';
import {
IrisGridUtils,
- InputFilter,
- ColumnName,
- TableSettings,
+ type InputFilter,
+ type ColumnName,
+ type TableSettings,
} from '@deephaven/iris-grid';
import type { dh } from '@deephaven/jsapi-types';
import { FadeTransition } from '@deephaven/components';
@@ -32,9 +32,9 @@ import Log from '@deephaven/log';
import {
getActiveTool,
getSettings,
- RootState,
+ type RootState,
setActiveTool as setActiveToolAction,
- WorkspaceSettings,
+ type WorkspaceSettings,
} from '@deephaven/redux';
import {
assertNotNull,
@@ -53,19 +53,19 @@ import {
getTableMapForDashboard,
setDashboardIsolatedLinkerPanelId as setDashboardIsolatedLinkerPanelIdAction,
} from '../redux';
-import ChartFilterOverlay, { ColumnMap } from './ChartFilterOverlay';
+import ChartFilterOverlay, { type ColumnMap } from './ChartFilterOverlay';
import ChartColumnSelectorOverlay, {
- SelectorColumn,
+ type SelectorColumn,
} from './ChartColumnSelectorOverlay';
import './ChartPanel.scss';
-import { Link, LinkFilterMap } from '../linker/LinkerUtils';
-import { PanelState as IrisGridPanelState } from './IrisGridPanel';
+import { type Link, type LinkFilterMap } from '../linker/LinkerUtils';
+import { type PanelState as IrisGridPanelState } from './IrisGridPanel';
import {
isChartPanelFigureMetadata,
isChartPanelTableMetadata,
} from './ChartPanelUtils';
-import { ColumnSelectionValidator } from '../linker/ColumnSelectionValidator';
-import { WidgetPanelDescriptor } from './WidgetPanelTypes';
+import { type ColumnSelectionValidator } from '../linker/ColumnSelectionValidator';
+import { type WidgetPanelDescriptor } from './WidgetPanelTypes';
const log = Log.module('ChartPanel');
const UPDATE_MODEL_DEBOUNCE = 150;
diff --git a/packages/dashboard-core-plugins/src/panels/ChartPanelUtils.ts b/packages/dashboard-core-plugins/src/panels/ChartPanelUtils.ts
index af29c8e067..aeb55d1f29 100644
--- a/packages/dashboard-core-plugins/src/panels/ChartPanelUtils.ts
+++ b/packages/dashboard-core-plugins/src/panels/ChartPanelUtils.ts
@@ -1,4 +1,4 @@
-import { DehydratedDashboardPanelProps } from '@deephaven/dashboard';
+import { type DehydratedDashboardPanelProps } from '@deephaven/dashboard';
import type {
ChartPanelMetadata,
ChartPanelTableMetadata,
diff --git a/packages/dashboard-core-plugins/src/panels/CommandHistoryPanel.tsx b/packages/dashboard-core-plugins/src/panels/CommandHistoryPanel.tsx
index e0599635e9..c989196937 100644
--- a/packages/dashboard-core-plugins/src/panels/CommandHistoryPanel.tsx
+++ b/packages/dashboard-core-plugins/src/panels/CommandHistoryPanel.tsx
@@ -1,16 +1,16 @@
-import React, { Component, RefObject } from 'react';
+import React, { Component, type RefObject } from 'react';
import { connect } from 'react-redux';
-import { ContextAction, ContextActions } from '@deephaven/components';
+import { type ContextAction, ContextActions } from '@deephaven/components';
import {
CommandHistory,
- CommandHistoryStorage,
+ type CommandHistoryStorage,
SHORTCUTS,
- CommandHistorySettings,
- CommandHistoryTable,
+ type CommandHistorySettings,
+ type CommandHistoryTable,
} from '@deephaven/console';
-import { DashboardPanelProps } from '@deephaven/dashboard';
+import { type DashboardPanelProps } from '@deephaven/dashboard';
import Log from '@deephaven/log';
-import { getCommandHistoryStorage, RootState } from '@deephaven/redux';
+import { getCommandHistoryStorage, type RootState } from '@deephaven/redux';
import { assertNotNull, Pending } from '@deephaven/utils';
import type { dh } from '@deephaven/jsapi-types';
import { ConsoleEvent, NotebookEvent } from '../events';
diff --git a/packages/dashboard-core-plugins/src/panels/ConsolePanel.test.tsx b/packages/dashboard-core-plugins/src/panels/ConsolePanel.test.tsx
index 92e90c214d..adc4cb1416 100644
--- a/packages/dashboard-core-plugins/src/panels/ConsolePanel.test.tsx
+++ b/packages/dashboard-core-plugins/src/panels/ConsolePanel.test.tsx
@@ -1,10 +1,13 @@
import React from 'react';
import { render } from '@testing-library/react';
-import { CommandHistoryStorage } from '@deephaven/console';
+import { type CommandHistoryStorage } from '@deephaven/console';
import type { Container, EventEmitter } from '@deephaven/golden-layout';
import type { IdeConnection, IdeSession } from '@deephaven/jsapi-types';
import { dh } from '@deephaven/jsapi-shim';
-import { SessionConfig, SessionWrapper } from '@deephaven/jsapi-utils';
+import {
+ type SessionConfig,
+ type SessionWrapper,
+} from '@deephaven/jsapi-utils';
import { TestUtils } from '@deephaven/test-utils';
import { ConsolePanel } from './ConsolePanel';
diff --git a/packages/dashboard-core-plugins/src/panels/ConsolePanel.tsx b/packages/dashboard-core-plugins/src/panels/ConsolePanel.tsx
index b99cd541d1..7299fa1e98 100644
--- a/packages/dashboard-core-plugins/src/panels/ConsolePanel.tsx
+++ b/packages/dashboard-core-plugins/src/panels/ConsolePanel.tsx
@@ -1,19 +1,19 @@
// Wrapper for the Console for use in a golden layout container
// Will probably need to handle window popping out from golden layout here.
-import React, { PureComponent, ReactElement, RefObject } from 'react';
+import React, { PureComponent, type ReactElement, type RefObject } from 'react';
import { nanoid } from 'nanoid';
import debounce from 'lodash.debounce';
import { connect } from 'react-redux';
import { LoadingOverlay } from '@deephaven/components';
import {
- CommandHistoryStorage,
+ type CommandHistoryStorage,
Console,
ConsoleConstants,
HeapUsage,
ObjectIcon,
} from '@deephaven/console';
import {
- DashboardPanelProps,
+ type DashboardPanelProps,
emitPanelOpen,
LayoutManagerContext,
LayoutUtils,
@@ -21,13 +21,13 @@ import {
} from '@deephaven/dashboard';
import type { dh } from '@deephaven/jsapi-types';
import { getVariableDescriptor } from '@deephaven/jsapi-bootstrap';
-import { SessionWrapper } from '@deephaven/jsapi-utils';
+import { type SessionWrapper } from '@deephaven/jsapi-utils';
import Log from '@deephaven/log';
import {
getCommandHistoryStorage,
getPlugins,
getTimeZone,
- RootState,
+ type RootState,
} from '@deephaven/redux';
import { assertNotNull } from '@deephaven/utils';
import {
diff --git a/packages/dashboard-core-plugins/src/panels/DropdownFilterPanel.test.tsx b/packages/dashboard-core-plugins/src/panels/DropdownFilterPanel.test.tsx
index a7edd436ec..dd63094b53 100644
--- a/packages/dashboard-core-plugins/src/panels/DropdownFilterPanel.test.tsx
+++ b/packages/dashboard-core-plugins/src/panels/DropdownFilterPanel.test.tsx
@@ -4,7 +4,7 @@ import type { Container, EventHub } from '@deephaven/golden-layout';
import dh from '@deephaven/jsapi-shim';
import {
DropdownFilterPanel,
- DropdownFilterPanelProps,
+ type DropdownFilterPanelProps,
} from './DropdownFilterPanel';
import DropdownFilter from '../controls/dropdown-filter/DropdownFilter';
diff --git a/packages/dashboard-core-plugins/src/panels/DropdownFilterPanel.tsx b/packages/dashboard-core-plugins/src/panels/DropdownFilterPanel.tsx
index 52b4005a98..8d26da5925 100644
--- a/packages/dashboard-core-plugins/src/panels/DropdownFilterPanel.tsx
+++ b/packages/dashboard-core-plugins/src/panels/DropdownFilterPanel.tsx
@@ -1,15 +1,15 @@
-import React, { Component, RefObject } from 'react';
-import { connect, ConnectedProps } from 'react-redux';
+import React, { Component, type RefObject } from 'react';
+import { connect, type ConnectedProps } from 'react-redux';
import debounce from 'lodash.debounce';
import deepEqual from 'fast-deep-equal';
import memoize from 'memoizee';
-import { DashboardPanelProps, LayoutUtils } from '@deephaven/dashboard';
+import { type DashboardPanelProps, LayoutUtils } from '@deephaven/dashboard';
import type { dh as DhType } from '@deephaven/jsapi-types';
import {
DateTimeColumnFormatter,
Formatter,
FormatterUtils,
- FormattingRule,
+ type FormattingRule,
TableUtils,
} from '@deephaven/jsapi-utils';
import Log from '@deephaven/log';
@@ -17,11 +17,11 @@ import {
getActiveTool,
getApi,
getSettings,
- RootState,
+ type RootState,
} from '@deephaven/redux';
import { EMPTY_ARRAY, Pending, PromiseUtils } from '@deephaven/utils';
import DropdownFilter, {
- DropdownFilterColumn,
+ type DropdownFilterColumn,
} from '../controls/dropdown-filter/DropdownFilter';
import { InputFilterEvent } from '../events';
import {
@@ -35,8 +35,8 @@ import './DropdownFilterPanel.scss';
import ToolType from '../linker/ToolType';
import WidgetPanel from './WidgetPanel';
import type { Link, LinkPoint } from '../linker/LinkerUtils';
-import { ColumnSelectionValidator } from '../linker/ColumnSelectionValidator';
-import { PanelState as InputFilterPanelState } from './InputFilterPanel';
+import { type ColumnSelectionValidator } from '../linker/ColumnSelectionValidator';
+import { type PanelState as InputFilterPanelState } from './InputFilterPanel';
const log = Log.module('DropdownFilterPanel');
diff --git a/packages/dashboard-core-plugins/src/panels/FileExplorerPanel.test.tsx b/packages/dashboard-core-plugins/src/panels/FileExplorerPanel.test.tsx
index c491068a7b..cf4371d63f 100644
--- a/packages/dashboard-core-plugins/src/panels/FileExplorerPanel.test.tsx
+++ b/packages/dashboard-core-plugins/src/panels/FileExplorerPanel.test.tsx
@@ -8,12 +8,15 @@ import {
} from '@testing-library/react';
import userEvent from '@testing-library/user-event';
import {
- DirectoryStorageItem,
- FileStorageItem,
+ type DirectoryStorageItem,
+ type FileStorageItem,
} from '@deephaven/file-explorer';
import type { Container } from '@deephaven/golden-layout';
import { TestUtils } from '@deephaven/test-utils';
-import { FileExplorerPanel, FileExplorerPanelProps } from './FileExplorerPanel';
+import {
+ FileExplorerPanel,
+ type FileExplorerPanelProps,
+} from './FileExplorerPanel';
import MockFileStorage from './MockFileStorage';
function makeFileName(index = 0): string {
diff --git a/packages/dashboard-core-plugins/src/panels/FileExplorerPanel.tsx b/packages/dashboard-core-plugins/src/panels/FileExplorerPanel.tsx
index 47b0d251f5..bfeb2821ad 100644
--- a/packages/dashboard-core-plugins/src/panels/FileExplorerPanel.tsx
+++ b/packages/dashboard-core-plugins/src/panels/FileExplorerPanel.tsx
@@ -1,16 +1,16 @@
-import { DashboardPanelProps } from '@deephaven/dashboard';
+import { type DashboardPanelProps } from '@deephaven/dashboard';
import Log from '@deephaven/log';
-import { getFileStorage, RootState } from '@deephaven/redux';
+import { getFileStorage, type RootState } from '@deephaven/redux';
import FileExplorer, {
FileExplorerToolbar,
- FileStorage,
- FileStorageItem,
+ type FileStorage,
+ type FileStorageItem,
FileUtils,
NewItemModal,
isDirectory,
} from '@deephaven/file-explorer';
-import React, { ReactNode } from 'react';
-import { connect, ConnectedProps } from 'react-redux';
+import React, { type ReactNode } from 'react';
+import { connect, type ConnectedProps } from 'react-redux';
import type { dh } from '@deephaven/jsapi-types';
import Panel from './Panel';
import { NotebookEvent } from '../events';
diff --git a/packages/dashboard-core-plugins/src/panels/FilterSetManager.tsx b/packages/dashboard-core-plugins/src/panels/FilterSetManager.tsx
index 23c86ca0e2..4e8dbba29c 100644
--- a/packages/dashboard-core-plugins/src/panels/FilterSetManager.tsx
+++ b/packages/dashboard-core-plugins/src/panels/FilterSetManager.tsx
@@ -3,11 +3,11 @@
// background click is just a convenience method, not an actual a11y issue
import React, {
- ChangeEvent,
+ type ChangeEvent,
Component,
- ReactNode,
- KeyboardEvent,
- MouseEvent,
+ type ReactNode,
+ type KeyboardEvent,
+ type MouseEvent,
} from 'react';
import memoizeOne from 'memoize-one';
import { nanoid } from 'nanoid';
diff --git a/packages/dashboard-core-plugins/src/panels/FilterSetManagerPanel.tsx b/packages/dashboard-core-plugins/src/panels/FilterSetManagerPanel.tsx
index 4a9cc59a79..d1b8df6782 100644
--- a/packages/dashboard-core-plugins/src/panels/FilterSetManagerPanel.tsx
+++ b/packages/dashboard-core-plugins/src/panels/FilterSetManagerPanel.tsx
@@ -1,21 +1,21 @@
-import React, { Component, ReactElement } from 'react';
+import React, { Component, type ReactElement } from 'react';
import { connect } from 'react-redux';
import {
getOpenedPanelMapForDashboard,
LayoutUtils,
- PanelComponent,
+ type PanelComponent,
} from '@deephaven/dashboard';
import Log from '@deephaven/log';
import type { Container, EventEmitter } from '@deephaven/golden-layout';
import type { dh } from '@deephaven/jsapi-types';
-import { RootState } from '@deephaven/redux';
+import { type RootState } from '@deephaven/redux';
import {
- AdvancedFilter,
- ColumnName,
- DehydratedIrisGridState,
- QuickFilter,
+ type AdvancedFilter,
+ type ColumnName,
+ type DehydratedIrisGridState,
+ type QuickFilter,
} from '@deephaven/iris-grid';
-import { GridState } from '@deephaven/grid';
+import { type GridState } from '@deephaven/grid';
import {
getFilterSetsForDashboard,
getInputFiltersForDashboard,
@@ -24,17 +24,17 @@ import {
} from '../redux';
import Panel from './Panel';
import FilterSetManager, {
- ChangeHandlerArgs,
- FilterSet,
- FilterSetPanel,
+ type ChangeHandlerArgs,
+ type FilterSet,
+ type FilterSetPanel,
} from './FilterSetManager';
import { IrisGridPanel } from './IrisGridPanel';
import DropdownFilterPanel from './DropdownFilterPanel';
import InputFilterPanel, {
- PanelState as InputFilterPanelState,
+ type PanelState as InputFilterPanelState,
} from './InputFilterPanel';
import './FilterSetManagerPanel.scss';
-import { FilterChangeEvent } from '../FilterPlugin';
+import { type FilterChangeEvent } from '../FilterPlugin';
const log = Log.module('FilterSetManagerPanel');
interface IrisGridState {
diff --git a/packages/dashboard-core-plugins/src/panels/InputFilterPanel.tsx b/packages/dashboard-core-plugins/src/panels/InputFilterPanel.tsx
index 991da3957c..9553fcd4fe 100644
--- a/packages/dashboard-core-plugins/src/panels/InputFilterPanel.tsx
+++ b/packages/dashboard-core-plugins/src/panels/InputFilterPanel.tsx
@@ -1,11 +1,11 @@
-import React, { Component, RefObject } from 'react';
+import React, { Component, type RefObject } from 'react';
import { connect } from 'react-redux';
import debounce from 'lodash.debounce';
import type { Container, EventEmitter } from '@deephaven/golden-layout';
-import { RootState } from '@deephaven/redux';
+import { type RootState } from '@deephaven/redux';
import Panel from './Panel';
import InputFilter, {
- InputFilterColumn,
+ type InputFilterColumn,
} from '../controls/input-filter/InputFilter';
import { InputFilterEvent } from '../events';
import { getColumnsForDashboard } from '../redux';
diff --git a/packages/dashboard-core-plugins/src/panels/IrisGridPanel.test.tsx b/packages/dashboard-core-plugins/src/panels/IrisGridPanel.test.tsx
index 53e8a14b5d..cb3e882b5a 100644
--- a/packages/dashboard-core-plugins/src/panels/IrisGridPanel.test.tsx
+++ b/packages/dashboard-core-plugins/src/panels/IrisGridPanel.test.tsx
@@ -6,7 +6,7 @@ import { IrisGridModelFactory } from '@deephaven/iris-grid';
import dh from '@deephaven/jsapi-shim';
import { TestUtils } from '@deephaven/test-utils';
import type { Container } from '@deephaven/golden-layout';
-import { Workspace } from '@deephaven/redux';
+import { type Workspace } from '@deephaven/redux';
import { IrisGridPanel } from './IrisGridPanel';
const MockIrisGrid: React.FC & jest.Mock = jest.fn(() => null);
diff --git a/packages/dashboard-core-plugins/src/panels/IrisGridPanel.tsx b/packages/dashboard-core-plugins/src/panels/IrisGridPanel.tsx
index 34d0b62fc3..e4efb20dda 100644
--- a/packages/dashboard-core-plugins/src/panels/IrisGridPanel.tsx
+++ b/packages/dashboard-core-plugins/src/panels/IrisGridPanel.tsx
@@ -2,19 +2,19 @@
// Will probably need to handle window popping out from golden layout here.
import React, {
PureComponent,
- ReactElement,
- ReactNode,
- RefObject,
+ type ReactElement,
+ type ReactNode,
+ type RefObject,
} from 'react';
import memoize from 'memoize-one';
import { connect } from 'react-redux';
import debounce from 'lodash.debounce';
import {
- DashboardPanelProps,
+ type DashboardPanelProps,
DEFAULT_DASHBOARD_ID,
LayoutUtils,
- PanelComponent,
- PanelMetadata,
+ type PanelComponent,
+ type PanelMetadata,
} from '@deephaven/dashboard';
import {
AdvancedSettings,
@@ -23,55 +23,55 @@ import {
IrisGridModel,
IrisGridUtils,
isIrisGridTableModelTemplate,
- ColumnName,
- PendingDataMap,
- InputFilter,
- IrisGridThemeType,
- ReadonlyAdvancedFilterMap,
- AggregationSettings,
- AdvancedSettingsType,
- UIRollupConfig,
- UIRow,
- ReadonlyQuickFilterMap,
- FilterMap,
- QuickFilter,
- AdvancedFilter,
- SidebarFormattingRule,
- IrisGridState,
- ChartBuilderSettings,
- DehydratedIrisGridState,
- DehydratedIrisGridPanelState,
- ColumnHeaderGroup,
- IrisGridContextMenuData,
- PartitionConfig,
+ type ColumnName,
+ type PendingDataMap,
+ type InputFilter,
+ type IrisGridThemeType,
+ type ReadonlyAdvancedFilterMap,
+ type AggregationSettings,
+ type AdvancedSettingsType,
+ type UIRollupConfig,
+ type UIRow,
+ type ReadonlyQuickFilterMap,
+ type FilterMap,
+ type QuickFilter,
+ type AdvancedFilter,
+ type SidebarFormattingRule,
+ type IrisGridState,
+ type ChartBuilderSettings,
+ type DehydratedIrisGridState,
+ type DehydratedIrisGridPanelState,
+ type ColumnHeaderGroup,
+ type IrisGridContextMenuData,
+ type PartitionConfig,
} from '@deephaven/iris-grid';
import {
- AdvancedFilterOptions,
- FormattingRule,
- ReverseType,
+ type AdvancedFilterOptions,
+ type FormattingRule,
+ type ReverseType,
TableUtils,
} from '@deephaven/jsapi-utils';
import Log from '@deephaven/log';
import {
getSettings,
getUser,
- RootState,
- User,
- WorkspaceSettings,
+ type RootState,
+ type User,
+ type WorkspaceSettings,
} from '@deephaven/redux';
import {
assertNotNull,
- CancelablePromise,
- EventT,
+ type CancelablePromise,
+ type EventT,
PromiseUtils,
} from '@deephaven/utils';
-import { ResolvableContextAction } from '@deephaven/components';
+import { type ResolvableContextAction } from '@deephaven/components';
import type { dh } from '@deephaven/jsapi-types';
import {
- GridState,
- ModelIndex,
- ModelSizeMap,
- MoveOperation,
+ type GridState,
+ type ModelIndex,
+ type ModelSizeMap,
+ type MoveOperation,
} from '@deephaven/grid';
import type {
TablePluginComponent,
@@ -85,13 +85,13 @@ import {
} from '../redux';
import WidgetPanel from './WidgetPanel';
import './IrisGridPanel.scss';
-import { Link, LinkColumn } from '../linker/LinkerUtils';
+import { type Link, type LinkColumn } from '../linker/LinkerUtils';
import IrisGridPanelTooltip from './IrisGridPanelTooltip';
import {
isIrisGridPanelMetadata,
isLegacyIrisGridPanelMetadata,
} from './IrisGridPanelTypes';
-import { WidgetPanelDescriptor } from './WidgetPanelTypes';
+import { type WidgetPanelDescriptor } from './WidgetPanelTypes';
const log = Log.module('IrisGridPanel');
diff --git a/packages/dashboard-core-plugins/src/panels/IrisGridPanelTooltip.tsx b/packages/dashboard-core-plugins/src/panels/IrisGridPanelTooltip.tsx
index 2c71e3a00d..31b1cbcebd 100644
--- a/packages/dashboard-core-plugins/src/panels/IrisGridPanelTooltip.tsx
+++ b/packages/dashboard-core-plugins/src/panels/IrisGridPanelTooltip.tsx
@@ -1,7 +1,7 @@
-import React, { ReactElement } from 'react';
-import { IrisGridModel } from '@deephaven/iris-grid';
+import React, { type ReactElement } from 'react';
+import { type IrisGridModel } from '@deephaven/iris-grid';
import WidgetPanelTooltip from './WidgetPanelTooltip';
-import { WidgetPanelTooltipProps } from './WidgetPanelTypes';
+import { type WidgetPanelTooltipProps } from './WidgetPanelTypes';
type IrisGridPanelTooltipProps = WidgetPanelTooltipProps & {
model?: IrisGridModel;
diff --git a/packages/dashboard-core-plugins/src/panels/IrisGridPanelTypes.ts b/packages/dashboard-core-plugins/src/panels/IrisGridPanelTypes.ts
index 61b7e41528..aa41d66438 100644
--- a/packages/dashboard-core-plugins/src/panels/IrisGridPanelTypes.ts
+++ b/packages/dashboard-core-plugins/src/panels/IrisGridPanelTypes.ts
@@ -1,4 +1,4 @@
-import { PanelMetadata } from '@deephaven/dashboard';
+import { type PanelMetadata } from '@deephaven/dashboard';
/**
* @deprecated use `IrisGridPanelMetadata` instead
diff --git a/packages/dashboard-core-plugins/src/panels/LogPanel.tsx b/packages/dashboard-core-plugins/src/panels/LogPanel.tsx
index 536d228ec5..03c34ff7f1 100644
--- a/packages/dashboard-core-plugins/src/panels/LogPanel.tsx
+++ b/packages/dashboard-core-plugins/src/panels/LogPanel.tsx
@@ -4,9 +4,9 @@ import React, { PureComponent } from 'react';
import { connect } from 'react-redux';
import { LogView } from '@deephaven/console';
import type { dh } from '@deephaven/jsapi-types';
-import { DashboardPanelProps } from '@deephaven/dashboard';
+import { type DashboardPanelProps } from '@deephaven/dashboard';
import Log from '@deephaven/log';
-import { RootState } from '@deephaven/redux';
+import { type RootState } from '@deephaven/redux';
import './LogPanel.scss';
import Panel from './Panel';
import { getDashboardSessionWrapper } from '../redux';
diff --git a/packages/dashboard-core-plugins/src/panels/MarkdownNotebook.tsx b/packages/dashboard-core-plugins/src/panels/MarkdownNotebook.tsx
index 6d362d1916..120c46873a 100644
--- a/packages/dashboard-core-plugins/src/panels/MarkdownNotebook.tsx
+++ b/packages/dashboard-core-plugins/src/panels/MarkdownNotebook.tsx
@@ -1,12 +1,12 @@
import React, {
PureComponent,
- ReactElement,
- RefObject,
- MouseEvent,
- MouseEventHandler,
+ type ReactElement,
+ type RefObject,
+ type MouseEvent,
+ type MouseEventHandler,
} from 'react';
import classNames from 'classnames';
-import Markdown, { Options } from 'react-markdown';
+import Markdown, { type Options } from 'react-markdown';
import remarkGfm from 'remark-gfm';
import remarkMath from 'remark-math';
import rehypeMathjax from 'rehype-mathjax';
@@ -14,7 +14,7 @@ import { Button } from '@deephaven/components';
import { Code } from '@deephaven/console';
import { vsPlay } from '@deephaven/icons';
import './MarkdownNotebook.scss';
-import { ReactMarkdownProps } from 'react-markdown/lib/ast-to-react';
+import { type ReactMarkdownProps } from 'react-markdown/lib/ast-to-react';
import { assertNotNull } from '@deephaven/utils';
interface MarkdownNotebookProps {
diff --git a/packages/dashboard-core-plugins/src/panels/MarkdownPanel.tsx b/packages/dashboard-core-plugins/src/panels/MarkdownPanel.tsx
index 37d06627d4..9c9823457f 100644
--- a/packages/dashboard-core-plugins/src/panels/MarkdownPanel.tsx
+++ b/packages/dashboard-core-plugins/src/panels/MarkdownPanel.tsx
@@ -1,16 +1,16 @@
import React, {
Component,
- FocusEvent,
- MouseEvent,
- ReactElement,
+ type FocusEvent,
+ type MouseEvent,
+ type ReactElement,
Suspense,
lazy,
} from 'react';
import memoize from 'memoize-one';
import { connect } from 'react-redux';
import {
- ClosedPanel,
- DashboardPanelProps,
+ type ClosedPanel,
+ type DashboardPanelProps,
getClosedPanelsForDashboard,
LayoutUtils,
PanelEvent,
@@ -19,7 +19,7 @@ import Log from '@deephaven/log';
import type { ReactComponentConfig } from '@deephaven/golden-layout';
import type * as monaco from 'monaco-editor';
import { assertNotNull } from '@deephaven/utils';
-import { RootState } from '@deephaven/redux';
+import { type RootState } from '@deephaven/redux';
import { LoadingOverlay } from '@deephaven/components';
import Panel from './Panel';
import MarkdownContainer from '../controls/markdown/MarkdownContainer';
diff --git a/packages/dashboard-core-plugins/src/panels/MockFileStorage.ts b/packages/dashboard-core-plugins/src/panels/MockFileStorage.ts
index f1e6d98bee..8f1244ca19 100644
--- a/packages/dashboard-core-plugins/src/panels/MockFileStorage.ts
+++ b/packages/dashboard-core-plugins/src/panels/MockFileStorage.ts
@@ -1,9 +1,9 @@
import {
- File,
+ type File,
FileNotFoundError,
- FileStorage,
- FileStorageItem,
- FileStorageTable,
+ type FileStorage,
+ type FileStorageItem,
+ type FileStorageTable,
FileUtils,
} from '@deephaven/file-explorer';
import MockFileStorageTable from './MockFileStorageTable';
diff --git a/packages/dashboard-core-plugins/src/panels/MockFileStorageTable.ts b/packages/dashboard-core-plugins/src/panels/MockFileStorageTable.ts
index 9f0c09f1e9..5f8ae4c0c3 100644
--- a/packages/dashboard-core-plugins/src/panels/MockFileStorageTable.ts
+++ b/packages/dashboard-core-plugins/src/panels/MockFileStorageTable.ts
@@ -1,17 +1,17 @@
import {
- FileStorageItem,
- FileStorageTable,
+ type FileStorageItem,
+ type FileStorageTable,
isDirectory,
} from '@deephaven/file-explorer';
import {
- ViewportData,
- IndexRange,
- StorageSnapshot,
- StorageTableViewport,
- FilterConfig,
- SortConfig,
- ViewportUpdateCallback,
- StorageListenerRemover,
+ type ViewportData,
+ type IndexRange,
+ type StorageSnapshot,
+ type StorageTableViewport,
+ type FilterConfig,
+ type SortConfig,
+ type ViewportUpdateCallback,
+ type StorageListenerRemover,
} from '@deephaven/storage';
export class MockFileStorageTable implements FileStorageTable {
diff --git a/packages/dashboard-core-plugins/src/panels/NotebookPanel.tsx b/packages/dashboard-core-plugins/src/panels/NotebookPanel.tsx
index 35e68a26f6..10d78fdc94 100644
--- a/packages/dashboard-core-plugins/src/panels/NotebookPanel.tsx
+++ b/packages/dashboard-core-plugins/src/panels/NotebookPanel.tsx
@@ -1,5 +1,5 @@
// Wrapper for the Notebook for use in a golden layout container
-import React, { Component, ReactElement, Suspense, lazy } from 'react';
+import React, { Component, type ReactElement, Suspense, lazy } from 'react';
import ReactDOM from 'react-dom';
import memoize from 'memoize-one';
import { connect } from 'react-redux';
@@ -12,15 +12,15 @@ import {
Tooltip,
GLOBAL_SHORTCUTS,
Button,
- DropdownAction,
+ type DropdownAction,
LoadingOverlay,
} from '@deephaven/components';
import { ScriptEditor, ScriptEditorUtils, SHORTCUTS } from '@deephaven/console';
import {
- FileStorage,
+ type FileStorage,
FileUtils,
NewItemModal,
- File,
+ type File,
} from '@deephaven/file-explorer';
import {
vsSave,
@@ -36,16 +36,16 @@ import {
import {
getFileStorage,
updateSettings as updateSettingsAction,
- RootState,
- WorkspaceSettings,
+ type RootState,
+ type WorkspaceSettings,
getDefaultNotebookSettings,
} from '@deephaven/redux';
import classNames from 'classnames';
import debounce from 'lodash.debounce';
import {
- DashboardPanelProps,
+ type DashboardPanelProps,
PanelEvent,
- PanelMetadata,
+ type PanelMetadata,
} from '@deephaven/dashboard';
import Log from '@deephaven/log';
import { assertNotNull, Pending, PromiseUtils } from '@deephaven/utils';
diff --git a/packages/dashboard-core-plugins/src/panels/PandasPanel.tsx b/packages/dashboard-core-plugins/src/panels/PandasPanel.tsx
index 9ca0cd34a3..9ed31245d3 100644
--- a/packages/dashboard-core-plugins/src/panels/PandasPanel.tsx
+++ b/packages/dashboard-core-plugins/src/panels/PandasPanel.tsx
@@ -1,6 +1,6 @@
/* eslint-disable react/jsx-props-no-spreading */
/* eslint-disable react/no-unused-state */
-import React, { Component, ReactElement, RefObject } from 'react';
+import React, { Component, type ReactElement, type RefObject } from 'react';
import ConnectedIrisGridPanel, {
type IrisGridPanel,
type OwnProps as IrisGridPanelOwnProps,
diff --git a/packages/dashboard-core-plugins/src/panels/Panel.tsx b/packages/dashboard-core-plugins/src/panels/Panel.tsx
index 87381dbf4c..beb753535a 100644
--- a/packages/dashboard-core-plugins/src/panels/Panel.tsx
+++ b/packages/dashboard-core-plugins/src/panels/Panel.tsx
@@ -1,21 +1,25 @@
import React, {
- FocusEvent,
- FocusEventHandler,
+ type FocusEvent,
+ type FocusEventHandler,
PureComponent,
- ReactElement,
- ReactNode,
+ type ReactElement,
+ type ReactNode,
} from 'react';
import ReactDOM from 'react-dom';
import classNames from 'classnames';
import memoize from 'memoize-one';
import {
- ContextAction,
+ type ContextAction,
ContextActions,
createXComponent,
LoadingOverlay,
Tooltip,
} from '@deephaven/components';
-import { LayoutUtils, PanelComponent, PanelEvent } from '@deephaven/dashboard';
+import {
+ LayoutUtils,
+ type PanelComponent,
+ PanelEvent,
+} from '@deephaven/dashboard';
import type {
Container,
EventEmitter,
diff --git a/packages/dashboard-core-plugins/src/panels/PanelContextMenu.tsx b/packages/dashboard-core-plugins/src/panels/PanelContextMenu.tsx
index 46223d207a..11da9d351a 100644
--- a/packages/dashboard-core-plugins/src/panels/PanelContextMenu.tsx
+++ b/packages/dashboard-core-plugins/src/panels/PanelContextMenu.tsx
@@ -1,14 +1,18 @@
-import React, { PureComponent, ReactElement } from 'react';
-import { ContextAction, ContextActions } from '@deephaven/components';
+import React, { PureComponent, type ReactElement } from 'react';
+import { type ContextAction, ContextActions } from '@deephaven/components';
import type { Container, EventEmitter, Tab } from '@deephaven/golden-layout';
import {
- CustomizableWorkspace,
- RootState,
+ type CustomizableWorkspace,
+ type RootState,
getWorkspace,
setWorkspace as setWorkspaceAction,
} from '@deephaven/redux';
import { connect } from 'react-redux';
-import { ClosedPanel, LayoutUtils, PanelEvent } from '@deephaven/dashboard';
+import {
+ type ClosedPanel,
+ LayoutUtils,
+ PanelEvent,
+} from '@deephaven/dashboard';
interface PanelContextMenuProps {
additionalActions: ContextAction[];
diff --git a/packages/dashboard-core-plugins/src/panels/RenameDialog.tsx b/packages/dashboard-core-plugins/src/panels/RenameDialog.tsx
index 79282a99cd..371e0fe76c 100644
--- a/packages/dashboard-core-plugins/src/panels/RenameDialog.tsx
+++ b/packages/dashboard-core-plugins/src/panels/RenameDialog.tsx
@@ -1,9 +1,9 @@
import React, {
- ChangeEvent,
- FormEvent,
+ type ChangeEvent,
+ type FormEvent,
PureComponent,
- ReactElement,
- RefObject,
+ type ReactElement,
+ type RefObject,
} from 'react';
import classNames from 'classnames';
import { Button, Popper } from '@deephaven/components';
diff --git a/packages/dashboard-core-plugins/src/panels/WidgetPanel.tsx b/packages/dashboard-core-plugins/src/panels/WidgetPanel.tsx
index 2418e9d384..1841b5f398 100644
--- a/packages/dashboard-core-plugins/src/panels/WidgetPanel.tsx
+++ b/packages/dashboard-core-plugins/src/panels/WidgetPanel.tsx
@@ -1,17 +1,17 @@
-import React, { PureComponent, ReactElement } from 'react';
+import React, { PureComponent, type ReactElement } from 'react';
import classNames from 'classnames';
import memoize from 'memoize-one';
import {
- ContextAction,
+ type ContextAction,
ContextActions,
createXComponent,
} from '@deephaven/components';
import type { dh } from '@deephaven/jsapi-types';
import { copyToClipboard, EMPTY_ARRAY } from '@deephaven/utils';
-import Panel, { CorePanelProps } from './Panel';
+import Panel, { type CorePanelProps } from './Panel';
import WidgetPanelTooltip from './WidgetPanelTooltip';
import './WidgetPanel.scss';
-import { WidgetPanelDescriptor } from './WidgetPanelTypes';
+import { type WidgetPanelDescriptor } from './WidgetPanelTypes';
export type WidgetPanelProps = CorePanelProps & {
descriptor: WidgetPanelDescriptor;
diff --git a/packages/dashboard-core-plugins/src/panels/WidgetPanelTooltip.tsx b/packages/dashboard-core-plugins/src/panels/WidgetPanelTooltip.tsx
index 1c9896ea93..61344f0448 100644
--- a/packages/dashboard-core-plugins/src/panels/WidgetPanelTooltip.tsx
+++ b/packages/dashboard-core-plugins/src/panels/WidgetPanelTooltip.tsx
@@ -1,7 +1,7 @@
-import React, { ReactElement } from 'react';
+import React, { type ReactElement } from 'react';
import { CopyButton, createXComponent } from '@deephaven/components';
import './WidgetPanelTooltip.scss';
-import { WidgetPanelTooltipProps } from './WidgetPanelTypes';
+import { type WidgetPanelTooltipProps } from './WidgetPanelTypes';
function WidgetPanelTooltip(props: WidgetPanelTooltipProps): ReactElement {
const { children, descriptor } = props;
diff --git a/packages/dashboard-core-plugins/src/panels/WidgetPanelTypes.ts b/packages/dashboard-core-plugins/src/panels/WidgetPanelTypes.ts
index c370d7beb3..4708e8376a 100644
--- a/packages/dashboard-core-plugins/src/panels/WidgetPanelTypes.ts
+++ b/packages/dashboard-core-plugins/src/panels/WidgetPanelTypes.ts
@@ -1,4 +1,4 @@
-import { ReactNode } from 'react';
+import { type ReactNode } from 'react';
export type WidgetPanelDescriptor = {
/** Type of the widget. */
diff --git a/packages/dashboard-core-plugins/src/redux/actions.ts b/packages/dashboard-core-plugins/src/redux/actions.ts
index 701d5472d9..47e00db2e3 100644
--- a/packages/dashboard-core-plugins/src/redux/actions.ts
+++ b/packages/dashboard-core-plugins/src/redux/actions.ts
@@ -1,14 +1,14 @@
import deepEqual from 'fast-deep-equal';
-import { ThunkAction } from 'redux-thunk';
+import { type ThunkAction } from 'redux-thunk';
import { updateDashboardData } from '@deephaven/dashboard';
-import { SessionWrapper } from '@deephaven/jsapi-utils';
-import { RootState } from '@deephaven/redux';
-import { Action } from 'redux';
+import { type SessionWrapper } from '@deephaven/jsapi-utils';
+import { type RootState } from '@deephaven/redux';
+import { type Action } from 'redux';
import type { dh } from '@deephaven/jsapi-types';
import { getLinksForDashboard } from './selectors';
-import { FilterSet } from '../panels';
-import { Link } from '../linker/LinkerUtils';
-import { ColumnSelectionValidator } from '../linker/ColumnSelectionValidator';
+import { type FilterSet } from '../panels';
+import { type Link } from '../linker/LinkerUtils';
+import { type ColumnSelectionValidator } from '../linker/ColumnSelectionValidator';
/**
* Set the connection for the dashboard specified
diff --git a/packages/dashboard-core-plugins/src/redux/selectors.ts b/packages/dashboard-core-plugins/src/redux/selectors.ts
index fef299bc16..f815a41280 100644
--- a/packages/dashboard-core-plugins/src/redux/selectors.ts
+++ b/packages/dashboard-core-plugins/src/redux/selectors.ts
@@ -1,11 +1,11 @@
import { getDashboardData } from '@deephaven/dashboard';
import type { dh } from '@deephaven/jsapi-types';
-import { SessionWrapper } from '@deephaven/jsapi-utils';
-import { RootState } from '@deephaven/redux';
-import { FilterChangeEvent } from '../FilterPlugin';
-import { Link } from '../linker/LinkerUtils';
-import { FilterSet } from '../panels';
-import { ColumnSelectionValidator } from '../linker/ColumnSelectionValidator';
+import { type SessionWrapper } from '@deephaven/jsapi-utils';
+import { type RootState } from '@deephaven/redux';
+import { type FilterChangeEvent } from '../FilterPlugin';
+import { type Link } from '../linker/LinkerUtils';
+import { type FilterSet } from '../panels';
+import { type ColumnSelectionValidator } from '../linker/ColumnSelectionValidator';
const EMPTY_OBJECT = Object.freeze({});
diff --git a/packages/dashboard-core-plugins/src/useIrisGridModel.test.ts b/packages/dashboard-core-plugins/src/useIrisGridModel.test.ts
index 02a6224b6b..6e336ce73e 100644
--- a/packages/dashboard-core-plugins/src/useIrisGridModel.test.ts
+++ b/packages/dashboard-core-plugins/src/useIrisGridModel.test.ts
@@ -1,11 +1,11 @@
-import { IrisGridModel } from '@deephaven/iris-grid';
+import { type IrisGridModel } from '@deephaven/iris-grid';
import { type dh } from '@deephaven/jsapi-types';
import { TestUtils } from '@deephaven/test-utils';
import { renderHook } from '@testing-library/react-hooks';
import { act } from 'react-test-renderer';
import {
- IrisGridModelFetchErrorResult,
- IrisGridModelFetchSuccessResult,
+ type IrisGridModelFetchErrorResult,
+ type IrisGridModelFetchSuccessResult,
useIrisGridModel,
} from './useIrisGridModel';
diff --git a/packages/dashboard/src/Dashboard.test.tsx b/packages/dashboard/src/Dashboard.test.tsx
index 256c20874e..9faf59937c 100644
--- a/packages/dashboard/src/Dashboard.test.tsx
+++ b/packages/dashboard/src/Dashboard.test.tsx
@@ -1,7 +1,7 @@
import React from 'react';
-import { render, RenderResult } from '@testing-library/react';
+import { render, type RenderResult } from '@testing-library/react';
import { ApiContext } from '@deephaven/jsapi-bootstrap';
-import Dashboard, { DashboardProps } from './Dashboard';
+import Dashboard, { type DashboardProps } from './Dashboard';
const mockDispatch = jest.fn();
jest.mock('react-redux', () => ({
diff --git a/packages/dashboard/src/Dashboard.tsx b/packages/dashboard/src/Dashboard.tsx
index 6a285844c7..41b1a768d7 100644
--- a/packages/dashboard/src/Dashboard.tsx
+++ b/packages/dashboard/src/Dashboard.tsx
@@ -1,7 +1,7 @@
import React, {
- ComponentType,
- ForwardRefExoticComponent,
- RefAttributes,
+ type ComponentType,
+ type ForwardRefExoticComponent,
+ type RefAttributes,
useEffect,
useMemo,
useRef,
@@ -16,9 +16,9 @@ import LayoutUtils from './layout/LayoutUtils';
import PanelPlaceholder from './PanelPlaceholder';
import DashboardLayout from './DashboardLayout';
import {
- PanelDehydrateFunction,
- PanelHydrateFunction,
- PanelProps,
+ type PanelDehydrateFunction,
+ type PanelHydrateFunction,
+ type PanelProps,
} from './DashboardPlugin';
import './Dashboard.scss';
import { LayoutManagerContext } from './layout';
diff --git a/packages/dashboard/src/DashboardLayout.tsx b/packages/dashboard/src/DashboardLayout.tsx
index 6410c4efa7..cc2e05b7f7 100644
--- a/packages/dashboard/src/DashboardLayout.tsx
+++ b/packages/dashboard/src/DashboardLayout.tsx
@@ -1,13 +1,13 @@
import React, {
- ComponentType,
- ReactElement,
+ type ComponentType,
+ type ReactElement,
useCallback,
useEffect,
useMemo,
useState,
} from 'react';
import PropTypes from 'prop-types';
-import GoldenLayout from '@deephaven/golden-layout';
+import type GoldenLayout from '@deephaven/golden-layout';
import type {
Container,
ItemConfig,
@@ -16,9 +16,9 @@ import type {
import Log from '@deephaven/log';
import { usePrevious, useThrottledCallback } from '@deephaven/react-hooks';
import { ErrorBoundary } from '@deephaven/components';
-import { RootState } from '@deephaven/redux';
+import { type RootState } from '@deephaven/redux';
import { useDispatch, useSelector } from 'react-redux';
-import PanelManager, { ClosedPanels } from './PanelManager';
+import PanelManager, { type ClosedPanels } from './PanelManager';
import PanelErrorBoundary from './PanelErrorBoundary';
import LayoutUtils from './layout/LayoutUtils';
import {
@@ -30,10 +30,10 @@ import PanelEvent from './PanelEvent';
import { GLPropTypes, useListener } from './layout';
import { getDashboardData, updateDashboardData } from './redux';
import {
- PanelComponentType,
- PanelDehydrateFunction,
- PanelHydrateFunction,
- PanelProps,
+ type PanelComponentType,
+ type PanelDehydrateFunction,
+ type PanelHydrateFunction,
+ type PanelProps,
} from './DashboardPlugin';
import DashboardPanelWrapper from './DashboardPanelWrapper';
diff --git a/packages/dashboard/src/DashboardPanelWrapper.tsx b/packages/dashboard/src/DashboardPanelWrapper.tsx
index ca07c4a336..1b76343103 100644
--- a/packages/dashboard/src/DashboardPanelWrapper.tsx
+++ b/packages/dashboard/src/DashboardPanelWrapper.tsx
@@ -1,4 +1,4 @@
-import React, { PropsWithChildren } from 'react';
+import React, { type PropsWithChildren } from 'react';
export function DashboardPanelWrapper({
children,
diff --git a/packages/dashboard/src/DashboardPlugin.ts b/packages/dashboard/src/DashboardPlugin.ts
index 592c27928b..dfa716cdd3 100644
--- a/packages/dashboard/src/DashboardPlugin.ts
+++ b/packages/dashboard/src/DashboardPlugin.ts
@@ -5,14 +5,14 @@ import type {
PropsWithoutRef,
RefAttributes,
} from 'react';
-import { ConnectedComponent } from 'react-redux';
+import { type ConnectedComponent } from 'react-redux';
import GoldenLayout from '@deephaven/golden-layout';
import type {
GLPanelProps,
ReactComponentConfig,
} from '@deephaven/golden-layout';
import PanelManager from './PanelManager';
-import { WidgetDescriptor } from './PanelEvent';
+import { type WidgetDescriptor } from './PanelEvent';
export { isWrappedComponent } from '@deephaven/components';
diff --git a/packages/dashboard/src/DashboardUtils.tsx b/packages/dashboard/src/DashboardUtils.tsx
index 09d48607d8..320a0fc637 100644
--- a/packages/dashboard/src/DashboardUtils.tsx
+++ b/packages/dashboard/src/DashboardUtils.tsx
@@ -1,7 +1,7 @@
import {
- DehydratedDashboardPanelProps,
- DehydratedPanelConfig,
- PanelConfig,
+ type DehydratedDashboardPanelProps,
+ type DehydratedPanelConfig,
+ type PanelConfig,
} from './DashboardPlugin';
export { canHaveRef } from '@deephaven/components';
diff --git a/packages/dashboard/src/LazyDashboard.tsx b/packages/dashboard/src/LazyDashboard.tsx
index 219731d9d2..510d1ff6e0 100644
--- a/packages/dashboard/src/LazyDashboard.tsx
+++ b/packages/dashboard/src/LazyDashboard.tsx
@@ -2,9 +2,9 @@ import React, { useCallback, useState } from 'react';
import { useDispatch } from 'react-redux';
import { LoadingOverlay } from '@deephaven/components';
import { updateWorkspaceData } from '@deephaven/redux';
-import { Dashboard, DashboardProps } from './Dashboard';
+import { Dashboard, type DashboardProps } from './Dashboard';
import { updateDashboardData } from './redux';
-import { DashboardLayoutConfig } from './DashboardLayout';
+import { type DashboardLayoutConfig } from './DashboardLayout';
import { DEFAULT_DASHBOARD_ID } from './DashboardConstants';
export interface LazyDashboardProps extends DashboardProps {
diff --git a/packages/dashboard/src/PanelErrorBoundary.tsx b/packages/dashboard/src/PanelErrorBoundary.tsx
index de1945b6cd..91f9223c65 100644
--- a/packages/dashboard/src/PanelErrorBoundary.tsx
+++ b/packages/dashboard/src/PanelErrorBoundary.tsx
@@ -1,4 +1,4 @@
-import React, { Component, ReactNode } from 'react';
+import React, { Component, type ReactNode } from 'react';
import { LoadingOverlay } from '@deephaven/components';
import type { Container, EventEmitter } from '@deephaven/golden-layout';
import Log from '@deephaven/log';
diff --git a/packages/dashboard/src/PanelManager.test.ts b/packages/dashboard/src/PanelManager.test.ts
index 0e4079ba76..2ca8e11f25 100644
--- a/packages/dashboard/src/PanelManager.test.ts
+++ b/packages/dashboard/src/PanelManager.test.ts
@@ -9,7 +9,7 @@ import GoldenLayout from '@deephaven/golden-layout';
import type { ContentItem, Tab } from '@deephaven/golden-layout';
import PanelManager from './PanelManager';
import PanelEvent from './PanelEvent';
-import { PanelProps } from './DashboardPlugin';
+import { type PanelProps } from './DashboardPlugin';
type TestComponentProps = { id: string } & PanelProps;
diff --git a/packages/dashboard/src/PanelManager.ts b/packages/dashboard/src/PanelManager.ts
index 9effe1832c..8804736cee 100644
--- a/packages/dashboard/src/PanelManager.ts
+++ b/packages/dashboard/src/PanelManager.ts
@@ -1,5 +1,5 @@
-import { ComponentType } from 'react';
-import GoldenLayout from '@deephaven/golden-layout';
+import { type ComponentType } from 'react';
+import type GoldenLayout from '@deephaven/golden-layout';
import type {
Container,
ContentItem,
@@ -11,9 +11,9 @@ import PanelEvent from './PanelEvent';
import LayoutUtils, { isReactComponentConfig } from './layout/LayoutUtils';
import {
isWrappedComponent,
- PanelComponent,
- PanelComponentType,
- PanelProps,
+ type PanelComponent,
+ type PanelComponentType,
+ type PanelProps,
} from './DashboardPlugin';
const log = Log.module('PanelManager');
diff --git a/packages/dashboard/src/PanelPlaceholder.tsx b/packages/dashboard/src/PanelPlaceholder.tsx
index d0684500aa..f76d879f43 100644
--- a/packages/dashboard/src/PanelPlaceholder.tsx
+++ b/packages/dashboard/src/PanelPlaceholder.tsx
@@ -1,7 +1,7 @@
-import React, { ForwardedRef } from 'react';
+import React, { type ForwardedRef } from 'react';
import './PanelPlaceholder.scss';
import LayoutUtils from './layout/LayoutUtils';
-import { PanelProps } from './DashboardPlugin';
+import { type PanelProps } from './DashboardPlugin';
/**
* Displays a placeholder for unregistered panel types.
diff --git a/packages/dashboard/src/layout/LayoutManagerContext.ts b/packages/dashboard/src/layout/LayoutManagerContext.ts
index b1804dadfb..56363e4a3f 100644
--- a/packages/dashboard/src/layout/LayoutManagerContext.ts
+++ b/packages/dashboard/src/layout/LayoutManagerContext.ts
@@ -1,5 +1,5 @@
import React from 'react';
-import GoldenLayout from '@deephaven/golden-layout';
+import type GoldenLayout from '@deephaven/golden-layout';
export const LayoutManagerContext: React.Context =
React.createContext(undefined);
diff --git a/packages/dashboard/src/layout/LayoutUtils.ts b/packages/dashboard/src/layout/LayoutUtils.ts
index 9cecf91d58..779d41139b 100644
--- a/packages/dashboard/src/layout/LayoutUtils.ts
+++ b/packages/dashboard/src/layout/LayoutUtils.ts
@@ -2,12 +2,12 @@ import deepEqual from 'fast-deep-equal';
import { nanoid } from 'nanoid';
import isMatch from 'lodash.ismatch';
import Log from '@deephaven/log';
-import GoldenLayout, {
+import type GoldenLayout from '@deephaven/golden-layout';
+import {
isComponent,
isRoot,
isStack,
GoldenLayoutThemeExport,
- GLPanelProps,
} from '@deephaven/golden-layout';
import type {
ComponentConfig,
@@ -19,10 +19,11 @@ import type {
Stack,
Tab,
CloseOptions,
+ GLPanelProps,
} from '@deephaven/golden-layout';
import { assertNotNull } from '@deephaven/utils';
-import { DashboardLayoutConfig } from '../DashboardLayout';
-import { PanelConfig } from '../DashboardPlugin';
+import { type DashboardLayoutConfig } from '../DashboardLayout';
+import { type PanelConfig } from '../DashboardPlugin';
const log = Log.module('LayoutUtils');
diff --git a/packages/dashboard/src/layout/useDashboardPanel.ts b/packages/dashboard/src/layout/useDashboardPanel.ts
index 4b01168ac9..cfe107fca4 100644
--- a/packages/dashboard/src/layout/useDashboardPanel.ts
+++ b/packages/dashboard/src/layout/useDashboardPanel.ts
@@ -1,15 +1,15 @@
-import { ComponentType, useCallback } from 'react';
+import { type ComponentType, useCallback } from 'react';
import type { ReactComponentConfig } from '@deephaven/golden-layout';
import { nanoid } from 'nanoid';
import {
- DashboardPanelProps,
- DashboardPluginComponentProps,
- DehydratedDashboardPanelProps,
- PanelComponentType,
- PanelDehydrateFunction,
- PanelHydrateFunction,
+ type DashboardPanelProps,
+ type DashboardPluginComponentProps,
+ type DehydratedDashboardPanelProps,
+ type PanelComponentType,
+ type PanelDehydrateFunction,
+ type PanelHydrateFunction,
} from '../DashboardPlugin';
-import { PanelOpenEventDetail, usePanelOpenListener } from '../PanelEvent';
+import { type PanelOpenEventDetail, usePanelOpenListener } from '../PanelEvent';
import LayoutUtils from './LayoutUtils';
import usePanelRegistration from './usePanelRegistration';
diff --git a/packages/dashboard/src/layout/useLayoutManager.ts b/packages/dashboard/src/layout/useLayoutManager.ts
index 764cc3ee5a..016633871c 100644
--- a/packages/dashboard/src/layout/useLayoutManager.ts
+++ b/packages/dashboard/src/layout/useLayoutManager.ts
@@ -1,5 +1,5 @@
import { useContext } from 'react';
-import LayoutManager from '@deephaven/golden-layout';
+import type LayoutManager from '@deephaven/golden-layout';
import LayoutManagerContext from './LayoutManagerContext';
/**
diff --git a/packages/dashboard/src/layout/useListener.test.ts b/packages/dashboard/src/layout/useListener.test.ts
index 26a1fe1cd6..3529979bf4 100644
--- a/packages/dashboard/src/layout/useListener.test.ts
+++ b/packages/dashboard/src/layout/useListener.test.ts
@@ -1,4 +1,4 @@
-import { EventEmitter } from '@deephaven/golden-layout';
+import { type EventEmitter } from '@deephaven/golden-layout';
import { TestUtils } from '@deephaven/test-utils';
import { renderHook } from '@testing-library/react-hooks';
import useListener from './useListener';
diff --git a/packages/dashboard/src/layout/usePanelRegistration.test.tsx b/packages/dashboard/src/layout/usePanelRegistration.test.tsx
index 8228894a69..51de1b921d 100644
--- a/packages/dashboard/src/layout/usePanelRegistration.test.tsx
+++ b/packages/dashboard/src/layout/usePanelRegistration.test.tsx
@@ -2,7 +2,7 @@
import React from 'react';
import { renderHook } from '@testing-library/react-hooks';
import usePanelRegistration from './usePanelRegistration';
-import { PanelProps } from '../DashboardPlugin';
+import { type PanelProps } from '../DashboardPlugin';
/* eslint-disable react/prefer-stateless-function */
class ClassCOMPONENT extends React.Component {
diff --git a/packages/dashboard/src/layout/usePanelRegistration.ts b/packages/dashboard/src/layout/usePanelRegistration.ts
index 0ef871c11e..1e02dfc794 100644
--- a/packages/dashboard/src/layout/usePanelRegistration.ts
+++ b/packages/dashboard/src/layout/usePanelRegistration.ts
@@ -1,10 +1,10 @@
import React from 'react';
import {
- DashboardPanelProps,
- DashboardPluginComponentProps,
- PanelComponentType,
- PanelDehydrateFunction,
- PanelHydrateFunction,
+ type DashboardPanelProps,
+ type DashboardPluginComponentProps,
+ type PanelComponentType,
+ type PanelDehydrateFunction,
+ type PanelHydrateFunction,
} from '../DashboardPlugin';
/**
diff --git a/packages/dashboard/src/redux/actions.ts b/packages/dashboard/src/redux/actions.ts
index af297b474d..2268390a66 100644
--- a/packages/dashboard/src/redux/actions.ts
+++ b/packages/dashboard/src/redux/actions.ts
@@ -1,4 +1,8 @@
-import { DashboardData, PluginData, RootState } from '@deephaven/redux';
+import {
+ type DashboardData,
+ type PluginData,
+ type RootState,
+} from '@deephaven/redux';
import type { Action } from 'redux';
import type { ThunkAction } from 'redux-thunk';
import { SET_DASHBOARD_DATA } from './actionTypes';
diff --git a/packages/dashboard/src/redux/hooks.ts b/packages/dashboard/src/redux/hooks.ts
index 935f1446e8..e5b0519d91 100644
--- a/packages/dashboard/src/redux/hooks.ts
+++ b/packages/dashboard/src/redux/hooks.ts
@@ -1,6 +1,6 @@
import { useCallback } from 'react';
import { useDispatch, useSelector } from 'react-redux';
-import { PluginData, RootState } from '@deephaven/redux';
+import { type PluginData, type RootState } from '@deephaven/redux';
import { getPluginDataForDashboard } from './selectors';
import { setDashboardPluginData } from './actions';
diff --git a/packages/dashboard/src/redux/selectors.ts b/packages/dashboard/src/redux/selectors.ts
index a57c160873..63b761a80a 100644
--- a/packages/dashboard/src/redux/selectors.ts
+++ b/packages/dashboard/src/redux/selectors.ts
@@ -1,18 +1,18 @@
import {
- AppStore,
- DashboardData,
- PluginData,
- PluginDataMap,
- RootDispatch,
- RootState,
+ type AppStore,
+ type DashboardData,
+ type PluginData,
+ type PluginDataMap,
+ type RootDispatch,
+ type RootState,
} from '@deephaven/redux';
import {
- TypedUseSelectorHook,
+ type TypedUseSelectorHook,
useDispatch,
useSelector,
useStore,
} from 'react-redux';
-import { ClosedPanels, OpenedPanelMap } from '../PanelManager';
+import { type ClosedPanels, type OpenedPanelMap } from '../PanelManager';
const EMPTY_MAP = new Map();
diff --git a/packages/embed-widget/src/App.tsx b/packages/embed-widget/src/App.tsx
index 817289b5cc..ae68053cb1 100644
--- a/packages/embed-widget/src/App.tsx
+++ b/packages/embed-widget/src/App.tsx
@@ -25,7 +25,7 @@ import { useDashboardPlugins } from '@deephaven/plugin';
import {
getAllDashboardsData,
listenForCreateDashboard,
- CreateDashboardPayload,
+ type CreateDashboardPayload,
setDashboardPluginData,
stopListenForCreateDashboard,
emitPanelOpen,
diff --git a/packages/eslint-config/index.js b/packages/eslint-config/index.js
index a9113c3e3f..3eec7b0406 100644
--- a/packages/eslint-config/index.js
+++ b/packages/eslint-config/index.js
@@ -89,23 +89,27 @@ module.exports = {
plugins: ['@typescript-eslint'],
extends: ['plugin:@typescript-eslint/recommended'],
rules: {
- 'default-case': 'off', // Typescript checks for exhaustive switch/case and doesn't require a default
- 'consistent-return': 'off', // JS rule which complains if you don't have a default case
- 'no-shadow': 'off',
+ '@typescript-eslint/consistent-type-imports': [
+ 'error',
+ { fixStyle: 'inline-type-imports' },
+ ],
+ '@typescript-eslint/default-param-last': ['error'],
+ '@typescript-eslint/explicit-module-boundary-types': 'error',
+ '@typescript-eslint/method-signature-style': 'error',
'@typescript-eslint/no-shadow': ['error'],
- 'no-use-before-define': 'off',
'@typescript-eslint/no-use-before-define': 'error',
- 'no-useless-constructor': 'off',
- 'react/static-property-placement': ['error', 'static public field'],
+ '@typescript-eslint/return-await': 'error',
'@typescript-eslint/strict-boolean-expressions': ['error'],
+ 'consistent-return': 'off', // JS rule which complains if you don't have a default case
+ 'default-case': 'off', // Typescript checks for exhaustive switch/case and doesn't require a default
'default-param-last': 'off',
- '@typescript-eslint/default-param-last': ['error'],
- '@typescript-eslint/explicit-module-boundary-types': 'error',
- '@typescript-eslint/method-signature-style': 'error',
// `no-return-await` needs to be disabled when enabling `@typescript-eslint/return-await`
// to avoid incorrectly reporting errors
'no-return-await': 'off',
- '@typescript-eslint/return-await': 'error',
+ 'no-shadow': 'off',
+ 'no-use-before-define': 'off',
+ 'no-useless-constructor': 'off',
+ 'react/static-property-placement': ['error', 'static public field'],
},
},
{
diff --git a/packages/file-explorer/src/FileExistsError.ts b/packages/file-explorer/src/FileExistsError.ts
index 4a481f333d..92593afce9 100644
--- a/packages/file-explorer/src/FileExistsError.ts
+++ b/packages/file-explorer/src/FileExistsError.ts
@@ -1,5 +1,5 @@
import { ValidationError } from '@deephaven/utils';
-import { FileStorageItem } from './FileStorage';
+import { type FileStorageItem } from './FileStorage';
class FileExistsError extends ValidationError {
isExistingFile = true;
diff --git a/packages/file-explorer/src/FileExplorer.test.tsx b/packages/file-explorer/src/FileExplorer.test.tsx
index bbe2e9b31c..0a3867c9cf 100644
--- a/packages/file-explorer/src/FileExplorer.test.tsx
+++ b/packages/file-explorer/src/FileExplorer.test.tsx
@@ -8,11 +8,9 @@ import userEvent from '@testing-library/user-event/';
import { MockFileStorage } from '@deephaven/dashboard-core-plugins';
import { ContextMenuRoot } from '@deephaven/components';
import { TestUtils } from '@deephaven/test-utils';
-import FileStorage, {
- DirectoryStorageItem,
- FileStorageItem,
-} from './FileStorage';
-import FileExplorer, { FileExplorerProps } from './FileExplorer';
+import { type DirectoryStorageItem, type FileStorageItem } from './FileStorage';
+import type FileStorage from './FileStorage';
+import FileExplorer, { type FileExplorerProps } from './FileExplorer';
import { makeDirectories, makeFiles, makeNested } from './FileTestUtils';
function makeMockFileStorage(): FileStorage {
diff --git a/packages/file-explorer/src/FileExplorer.tsx b/packages/file-explorer/src/FileExplorer.tsx
index 57342249ac..f3294d7a26 100644
--- a/packages/file-explorer/src/FileExplorer.tsx
+++ b/packages/file-explorer/src/FileExplorer.tsx
@@ -1,13 +1,14 @@
import { BasicModal } from '@deephaven/components';
import Log from '@deephaven/log';
-import { CancelablePromise, PromiseUtils } from '@deephaven/utils';
+import { type CancelablePromise, PromiseUtils } from '@deephaven/utils';
import React, { useCallback, useEffect, useMemo, useState } from 'react';
import { DEFAULT_ROW_HEIGHT } from './FileListUtils';
-import FileStorage, {
- FileStorageItem,
- FileStorageTable,
+import {
+ type FileStorageItem,
+ type FileStorageTable,
isDirectory,
} from './FileStorage';
+import type FileStorage from './FileStorage';
import './FileExplorer.scss';
import FileListContainer from './FileListContainer';
import FileUtils from './FileUtils';
diff --git a/packages/file-explorer/src/FileList.test.tsx b/packages/file-explorer/src/FileList.test.tsx
index bebcf80342..50dc636692 100644
--- a/packages/file-explorer/src/FileList.test.tsx
+++ b/packages/file-explorer/src/FileList.test.tsx
@@ -5,11 +5,11 @@ import { MockFileStorage } from '@deephaven/dashboard-core-plugins';
import { ContextMenuRoot } from '@deephaven/components';
import { TestUtils } from '@deephaven/test-utils';
import {
- DirectoryStorageItem,
- FileStorageItem,
- FileStorageTable,
+ type DirectoryStorageItem,
+ type FileStorageItem,
+ type FileStorageTable,
} from './FileStorage';
-import FileList, { FileListProps } from './FileList';
+import FileList, { type FileListProps } from './FileList';
import {
makeDirectories,
makeDirectory,
diff --git a/packages/file-explorer/src/FileList.tsx b/packages/file-explorer/src/FileList.tsx
index 908101c891..a96ab569a1 100644
--- a/packages/file-explorer/src/FileList.tsx
+++ b/packages/file-explorer/src/FileList.tsx
@@ -1,4 +1,4 @@
-import { ItemList, Range } from '@deephaven/components';
+import { ItemList, type Range } from '@deephaven/components';
import Log from '@deephaven/log';
import { RangeUtils } from '@deephaven/utils';
import classNames from 'classnames';
@@ -9,10 +9,14 @@ import React, {
useRef,
useState,
} from 'react';
-import { FileStorageItem, FileStorageTable, isDirectory } from './FileStorage';
+import {
+ type FileStorageItem,
+ type FileStorageTable,
+ isDirectory,
+} from './FileStorage';
import './FileList.scss';
import { DEFAULT_ROW_HEIGHT, getMoveOperation } from './FileListUtils';
-import { FileListItem, FileListRenderItemProps } from './FileListItem';
+import { FileListItem, type FileListRenderItemProps } from './FileListItem';
const log = Log.module('FileList');
diff --git a/packages/file-explorer/src/FileListContainer.test.tsx b/packages/file-explorer/src/FileListContainer.test.tsx
index c26af77927..ce84788019 100644
--- a/packages/file-explorer/src/FileListContainer.test.tsx
+++ b/packages/file-explorer/src/FileListContainer.test.tsx
@@ -4,8 +4,10 @@ import userEvent from '@testing-library/user-event';
import { MockFileStorage } from '@deephaven/dashboard-core-plugins';
import { TestUtils } from '@deephaven/test-utils';
import { ContextMenuRoot } from '@deephaven/components';
-import { FileStorageItem, FileStorageTable } from './FileStorage';
-import FileListContainer, { FileListContainerProps } from './FileListContainer';
+import { type FileStorageItem, type FileStorageTable } from './FileStorage';
+import FileListContainer, {
+ type FileListContainerProps,
+} from './FileListContainer';
import { makeFiles } from './FileTestUtils';
const renderFileListContainer = async ({
diff --git a/packages/file-explorer/src/FileListContainer.tsx b/packages/file-explorer/src/FileListContainer.tsx
index fab8338aaa..af6358742a 100644
--- a/packages/file-explorer/src/FileListContainer.tsx
+++ b/packages/file-explorer/src/FileListContainer.tsx
@@ -1,10 +1,14 @@
-import { ContextAction, ContextActions } from '@deephaven/components';
+import { type ContextAction, ContextActions } from '@deephaven/components';
import { assertNotNull } from '@deephaven/utils';
import React, { useCallback, useMemo, useState } from 'react';
import FileList from './FileList';
-import { FileListItem, FileListRenderItemProps } from './FileListItem';
+import { FileListItem, type FileListRenderItemProps } from './FileListItem';
import { DEFAULT_ROW_HEIGHT } from './FileListUtils';
-import { FileStorageItem, FileStorageTable, isDirectory } from './FileStorage';
+import {
+ type FileStorageItem,
+ type FileStorageTable,
+ isDirectory,
+} from './FileStorage';
import SHORTCUTS from './FileExplorerShortcuts';
import './FileExplorer.scss';
import FileUtils from './FileUtils';
diff --git a/packages/file-explorer/src/FileListItem.tsx b/packages/file-explorer/src/FileListItem.tsx
index 71714049fc..6ccf27b251 100644
--- a/packages/file-explorer/src/FileListItem.tsx
+++ b/packages/file-explorer/src/FileListItem.tsx
@@ -1,10 +1,10 @@
import React from 'react';
-import { Tooltip, RenderItemProps } from '@deephaven/components';
+import { Tooltip, type RenderItemProps } from '@deephaven/components';
import { dhPython, vsCode, vsFolder, vsFolderOpened } from '@deephaven/icons';
-import { IconDefinition } from '@fortawesome/fontawesome-svg-core';
+import { type IconDefinition } from '@fortawesome/fontawesome-svg-core';
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
import classNames from 'classnames';
-import { FileStorageItem, isDirectory } from './FileStorage';
+import { type FileStorageItem, isDirectory } from './FileStorage';
import './FileList.scss';
import FileUtils, { MIME_TYPE } from './FileUtils';
import { getPathFromItem } from './FileListUtils';
diff --git a/packages/file-explorer/src/FileListItemEditor.test.tsx b/packages/file-explorer/src/FileListItemEditor.test.tsx
index 072f54579b..45dd80df04 100644
--- a/packages/file-explorer/src/FileListItemEditor.test.tsx
+++ b/packages/file-explorer/src/FileListItemEditor.test.tsx
@@ -3,9 +3,9 @@ import { render, screen, waitFor } from '@testing-library/react';
import userEvent from '@testing-library/user-event';
import {
FileListItemEditor,
- FileListItemEditorProps,
+ type FileListItemEditorProps,
} from './FileListItemEditor';
-import { FileStorageItem } from './FileStorage';
+import { type FileStorageItem } from './FileStorage';
function makeItem(name = 'DEFAULT_NAME'): FileStorageItem {
return {
diff --git a/packages/file-explorer/src/FileListItemEditor.tsx b/packages/file-explorer/src/FileListItemEditor.tsx
index 4f99f5cdbf..e82415f5c8 100644
--- a/packages/file-explorer/src/FileListItemEditor.tsx
+++ b/packages/file-explorer/src/FileListItemEditor.tsx
@@ -1,7 +1,7 @@
import React, {
- ChangeEvent,
- KeyboardEvent,
- MouseEvent,
+ type ChangeEvent,
+ type KeyboardEvent,
+ type MouseEvent,
useCallback,
useEffect,
useRef,
@@ -11,7 +11,7 @@ import classNames from 'classnames';
import Log from '@deephaven/log';
import { PromiseUtils } from '@deephaven/utils';
import './FileListItemEditor.scss';
-import { FileStorageItem } from './FileStorage';
+import { type FileStorageItem } from './FileStorage';
const log = Log.module('FileListItemEditor');
diff --git a/packages/file-explorer/src/FileStorage.ts b/packages/file-explorer/src/FileStorage.ts
index f2370bb877..5c0020300e 100644
--- a/packages/file-explorer/src/FileStorage.ts
+++ b/packages/file-explorer/src/FileStorage.ts
@@ -1,4 +1,4 @@
-import { StorageTable, StorageItem } from '@deephaven/storage';
+import { type StorageTable, type StorageItem } from '@deephaven/storage';
/**
* Basic metadata of the file
diff --git a/packages/file-explorer/src/FileUtils.ts b/packages/file-explorer/src/FileUtils.ts
index 6acaae7f58..5f20a0d03f 100644
--- a/packages/file-explorer/src/FileUtils.ts
+++ b/packages/file-explorer/src/FileUtils.ts
@@ -1,6 +1,6 @@
import { ValidationError } from '@deephaven/utils';
import FileNotFoundError from './FileNotFoundError';
-import { FileStorage } from './FileStorage';
+import { type FileStorage } from './FileStorage';
/**
* A basic list of some common MIME types.
diff --git a/packages/file-explorer/src/NewItemModal.tsx b/packages/file-explorer/src/NewItemModal.tsx
index eb30acaf73..0013c08424 100644
--- a/packages/file-explorer/src/NewItemModal.tsx
+++ b/packages/file-explorer/src/NewItemModal.tsx
@@ -1,4 +1,8 @@
-import React, { ChangeEvent, KeyboardEvent, PureComponent } from 'react';
+import React, {
+ type ChangeEvent,
+ type KeyboardEvent,
+ PureComponent,
+} from 'react';
import PropTypes from 'prop-types';
import classNames from 'classnames';
import {
@@ -10,7 +14,7 @@ import {
Button,
} from '@deephaven/components';
import {
- CancelablePromise,
+ type CancelablePromise,
Pending,
PromiseUtils,
ValidationError,
@@ -19,7 +23,8 @@ import Log from '@deephaven/log';
import { vsHome } from '@deephaven/icons';
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
import FileExplorer from './FileExplorer';
-import FileStorage, { FileStorageItem, FileType } from './FileStorage';
+import { type FileStorageItem, type FileType } from './FileStorage';
+import type FileStorage from './FileStorage';
import FileUtils from './FileUtils';
import './NewItemModal.scss';
diff --git a/packages/filters/src/Utils.ts b/packages/filters/src/Utils.ts
index 16f86b793f..de42864160 100644
--- a/packages/filters/src/Utils.ts
+++ b/packages/filters/src/Utils.ts
@@ -1,4 +1,4 @@
-import { Type, TypeValue } from './Type';
+import { Type, type TypeValue } from './Type';
export function getLabelForTextFilter(filterType: TypeValue): string {
switch (filterType) {
diff --git a/packages/grid/src/CellRenderer.ts b/packages/grid/src/CellRenderer.ts
index 0326a9442d..d29f36a167 100644
--- a/packages/grid/src/CellRenderer.ts
+++ b/packages/grid/src/CellRenderer.ts
@@ -1,10 +1,14 @@
/* eslint-disable class-methods-use-this */
import { getOrThrow } from '@deephaven/utils';
import { isExpandableGridModel } from './ExpandableGridModel';
-import { VisibleIndex, Coordinate, BoxCoordinates } from './GridMetrics';
+import {
+ type VisibleIndex,
+ type Coordinate,
+ type BoxCoordinates,
+} from './GridMetrics';
import GridRenderer from './GridRenderer';
-import { GridRenderState } from './GridRendererTypes';
-import { GridColor } from './GridTheme';
+import { type GridRenderState } from './GridRendererTypes';
+import { type GridColor } from './GridTheme';
import memoizeClear from './memoizeClear';
export type CellRenderType = 'text' | 'dataBar';
diff --git a/packages/grid/src/ColumnHeaderGroup.ts b/packages/grid/src/ColumnHeaderGroup.ts
index 42e94e85d7..7cd6609545 100644
--- a/packages/grid/src/ColumnHeaderGroup.ts
+++ b/packages/grid/src/ColumnHeaderGroup.ts
@@ -1,5 +1,5 @@
-import { MoveOperation } from './GridMetrics';
-import { BoundedAxisRange } from './GridAxisRange';
+import { type MoveOperation } from './GridMetrics';
+import { type BoundedAxisRange } from './GridAxisRange';
export interface IColumnHeaderGroup {
name: string;
diff --git a/packages/grid/src/DataBarCellRenderer.ts b/packages/grid/src/DataBarCellRenderer.ts
index 9b0db224b5..9a9a94b6a8 100644
--- a/packages/grid/src/DataBarCellRenderer.ts
+++ b/packages/grid/src/DataBarCellRenderer.ts
@@ -3,12 +3,16 @@ import { getOrThrow } from '@deephaven/utils';
import CellRenderer from './CellRenderer';
import { isExpandableGridModel } from './ExpandableGridModel';
import { isDataBarGridModel } from './DataBarGridModel';
-import { ModelIndex, VisibleIndex, VisibleToModelMap } from './GridMetrics';
+import {
+ type ModelIndex,
+ type VisibleIndex,
+ type VisibleToModelMap,
+} from './GridMetrics';
import GridColorUtils from './GridColorUtils';
import GridUtils from './GridUtils';
import memoizeClear from './memoizeClear';
-import { DEFAULT_FONT_WIDTH, GridRenderState } from './GridRendererTypes';
-import GridModel from './GridModel';
+import { DEFAULT_FONT_WIDTH, type GridRenderState } from './GridRendererTypes';
+import type GridModel from './GridModel';
interface DataBarRenderMetrics {
/** The total width the entire bar from the min to max value can take up (rightmostPosition - leftmostPosition) */
diff --git a/packages/grid/src/DataBarGridModel.ts b/packages/grid/src/DataBarGridModel.ts
index 0bad337fe7..de6806f42a 100644
--- a/packages/grid/src/DataBarGridModel.ts
+++ b/packages/grid/src/DataBarGridModel.ts
@@ -1,6 +1,6 @@
-import { ModelIndex } from './GridMetrics';
-import GridModel from './GridModel';
-import { GridColor, type GridTheme as GridThemeType } from './GridTheme';
+import { type ModelIndex } from './GridMetrics';
+import type GridModel from './GridModel';
+import { type GridColor, type GridTheme as GridThemeType } from './GridTheme';
export type Marker = { value: number; color: string };
export type AxisOption = 'proportional' | 'middle' | 'directional';
diff --git a/packages/grid/src/DeletableGridModel.ts b/packages/grid/src/DeletableGridModel.ts
index df855a096b..de6fc436b0 100644
--- a/packages/grid/src/DeletableGridModel.ts
+++ b/packages/grid/src/DeletableGridModel.ts
@@ -1,5 +1,5 @@
-import GridRange from './GridRange';
-import GridModel from './GridModel';
+import type GridRange from './GridRange';
+import type GridModel from './GridModel';
import { AssertionError } from './errors';
export function isDeletableGridModel(
diff --git a/packages/grid/src/EditableGridModel.ts b/packages/grid/src/EditableGridModel.ts
index 8840479fdc..d15d2b4845 100644
--- a/packages/grid/src/EditableGridModel.ts
+++ b/packages/grid/src/EditableGridModel.ts
@@ -1,6 +1,6 @@
-import GridRange from './GridRange';
-import { ModelIndex } from './GridMetrics';
-import GridModel from './GridModel';
+import type GridRange from './GridRange';
+import { type ModelIndex } from './GridMetrics';
+import type GridModel from './GridModel';
import { AssertionError } from './errors';
export function isEditableGridModel(
diff --git a/packages/grid/src/ExpandableGridModel.ts b/packages/grid/src/ExpandableGridModel.ts
index 4e8cee6784..14e1177a85 100644
--- a/packages/grid/src/ExpandableGridModel.ts
+++ b/packages/grid/src/ExpandableGridModel.ts
@@ -1,5 +1,5 @@
-import GridModel from './GridModel';
-import { ModelIndex } from './GridMetrics';
+import type GridModel from './GridModel';
+import { type ModelIndex } from './GridMetrics';
export function isExpandableGridModel(
model: GridModel
diff --git a/packages/grid/src/Grid.test.tsx b/packages/grid/src/Grid.test.tsx
index 9324173001..f1b1a76ae0 100644
--- a/packages/grid/src/Grid.test.tsx
+++ b/packages/grid/src/Grid.test.tsx
@@ -1,14 +1,14 @@
-import React, { ReactElement } from 'react';
+import React, { type ReactElement } from 'react';
import TestRenderer from 'react-test-renderer';
import Grid from './Grid';
import GridRange from './GridRange';
import GridRenderer from './GridRenderer';
-import GridTheme, { GridTheme as GridThemeType } from './GridTheme';
+import GridTheme, { type GridTheme as GridThemeType } from './GridTheme';
import GridUtils from './GridUtils';
import MockGridModel from './MockGridModel';
import MockGridData from './MockGridData';
-import { VisibleIndex } from './GridMetrics';
-import GridModel from './GridModel';
+import { type VisibleIndex } from './GridMetrics';
+import type GridModel from './GridModel';
function makeMockContext(): CanvasRenderingContext2D {
// Just return a partial mock
diff --git a/packages/grid/src/Grid.tsx b/packages/grid/src/Grid.tsx
index 74c64f70b4..738d78de99 100644
--- a/packages/grid/src/Grid.tsx
+++ b/packages/grid/src/Grid.tsx
@@ -1,24 +1,34 @@
/* eslint react/no-did-update-set-state: "off" */
import React, {
- CSSProperties,
+ type CSSProperties,
PureComponent,
- ReactNode,
- RefObject,
+ type ReactNode,
+ type RefObject,
} from 'react';
import classNames from 'classnames';
import memoize from 'memoize-one';
import clamp from 'lodash.clamp';
import { assertNotNull, EMPTY_ARRAY, getChangedKeys } from '@deephaven/utils';
-import GridMetricCalculator, { GridMetricState } from './GridMetricCalculator';
-import GridModel from './GridModel';
-import GridMouseHandler, {
- GridMouseEvent,
- GridMouseHandlerFunctionName,
+import GridMetricCalculator, {
+ type GridMetricState,
+} from './GridMetricCalculator';
+import type GridModel from './GridModel';
+import {
+ type GridMouseEvent,
+ type GridMouseHandlerFunctionName,
} from './GridMouseHandler';
-import GridTheme, { GridTheme as GridThemeType } from './GridTheme';
-import GridRange, { GridRangeIndex, SELECTION_DIRECTION } from './GridRange';
+import type GridMouseHandler from './GridMouseHandler';
+import GridTheme, { type GridTheme as GridThemeType } from './GridTheme';
+import GridRange, {
+ type GridRangeIndex,
+ SELECTION_DIRECTION,
+} from './GridRange';
import GridRenderer from './GridRenderer';
-import GridUtils, { GridPoint, isLinkToken, Token } from './GridUtils';
+import GridUtils, {
+ type GridPoint,
+ isLinkToken,
+ type Token,
+} from './GridUtils';
import {
GridSelectionMouseHandler,
GridColumnMoveMouseHandler,
@@ -30,14 +40,15 @@ import {
GridScrollBarCornerMouseHandler,
GridVerticalScrollBarMouseHandler,
EditMouseHandler,
- GridSeparator,
+ type GridSeparator,
GridTokenMouseHandler,
} from './mouse-handlers';
import './Grid.scss';
-import KeyHandler, {
- GridKeyHandlerFunctionName,
- GridKeyboardEvent,
+import {
+ type GridKeyHandlerFunctionName,
+ type GridKeyboardEvent,
} from './KeyHandler';
+import type KeyHandler from './KeyHandler';
import {
EditKeyHandler,
PasteKeyHandler,
@@ -46,26 +57,27 @@ import {
} from './key-handlers';
import CellInputField from './CellInputField';
import PasteError from './errors/PasteError';
-import GridMetrics, {
- Coordinate,
- ModelIndex,
- MoveOperation,
- VisibleIndex,
+import {
+ type Coordinate,
+ type ModelIndex,
+ type MoveOperation,
+ type VisibleIndex,
} from './GridMetrics';
+import type GridMetrics from './GridMetrics';
import { isExpandableGridModel } from './ExpandableGridModel';
import {
assertIsEditableGridModel,
- EditOperation,
+ type EditOperation,
isEditableGridModel,
} from './EditableGridModel';
-import { EventHandlerResultOptions } from './EventHandlerResult';
+import { type EventHandlerResultOptions } from './EventHandlerResult';
import { assertIsDefined } from './errors';
import ThemeContext from './ThemeContext';
-import { DraggingColumn } from './mouse-handlers/GridColumnMoveMouseHandler';
+import { type DraggingColumn } from './mouse-handlers/GridColumnMoveMouseHandler';
import {
- EditingCell,
- GridRenderState,
- EditingCellTextSelectionRange,
+ type EditingCell,
+ type GridRenderState,
+ type EditingCellTextSelectionRange,
} from './GridRendererTypes';
type LegacyCanvasRenderingContext2D = CanvasRenderingContext2D & {
diff --git a/packages/grid/src/GridColorUtils.ts b/packages/grid/src/GridColorUtils.ts
index 88f61c8657..12cecf6866 100644
--- a/packages/grid/src/GridColorUtils.ts
+++ b/packages/grid/src/GridColorUtils.ts
@@ -1,7 +1,7 @@
import convert from 'color-convert';
-import { HEX } from 'color-convert/conversions';
+import { type HEX } from 'color-convert/conversions';
import clamp from 'lodash.clamp';
-import { GridColor } from './GridTheme';
+import { type GridColor } from './GridTheme';
export type RGB = { r: number; g: number; b: number };
export type Oklab = { L: number; a: number; b: number };
diff --git a/packages/grid/src/GridMetricCalculator.ts b/packages/grid/src/GridMetricCalculator.ts
index a67ace195f..90ee7b7ee8 100644
--- a/packages/grid/src/GridMetricCalculator.ts
+++ b/packages/grid/src/GridMetricCalculator.ts
@@ -1,6 +1,6 @@
import clamp from 'lodash.clamp';
import { getOrThrow } from '@deephaven/utils';
-import GridModel from './GridModel';
+import type GridModel from './GridModel';
import type {
GridMetrics,
BoxCoordinates,
@@ -14,9 +14,9 @@ import type {
SizeMap,
} from './GridMetrics';
import GridUtils from './GridUtils';
-import { GridFont, GridTheme } from './GridTheme';
+import { type GridFont, type GridTheme } from './GridTheme';
import { isExpandableGridModel } from './ExpandableGridModel';
-import { DraggingColumn } from './mouse-handlers/GridColumnMoveMouseHandler';
+import { type DraggingColumn } from './mouse-handlers/GridColumnMoveMouseHandler';
export { getOrThrow } from '@deephaven/utils';
/* eslint class-methods-use-this: "off" */
diff --git a/packages/grid/src/GridModel.ts b/packages/grid/src/GridModel.ts
index c52db2e765..1699f02099 100644
--- a/packages/grid/src/GridModel.ts
+++ b/packages/grid/src/GridModel.ts
@@ -1,10 +1,14 @@
-import { EventTarget, Event } from 'event-target-shim';
+import { EventTarget, type Event } from 'event-target-shim';
import type { IColumnHeaderGroup } from './ColumnHeaderGroup';
-import { ModelIndex } from './GridMetrics';
-import { GridColor, GridTheme, NullableGridColor } from './GridTheme';
+import { type ModelIndex } from './GridMetrics';
+import {
+ type GridColor,
+ type GridTheme,
+ type NullableGridColor,
+} from './GridTheme';
import memoizeClear from './memoizeClear';
-import GridUtils, { Token } from './GridUtils';
-import { CellRenderType } from './CellRenderer';
+import GridUtils, { type Token } from './GridUtils';
+import { type CellRenderType } from './CellRenderer';
const LINK_TRUNCATION_LENGTH = 5000;
diff --git a/packages/grid/src/GridMouseHandler.ts b/packages/grid/src/GridMouseHandler.ts
index b81baec0c3..e439c1a632 100644
--- a/packages/grid/src/GridMouseHandler.ts
+++ b/packages/grid/src/GridMouseHandler.ts
@@ -1,8 +1,8 @@
/* eslint class-methods-use-this: "off" */
/* eslint no-unused-vars: "off" */
-import { EventHandlerResult } from './EventHandlerResult';
-import Grid from './Grid';
-import { GridPoint } from './GridUtils';
+import { type EventHandlerResult } from './EventHandlerResult';
+import type Grid from './Grid';
+import { type GridPoint } from './GridUtils';
/**
* Some events we listen to are a native mouse event, and others are wrapped with React's SyntheticEvent.
diff --git a/packages/grid/src/GridRenderer.test.tsx b/packages/grid/src/GridRenderer.test.tsx
index 7828327795..291458d60b 100644
--- a/packages/grid/src/GridRenderer.test.tsx
+++ b/packages/grid/src/GridRenderer.test.tsx
@@ -1,11 +1,11 @@
-import GridMetrics from './GridMetrics';
-import GridModel from './GridModel';
+import type GridMetrics from './GridMetrics';
+import type GridModel from './GridModel';
import GridRenderer from './GridRenderer';
import MockGridModel from './MockGridModel';
import GridTheme from './GridTheme';
-import TextCellRenderer from './TextCellRenderer';
-import { LinkToken } from './GridUtils';
-import { GridRenderState } from './GridRendererTypes';
+import type TextCellRenderer from './TextCellRenderer';
+import { type LinkToken } from './GridUtils';
+import { type GridRenderState } from './GridRendererTypes';
const makeMockContext = (): CanvasRenderingContext2D =>
// Just return a partial mock
diff --git a/packages/grid/src/GridRenderer.ts b/packages/grid/src/GridRenderer.ts
index 429e2e29d1..73892677cd 100644
--- a/packages/grid/src/GridRenderer.ts
+++ b/packages/grid/src/GridRenderer.ts
@@ -4,13 +4,18 @@ import memoizeClear from './memoizeClear';
import GridUtils from './GridUtils';
import GridColorUtils from './GridColorUtils';
import { isExpandableGridModel } from './ExpandableGridModel';
-import { GridColor, GridColorWay, NullableGridColor } from './GridTheme';
-import { Coordinate, VisibleIndex } from './GridMetrics';
+import {
+ type GridColor,
+ type GridColorWay,
+ type NullableGridColor,
+} from './GridTheme';
+import { type Coordinate, type VisibleIndex } from './GridMetrics';
import { isEditableGridModel } from './EditableGridModel';
import GridColumnSeparatorMouseHandler from './mouse-handlers/GridColumnSeparatorMouseHandler';
-import { BoundedAxisRange } from './GridAxisRange';
-import { DEFAULT_FONT_WIDTH, GridRenderState } from './GridRendererTypes';
-import CellRenderer, { CellRenderType } from './CellRenderer';
+import { type BoundedAxisRange } from './GridAxisRange';
+import { DEFAULT_FONT_WIDTH, type GridRenderState } from './GridRendererTypes';
+import { type CellRenderType } from './CellRenderer';
+import type CellRenderer from './CellRenderer';
import DataBarCellRenderer from './DataBarCellRenderer';
import TextCellRenderer from './TextCellRenderer';
diff --git a/packages/grid/src/GridRendererTypes.ts b/packages/grid/src/GridRendererTypes.ts
index fecf47c366..6ef99e438f 100644
--- a/packages/grid/src/GridRendererTypes.ts
+++ b/packages/grid/src/GridRendererTypes.ts
@@ -1,9 +1,10 @@
-import GridMetrics, { VisibleIndex, Coordinate } from './GridMetrics';
-import GridModel from './GridModel';
-import GridRange from './GridRange';
-import { GridTheme } from './GridTheme';
-import { DraggingColumn } from './mouse-handlers/GridColumnMoveMouseHandler';
-import { GridSeparator } from './mouse-handlers/GridSeparatorMouseHandler';
+import { type VisibleIndex, type Coordinate } from './GridMetrics';
+import type GridMetrics from './GridMetrics';
+import type GridModel from './GridModel';
+import type GridRange from './GridRange';
+import { type GridTheme } from './GridTheme';
+import { type DraggingColumn } from './mouse-handlers/GridColumnMoveMouseHandler';
+import { type GridSeparator } from './mouse-handlers/GridSeparatorMouseHandler';
// Default font width in pixels if it cannot be retrieved from the context
export const DEFAULT_FONT_WIDTH = 10;
diff --git a/packages/grid/src/GridUtils.test.ts b/packages/grid/src/GridUtils.test.ts
index 2fb2dd46db..458a51d950 100644
--- a/packages/grid/src/GridUtils.test.ts
+++ b/packages/grid/src/GridUtils.test.ts
@@ -1,7 +1,8 @@
-import { AxisRange } from './GridAxisRange';
-import GridMetrics, { ModelIndex, MoveOperation } from './GridMetrics';
-import GridRange, { GridRangeIndex } from './GridRange';
-import GridUtils, { Token, TokenBox } from './GridUtils';
+import { type AxisRange } from './GridAxisRange';
+import { type ModelIndex, type MoveOperation } from './GridMetrics';
+import type GridMetrics from './GridMetrics';
+import GridRange, { type GridRangeIndex } from './GridRange';
+import GridUtils, { type Token, type TokenBox } from './GridUtils';
import type { BoundedAxisRange } from './GridAxisRange';
function expectModelIndexes(
diff --git a/packages/grid/src/GridUtils.ts b/packages/grid/src/GridUtils.ts
index 47511a31b5..83eb9e1c26 100644
--- a/packages/grid/src/GridUtils.ts
+++ b/packages/grid/src/GridUtils.ts
@@ -1,30 +1,30 @@
-import React from 'react';
+import type React from 'react';
import clamp from 'lodash.clamp';
import { find as linkifyFind } from 'linkifyjs';
import { EMPTY_ARRAY, getOrThrow } from '@deephaven/utils';
-import GridRange, { GridRangeIndex } from './GridRange';
+import GridRange, { type GridRangeIndex } from './GridRange';
import {
- BoxCoordinates,
- Coordinate,
- CoordinateMap,
- VisibleIndex,
- VisibleToModelMap,
- ModelIndex,
- ModelSizeMap,
- MoveOperation,
- SizeMap,
+ type BoxCoordinates,
+ type Coordinate,
+ type CoordinateMap,
+ type VisibleIndex,
+ type VisibleToModelMap,
+ type ModelIndex,
+ type ModelSizeMap,
+ type MoveOperation,
+ type SizeMap,
} from './GridMetrics';
import type { GridMetrics } from './GridMetrics';
-import { GridTheme } from './GridTheme';
-import { GridWheelEvent } from './GridMouseHandler';
+import { type GridTheme } from './GridTheme';
+import { type GridWheelEvent } from './GridMouseHandler';
import {
- AxisRange,
- BoundedAxisRange,
+ type AxisRange,
+ type BoundedAxisRange,
isBoundedAxisRange,
- Range,
+ type Range,
} from './GridAxisRange';
import { isExpandableGridModel } from './ExpandableGridModel';
-import { GridRenderState } from './GridRendererTypes';
+import { type GridRenderState } from './GridRendererTypes';
export type GridPoint = {
x: Coordinate;
diff --git a/packages/grid/src/KeyHandler.ts b/packages/grid/src/KeyHandler.ts
index 776b533383..e0c377552c 100644
--- a/packages/grid/src/KeyHandler.ts
+++ b/packages/grid/src/KeyHandler.ts
@@ -5,8 +5,8 @@
* Return true from any of the events to indicate they're consumed, and stopPropagation/preventDefault will be called.
*/
-import React from 'react';
-import { EventHandlerResult } from './EventHandlerResult';
+import type React from 'react';
+import { type EventHandlerResult } from './EventHandlerResult';
import type Grid from './Grid';
/**
diff --git a/packages/grid/src/MockDataBarGridModel.ts b/packages/grid/src/MockDataBarGridModel.ts
index 55fae2e54d..923f7729d5 100644
--- a/packages/grid/src/MockDataBarGridModel.ts
+++ b/packages/grid/src/MockDataBarGridModel.ts
@@ -1,21 +1,21 @@
/* eslint-disable class-methods-use-this */
import { getOrThrow } from '@deephaven/utils';
-import { CellRenderType } from './CellRenderer';
+import { type CellRenderType } from './CellRenderer';
import {
- AxisOption,
- ColorMap,
- ColumnAxisMap,
- DataBarGridModel,
- DataBarOptions,
- DirectionMap,
- MarkerMap,
- MaxMap,
- MinMap,
- OpacityMap,
- TextAlignmentMap,
- ValuePlacementMap,
+ type AxisOption,
+ type ColorMap,
+ type ColumnAxisMap,
+ type DataBarGridModel,
+ type DataBarOptions,
+ type DirectionMap,
+ type MarkerMap,
+ type MaxMap,
+ type MinMap,
+ type OpacityMap,
+ type TextAlignmentMap,
+ type ValuePlacementMap,
} from './DataBarGridModel';
-import { ModelIndex } from './GridMetrics';
+import { type ModelIndex } from './GridMetrics';
import GridModel from './GridModel';
import GridTheme from './GridTheme';
diff --git a/packages/grid/src/MockGridModel.test.ts b/packages/grid/src/MockGridModel.test.ts
index 7d28c78c7b..e4ed53b6f8 100644
--- a/packages/grid/src/MockGridModel.test.ts
+++ b/packages/grid/src/MockGridModel.test.ts
@@ -1,4 +1,4 @@
-import { LinkToken } from './GridUtils';
+import { type LinkToken } from './GridUtils';
import MockGridModel from './MockGridModel';
describe('tokensForCell', () => {
diff --git a/packages/grid/src/MockGridModel.ts b/packages/grid/src/MockGridModel.ts
index afaab6e700..715294102a 100644
--- a/packages/grid/src/MockGridModel.ts
+++ b/packages/grid/src/MockGridModel.ts
@@ -1,10 +1,11 @@
/* eslint class-methods-use-this: "off" */
/* eslint no-unused-vars: "off" */
-import EditableGridModel, { EditOperation } from './EditableGridModel';
-import { ModelIndex } from './GridMetrics';
+import { type EditOperation } from './EditableGridModel';
+import type EditableGridModel from './EditableGridModel';
+import { type ModelIndex } from './GridMetrics';
import GridModel from './GridModel';
import GridRange from './GridRange';
-import { GridColor, GridTheme } from './GridTheme';
+import { type GridColor, type GridTheme } from './GridTheme';
/**
* Mock model implementing GridModel for testing out grid functionality
diff --git a/packages/grid/src/MockTreeGridModel.ts b/packages/grid/src/MockTreeGridModel.ts
index cda9fc86de..58cdf0925f 100644
--- a/packages/grid/src/MockTreeGridModel.ts
+++ b/packages/grid/src/MockTreeGridModel.ts
@@ -2,8 +2,8 @@
/* eslint no-unused-vars: "off" */
import MockGridModel from './MockGridModel';
import memoizeClear from './memoizeClear';
-import ExpandableGridModel from './ExpandableGridModel';
-import { ModelIndex } from './GridMetrics';
+import type ExpandableGridModel from './ExpandableGridModel';
+import { type ModelIndex } from './GridMetrics';
type ChildrenTreeMap = Map;
diff --git a/packages/grid/src/TextCellRenderer.ts b/packages/grid/src/TextCellRenderer.ts
index ac7515f1cc..e32a830884 100644
--- a/packages/grid/src/TextCellRenderer.ts
+++ b/packages/grid/src/TextCellRenderer.ts
@@ -2,11 +2,11 @@
import { EMPTY_ARRAY, getOrThrow } from '@deephaven/utils';
import CellRenderer from './CellRenderer';
import { isExpandableGridModel } from './ExpandableGridModel';
-import { VisibleIndex } from './GridMetrics';
-import { DEFAULT_FONT_WIDTH, GridRenderState } from './GridRendererTypes';
-import GridUtils, { TokenBox, Token } from './GridUtils';
+import { type VisibleIndex } from './GridMetrics';
+import { DEFAULT_FONT_WIDTH, type GridRenderState } from './GridRendererTypes';
+import GridUtils, { type TokenBox, type Token } from './GridUtils';
import memoizeClear from './memoizeClear';
-import TokenBoxCellRenderer from './TokenBoxCellRenderer';
+import type TokenBoxCellRenderer from './TokenBoxCellRenderer';
class TextCellRenderer extends CellRenderer implements TokenBoxCellRenderer {
drawCellContent(
diff --git a/packages/grid/src/ThemeContext.ts b/packages/grid/src/ThemeContext.ts
index 4b89a746d9..0d3c55bf9e 100644
--- a/packages/grid/src/ThemeContext.ts
+++ b/packages/grid/src/ThemeContext.ts
@@ -1,5 +1,5 @@
import React from 'react';
-import { GridTheme as GridThemeType } from './GridTheme';
+import { type GridTheme as GridThemeType } from './GridTheme';
export type ThemeContextValue = Partial;
diff --git a/packages/grid/src/TokenBoxCellRenderer.ts b/packages/grid/src/TokenBoxCellRenderer.ts
index 8bbb5bde16..edbb113d58 100644
--- a/packages/grid/src/TokenBoxCellRenderer.ts
+++ b/packages/grid/src/TokenBoxCellRenderer.ts
@@ -1,7 +1,7 @@
-import CellRenderer from './CellRenderer';
-import { VisibleIndex } from './GridMetrics';
-import { GridRenderState } from './GridRendererTypes';
-import { TokenBox } from './GridUtils';
+import type CellRenderer from './CellRenderer';
+import { type VisibleIndex } from './GridMetrics';
+import { type GridRenderState } from './GridRendererTypes';
+import { type TokenBox } from './GridUtils';
export function isTokenBoxCellRenderer(
cellRenderer: CellRenderer
diff --git a/packages/grid/src/key-handlers/EditKeyHandler.ts b/packages/grid/src/key-handlers/EditKeyHandler.ts
index 3b8a270253..3ad20b7075 100644
--- a/packages/grid/src/key-handlers/EditKeyHandler.ts
+++ b/packages/grid/src/key-handlers/EditKeyHandler.ts
@@ -1,10 +1,10 @@
/* eslint class-methods-use-this: "off" */
import GridUtils from '../GridUtils';
-import Grid from '../Grid';
+import type Grid from '../Grid';
import GridRange from '../GridRange';
-import KeyHandler, { GridKeyboardEvent } from '../KeyHandler';
+import KeyHandler, { type GridKeyboardEvent } from '../KeyHandler';
import { isEditableGridModel } from '../EditableGridModel';
-import { EventHandlerResult } from '../EventHandlerResult';
+import { type EventHandlerResult } from '../EventHandlerResult';
class EditKeyHandler extends KeyHandler {
onDown(event: GridKeyboardEvent, grid: Grid): EventHandlerResult {
diff --git a/packages/grid/src/key-handlers/PasteKeyHandler.ts b/packages/grid/src/key-handlers/PasteKeyHandler.ts
index 68b8528f86..d8a1f281f4 100644
--- a/packages/grid/src/key-handlers/PasteKeyHandler.ts
+++ b/packages/grid/src/key-handlers/PasteKeyHandler.ts
@@ -1,8 +1,8 @@
/* eslint class-methods-use-this: "off" */
-import { EventHandlerResult } from '../EventHandlerResult';
-import Grid from '../Grid';
+import { type EventHandlerResult } from '../EventHandlerResult';
+import type Grid from '../Grid';
import GridUtils from '../GridUtils';
-import KeyHandler, { GridKeyboardEvent } from '../KeyHandler';
+import KeyHandler, { type GridKeyboardEvent } from '../KeyHandler';
/**
* Parse out data from an HTML table. Currently does not support colspan/rowspan
diff --git a/packages/grid/src/key-handlers/SelectionKeyHandler.ts b/packages/grid/src/key-handlers/SelectionKeyHandler.ts
index 20ae726f13..024d9134c1 100644
--- a/packages/grid/src/key-handlers/SelectionKeyHandler.ts
+++ b/packages/grid/src/key-handlers/SelectionKeyHandler.ts
@@ -1,10 +1,10 @@
/* eslint class-methods-use-this: "off" */
import clamp from 'lodash.clamp';
-import { EventHandlerResult } from '../EventHandlerResult';
-import Grid from '../Grid';
+import { type EventHandlerResult } from '../EventHandlerResult';
+import type Grid from '../Grid';
import GridRange from '../GridRange';
import GridUtils from '../GridUtils';
-import KeyHandler, { GridKeyboardEvent } from '../KeyHandler';
+import KeyHandler, { type GridKeyboardEvent } from '../KeyHandler';
class SelectionKeyHandler extends KeyHandler {
onDown(event: GridKeyboardEvent, grid: Grid): EventHandlerResult {
diff --git a/packages/grid/src/key-handlers/TreeKeyHandler.ts b/packages/grid/src/key-handlers/TreeKeyHandler.ts
index 8b2f39c1a1..7eff227138 100644
--- a/packages/grid/src/key-handlers/TreeKeyHandler.ts
+++ b/packages/grid/src/key-handlers/TreeKeyHandler.ts
@@ -1,7 +1,7 @@
/* eslint class-methods-use-this: "off" */
import { isExpandableGridModel } from '../ExpandableGridModel';
-import Grid from '../Grid';
-import GridRange from '../GridRange';
+import type Grid from '../Grid';
+import type GridRange from '../GridRange';
import KeyHandler from '../KeyHandler';
class TreeKeyHandler extends KeyHandler {
diff --git a/packages/grid/src/mouse-handlers/EditMouseHandler.ts b/packages/grid/src/mouse-handlers/EditMouseHandler.ts
index dd3dbc81a8..a1ae10f5c7 100644
--- a/packages/grid/src/mouse-handlers/EditMouseHandler.ts
+++ b/packages/grid/src/mouse-handlers/EditMouseHandler.ts
@@ -1,10 +1,10 @@
/* eslint class-methods-use-this: "off" */
import { isEditableGridModel } from '../EditableGridModel';
-import { EventHandlerResult } from '../EventHandlerResult';
-import Grid from '../Grid';
+import { type EventHandlerResult } from '../EventHandlerResult';
+import type Grid from '../Grid';
import GridMouseHandler from '../GridMouseHandler';
import GridRange from '../GridRange';
-import { GridPoint } from '../GridUtils';
+import { type GridPoint } from '../GridUtils';
/**
* Handles clicking on a cell to edit it in an editable grid
diff --git a/packages/grid/src/mouse-handlers/GridColumnMoveMouseHandler.ts b/packages/grid/src/mouse-handlers/GridColumnMoveMouseHandler.ts
index b65f8362bb..c728e8f34a 100644
--- a/packages/grid/src/mouse-handlers/GridColumnMoveMouseHandler.ts
+++ b/packages/grid/src/mouse-handlers/GridColumnMoveMouseHandler.ts
@@ -1,9 +1,9 @@
import clamp from 'lodash.clamp';
import { assertNotNull } from '@deephaven/utils';
-import Grid from '../Grid';
-import GridUtils, { GridPoint } from '../GridUtils';
-import GridMouseHandler, { GridMouseEvent } from '../GridMouseHandler';
-import { EventHandlerResult } from '../EventHandlerResult';
+import type Grid from '../Grid';
+import GridUtils, { type GridPoint } from '../GridUtils';
+import GridMouseHandler, { type GridMouseEvent } from '../GridMouseHandler';
+import { type EventHandlerResult } from '../EventHandlerResult';
import type {
VisibleIndex,
ModelIndex,
diff --git a/packages/grid/src/mouse-handlers/GridColumnSeparatorMouseHandler.ts b/packages/grid/src/mouse-handlers/GridColumnSeparatorMouseHandler.ts
index 83b52eed29..a401ec45d5 100644
--- a/packages/grid/src/mouse-handlers/GridColumnSeparatorMouseHandler.ts
+++ b/packages/grid/src/mouse-handlers/GridColumnSeparatorMouseHandler.ts
@@ -1,12 +1,12 @@
/* eslint class-methods-use-this: "off" */
-import Grid from '../Grid';
-import GridMetricCalculator from '../GridMetricCalculator';
+import type Grid from '../Grid';
+import type GridMetricCalculator from '../GridMetricCalculator';
import type { ModelIndex, GridMetrics } from '../GridMetrics';
import type GridModel from '../GridModel';
import type { GridTheme } from '../GridTheme';
-import GridUtils, { GridPoint } from '../GridUtils';
+import GridUtils, { type GridPoint } from '../GridUtils';
import GridSeparatorMouseHandler, {
- GridSeparator,
+ type GridSeparator,
} from './GridSeparatorMouseHandler';
class GridColumnSeparatorMouseHandler extends GridSeparatorMouseHandler {
diff --git a/packages/grid/src/mouse-handlers/GridHorizontalScrollBarMouseHandler.ts b/packages/grid/src/mouse-handlers/GridHorizontalScrollBarMouseHandler.ts
index 3403fba188..741aa585ec 100644
--- a/packages/grid/src/mouse-handlers/GridHorizontalScrollBarMouseHandler.ts
+++ b/packages/grid/src/mouse-handlers/GridHorizontalScrollBarMouseHandler.ts
@@ -1,9 +1,9 @@
import clamp from 'lodash.clamp';
-import { EventHandlerResult } from '../EventHandlerResult';
-import Grid from '../Grid';
-import { VisibleIndex } from '../GridMetrics';
+import { type EventHandlerResult } from '../EventHandlerResult';
+import type Grid from '../Grid';
+import { type VisibleIndex } from '../GridMetrics';
import GridMouseHandler from '../GridMouseHandler';
-import { GridPoint } from '../GridUtils';
+import { type GridPoint } from '../GridUtils';
/* eslint class-methods-use-this: "off" */
class GridHorizontalScrollBarMouseHandler extends GridMouseHandler {
diff --git a/packages/grid/src/mouse-handlers/GridRowMoveMouseHandler.ts b/packages/grid/src/mouse-handlers/GridRowMoveMouseHandler.ts
index c892a80736..27b94a468b 100644
--- a/packages/grid/src/mouse-handlers/GridRowMoveMouseHandler.ts
+++ b/packages/grid/src/mouse-handlers/GridRowMoveMouseHandler.ts
@@ -1,8 +1,8 @@
import { getOrThrow } from '@deephaven/utils';
-import { EventHandlerResult } from '../EventHandlerResult';
-import Grid from '../Grid';
+import { type EventHandlerResult } from '../EventHandlerResult';
+import type Grid from '../Grid';
import GridMouseHandler from '../GridMouseHandler';
-import GridUtils, { GridPoint } from '../GridUtils';
+import GridUtils, { type GridPoint } from '../GridUtils';
class GridRowMoveMouseHandler extends GridMouseHandler {
cursor = 'move';
diff --git a/packages/grid/src/mouse-handlers/GridRowSeparatorMouseHandler.ts b/packages/grid/src/mouse-handlers/GridRowSeparatorMouseHandler.ts
index ddac0b680c..1215047a25 100644
--- a/packages/grid/src/mouse-handlers/GridRowSeparatorMouseHandler.ts
+++ b/packages/grid/src/mouse-handlers/GridRowSeparatorMouseHandler.ts
@@ -1,12 +1,12 @@
/* eslint class-methods-use-this: "off" */
-import Grid from '../Grid';
-import GridMetricCalculator from '../GridMetricCalculator';
+import type Grid from '../Grid';
+import type GridMetricCalculator from '../GridMetricCalculator';
import type { ModelIndex, GridMetrics } from '../GridMetrics';
import type GridModel from '../GridModel';
-import { GridTheme } from '../GridTheme';
-import GridUtils, { GridPoint } from '../GridUtils';
+import { type GridTheme } from '../GridTheme';
+import GridUtils, { type GridPoint } from '../GridUtils';
import GridSeparatorMouseHandler, {
- GridSeparator,
+ type GridSeparator,
} from './GridSeparatorMouseHandler';
class GridRowSeparatorMouseHandler extends GridSeparatorMouseHandler {
diff --git a/packages/grid/src/mouse-handlers/GridRowTreeMouseHandler.ts b/packages/grid/src/mouse-handlers/GridRowTreeMouseHandler.ts
index 9b0a4dd364..3c14466b13 100644
--- a/packages/grid/src/mouse-handlers/GridRowTreeMouseHandler.ts
+++ b/packages/grid/src/mouse-handlers/GridRowTreeMouseHandler.ts
@@ -1,9 +1,9 @@
/* eslint class-methods-use-this: "off" */
import { getOrThrow } from '@deephaven/utils';
-import { EventHandlerResult } from '../EventHandlerResult';
-import Grid from '../Grid';
+import { type EventHandlerResult } from '../EventHandlerResult';
+import type Grid from '../Grid';
import GridMouseHandler from '../GridMouseHandler';
-import GridUtils, { GridPoint } from '../GridUtils';
+import GridUtils, { type GridPoint } from '../GridUtils';
/**
* Detect when the tree expand/collapse button is clicked
diff --git a/packages/grid/src/mouse-handlers/GridScrollBarCornerMouseHandler.ts b/packages/grid/src/mouse-handlers/GridScrollBarCornerMouseHandler.ts
index c2f4463ebb..ccabe8bef4 100644
--- a/packages/grid/src/mouse-handlers/GridScrollBarCornerMouseHandler.ts
+++ b/packages/grid/src/mouse-handlers/GridScrollBarCornerMouseHandler.ts
@@ -1,8 +1,8 @@
/* eslint class-methods-use-this: "off" */
-import { EventHandlerResult } from '../EventHandlerResult';
-import Grid from '../Grid';
+import { type EventHandlerResult } from '../EventHandlerResult';
+import type Grid from '../Grid';
import GridMouseHandler from '../GridMouseHandler';
-import { GridPoint } from '../GridUtils';
+import { type GridPoint } from '../GridUtils';
/**
* Used to eat the mouse event in the bottom right corner of the scroll bar
diff --git a/packages/grid/src/mouse-handlers/GridSelectionMouseHandler.ts b/packages/grid/src/mouse-handlers/GridSelectionMouseHandler.ts
index 1a5ce5f4b8..f6d1ea4047 100644
--- a/packages/grid/src/mouse-handlers/GridSelectionMouseHandler.ts
+++ b/packages/grid/src/mouse-handlers/GridSelectionMouseHandler.ts
@@ -1,8 +1,8 @@
-import { EventHandlerResult } from '../EventHandlerResult';
-import Grid from '../Grid';
-import GridMouseHandler, { GridMouseEvent } from '../GridMouseHandler';
+import { type EventHandlerResult } from '../EventHandlerResult';
+import type Grid from '../Grid';
+import GridMouseHandler, { type GridMouseEvent } from '../GridMouseHandler';
import GridRange from '../GridRange';
-import GridUtils, { GridPoint } from '../GridUtils';
+import GridUtils, { type GridPoint } from '../GridUtils';
const DEFAULT_INTERVAL_MS = 100;
diff --git a/packages/grid/src/mouse-handlers/GridSeparatorMouseHandler.ts b/packages/grid/src/mouse-handlers/GridSeparatorMouseHandler.ts
index e9321b7051..d27e0b03ff 100644
--- a/packages/grid/src/mouse-handlers/GridSeparatorMouseHandler.ts
+++ b/packages/grid/src/mouse-handlers/GridSeparatorMouseHandler.ts
@@ -2,8 +2,9 @@ import { getOrThrow } from '@deephaven/utils';
import type Grid from '../Grid';
import type { GridMetricCalculator } from '../GridMetricCalculator';
import type GridModel from '../GridModel';
-import { EventHandlerResult } from '../EventHandlerResult';
-import GridMetrics, { ModelIndex, VisibleIndex } from '../GridMetrics';
+import { type EventHandlerResult } from '../EventHandlerResult';
+import { type ModelIndex, type VisibleIndex } from '../GridMetrics';
+import type GridMetrics from '../GridMetrics';
import GridMouseHandler from '../GridMouseHandler';
import type { GridTheme } from '../GridTheme';
import type { GridPoint } from '../GridUtils';
diff --git a/packages/grid/src/mouse-handlers/GridTokenMouseHandler.ts b/packages/grid/src/mouse-handlers/GridTokenMouseHandler.ts
index 648aa5aee4..08612bcf6d 100644
--- a/packages/grid/src/mouse-handlers/GridTokenMouseHandler.ts
+++ b/packages/grid/src/mouse-handlers/GridTokenMouseHandler.ts
@@ -2,11 +2,15 @@
import { getOrThrow } from '@deephaven/utils';
import { isEditableGridModel } from '../EditableGridModel';
-import { EventHandlerResult } from '../EventHandlerResult';
-import Grid from '../Grid';
-import GridMouseHandler, { GridMouseEvent } from '../GridMouseHandler';
+import { type EventHandlerResult } from '../EventHandlerResult';
+import type Grid from '../Grid';
+import GridMouseHandler, { type GridMouseEvent } from '../GridMouseHandler';
import GridRange from '../GridRange';
-import GridUtils, { GridPoint, isLinkToken, TokenBox } from '../GridUtils';
+import GridUtils, {
+ type GridPoint,
+ isLinkToken,
+ type TokenBox,
+} from '../GridUtils';
import { isTokenBoxCellRenderer } from '../TokenBoxCellRenderer';
class GridTokenMouseHandler extends GridMouseHandler {
diff --git a/packages/grid/src/mouse-handlers/GridVerticalScrollBarMouseHandler.ts b/packages/grid/src/mouse-handlers/GridVerticalScrollBarMouseHandler.ts
index bc044cc625..43df4dff2a 100644
--- a/packages/grid/src/mouse-handlers/GridVerticalScrollBarMouseHandler.ts
+++ b/packages/grid/src/mouse-handlers/GridVerticalScrollBarMouseHandler.ts
@@ -1,9 +1,9 @@
import clamp from 'lodash.clamp';
-import { EventHandlerResult } from '../EventHandlerResult';
-import Grid from '../Grid';
-import { VisibleIndex } from '../GridMetrics';
+import { type EventHandlerResult } from '../EventHandlerResult';
+import type Grid from '../Grid';
+import { type VisibleIndex } from '../GridMetrics';
import GridMouseHandler from '../GridMouseHandler';
-import { GridPoint } from '../GridUtils';
+import { type GridPoint } from '../GridUtils';
/* eslint class-methods-use-this: "off" */
class GridVerticalScrollBarMouseHandler extends GridMouseHandler {
diff --git a/packages/iris-grid/src/AdvancedFilterCreator.test.tsx b/packages/iris-grid/src/AdvancedFilterCreator.test.tsx
index 0b5f21004e..1de9d91750 100644
--- a/packages/iris-grid/src/AdvancedFilterCreator.test.tsx
+++ b/packages/iris-grid/src/AdvancedFilterCreator.test.tsx
@@ -9,9 +9,9 @@ import dh from '@deephaven/jsapi-shim';
// Operator as FilterOperator,
// } from '@deephaven/filters';
import AdvancedFilterCreator from './AdvancedFilterCreator';
-import { AdvancedFilterOptions } from './CommonTypes';
+import { type AdvancedFilterOptions } from './CommonTypes';
import IrisGridTestUtils from './IrisGridTestUtils';
-import IrisGridModel from './IrisGridModel';
+import type IrisGridModel from './IrisGridModel';
const irisGridTestUtils = new IrisGridTestUtils(dh);
diff --git a/packages/iris-grid/src/AdvancedFilterCreator.tsx b/packages/iris-grid/src/AdvancedFilterCreator.tsx
index 3747c05011..fd30b2da69 100644
--- a/packages/iris-grid/src/AdvancedFilterCreator.tsx
+++ b/packages/iris-grid/src/AdvancedFilterCreator.tsx
@@ -7,22 +7,22 @@ import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
import memoize from 'memoize-one';
import {
Operator as FilterOperator,
- OperatorValue as FilterOperatorValue,
- TypeValue as FilterTypeValue,
+ type OperatorValue as FilterOperatorValue,
+ type TypeValue as FilterTypeValue,
assertOperatorValue as assertFilterOperatorValue,
} from '@deephaven/filters';
import { dhSortAmountDown, dhNewCircleLargeFilled } from '@deephaven/icons';
import {
- Formatter,
+ type Formatter,
TableUtils,
- SortDirection,
- FilterItem,
+ type SortDirection,
+ type FilterItem,
} from '@deephaven/jsapi-utils';
import { Button, ContextActionUtils } from '@deephaven/components';
import Log from '@deephaven/log';
import {
assertNotNull,
- CancelablePromise,
+ type CancelablePromise,
PromiseUtils,
} from '@deephaven/utils';
import type { dh } from '@deephaven/jsapi-types';
@@ -30,8 +30,8 @@ import { nanoid } from 'nanoid';
import AdvancedFilterCreatorFilterItem from './AdvancedFilterCreatorFilterItem';
import AdvancedFilterCreatorSelectValue from './AdvancedFilterCreatorSelectValue';
import './AdvancedFilterCreator.scss';
-import IrisGridModel from './IrisGridModel';
-import { AdvancedFilterOptions } from './CommonTypes';
+import type IrisGridModel from './IrisGridModel';
+import { type AdvancedFilterOptions } from './CommonTypes';
const log = Log.module('AdvancedFilterCreator');
diff --git a/packages/iris-grid/src/AdvancedFilterCreatorFilterItem.tsx b/packages/iris-grid/src/AdvancedFilterCreatorFilterItem.tsx
index 9b1eb37909..10de1a6204 100644
--- a/packages/iris-grid/src/AdvancedFilterCreatorFilterItem.tsx
+++ b/packages/iris-grid/src/AdvancedFilterCreatorFilterItem.tsx
@@ -6,13 +6,13 @@ import {
getLabelForDateFilter,
getLabelForNumberFilter,
getLabelForTextFilter,
- TypeValue as FilterTypeValue,
+ type TypeValue as FilterTypeValue,
} from '@deephaven/filters';
import { vsTrash } from '@deephaven/icons';
import type { dh } from '@deephaven/jsapi-types';
import {
- AdvancedFilterItemType,
- Formatter,
+ type AdvancedFilterItemType,
+ type Formatter,
TableUtils,
} from '@deephaven/jsapi-utils';
import Log from '@deephaven/log';
diff --git a/packages/iris-grid/src/AdvancedFilterCreatorSelectValue.tsx b/packages/iris-grid/src/AdvancedFilterCreatorSelectValue.tsx
index 2e3ba2937a..12e0e7984f 100644
--- a/packages/iris-grid/src/AdvancedFilterCreatorSelectValue.tsx
+++ b/packages/iris-grid/src/AdvancedFilterCreatorSelectValue.tsx
@@ -1,12 +1,12 @@
/* eslint react/no-did-update-set-state: "off" */
import React, { PureComponent } from 'react';
import classNames from 'classnames';
-import { Formatter, TableUtils } from '@deephaven/jsapi-utils';
+import { type Formatter, TableUtils } from '@deephaven/jsapi-utils';
import type { dh as DhType } from '@deephaven/jsapi-types';
import { Button, FadeTransition } from '@deephaven/components';
import AdvancedFilterCreatorSelectValueList from './AdvancedFilterCreatorSelectValueList';
import './AdvancedFilterCreatorSelectValue.scss';
-import { ColumnName } from './CommonTypes';
+import { type ColumnName } from './CommonTypes';
interface AdvancedFilterCreatorSelectValueProps {
dh: typeof DhType;
diff --git a/packages/iris-grid/src/AdvancedFilterCreatorSelectValueList.tsx b/packages/iris-grid/src/AdvancedFilterCreatorSelectValueList.tsx
index fd667cb7e3..9d19078b6a 100644
--- a/packages/iris-grid/src/AdvancedFilterCreatorSelectValueList.tsx
+++ b/packages/iris-grid/src/AdvancedFilterCreatorSelectValueList.tsx
@@ -1,11 +1,11 @@
/* eslint react/no-did-update-set-state: "off" */
-import React, { PureComponent, ReactElement } from 'react';
+import React, { PureComponent, type ReactElement } from 'react';
import type { dh as DhType } from '@deephaven/jsapi-types';
-import { Formatter } from '@deephaven/jsapi-utils';
+import { type Formatter } from '@deephaven/jsapi-utils';
import {
LoadingSpinner,
SelectValueList,
- SelectItem,
+ type SelectItem,
FadeTransition,
} from '@deephaven/components';
import Log from '@deephaven/log';
diff --git a/packages/iris-grid/src/ColumnHeaderGroup.ts b/packages/iris-grid/src/ColumnHeaderGroup.ts
index 33b4fa78d7..d0bc17bd3a 100644
--- a/packages/iris-grid/src/ColumnHeaderGroup.ts
+++ b/packages/iris-grid/src/ColumnHeaderGroup.ts
@@ -1,9 +1,9 @@
import {
- MoveOperation,
+ type MoveOperation,
GridUtils,
- ModelIndex,
- BoundedAxisRange,
- IColumnHeaderGroup,
+ type ModelIndex,
+ type BoundedAxisRange,
+ type IColumnHeaderGroup,
} from '@deephaven/grid';
import memoizeOne from 'memoize-one';
import Log from '@deephaven/log';
diff --git a/packages/iris-grid/src/ColumnStatistics.tsx b/packages/iris-grid/src/ColumnStatistics.tsx
index f4f78d95fa..10fd3c6918 100644
--- a/packages/iris-grid/src/ColumnStatistics.tsx
+++ b/packages/iris-grid/src/ColumnStatistics.tsx
@@ -1,14 +1,15 @@
-import React, { Component, Key } from 'react';
+import React, { Component, type Key } from 'react';
import classNames from 'classnames';
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
import { Button, CopyButton, LoadingSpinner } from '@deephaven/components';
import { dhFreeze, dhRefresh, dhSortSlash, vsLock } from '@deephaven/icons';
import type { dh } from '@deephaven/jsapi-types';
import Log from '@deephaven/log';
-import { CancelablePromise, PromiseUtils } from '@deephaven/utils';
+import { type CancelablePromise, PromiseUtils } from '@deephaven/utils';
import { isExpandableGridModel } from '@deephaven/grid';
import './ColumnStatistics.scss';
-import IrisGridModel, { DisplayColumn } from './IrisGridModel';
+import { type DisplayColumn } from './IrisGridModel';
+import type IrisGridModel from './IrisGridModel';
const log = Log.module('ColumnStatistics');
const STATS_LABEL_OVERRIDES: Record = {
diff --git a/packages/iris-grid/src/CommonTypes.tsx b/packages/iris-grid/src/CommonTypes.tsx
index a99ee66baa..2ff8f6a7a3 100644
--- a/packages/iris-grid/src/CommonTypes.tsx
+++ b/packages/iris-grid/src/CommonTypes.tsx
@@ -1,10 +1,10 @@
-import { AdvancedFilterOptions } from '@deephaven/jsapi-utils';
-import { ModelIndex } from '@deephaven/grid';
+import { type AdvancedFilterOptions } from '@deephaven/jsapi-utils';
+import { type ModelIndex } from '@deephaven/grid';
import type { dh } from '@deephaven/jsapi-types';
-import { Shortcut } from '@deephaven/components';
-import { IconDefinition } from '@deephaven/icons';
-import AggregationOperation from './sidebar/aggregations/AggregationOperation';
-import { OptionType } from './sidebar';
+import { type Shortcut } from '@deephaven/components';
+import { type IconDefinition } from '@deephaven/icons';
+import type AggregationOperation from './sidebar/aggregations/AggregationOperation';
+import { type OptionType } from './sidebar';
export type RowIndex = ModelIndex;
diff --git a/packages/iris-grid/src/CrossColumnSearch.tsx b/packages/iris-grid/src/CrossColumnSearch.tsx
index 8a5b1b33f2..95d89602a3 100644
--- a/packages/iris-grid/src/CrossColumnSearch.tsx
+++ b/packages/iris-grid/src/CrossColumnSearch.tsx
@@ -12,8 +12,8 @@ import {
import type { dh as DhType } from '@deephaven/jsapi-types';
import { TableUtils } from '@deephaven/jsapi-utils';
import './CrossColumnSearch.scss';
-import { ColumnName } from './CommonTypes';
-import { DisplayColumn } from './IrisGridModel';
+import { type ColumnName } from './CommonTypes';
+import { type DisplayColumn } from './IrisGridModel';
interface CrossColumnSearchProps {
value: string;
diff --git a/packages/iris-grid/src/EmptyIrisGridModel.ts b/packages/iris-grid/src/EmptyIrisGridModel.ts
index 68c1471ae5..c535af09af 100644
--- a/packages/iris-grid/src/EmptyIrisGridModel.ts
+++ b/packages/iris-grid/src/EmptyIrisGridModel.ts
@@ -1,19 +1,19 @@
/* eslint class-methods-use-this: "off" */
import {
- GridRange,
- ModelIndex,
- MoveOperation,
- VisibleIndex,
+ type GridRange,
+ type ModelIndex,
+ type MoveOperation,
+ type VisibleIndex,
} from '@deephaven/grid';
-import { dh as DhType } from '@deephaven/jsapi-types';
-import { ColumnName, Formatter } from '@deephaven/jsapi-utils';
+import { type dh as DhType } from '@deephaven/jsapi-types';
+import { type ColumnName, Formatter } from '@deephaven/jsapi-utils';
import { EMPTY_ARRAY, EMPTY_MAP } from '@deephaven/utils';
import IrisGridModel from './IrisGridModel';
-import ColumnHeaderGroup from './ColumnHeaderGroup';
+import type ColumnHeaderGroup from './ColumnHeaderGroup';
import {
- PendingDataErrorMap,
- PendingDataMap,
- UITotalsTableConfig,
+ type PendingDataErrorMap,
+ type PendingDataMap,
+ type UITotalsTableConfig,
} from './CommonTypes';
class EmptyIrisGridModel extends IrisGridModel {
diff --git a/packages/iris-grid/src/FilterInputField.tsx b/packages/iris-grid/src/FilterInputField.tsx
index f968f5d61c..0c7c018c65 100644
--- a/packages/iris-grid/src/FilterInputField.tsx
+++ b/packages/iris-grid/src/FilterInputField.tsx
@@ -1,4 +1,8 @@
-import React, { ChangeEvent, PureComponent, ReactElement } from 'react';
+import React, {
+ type ChangeEvent,
+ PureComponent,
+ type ReactElement,
+} from 'react';
import classNames from 'classnames';
import debounce from 'lodash.debounce';
import { vsFilter, dhFilterFilled } from '@deephaven/icons';
diff --git a/packages/iris-grid/src/GotoRow.test.tsx b/packages/iris-grid/src/GotoRow.test.tsx
index 7724a96eaf..f23af47bd5 100644
--- a/packages/iris-grid/src/GotoRow.test.tsx
+++ b/packages/iris-grid/src/GotoRow.test.tsx
@@ -4,7 +4,7 @@ import userEvent from '@testing-library/user-event';
import dh from '@deephaven/jsapi-shim';
import {
Type as FilterType,
- TypeValue as FilterTypeValue,
+ type TypeValue as FilterTypeValue,
} from '@deephaven/filters';
import { TableUtils } from '@deephaven/jsapi-utils';
import GotoRow from './GotoRow';
diff --git a/packages/iris-grid/src/GotoRow.tsx b/packages/iris-grid/src/GotoRow.tsx
index d451cafc0d..897fbd089c 100644
--- a/packages/iris-grid/src/GotoRow.tsx
+++ b/packages/iris-grid/src/GotoRow.tsx
@@ -1,9 +1,9 @@
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
import { vsClose, vsArrowUp, vsArrowDown } from '@deephaven/icons';
import React, {
- ChangeEvent,
- KeyboardEvent,
- ReactElement,
+ type ChangeEvent,
+ type KeyboardEvent,
+ type ReactElement,
forwardRef,
useEffect,
useImperativeHandle,
@@ -14,16 +14,16 @@ import React, {
import type { dh } from '@deephaven/jsapi-types';
import {
Type as FilterType,
- TypeValue as FilterTypeValue,
+ type TypeValue as FilterTypeValue,
} from '@deephaven/filters';
import { Button, DateTimeInput, Select } from '@deephaven/components';
import { TableUtils } from '@deephaven/jsapi-utils';
import classNames from 'classnames';
import './GotoRow.scss';
import { nanoid } from 'nanoid';
-import IrisGridModel from './IrisGridModel';
+import type IrisGridModel from './IrisGridModel';
import IrisGridBottomBar from './IrisGridBottomBar';
-import { ColumnName } from './CommonTypes';
+import { type ColumnName } from './CommonTypes';
import { isIrisGridTableModelTemplate } from './IrisGridTableModelTemplate';
const DEFAULT_FORMAT_STRING = '###,##0';
diff --git a/packages/iris-grid/src/IrisGrid.test.tsx b/packages/iris-grid/src/IrisGrid.test.tsx
index 1f7e0d5121..f6709a5acd 100644
--- a/packages/iris-grid/src/IrisGrid.test.tsx
+++ b/packages/iris-grid/src/IrisGrid.test.tsx
@@ -1,9 +1,9 @@
-import React, { ReactElement } from 'react';
+import React, { type ReactElement } from 'react';
import TestRenderer from 'react-test-renderer';
import dh from '@deephaven/jsapi-shim';
-import { DateUtils, Settings } from '@deephaven/jsapi-utils';
+import { DateUtils, type Settings } from '@deephaven/jsapi-utils';
import { TestUtils } from '@deephaven/test-utils';
-import { TypeValue } from '@deephaven/filters';
+import { type TypeValue } from '@deephaven/filters';
import IrisGrid from './IrisGrid';
import IrisGridTestUtils from './IrisGridTestUtils';
diff --git a/packages/iris-grid/src/IrisGrid.tsx b/packages/iris-grid/src/IrisGrid.tsx
index 3797af5169..72c9df1b21 100644
--- a/packages/iris-grid/src/IrisGrid.tsx
+++ b/packages/iris-grid/src/IrisGrid.tsx
@@ -1,9 +1,9 @@
import React, {
- ChangeEvent,
+ type ChangeEvent,
Component,
- CSSProperties,
- ReactElement,
- ReactNode,
+ type CSSProperties,
+ type ReactElement,
+ type ReactNode,
} from 'react';
import memoize from 'memoizee';
import classNames from 'classnames';
@@ -20,30 +20,30 @@ import {
Popper,
ThemeExport,
Tooltip,
- ContextAction,
- PopperOptions,
- ReferenceObject,
+ type ContextAction,
+ type PopperOptions,
+ type ReferenceObject,
Button,
ContextActionUtils,
- ResolvableContextAction,
+ type ResolvableContextAction,
SlideTransition,
} from '@deephaven/components';
import {
Grid,
- GridMetrics,
- GridMouseHandler,
+ type GridMetrics,
+ type GridMouseHandler,
GridRange,
- GridRangeIndex,
- GridThemeType,
+ type GridRangeIndex,
+ type GridThemeType,
GridUtils,
- KeyHandler,
- ModelIndex,
- ModelSizeMap,
- MoveOperation,
- VisibleIndex,
- GridState,
+ type KeyHandler,
+ type ModelIndex,
+ type ModelSizeMap,
+ type MoveOperation,
+ type VisibleIndex,
+ type GridState,
isEditableGridModel,
- BoundedAxisRange,
+ type BoundedAxisRange,
isExpandableGridModel,
isDeletableGridModel,
} from '@deephaven/grid';
@@ -70,13 +70,13 @@ import {
Formatter,
FormatterUtils,
TableUtils,
- FormattingRule,
- ReverseType,
- RowDataMap,
- SortDirection,
- DateTimeColumnFormatterOptions,
- TableColumnFormat,
- Settings,
+ type FormattingRule,
+ type ReverseType,
+ type RowDataMap,
+ type SortDirection,
+ type DateTimeColumnFormatterOptions,
+ type TableColumnFormat,
+ type Settings,
isSortDirection,
} from '@deephaven/jsapi-utils';
import {
@@ -92,17 +92,17 @@ import {
} from '@deephaven/utils';
import {
Type as FilterType,
- TypeValue as FilterTypeValue,
+ type TypeValue as FilterTypeValue,
} from '@deephaven/filters';
import throttle from 'lodash.throttle';
import debounce from 'lodash.debounce';
import clamp from 'lodash.clamp';
import {
- FormattingRule as SidebarFormattingRule,
+ type FormattingRule as SidebarFormattingRule,
getFormatColumns,
} from './sidebar/conditional-formatting/ConditionalFormattingUtils';
import PendingDataBottomBar from './PendingDataBottomBar';
-import IrisGridCopyHandler, { CopyOperation } from './IrisGridCopyHandler';
+import IrisGridCopyHandler, { type CopyOperation } from './IrisGridCopyHandler';
import FilterInputField from './FilterInputField';
import {
CopyCellKeyHandler,
@@ -128,7 +128,10 @@ import ToastBottomBar from './ToastBottomBar';
import IrisGridMetricCalculator from './IrisGridMetricCalculator';
import IrisGridModelUpdater from './IrisGridModelUpdater';
import IrisGridRenderer from './IrisGridRenderer';
-import { createDefaultIrisGridTheme, IrisGridThemeType } from './IrisGridTheme';
+import {
+ createDefaultIrisGridTheme,
+ type IrisGridThemeType,
+} from './IrisGridTheme';
import ColumnStatistics from './ColumnStatistics';
import './IrisGrid.scss';
import AdvancedFilterCreator from './AdvancedFilterCreator';
@@ -150,45 +153,45 @@ import CrossColumnSearch from './CrossColumnSearch';
import IrisGridModel from './IrisGridModel';
import {
isPartitionedGridModel,
- PartitionConfig,
- PartitionedGridModel,
+ type PartitionConfig,
+ type PartitionedGridModel,
} from './PartitionedGridModel';
import IrisGridPartitionSelector from './IrisGridPartitionSelector';
import SelectDistinctBuilder from './sidebar/SelectDistinctBuilder';
import AdvancedSettingsType from './sidebar/AdvancedSettingsType';
import AdvancedSettingsMenu, {
- AdvancedSettingsMenuCallback,
+ type AdvancedSettingsMenuCallback,
} from './sidebar/AdvancedSettingsMenu';
import SHORTCUTS from './IrisGridShortcuts';
import ConditionalFormattingMenu from './sidebar/conditional-formatting/ConditionalFormattingMenu';
import ConditionalFormatEditor from './sidebar/conditional-formatting/ConditionalFormatEditor';
import IrisGridCellOverflowModal from './IrisGridCellOverflowModal';
-import GotoRow, { GotoRowElement } from './GotoRow';
+import GotoRow, { type GotoRowElement } from './GotoRow';
import {
- Aggregation,
- AggregationSettings,
+ type Aggregation,
+ type AggregationSettings,
} from './sidebar/aggregations/Aggregations';
-import { ChartBuilderSettings } from './sidebar/ChartBuilder';
+import { type ChartBuilderSettings } from './sidebar/ChartBuilder';
import AggregationOperation from './sidebar/aggregations/AggregationOperation';
-import { UIRollupConfig } from './sidebar/RollupRows';
+import { type UIRollupConfig } from './sidebar/RollupRows';
import {
- Action,
- AdvancedFilterMap,
- AdvancedFilterOptions,
- ColumnName,
- InputFilter,
- OperationMap,
- OptionItem,
- PendingDataErrorMap,
- PendingDataMap,
- QuickFilterMap,
- ReadonlyAdvancedFilterMap,
- ReadonlyAggregationMap,
- ReadonlyQuickFilterMap,
- UITotalsTableConfig,
+ type Action,
+ type AdvancedFilterMap,
+ type AdvancedFilterOptions,
+ type ColumnName,
+ type InputFilter,
+ type OperationMap,
+ type OptionItem,
+ type PendingDataErrorMap,
+ type PendingDataMap,
+ type QuickFilterMap,
+ type ReadonlyAdvancedFilterMap,
+ type ReadonlyAggregationMap,
+ type ReadonlyQuickFilterMap,
+ type UITotalsTableConfig,
} from './CommonTypes';
-import ColumnHeaderGroup from './ColumnHeaderGroup';
+import type ColumnHeaderGroup from './ColumnHeaderGroup';
import { IrisGridThemeContext } from './IrisGridThemeProvider';
import { isMissingPartitionError } from './MissingPartitionError';
diff --git a/packages/iris-grid/src/IrisGridCellRendererUtils.ts b/packages/iris-grid/src/IrisGridCellRendererUtils.ts
index 2d22efb9a7..af32e76fb9 100644
--- a/packages/iris-grid/src/IrisGridCellRendererUtils.ts
+++ b/packages/iris-grid/src/IrisGridCellRendererUtils.ts
@@ -1,6 +1,6 @@
-import { BoxCoordinates, Coordinate } from '@deephaven/grid';
+import { type BoxCoordinates, type Coordinate } from '@deephaven/grid';
import { getIcon } from './IrisGridIcons';
-import { IrisGridRenderState } from './IrisGridRenderer';
+import { type IrisGridRenderState } from './IrisGridRenderer';
class IrisGridCellRendererUtils {
static drawTreeMarker(
diff --git a/packages/iris-grid/src/IrisGridCopyHandler.test.tsx b/packages/iris-grid/src/IrisGridCopyHandler.test.tsx
index cb4bab3d91..f8ff1d47d2 100644
--- a/packages/iris-grid/src/IrisGridCopyHandler.test.tsx
+++ b/packages/iris-grid/src/IrisGridCopyHandler.test.tsx
@@ -6,11 +6,11 @@ import { copyToClipboard } from '@deephaven/utils';
import dh from '@deephaven/jsapi-shim';
import IrisGridTestUtils from './IrisGridTestUtils';
import IrisGridCopyHandler, {
- CopyOperation,
- CopyHeaderOperation,
- CopyRangesOperation,
+ type CopyOperation,
+ type CopyHeaderOperation,
+ type CopyRangesOperation,
} from './IrisGridCopyHandler';
-import IrisGridProxyModel from './IrisGridProxyModel';
+import type IrisGridProxyModel from './IrisGridProxyModel';
jest.mock('@deephaven/utils', () => ({
...jest.requireActual('@deephaven/utils'),
diff --git a/packages/iris-grid/src/IrisGridCopyHandler.tsx b/packages/iris-grid/src/IrisGridCopyHandler.tsx
index c52a1b0e53..6198aff47d 100644
--- a/packages/iris-grid/src/IrisGridCopyHandler.tsx
+++ b/packages/iris-grid/src/IrisGridCopyHandler.tsx
@@ -4,11 +4,11 @@ import { Button, FadeTransition, LoadingSpinner } from '@deephaven/components';
import {
GridRange,
GridUtils,
- ModelSizeMap,
- MoveOperation,
+ type ModelSizeMap,
+ type MoveOperation,
} from '@deephaven/grid';
import {
- CancelablePromise,
+ type CancelablePromise,
CanceledPromiseError,
copyToClipboard,
PromiseUtils,
@@ -18,7 +18,7 @@ import type { dh } from '@deephaven/jsapi-types';
import IrisGridUtils from './IrisGridUtils';
import IrisGridBottomBar from './IrisGridBottomBar';
import './IrisGridCopyHandler.scss';
-import IrisGridModel from './IrisGridModel';
+import type IrisGridModel from './IrisGridModel';
const log = Log.module('IrisGridCopyHandler');
diff --git a/packages/iris-grid/src/IrisGridDataBarCellRenderer.ts b/packages/iris-grid/src/IrisGridDataBarCellRenderer.ts
index d70239491e..e6b7842dee 100644
--- a/packages/iris-grid/src/IrisGridDataBarCellRenderer.ts
+++ b/packages/iris-grid/src/IrisGridDataBarCellRenderer.ts
@@ -1,10 +1,10 @@
/* eslint-disable class-methods-use-this */
import {
- BoxCoordinates,
- Coordinate,
+ type BoxCoordinates,
+ type Coordinate,
DataBarCellRenderer,
} from '@deephaven/grid';
-import { IrisGridRenderState } from './IrisGridRenderer';
+import { type IrisGridRenderState } from './IrisGridRenderer';
import IrisGridCellRendererUtils from './IrisGridCellRendererUtils';
class IrisGridDataBarCellRenderer extends DataBarCellRenderer {
diff --git a/packages/iris-grid/src/IrisGridIcons.ts b/packages/iris-grid/src/IrisGridIcons.ts
index 37c41de97d..547792df0a 100644
--- a/packages/iris-grid/src/IrisGridIcons.ts
+++ b/packages/iris-grid/src/IrisGridIcons.ts
@@ -4,7 +4,7 @@ import {
vsTriangleRight,
vsTriangleUp,
vsLinkExternal,
- IconDefinition,
+ type IconDefinition,
} from '@deephaven/icons';
export type IconName =
diff --git a/packages/iris-grid/src/IrisGridMetricCalculator.ts b/packages/iris-grid/src/IrisGridMetricCalculator.ts
index b9e04f71e8..efb242ea11 100644
--- a/packages/iris-grid/src/IrisGridMetricCalculator.ts
+++ b/packages/iris-grid/src/IrisGridMetricCalculator.ts
@@ -1,9 +1,9 @@
-import { GridMetricCalculator, ModelSizeMap } from '@deephaven/grid';
+import { GridMetricCalculator, type ModelSizeMap } from '@deephaven/grid';
import type { GridMetricState } from '@deephaven/grid';
import type { dh } from '@deephaven/jsapi-types';
import { TableUtils } from '@deephaven/jsapi-utils';
import type IrisGridModel from './IrisGridModel';
-import { IrisGridThemeType } from './IrisGridTheme';
+import { type IrisGridThemeType } from './IrisGridTheme';
export interface IrisGridMetricState extends GridMetricState {
model: IrisGridModel;
diff --git a/packages/iris-grid/src/IrisGridModel.test.ts b/packages/iris-grid/src/IrisGridModel.test.ts
index 99da0da325..34bd4bf7f1 100644
--- a/packages/iris-grid/src/IrisGridModel.test.ts
+++ b/packages/iris-grid/src/IrisGridModel.test.ts
@@ -9,7 +9,7 @@ import type {
import { Formatter } from '@deephaven/jsapi-utils';
import IrisGridModel from './IrisGridModel';
import IrisGridTestUtils from './IrisGridTestUtils';
-import { UITotalsTableConfig } from './CommonTypes';
+import { type UITotalsTableConfig } from './CommonTypes';
jest.useFakeTimers();
diff --git a/packages/iris-grid/src/IrisGridModel.ts b/packages/iris-grid/src/IrisGridModel.ts
index d23b95a164..83a7908f42 100644
--- a/packages/iris-grid/src/IrisGridModel.ts
+++ b/packages/iris-grid/src/IrisGridModel.ts
@@ -1,26 +1,26 @@
/* eslint-disable class-methods-use-this */
import type { Event, EventTarget } from 'event-target-shim';
import {
- BoundedAxisRange,
- DataBarGridModel,
- DataBarOptions,
- GridCell,
+ type BoundedAxisRange,
+ type DataBarGridModel,
+ type DataBarOptions,
+ type GridCell,
GridModel,
- GridRange,
- GridThemeType,
- ModelIndex,
- MoveOperation,
- VisibleIndex,
+ type GridRange,
+ type GridThemeType,
+ type ModelIndex,
+ type MoveOperation,
+ type VisibleIndex,
} from '@deephaven/grid';
import type { dh as DhType } from '@deephaven/jsapi-types';
-import { Formatter } from '@deephaven/jsapi-utils';
+import { type Formatter } from '@deephaven/jsapi-utils';
import {
- ColumnName,
- UITotalsTableConfig,
- PendingDataMap,
- PendingDataErrorMap,
+ type ColumnName,
+ type UITotalsTableConfig,
+ type PendingDataMap,
+ type PendingDataErrorMap,
} from './CommonTypes';
-import ColumnHeaderGroup from './ColumnHeaderGroup';
+import type ColumnHeaderGroup from './ColumnHeaderGroup';
export type DisplayColumn = DhType.Column & {
/**
diff --git a/packages/iris-grid/src/IrisGridModelFactory.ts b/packages/iris-grid/src/IrisGridModelFactory.ts
index df2106f67f..e7e52c26b6 100644
--- a/packages/iris-grid/src/IrisGridModelFactory.ts
+++ b/packages/iris-grid/src/IrisGridModelFactory.ts
@@ -1,6 +1,6 @@
import type { dh as DhType } from '@deephaven/jsapi-types';
import { Formatter, TableUtils } from '@deephaven/jsapi-utils';
-import IrisGridModel from './IrisGridModel';
+import type IrisGridModel from './IrisGridModel';
import IrisGridProxyModel from './IrisGridProxyModel';
/**
diff --git a/packages/iris-grid/src/IrisGridModelUpdater.tsx b/packages/iris-grid/src/IrisGridModelUpdater.tsx
index 8449340468..2f4f1e19f7 100644
--- a/packages/iris-grid/src/IrisGridModelUpdater.tsx
+++ b/packages/iris-grid/src/IrisGridModelUpdater.tsx
@@ -2,16 +2,24 @@
/* eslint-disable no-param-reassign */
import { useMemo } from 'react';
import type { dh } from '@deephaven/jsapi-types';
-import { ModelIndex, MoveOperation } from '@deephaven/grid';
-import { Formatter, ReverseType, TableUtils } from '@deephaven/jsapi-utils';
+import { type ModelIndex, type MoveOperation } from '@deephaven/grid';
+import {
+ type Formatter,
+ type ReverseType,
+ TableUtils,
+} from '@deephaven/jsapi-utils';
import { EMPTY_ARRAY, EMPTY_MAP } from '@deephaven/utils';
import { useOnChange } from '@deephaven/react-hooks';
import IrisGridUtils from './IrisGridUtils';
-import { ColumnName, UITotalsTableConfig, PendingDataMap } from './CommonTypes';
-import IrisGridModel from './IrisGridModel';
+import {
+ type ColumnName,
+ type UITotalsTableConfig,
+ type PendingDataMap,
+} from './CommonTypes';
+import type IrisGridModel from './IrisGridModel';
import type ColumnHeaderGroup from './ColumnHeaderGroup';
import {
- PartitionConfig,
+ type PartitionConfig,
isPartitionedGridModel,
} from './PartitionedGridModel';
import { isIrisGridTreeTableModel } from './IrisGridTreeTableModel';
diff --git a/packages/iris-grid/src/IrisGridPartitionSelector.test.tsx b/packages/iris-grid/src/IrisGridPartitionSelector.test.tsx
index 0e037dc65d..eaf5103672 100644
--- a/packages/iris-grid/src/IrisGridPartitionSelector.test.tsx
+++ b/packages/iris-grid/src/IrisGridPartitionSelector.test.tsx
@@ -4,7 +4,10 @@ import { ApiContext } from '@deephaven/jsapi-bootstrap';
import dh from '@deephaven/jsapi-shim';
import IrisGridPartitionSelector from './IrisGridPartitionSelector';
import IrisGridTestUtils from './IrisGridTestUtils';
-import { PartitionConfig, PartitionedGridModel } from './PartitionedGridModel';
+import {
+ type PartitionConfig,
+ type PartitionedGridModel,
+} from './PartitionedGridModel';
const irisGridTestUtils = new IrisGridTestUtils(dh);
diff --git a/packages/iris-grid/src/IrisGridPartitionSelector.tsx b/packages/iris-grid/src/IrisGridPartitionSelector.tsx
index a8346ae3db..28b528a09f 100644
--- a/packages/iris-grid/src/IrisGridPartitionSelector.tsx
+++ b/packages/iris-grid/src/IrisGridPartitionSelector.tsx
@@ -1,7 +1,7 @@
import React, { Component } from 'react';
import memoizee from 'memoizee';
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
-import { Button, ItemKey } from '@deephaven/components';
+import { Button, type ItemKey } from '@deephaven/components';
import { vsChevronRight, vsMerge, vsKey } from '@deephaven/icons';
import Log from '@deephaven/log';
import { Picker } from '@deephaven/jsapi-components';
@@ -9,7 +9,10 @@ import type { dh } from '@deephaven/jsapi-types';
import { TableUtils } from '@deephaven/jsapi-utils';
import { assertNotNull, Pending, PromiseUtils } from '@deephaven/utils';
import './IrisGridPartitionSelector.scss';
-import { PartitionConfig, PartitionedGridModel } from './PartitionedGridModel';
+import {
+ type PartitionConfig,
+ type PartitionedGridModel,
+} from './PartitionedGridModel';
const log = Log.module('IrisGridPartitionSelector');
diff --git a/packages/iris-grid/src/IrisGridPartitionedTableModel.ts b/packages/iris-grid/src/IrisGridPartitionedTableModel.ts
index 7140700167..5657dd455f 100644
--- a/packages/iris-grid/src/IrisGridPartitionedTableModel.ts
+++ b/packages/iris-grid/src/IrisGridPartitionedTableModel.ts
@@ -1,12 +1,12 @@
/* eslint class-methods-use-this: "off" */
import type { dh as DhType } from '@deephaven/jsapi-types';
import { Formatter } from '@deephaven/jsapi-utils';
-import { ColumnName } from './CommonTypes';
+import { type ColumnName } from './CommonTypes';
import EmptyIrisGridModel from './EmptyIrisGridModel';
import MissingPartitionError, {
isMissingPartitionError,
} from './MissingPartitionError';
-import { PartitionedGridModelProvider } from './PartitionedGridModel';
+import { type PartitionedGridModelProvider } from './PartitionedGridModel';
type PartitionedTableWithBaseTable = DhType.PartitionedTable & {
getBaseTable: () => DhType.Table;
diff --git a/packages/iris-grid/src/IrisGridProxyModel.test.ts b/packages/iris-grid/src/IrisGridProxyModel.test.ts
index 8df4bb70f5..293d6425ff 100644
--- a/packages/iris-grid/src/IrisGridProxyModel.test.ts
+++ b/packages/iris-grid/src/IrisGridProxyModel.test.ts
@@ -1,6 +1,6 @@
import dh from '@deephaven/jsapi-shim';
-import IrisGridModel from './IrisGridModel';
-import IrisGridProxyModel from './IrisGridProxyModel';
+import type IrisGridModel from './IrisGridModel';
+import type IrisGridProxyModel from './IrisGridProxyModel';
import IrisGridTestUtils from './IrisGridTestUtils';
const irisGridTestUtils = new IrisGridTestUtils(dh);
diff --git a/packages/iris-grid/src/IrisGridProxyModel.ts b/packages/iris-grid/src/IrisGridProxyModel.ts
index acd900b663..823c76fd72 100644
--- a/packages/iris-grid/src/IrisGridProxyModel.ts
+++ b/packages/iris-grid/src/IrisGridProxyModel.ts
@@ -2,7 +2,7 @@ import deepEqual from 'fast-deep-equal';
import { Formatter, TableUtils } from '@deephaven/jsapi-utils';
import Log from '@deephaven/log';
import {
- CancelablePromise,
+ type CancelablePromise,
EventShimCustomEvent,
PromiseUtils,
} from '@deephaven/utils';
@@ -11,11 +11,11 @@ import IrisGridTableModel from './IrisGridTableModel';
import IrisGridPartitionedTableModel from './IrisGridPartitionedTableModel';
import IrisGridTreeTableModel from './IrisGridTreeTableModel';
import IrisGridModel from './IrisGridModel';
-import { ColumnName } from './CommonTypes';
+import { type ColumnName } from './CommonTypes';
import { isIrisGridTableModelTemplate } from './IrisGridTableModelTemplate';
import {
- PartitionConfig,
- PartitionedGridModel,
+ type PartitionConfig,
+ type PartitionedGridModel,
isPartitionedGridModelProvider,
} from './PartitionedGridModel';
diff --git a/packages/iris-grid/src/IrisGridRenderer.ts b/packages/iris-grid/src/IrisGridRenderer.ts
index 9d57c7ee61..3ea6dfcd47 100644
--- a/packages/iris-grid/src/IrisGridRenderer.ts
+++ b/packages/iris-grid/src/IrisGridRenderer.ts
@@ -1,27 +1,27 @@
/* eslint class-methods-use-this: "off" */
import {
- BoundedAxisRange,
- Coordinate,
+ type BoundedAxisRange,
+ type Coordinate,
DEFAULT_FONT_WIDTH,
- GridMetrics,
- GridRangeIndex,
+ type GridMetrics,
+ type GridRangeIndex,
GridRenderer,
- GridRenderState,
- GridThemeType,
+ type GridRenderState,
+ type GridThemeType,
GridUtils,
- VisibleIndex,
+ type VisibleIndex,
} from '@deephaven/grid';
import type { dh } from '@deephaven/jsapi-types';
-import { TableUtils, ReverseType } from '@deephaven/jsapi-utils';
+import { TableUtils, type ReverseType } from '@deephaven/jsapi-utils';
import { assertNotNull, getOrThrow } from '@deephaven/utils';
import {
- ReadonlyAdvancedFilterMap,
- ReadonlyQuickFilterMap,
- AdvancedFilter,
- QuickFilter,
+ type ReadonlyAdvancedFilterMap,
+ type ReadonlyQuickFilterMap,
+ type AdvancedFilter,
+ type QuickFilter,
} from './CommonTypes';
-import { IrisGridThemeType } from './IrisGridTheme';
-import IrisGridModel from './IrisGridModel';
+import { type IrisGridThemeType } from './IrisGridTheme';
+import type IrisGridModel from './IrisGridModel';
import IrisGridTextCellRenderer from './IrisGridTextCellRenderer';
import IrisGridDataBarCellRenderer from './IrisGridDataBarCellRenderer';
import { getIcon } from './IrisGridIcons';
diff --git a/packages/iris-grid/src/IrisGridTableModel.ts b/packages/iris-grid/src/IrisGridTableModel.ts
index a75ce32dbf..3719f34864 100644
--- a/packages/iris-grid/src/IrisGridTableModel.ts
+++ b/packages/iris-grid/src/IrisGridTableModel.ts
@@ -1,6 +1,6 @@
/* eslint class-methods-use-this: "off" */
import memoize from 'memoize-one';
-import { GridRange, ModelIndex } from '@deephaven/grid';
+import { GridRange, type ModelIndex } from '@deephaven/grid';
import type { dh as DhType } from '@deephaven/jsapi-types';
import Log from '@deephaven/log';
import { Formatter } from '@deephaven/jsapi-utils';
@@ -11,9 +11,13 @@ import {
EMPTY_ARRAY,
} from '@deephaven/utils';
import IrisGridModel from './IrisGridModel';
-import { ColumnName, UIRow, UITotalsTableConfig } from './CommonTypes';
+import {
+ type ColumnName,
+ type UIRow,
+ type UITotalsTableConfig,
+} from './CommonTypes';
import IrisGridTableModelTemplate from './IrisGridTableModelTemplate';
-import { PartitionedGridModelProvider } from './PartitionedGridModel';
+import { type PartitionedGridModelProvider } from './PartitionedGridModel';
const log = Log.module('IrisGridTableModel');
diff --git a/packages/iris-grid/src/IrisGridTableModelTemplate.ts b/packages/iris-grid/src/IrisGridTableModelTemplate.ts
index e57eb299dd..51407547f0 100644
--- a/packages/iris-grid/src/IrisGridTableModelTemplate.ts
+++ b/packages/iris-grid/src/IrisGridTableModelTemplate.ts
@@ -3,40 +3,41 @@
import memoize from 'memoize-one';
import throttle from 'lodash.throttle';
import {
- DeletableGridModel,
- EditableGridModel,
- EditOperation,
+ type DeletableGridModel,
+ type EditableGridModel,
+ type EditOperation,
GridRange,
GridUtils,
memoizeClear,
- ModelIndex,
- MoveOperation,
- VisibleIndex,
+ type ModelIndex,
+ type MoveOperation,
+ type VisibleIndex,
} from '@deephaven/grid';
import type { dh as DhType } from '@deephaven/jsapi-types';
import Log from '@deephaven/log';
import {
- CancelablePromise,
+ type CancelablePromise,
EventShimCustomEvent,
PromiseUtils,
assertNotNull,
} from '@deephaven/utils';
import { TableUtils, Formatter, FormatterUtils } from '@deephaven/jsapi-utils';
-import IrisGridModel, { DisplayColumn } from './IrisGridModel';
+import IrisGridModel, { type DisplayColumn } from './IrisGridModel';
import AggregationOperation from './sidebar/aggregations/AggregationOperation';
import IrisGridUtils from './IrisGridUtils';
import MissingKeyError from './MissingKeyError';
import {
- ColumnName,
- UITotalsTableConfig,
- UIRow,
- PendingDataMap,
- CellData,
- UIViewportData,
- PendingDataErrorMap,
+ type ColumnName,
+ type UITotalsTableConfig,
+ type UIRow,
+ type PendingDataMap,
+ type CellData,
+ type UIViewportData,
+ type PendingDataErrorMap,
} from './CommonTypes';
-import { IrisGridThemeType } from './IrisGridTheme';
-import ColumnHeaderGroup, { isColumnHeaderGroup } from './ColumnHeaderGroup';
+import { type IrisGridThemeType } from './IrisGridTheme';
+import type ColumnHeaderGroup from './ColumnHeaderGroup';
+import { isColumnHeaderGroup } from './ColumnHeaderGroup';
const log = Log.module('IrisGridTableModelTemplate');
diff --git a/packages/iris-grid/src/IrisGridTestUtils.ts b/packages/iris-grid/src/IrisGridTestUtils.ts
index c36cc371ce..bc83a1bb05 100644
--- a/packages/iris-grid/src/IrisGridTestUtils.ts
+++ b/packages/iris-grid/src/IrisGridTestUtils.ts
@@ -1,4 +1,4 @@
-import { GridRangeIndex, ModelSizeMap } from '@deephaven/grid';
+import { type GridRangeIndex, type ModelSizeMap } from '@deephaven/grid';
import type { dh as DhType } from '@deephaven/jsapi-types';
import { Formatter } from '@deephaven/jsapi-utils';
import IrisGridProxyModel from './IrisGridProxyModel';
diff --git a/packages/iris-grid/src/IrisGridTextCellRenderer.ts b/packages/iris-grid/src/IrisGridTextCellRenderer.ts
index 09dc59deb3..143dd73ba5 100644
--- a/packages/iris-grid/src/IrisGridTextCellRenderer.ts
+++ b/packages/iris-grid/src/IrisGridTextCellRenderer.ts
@@ -1,16 +1,16 @@
/* eslint-disable class-methods-use-this */
import {
- BoxCoordinates,
- Coordinate,
+ type BoxCoordinates,
+ type Coordinate,
DEFAULT_FONT_WIDTH,
getOrThrow,
- GridMetrics,
+ type GridMetrics,
GridUtils,
TextCellRenderer,
- VisibleIndex,
+ type VisibleIndex,
} from '@deephaven/grid';
import { TableUtils } from '@deephaven/jsapi-utils';
-import { IrisGridRenderState } from './IrisGridRenderer';
+import { type IrisGridRenderState } from './IrisGridRenderer';
import IrisGridCellRendererUtils from './IrisGridCellRendererUtils';
import type { IrisGridThemeType } from './IrisGridTheme';
diff --git a/packages/iris-grid/src/IrisGridTheme.ts b/packages/iris-grid/src/IrisGridTheme.ts
index a51c52a2eb..eff77059e0 100644
--- a/packages/iris-grid/src/IrisGridTheme.ts
+++ b/packages/iris-grid/src/IrisGridTheme.ts
@@ -5,7 +5,10 @@ import {
import type { GridThemeType } from '@deephaven/grid';
import { GridTheme } from '@deephaven/grid';
import Log from '@deephaven/log';
-import { GridColor, NullableGridColor } from '@deephaven/grid/src/GridTheme';
+import {
+ type GridColor,
+ type NullableGridColor,
+} from '@deephaven/grid/src/GridTheme';
import { ColorUtils } from '@deephaven/utils';
import IrisGridThemeRaw from './IrisGridTheme.module.scss';
diff --git a/packages/iris-grid/src/IrisGridThemeProvider.tsx b/packages/iris-grid/src/IrisGridThemeProvider.tsx
index 117468eca0..22d7763e21 100644
--- a/packages/iris-grid/src/IrisGridThemeProvider.tsx
+++ b/packages/iris-grid/src/IrisGridThemeProvider.tsx
@@ -1,6 +1,9 @@
import { useTheme } from '@deephaven/components';
-import { createContext, ReactNode, useMemo } from 'react';
-import { createDefaultIrisGridTheme, IrisGridThemeType } from './IrisGridTheme';
+import { createContext, type ReactNode, useMemo } from 'react';
+import {
+ createDefaultIrisGridTheme,
+ type IrisGridThemeType,
+} from './IrisGridTheme';
/**
* The context value for the IrisGridThemeProvider.
diff --git a/packages/iris-grid/src/IrisGridTreeTableModel.ts b/packages/iris-grid/src/IrisGridTreeTableModel.ts
index c1a8f3a9dc..eb2c00b5e8 100644
--- a/packages/iris-grid/src/IrisGridTreeTableModel.ts
+++ b/packages/iris-grid/src/IrisGridTreeTableModel.ts
@@ -1,18 +1,18 @@
/* eslint class-methods-use-this: "off" */
import memoize from 'memoize-one';
import {
- BoundedAxisRange,
- GridCell,
+ type BoundedAxisRange,
+ type GridCell,
GridRange,
- ModelIndex,
+ type ModelIndex,
} from '@deephaven/grid';
import type { dh as DhType } from '@deephaven/jsapi-types';
import Log from '@deephaven/log';
import { Formatter, TableUtils } from '@deephaven/jsapi-utils';
import { assertNotNull, EventShimCustomEvent } from '@deephaven/utils';
-import { UIRow, ColumnName } from './CommonTypes';
+import { type UIRow, type ColumnName } from './CommonTypes';
import IrisGridTableModelTemplate from './IrisGridTableModelTemplate';
-import IrisGridModel, { DisplayColumn } from './IrisGridModel';
+import IrisGridModel, { type DisplayColumn } from './IrisGridModel';
const log = Log.module('IrisGridTreeTableModel');
diff --git a/packages/iris-grid/src/IrisGridUtils.test.ts b/packages/iris-grid/src/IrisGridUtils.test.ts
index 5402d55b39..5e1083122a 100644
--- a/packages/iris-grid/src/IrisGridUtils.test.ts
+++ b/packages/iris-grid/src/IrisGridUtils.test.ts
@@ -1,15 +1,15 @@
import deepEqual from 'deep-equal';
-import { GridUtils, GridRange, MoveOperation } from '@deephaven/grid';
+import { GridUtils, GridRange, type MoveOperation } from '@deephaven/grid';
import dh from '@deephaven/jsapi-shim';
import type { Column, Table, Sort } from '@deephaven/jsapi-types';
-import { TypeValue as FilterTypeValue } from '@deephaven/filters';
+import { type TypeValue as FilterTypeValue } from '@deephaven/filters';
import { DateUtils } from '@deephaven/jsapi-utils';
import type { AdvancedFilter } from './CommonTypes';
-import { FilterData } from './IrisGrid';
+import { type FilterData } from './IrisGrid';
import IrisGridTestUtils from './IrisGridTestUtils';
import IrisGridUtils, {
- DehydratedSort,
- LegacyDehydratedSort,
+ type DehydratedSort,
+ type LegacyDehydratedSort,
} from './IrisGridUtils';
const irisGridUtils = new IrisGridUtils(dh);
diff --git a/packages/iris-grid/src/IrisGridUtils.ts b/packages/iris-grid/src/IrisGridUtils.ts
index 539ee7341b..2bc9c079bf 100644
--- a/packages/iris-grid/src/IrisGridUtils.ts
+++ b/packages/iris-grid/src/IrisGridUtils.ts
@@ -1,19 +1,19 @@
import {
- GridMetrics,
- GridRange,
+ type GridMetrics,
+ type GridRange,
GridUtils,
- ModelIndex,
- ModelSizeMap,
- MoveOperation,
- VisibleIndex,
+ type ModelIndex,
+ type ModelSizeMap,
+ type MoveOperation,
+ type VisibleIndex,
} from '@deephaven/grid';
import type { dh as DhType } from '@deephaven/jsapi-types';
import {
DateUtils,
TableUtils,
- ReverseType,
- SortDirection,
- FormattingRule,
+ type ReverseType,
+ type SortDirection,
+ type FormattingRule,
} from '@deephaven/jsapi-utils';
import Log from '@deephaven/log';
import {
@@ -24,27 +24,31 @@ import {
} from '@deephaven/utils';
import AggregationUtils from './sidebar/aggregations/AggregationUtils';
import AggregationOperation from './sidebar/aggregations/AggregationOperation';
-import { FilterData, IrisGridProps, IrisGridState } from './IrisGrid';
import {
- ColumnName,
- ReadonlyAdvancedFilterMap,
- ReadonlyQuickFilterMap,
- InputFilter,
- CellData,
- PendingDataMap,
- UIRow,
- AdvancedFilterOptions,
+ type FilterData,
+ type IrisGridProps,
+ type IrisGridState,
+} from './IrisGrid';
+import {
+ type ColumnName,
+ type ReadonlyAdvancedFilterMap,
+ type ReadonlyQuickFilterMap,
+ type InputFilter,
+ type CellData,
+ type PendingDataMap,
+ type UIRow,
+ type AdvancedFilterOptions,
} from './CommonTypes';
-import { UIRollupConfig } from './sidebar/RollupRows';
-import { AggregationSettings } from './sidebar/aggregations/Aggregations';
-import { FormattingRule as SidebarFormattingRule } from './sidebar/conditional-formatting/ConditionalFormattingUtils';
-import IrisGridModel from './IrisGridModel';
+import { type UIRollupConfig } from './sidebar/RollupRows';
+import { type AggregationSettings } from './sidebar/aggregations/Aggregations';
+import { type FormattingRule as SidebarFormattingRule } from './sidebar/conditional-formatting/ConditionalFormattingUtils';
+import type IrisGridModel from './IrisGridModel';
import type AdvancedSettingsType from './sidebar/AdvancedSettingsType';
import AdvancedSettings from './sidebar/AdvancedSettings';
import ColumnHeaderGroup from './ColumnHeaderGroup';
import {
isPartitionedGridModelProvider,
- PartitionConfig,
+ type PartitionConfig,
} from './PartitionedGridModel';
const log = Log.module('IrisGridUtils');
diff --git a/packages/iris-grid/src/MissingKeyError.ts b/packages/iris-grid/src/MissingKeyError.ts
index 670a8adbc0..d3468e99e7 100644
--- a/packages/iris-grid/src/MissingKeyError.ts
+++ b/packages/iris-grid/src/MissingKeyError.ts
@@ -1,5 +1,5 @@
-import { ModelIndex } from '@deephaven/grid';
-import { ColumnName } from './CommonTypes';
+import { type ModelIndex } from '@deephaven/grid';
+import { type ColumnName } from './CommonTypes';
class MissingKeyError extends Error {
isMissingKey = true;
diff --git a/packages/iris-grid/src/PartitionedGridModel.ts b/packages/iris-grid/src/PartitionedGridModel.ts
index 5a188088f2..ed5fa1399b 100644
--- a/packages/iris-grid/src/PartitionedGridModel.ts
+++ b/packages/iris-grid/src/PartitionedGridModel.ts
@@ -1,5 +1,5 @@
import type { dh } from '@deephaven/jsapi-types';
-import IrisGridModel from './IrisGridModel';
+import type IrisGridModel from './IrisGridModel';
export function isPartitionedGridModelProvider(
model: IrisGridModel
diff --git a/packages/iris-grid/src/PendingDataBottomBar.tsx b/packages/iris-grid/src/PendingDataBottomBar.tsx
index 5efa55a74c..be671fb936 100644
--- a/packages/iris-grid/src/PendingDataBottomBar.tsx
+++ b/packages/iris-grid/src/PendingDataBottomBar.tsx
@@ -5,7 +5,7 @@ import { Button, LoadingSpinner } from '@deephaven/components';
import { usePrevious } from '@deephaven/react-hooks';
import IrisGridBottomBar from './IrisGridBottomBar';
import './PendingDataBottomBar.scss';
-import { PendingDataErrorMap, PendingDataMap } from './CommonTypes';
+import { type PendingDataErrorMap, type PendingDataMap } from './CommonTypes';
const HIDE_TIMEOUT = 3000;
diff --git a/packages/iris-grid/src/format-context-menus/DateTimeFormatContextMenu.ts b/packages/iris-grid/src/format-context-menus/DateTimeFormatContextMenu.ts
index 64ca3b0fab..720981c290 100644
--- a/packages/iris-grid/src/format-context-menus/DateTimeFormatContextMenu.ts
+++ b/packages/iris-grid/src/format-context-menus/DateTimeFormatContextMenu.ts
@@ -1,11 +1,11 @@
import {
DateTimeColumnFormatter,
- Formatter,
- TableColumnFormat,
+ type Formatter,
+ type TableColumnFormat,
TableUtils,
} from '@deephaven/jsapi-utils';
import FormatContextMenuUtils, {
- FormatContextMenuOption,
+ type FormatContextMenuOption,
} from './FormatContextMenuUtils';
class DateTimeFormatContextMenu {
diff --git a/packages/iris-grid/src/format-context-menus/DecimalFormatContextMenu.ts b/packages/iris-grid/src/format-context-menus/DecimalFormatContextMenu.ts
index de525b8e9b..c7b5daf099 100644
--- a/packages/iris-grid/src/format-context-menus/DecimalFormatContextMenu.ts
+++ b/packages/iris-grid/src/format-context-menus/DecimalFormatContextMenu.ts
@@ -1,10 +1,10 @@
import {
- DecimalColumnFormat,
+ type DecimalColumnFormat,
DecimalColumnFormatter,
} from '@deephaven/jsapi-utils';
import type { dh as DhType } from '@deephaven/jsapi-types';
import FormatContextMenuUtils, {
- FormatContextMenuOption,
+ type FormatContextMenuOption,
} from './FormatContextMenuUtils';
class DecimalFormatContextMenu {
diff --git a/packages/iris-grid/src/format-context-menus/FormatContextMenuUtils.tsx b/packages/iris-grid/src/format-context-menus/FormatContextMenuUtils.tsx
index 00bd1678ef..f068c606cf 100644
--- a/packages/iris-grid/src/format-context-menus/FormatContextMenuUtils.tsx
+++ b/packages/iris-grid/src/format-context-menus/FormatContextMenuUtils.tsx
@@ -1,6 +1,6 @@
import React from 'react';
import {
- TableColumnFormat,
+ type TableColumnFormat,
TableColumnFormatter,
} from '@deephaven/jsapi-utils';
import CustomFormatAction from './CustomFormatAction';
diff --git a/packages/iris-grid/src/format-context-menus/IntegerFormatContextMenu.ts b/packages/iris-grid/src/format-context-menus/IntegerFormatContextMenu.ts
index 31889be50b..4d2552f22b 100644
--- a/packages/iris-grid/src/format-context-menus/IntegerFormatContextMenu.ts
+++ b/packages/iris-grid/src/format-context-menus/IntegerFormatContextMenu.ts
@@ -1,10 +1,10 @@
import {
- IntegerColumnFormat,
+ type IntegerColumnFormat,
IntegerColumnFormatter,
} from '@deephaven/jsapi-utils';
import type { dh as DhType } from '@deephaven/jsapi-types';
import FormatContextMenuUtils, {
- FormatContextMenuOption,
+ type FormatContextMenuOption,
} from './FormatContextMenuUtils';
class IntegerFormatContextMenu {
diff --git a/packages/iris-grid/src/key-handlers/ClearFilterKeyHandler.ts b/packages/iris-grid/src/key-handlers/ClearFilterKeyHandler.ts
index 9952febc5c..65bd79b2e1 100644
--- a/packages/iris-grid/src/key-handlers/ClearFilterKeyHandler.ts
+++ b/packages/iris-grid/src/key-handlers/ClearFilterKeyHandler.ts
@@ -1,4 +1,4 @@
-import { KeyboardEvent } from 'react';
+import { type KeyboardEvent } from 'react';
import { KeyHandler } from '@deephaven/grid';
import type IrisGrid from '../IrisGrid';
import IrisGridShortcuts from '../IrisGridShortcuts';
diff --git a/packages/iris-grid/src/key-handlers/CopyCellKeyHandler.ts b/packages/iris-grid/src/key-handlers/CopyCellKeyHandler.ts
index f5cf18589e..8f1d18570e 100644
--- a/packages/iris-grid/src/key-handlers/CopyCellKeyHandler.ts
+++ b/packages/iris-grid/src/key-handlers/CopyCellKeyHandler.ts
@@ -1,4 +1,4 @@
-import { KeyboardEvent } from 'react';
+import { type KeyboardEvent } from 'react';
import { KeyHandler } from '@deephaven/grid';
import { ContextActionUtils } from '@deephaven/components';
import type { Grid } from '@deephaven/grid';
diff --git a/packages/iris-grid/src/key-handlers/CopyKeyHandler.ts b/packages/iris-grid/src/key-handlers/CopyKeyHandler.ts
index f8365fb37f..d255b7f08c 100644
--- a/packages/iris-grid/src/key-handlers/CopyKeyHandler.ts
+++ b/packages/iris-grid/src/key-handlers/CopyKeyHandler.ts
@@ -1,5 +1,5 @@
/* eslint class-methods-use-this: "off" */
-import { KeyboardEvent } from 'react';
+import { type KeyboardEvent } from 'react';
import { ContextActionUtils } from '@deephaven/components';
import { KeyHandler } from '@deephaven/grid';
import type IrisGrid from '../IrisGrid';
diff --git a/packages/iris-grid/src/key-handlers/ReverseKeyHandler.ts b/packages/iris-grid/src/key-handlers/ReverseKeyHandler.ts
index bb3cc1047e..a8e003138b 100644
--- a/packages/iris-grid/src/key-handlers/ReverseKeyHandler.ts
+++ b/packages/iris-grid/src/key-handlers/ReverseKeyHandler.ts
@@ -1,4 +1,4 @@
-import { KeyboardEvent } from 'react';
+import { type KeyboardEvent } from 'react';
import { KeyHandler } from '@deephaven/grid';
import { TableUtils } from '@deephaven/jsapi-utils';
import type IrisGrid from '../IrisGrid';
diff --git a/packages/iris-grid/src/mousehandlers/IrisGridCellOverflowMouseHandler.ts b/packages/iris-grid/src/mousehandlers/IrisGridCellOverflowMouseHandler.ts
index cf24496ca2..042c94760f 100644
--- a/packages/iris-grid/src/mousehandlers/IrisGridCellOverflowMouseHandler.ts
+++ b/packages/iris-grid/src/mousehandlers/IrisGridCellOverflowMouseHandler.ts
@@ -1,11 +1,11 @@
import {
- GridPoint,
+ type GridPoint,
GridMouseHandler,
- EventHandlerResult,
+ type EventHandlerResult,
} from '@deephaven/grid';
import deepEqual from 'fast-deep-equal';
import type IrisGrid from '../IrisGrid';
-import { IrisGridRenderState } from '../IrisGridRenderer';
+import { type IrisGridRenderState } from '../IrisGridRenderer';
/**
* Handles cursor and click action for cell overflow button
diff --git a/packages/iris-grid/src/mousehandlers/IrisGridColumnSelectMouseHandler.ts b/packages/iris-grid/src/mousehandlers/IrisGridColumnSelectMouseHandler.ts
index c0fc76465a..e9c29363c2 100644
--- a/packages/iris-grid/src/mousehandlers/IrisGridColumnSelectMouseHandler.ts
+++ b/packages/iris-grid/src/mousehandlers/IrisGridColumnSelectMouseHandler.ts
@@ -1,12 +1,12 @@
/* eslint class-methods-use-this: "off" */
import {
GridMouseHandler,
- GridPoint,
- EventHandlerResult,
+ type GridPoint,
+ type EventHandlerResult,
} from '@deephaven/grid';
import type { dh } from '@deephaven/jsapi-types';
import type IrisGrid from '../IrisGrid';
-import { DisplayColumn } from '../IrisGridModel';
+import { type DisplayColumn } from '../IrisGridModel';
/**
* Handles interaction with tables when the Linker tool is active
diff --git a/packages/iris-grid/src/mousehandlers/IrisGridColumnTooltipMouseHandler.ts b/packages/iris-grid/src/mousehandlers/IrisGridColumnTooltipMouseHandler.ts
index 4b753a2a55..e64ccd29cd 100644
--- a/packages/iris-grid/src/mousehandlers/IrisGridColumnTooltipMouseHandler.ts
+++ b/packages/iris-grid/src/mousehandlers/IrisGridColumnTooltipMouseHandler.ts
@@ -1,10 +1,10 @@
/* eslint class-methods-use-this: "off" */
import {
GridMouseHandler,
- GridPoint,
- EventHandlerResult,
- Grid,
- GridMouseEvent,
+ type GridPoint,
+ type EventHandlerResult,
+ type Grid,
+ type GridMouseEvent,
} from '@deephaven/grid';
import type IrisGrid from '../IrisGrid';
diff --git a/packages/iris-grid/src/mousehandlers/IrisGridContextMenuHandler.tsx b/packages/iris-grid/src/mousehandlers/IrisGridContextMenuHandler.tsx
index 728ee86891..fbc817192f 100644
--- a/packages/iris-grid/src/mousehandlers/IrisGridContextMenuHandler.tsx
+++ b/packages/iris-grid/src/mousehandlers/IrisGridContextMenuHandler.tsx
@@ -6,36 +6,36 @@ import {
vsRemove,
vsCheck,
vsFilter,
- IconDefinition,
+ type IconDefinition,
} from '@deephaven/icons';
import debounce from 'lodash.debounce';
import {
- ContextAction,
+ type ContextAction,
ContextActions,
ContextActionUtils,
GLOBAL_SHORTCUTS,
- ResolvableContextAction,
+ type ResolvableContextAction,
} from '@deephaven/components';
import {
- EventHandlerResult,
- Grid,
+ type EventHandlerResult,
+ type Grid,
GridMouseHandler,
- GridPoint,
+ type GridPoint,
GridRange,
GridRenderer,
isDeletableGridModel,
isEditableGridModel,
isExpandableGridModel,
- ModelIndex,
+ type ModelIndex,
} from '@deephaven/grid';
import type { dh as DhType } from '@deephaven/jsapi-types';
import {
TableColumnFormatter,
DateTimeColumnFormatter,
TableUtils,
- TableColumnFormat,
- IntegerColumnFormat,
- SortDirection,
+ type TableColumnFormat,
+ type IntegerColumnFormat,
+ type SortDirection,
} from '@deephaven/jsapi-utils';
import Log from '@deephaven/log';
import type { DebouncedFunc } from 'lodash';
@@ -53,8 +53,8 @@ import {
} from '../format-context-menus';
import './IrisGridContextMenuHandler.scss';
import SHORTCUTS from '../IrisGridShortcuts';
-import IrisGrid from '../IrisGrid';
-import { QuickFilter } from '../CommonTypes';
+import type IrisGrid from '../IrisGrid';
+import { type QuickFilter } from '../CommonTypes';
import { isPartitionedGridModel } from '../PartitionedGridModel';
const log = Log.module('IrisGridContextMenuHandler');
diff --git a/packages/iris-grid/src/mousehandlers/IrisGridCopyCellMouseHandler.ts b/packages/iris-grid/src/mousehandlers/IrisGridCopyCellMouseHandler.ts
index 8359dd639c..9b542ce5fc 100644
--- a/packages/iris-grid/src/mousehandlers/IrisGridCopyCellMouseHandler.ts
+++ b/packages/iris-grid/src/mousehandlers/IrisGridCopyCellMouseHandler.ts
@@ -1,13 +1,13 @@
import {
- Grid,
+ type Grid,
GridMouseHandler,
- GridPoint,
- EventHandlerResult,
- GridMouseEvent,
+ type GridPoint,
+ type EventHandlerResult,
+ type GridMouseEvent,
GridRange,
} from '@deephaven/grid';
import { ContextActionUtils } from '@deephaven/components';
-import IrisGrid from '../IrisGrid';
+import type IrisGrid from '../IrisGrid';
class IrisGridCopyCellMouseHandler extends GridMouseHandler {
private irisGrid: IrisGrid;
diff --git a/packages/iris-grid/src/mousehandlers/IrisGridDataSelectMouseHandler.ts b/packages/iris-grid/src/mousehandlers/IrisGridDataSelectMouseHandler.ts
index 7b1f8e9b0b..2a6eb80ae4 100644
--- a/packages/iris-grid/src/mousehandlers/IrisGridDataSelectMouseHandler.ts
+++ b/packages/iris-grid/src/mousehandlers/IrisGridDataSelectMouseHandler.ts
@@ -2,8 +2,8 @@
import {
type Grid,
GridMouseHandler,
- GridPoint,
- EventHandlerResult,
+ type GridPoint,
+ type EventHandlerResult,
} from '@deephaven/grid';
import type IrisGrid from '../IrisGrid';
diff --git a/packages/iris-grid/src/mousehandlers/IrisGridFilterMouseHandler.ts b/packages/iris-grid/src/mousehandlers/IrisGridFilterMouseHandler.ts
index 2e4402c320..7feaf44e3d 100644
--- a/packages/iris-grid/src/mousehandlers/IrisGridFilterMouseHandler.ts
+++ b/packages/iris-grid/src/mousehandlers/IrisGridFilterMouseHandler.ts
@@ -1,8 +1,8 @@
/* eslint class-methods-use-this: "off" */
import {
GridMouseHandler,
- GridPoint,
- EventHandlerResult,
+ type GridPoint,
+ type EventHandlerResult,
} from '@deephaven/grid';
import type IrisGrid from '../IrisGrid';
diff --git a/packages/iris-grid/src/mousehandlers/IrisGridPartitionedTableMouseHandler.ts b/packages/iris-grid/src/mousehandlers/IrisGridPartitionedTableMouseHandler.ts
index aec2af84a0..79d6a87d6d 100644
--- a/packages/iris-grid/src/mousehandlers/IrisGridPartitionedTableMouseHandler.ts
+++ b/packages/iris-grid/src/mousehandlers/IrisGridPartitionedTableMouseHandler.ts
@@ -2,8 +2,8 @@
import {
type Grid,
GridMouseHandler,
- GridPoint,
- EventHandlerResult,
+ type GridPoint,
+ type EventHandlerResult,
} from '@deephaven/grid';
import type IrisGrid from '../IrisGrid';
import { isPartitionedGridModel } from '../PartitionedGridModel';
diff --git a/packages/iris-grid/src/mousehandlers/IrisGridRowTreeMouseHandler.ts b/packages/iris-grid/src/mousehandlers/IrisGridRowTreeMouseHandler.ts
index 2dd8ba7084..3c17df7a90 100644
--- a/packages/iris-grid/src/mousehandlers/IrisGridRowTreeMouseHandler.ts
+++ b/packages/iris-grid/src/mousehandlers/IrisGridRowTreeMouseHandler.ts
@@ -1,8 +1,8 @@
import {
- EventHandlerResult,
- Grid,
+ type EventHandlerResult,
+ type Grid,
GridMouseHandler,
- GridPoint,
+ type GridPoint,
GridRowTreeMouseHandler,
isExpandableGridModel,
} from '@deephaven/grid';
diff --git a/packages/iris-grid/src/mousehandlers/IrisGridSortMouseHandler.ts b/packages/iris-grid/src/mousehandlers/IrisGridSortMouseHandler.ts
index c7bd60825e..bcd8f830f5 100644
--- a/packages/iris-grid/src/mousehandlers/IrisGridSortMouseHandler.ts
+++ b/packages/iris-grid/src/mousehandlers/IrisGridSortMouseHandler.ts
@@ -1,12 +1,12 @@
/* eslint class-methods-use-this: "off" */
import { ContextActionUtils } from '@deephaven/components';
import {
- Grid,
- GridMouseEvent,
+ type Grid,
+ type GridMouseEvent,
GridMouseHandler,
- GridPoint,
- GridRangeIndex,
- EventHandlerResult,
+ type GridPoint,
+ type GridRangeIndex,
+ type EventHandlerResult,
} from '@deephaven/grid';
import type IrisGrid from '../IrisGrid';
diff --git a/packages/iris-grid/src/mousehandlers/IrisGridTokenMouseHandler.ts b/packages/iris-grid/src/mousehandlers/IrisGridTokenMouseHandler.ts
index 3c62248c6d..b8d4a4b7f7 100644
--- a/packages/iris-grid/src/mousehandlers/IrisGridTokenMouseHandler.ts
+++ b/packages/iris-grid/src/mousehandlers/IrisGridTokenMouseHandler.ts
@@ -1,16 +1,16 @@
import {
- EventHandlerResult,
+ type EventHandlerResult,
getOrThrow,
- Grid,
+ type Grid,
GridMouseHandler,
- GridPoint,
+ type GridPoint,
GridUtils,
isLinkToken,
- TokenBox,
+ type TokenBox,
isTokenBoxCellRenderer,
} from '@deephaven/grid';
import deepEqual from 'fast-deep-equal';
-import IrisGrid from '../IrisGrid';
+import type IrisGrid from '../IrisGrid';
class IrisGridTokenMouseHandler extends GridMouseHandler {
private irisGrid: IrisGrid;
diff --git a/packages/iris-grid/src/mousehandlers/PendingMouseHandler.ts b/packages/iris-grid/src/mousehandlers/PendingMouseHandler.ts
index eb70591814..3681ad1e37 100644
--- a/packages/iris-grid/src/mousehandlers/PendingMouseHandler.ts
+++ b/packages/iris-grid/src/mousehandlers/PendingMouseHandler.ts
@@ -1,14 +1,14 @@
/* eslint class-methods-use-this: "off" */
import {
- Grid,
+ type Grid,
GridMouseHandler,
- GridPoint,
+ type GridPoint,
GridUtils,
- GridWheelEvent,
+ type GridWheelEvent,
isEditableGridModel,
} from '@deephaven/grid';
import { assertNotNull } from '@deephaven/utils';
-import IrisGrid from '../IrisGrid';
+import type IrisGrid from '../IrisGrid';
/**
* Handles sending data selected via double click
diff --git a/packages/iris-grid/src/sidebar/AdvancedSettingsMenu.tsx b/packages/iris-grid/src/sidebar/AdvancedSettingsMenu.tsx
index 68089731d2..7823340390 100644
--- a/packages/iris-grid/src/sidebar/AdvancedSettingsMenu.tsx
+++ b/packages/iris-grid/src/sidebar/AdvancedSettingsMenu.tsx
@@ -1,5 +1,5 @@
import React from 'react';
-import { Menu, SwitchMenuItemDef } from '@deephaven/components';
+import { Menu, type SwitchMenuItemDef } from '@deephaven/components';
import AdvancedSettingsType from './AdvancedSettingsType';
export type AdvancedSettingsMenuCallback = (
diff --git a/packages/iris-grid/src/sidebar/ChartBuilder.tsx b/packages/iris-grid/src/sidebar/ChartBuilder.tsx
index 887f84f349..47e8ecf3ca 100644
--- a/packages/iris-grid/src/sidebar/ChartBuilder.tsx
+++ b/packages/iris-grid/src/sidebar/ChartBuilder.tsx
@@ -22,7 +22,7 @@ import {
ScatterIcon,
} from './icons';
import './ChartBuilder.scss';
-import IrisGridModel from '../IrisGridModel';
+import type IrisGridModel from '../IrisGridModel';
const log = Log.module('ChartBuilder');
diff --git a/packages/iris-grid/src/sidebar/CustomColumnBuilder.test.tsx b/packages/iris-grid/src/sidebar/CustomColumnBuilder.test.tsx
index 8586920df6..9610933454 100644
--- a/packages/iris-grid/src/sidebar/CustomColumnBuilder.test.tsx
+++ b/packages/iris-grid/src/sidebar/CustomColumnBuilder.test.tsx
@@ -4,7 +4,7 @@ import userEvent from '@testing-library/user-event';
import { EventShimCustomEvent } from '@deephaven/utils';
import dh from '@deephaven/jsapi-shim';
import CustomColumnBuilder, {
- CustomColumnBuilderProps,
+ type CustomColumnBuilderProps,
} from './CustomColumnBuilder';
import IrisGridTestUtils from '../IrisGridTestUtils';
import IrisGridModel from '../IrisGridModel';
diff --git a/packages/iris-grid/src/sidebar/CustomColumnBuilder.tsx b/packages/iris-grid/src/sidebar/CustomColumnBuilder.tsx
index 0f32fe1fdd..a9c4052115 100644
--- a/packages/iris-grid/src/sidebar/CustomColumnBuilder.tsx
+++ b/packages/iris-grid/src/sidebar/CustomColumnBuilder.tsx
@@ -1,12 +1,16 @@
-import React, { Component, ReactElement } from 'react';
+import React, { Component, type ReactElement } from 'react';
import classNames from 'classnames';
import { nanoid } from 'nanoid';
import memoize from 'memoize-one';
-import { DragDropContext, Droppable, DropResult } from 'react-beautiful-dnd';
+import {
+ DragDropContext,
+ Droppable,
+ type DropResult,
+} from 'react-beautiful-dnd';
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
import { Button, DragUtils, LoadingSpinner } from '@deephaven/components';
import { dhNewCircleLargeFilled, vsWarning, vsPass } from '@deephaven/icons';
-import { DbNameValidator, EventT } from '@deephaven/utils';
+import { DbNameValidator, type EventT } from '@deephaven/utils';
import CustomColumnInput from './CustomColumnInput';
import './CustomColumnBuilder.scss';
import IrisGridModel from '../IrisGridModel';
diff --git a/packages/iris-grid/src/sidebar/CustomColumnInput.test.tsx b/packages/iris-grid/src/sidebar/CustomColumnInput.test.tsx
index c6f7cce053..25bb06f0b8 100644
--- a/packages/iris-grid/src/sidebar/CustomColumnInput.test.tsx
+++ b/packages/iris-grid/src/sidebar/CustomColumnInput.test.tsx
@@ -2,7 +2,9 @@ import { render, screen } from '@testing-library/react';
import userEvent from '@testing-library/user-event';
import React from 'react';
import { DragDropContext, Droppable } from 'react-beautiful-dnd';
-import CustomColumnInput, { CustomColumnInputProps } from './CustomColumnInput';
+import CustomColumnInput, {
+ type CustomColumnInputProps,
+} from './CustomColumnInput';
const TEST_ID = 'TEST_ID';
diff --git a/packages/iris-grid/src/sidebar/CustomColumnInput.tsx b/packages/iris-grid/src/sidebar/CustomColumnInput.tsx
index d15817e5b5..0d3cb9173c 100644
--- a/packages/iris-grid/src/sidebar/CustomColumnInput.tsx
+++ b/packages/iris-grid/src/sidebar/CustomColumnInput.tsx
@@ -5,7 +5,7 @@ import { Button } from '@deephaven/components';
import { vsTrash, vsGripper } from '@deephaven/icons';
import { DbNameValidator } from '@deephaven/utils';
import InputEditor from './InputEditor';
-import { CustomColumnKey } from './CustomColumnBuilder';
+import { type CustomColumnKey } from './CustomColumnBuilder';
export interface CustomColumnInputProps {
eventKey: string;
diff --git a/packages/iris-grid/src/sidebar/InputEditor.tsx b/packages/iris-grid/src/sidebar/InputEditor.tsx
index 68fe812b31..ae10feba05 100644
--- a/packages/iris-grid/src/sidebar/InputEditor.tsx
+++ b/packages/iris-grid/src/sidebar/InputEditor.tsx
@@ -1,4 +1,4 @@
-import React, { Component, ReactElement } from 'react';
+import React, { Component, type ReactElement } from 'react';
import * as monaco from 'monaco-editor';
import classNames from 'classnames';
import './InputEditor.scss';
diff --git a/packages/iris-grid/src/sidebar/RollupRows.tsx b/packages/iris-grid/src/sidebar/RollupRows.tsx
index b5c9ac5aea..d31f5e5544 100644
--- a/packages/iris-grid/src/sidebar/RollupRows.tsx
+++ b/packages/iris-grid/src/sidebar/RollupRows.tsx
@@ -1,13 +1,18 @@
/* eslint-disable jsx-a11y/click-events-have-key-events */
-import React, { ChangeEvent, Component, ReactElement, RefObject } from 'react';
+import React, {
+ type ChangeEvent,
+ Component,
+ type ReactElement,
+ type RefObject,
+} from 'react';
import classNames from 'classnames';
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
import {
DragDropContext,
- DraggableLocation,
- DragStart,
+ type DraggableLocation,
+ type DragStart,
Droppable,
- DropResult,
+ type DropResult,
} from 'react-beautiful-dnd';
import {
Checkbox,
@@ -15,20 +20,20 @@ import {
DragUtils,
SearchInput,
Tooltip,
- Range,
- RenderItemProps,
+ type Range,
+ type RenderItemProps,
Button,
} from '@deephaven/components';
import { vsTrash, dhSortAlphaDown, dhSortAlphaUp } from '@deephaven/icons';
-import { TableUtils, SortDirection } from '@deephaven/jsapi-utils';
+import { TableUtils, type SortDirection } from '@deephaven/jsapi-utils';
import memoize from 'memoizee';
import debounce from 'lodash.debounce';
import Log from '@deephaven/log';
import { assertNotNull } from '@deephaven/utils';
import './RollupRows.scss';
import type { dh } from '@deephaven/jsapi-types';
-import IrisGridModel from '../IrisGridModel';
-import { ColumnName } from '../CommonTypes';
+import type IrisGridModel from '../IrisGridModel';
+import { type ColumnName } from '../CommonTypes';
const log = Log.module('RollupRows');
const DEBOUNCE_SEARCH = 150;
diff --git a/packages/iris-grid/src/sidebar/SelectDistinctBuilder.tsx b/packages/iris-grid/src/sidebar/SelectDistinctBuilder.tsx
index 0f6c89cda1..5428470abe 100644
--- a/packages/iris-grid/src/sidebar/SelectDistinctBuilder.tsx
+++ b/packages/iris-grid/src/sidebar/SelectDistinctBuilder.tsx
@@ -1,15 +1,15 @@
-import React, { Component, ReactElement } from 'react';
+import React, { Component, type ReactElement } from 'react';
import deepEqual from 'fast-deep-equal';
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
import { dhNewCircleLargeFilled, vsTrash } from '@deephaven/icons';
import { Button, Select } from '@deephaven/components';
import Log from '@deephaven/log';
import type { dh } from '@deephaven/jsapi-types';
-import { ModelIndex } from '@deephaven/grid';
-import IrisGridModel from '../IrisGridModel';
+import { type ModelIndex } from '@deephaven/grid';
+import type IrisGridModel from '../IrisGridModel';
import './SelectDistinctBuilder.scss';
-import { ColumnName } from '../CommonTypes';
+import { type ColumnName } from '../CommonTypes';
const log = Log.module('SelectDistinctBuilder');
diff --git a/packages/iris-grid/src/sidebar/TableCsvExporter.tsx b/packages/iris-grid/src/sidebar/TableCsvExporter.tsx
index 0744362f93..74aa3ff81b 100644
--- a/packages/iris-grid/src/sidebar/TableCsvExporter.tsx
+++ b/packages/iris-grid/src/sidebar/TableCsvExporter.tsx
@@ -1,4 +1,4 @@
-import React, { Component, ReactElement } from 'react';
+import React, { Component, type ReactElement } from 'react';
import ClassNames from 'classnames';
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
import {
@@ -12,8 +12,8 @@ import {
import {
GridRange,
GridUtils,
- ModelSizeMap,
- MoveOperation,
+ type ModelSizeMap,
+ type MoveOperation,
} from '@deephaven/grid';
import { vsWarning } from '@deephaven/icons';
import type { dh as DhType } from '@deephaven/jsapi-types';
@@ -21,7 +21,7 @@ import { TimeUtils } from '@deephaven/utils';
import { nanoid } from 'nanoid';
import './TableCsvExporter.scss';
import Log from '@deephaven/log';
-import IrisGridModel from '../IrisGridModel';
+import type IrisGridModel from '../IrisGridModel';
import IrisGridUtils from '../IrisGridUtils';
const log = Log.module('TableCsvExporter');
diff --git a/packages/iris-grid/src/sidebar/TableSaver.tsx b/packages/iris-grid/src/sidebar/TableSaver.tsx
index e78004bdf5..afe730bf3a 100644
--- a/packages/iris-grid/src/sidebar/TableSaver.tsx
+++ b/packages/iris-grid/src/sidebar/TableSaver.tsx
@@ -1,10 +1,18 @@
import { PureComponent } from 'react';
import type { dh as DhType } from '@deephaven/jsapi-types';
import Log from '@deephaven/log';
-import { GridRange, GridRangeIndex, memoizeClear } from '@deephaven/grid';
-import { Formatter, FormatterUtils, TableUtils } from '@deephaven/jsapi-utils';
import {
- CancelablePromise,
+ type GridRange,
+ type GridRangeIndex,
+ memoizeClear,
+} from '@deephaven/grid';
+import {
+ type Formatter,
+ FormatterUtils,
+ TableUtils,
+} from '@deephaven/jsapi-utils';
+import {
+ type CancelablePromise,
PromiseUtils,
assertNotNull,
} from '@deephaven/utils';
diff --git a/packages/iris-grid/src/sidebar/aggregations/AggregationEdit.test.tsx b/packages/iris-grid/src/sidebar/aggregations/AggregationEdit.test.tsx
index dda9424b1e..74f147858a 100644
--- a/packages/iris-grid/src/sidebar/aggregations/AggregationEdit.test.tsx
+++ b/packages/iris-grid/src/sidebar/aggregations/AggregationEdit.test.tsx
@@ -1,7 +1,7 @@
import React from 'react';
-import { render, RenderResult, screen } from '@testing-library/react';
+import { render, type RenderResult, screen } from '@testing-library/react';
import userEvent from '@testing-library/user-event';
-import { Aggregation } from './Aggregations';
+import { type Aggregation } from './Aggregations';
import AggregationEdit from './AggregationEdit';
import AggregationOperation from './AggregationOperation';
diff --git a/packages/iris-grid/src/sidebar/aggregations/AggregationEdit.tsx b/packages/iris-grid/src/sidebar/aggregations/AggregationEdit.tsx
index 7e361b17da..29af5a2347 100644
--- a/packages/iris-grid/src/sidebar/aggregations/AggregationEdit.tsx
+++ b/packages/iris-grid/src/sidebar/aggregations/AggregationEdit.tsx
@@ -9,10 +9,10 @@ import {
} from '@deephaven/components';
import { dhSortAlphaDown, dhSortAlphaUp } from '@deephaven/icons';
import { TableUtils } from '@deephaven/jsapi-utils';
-import { Aggregation } from './Aggregations';
+import { type Aggregation } from './Aggregations';
import { filterValidColumns } from './AggregationUtils';
import './AggregationEdit.scss';
-import { DisplayColumn } from '../../IrisGridModel';
+import { type DisplayColumn } from '../../IrisGridModel';
interface AggregationEditItem {
value: string;
diff --git a/packages/iris-grid/src/sidebar/aggregations/AggregationUtils.ts b/packages/iris-grid/src/sidebar/aggregations/AggregationUtils.ts
index 9233ab906b..ff24a6873d 100644
--- a/packages/iris-grid/src/sidebar/aggregations/AggregationUtils.ts
+++ b/packages/iris-grid/src/sidebar/aggregations/AggregationUtils.ts
@@ -1,5 +1,5 @@
import { TableUtils } from '@deephaven/jsapi-utils';
-import { DisplayColumn } from '../../IrisGridModel';
+import { type DisplayColumn } from '../../IrisGridModel';
import AggregationOperation from './AggregationOperation';
export const SELECTABLE_OPTIONS = [
diff --git a/packages/iris-grid/src/sidebar/aggregations/Aggregations.test.tsx b/packages/iris-grid/src/sidebar/aggregations/Aggregations.test.tsx
index 3d081ec3a6..1004742832 100644
--- a/packages/iris-grid/src/sidebar/aggregations/Aggregations.test.tsx
+++ b/packages/iris-grid/src/sidebar/aggregations/Aggregations.test.tsx
@@ -1,7 +1,7 @@
import React from 'react';
-import { render, RenderResult, screen } from '@testing-library/react';
+import { render, type RenderResult, screen } from '@testing-library/react';
import userEvent from '@testing-library/user-event';
-import Aggregations, { Aggregation } from './Aggregations';
+import Aggregations, { type Aggregation } from './Aggregations';
import AggregationOperation from './AggregationOperation';
import { SELECTABLE_OPTIONS } from './AggregationUtils';
diff --git a/packages/iris-grid/src/sidebar/aggregations/Aggregations.tsx b/packages/iris-grid/src/sidebar/aggregations/Aggregations.tsx
index 4fe7a25499..71b9a0c776 100644
--- a/packages/iris-grid/src/sidebar/aggregations/Aggregations.tsx
+++ b/packages/iris-grid/src/sidebar/aggregations/Aggregations.tsx
@@ -19,8 +19,8 @@ import {
Button,
} from '@deephaven/components';
import type { DraggableRenderItemProps, Range } from '@deephaven/components';
-import { ModelIndex } from '@deephaven/grid';
-import AggregationOperation from './AggregationOperation';
+import { type ModelIndex } from '@deephaven/grid';
+import type AggregationOperation from './AggregationOperation';
import AggregationUtils, { SELECTABLE_OPTIONS } from './AggregationUtils';
import './Aggregations.scss';
diff --git a/packages/iris-grid/src/sidebar/conditional-formatting/ColumnFormatEditor.tsx b/packages/iris-grid/src/sidebar/conditional-formatting/ColumnFormatEditor.tsx
index 1417ff4622..499310b420 100644
--- a/packages/iris-grid/src/sidebar/conditional-formatting/ColumnFormatEditor.tsx
+++ b/packages/iris-grid/src/sidebar/conditional-formatting/ColumnFormatEditor.tsx
@@ -3,12 +3,12 @@ import Log from '@deephaven/log';
import { ComboBox } from '@deephaven/components';
import type { dh as DhType } from '@deephaven/jsapi-types';
import {
- BaseFormatConfig,
- ChangeCallback,
+ type BaseFormatConfig,
+ type ChangeCallback,
getDefaultConditionConfigForType,
getConditionConfig,
getDefaultStyleConfig,
- ModelColumn,
+ type ModelColumn,
FormatStyleType,
} from './ConditionalFormattingUtils';
import ConditionEditor from './ConditionEditor';
diff --git a/packages/iris-grid/src/sidebar/conditional-formatting/ConditionEditor.tsx b/packages/iris-grid/src/sidebar/conditional-formatting/ConditionEditor.tsx
index 712aa0a88f..8eb362da25 100644
--- a/packages/iris-grid/src/sidebar/conditional-formatting/ConditionEditor.tsx
+++ b/packages/iris-grid/src/sidebar/conditional-formatting/ConditionEditor.tsx
@@ -10,13 +10,13 @@ import {
getLabelForDateCondition,
getLabelForStringCondition,
NumberCondition,
- ModelColumn,
- ConditionConfig,
+ type ModelColumn,
+ type ConditionConfig,
getDefaultConditionForType,
getLabelForBooleanCondition,
BooleanCondition,
CharCondition,
- Condition,
+ type Condition,
getLabelForCharCondition,
isDateConditionValid,
getDefaultValueForType,
diff --git a/packages/iris-grid/src/sidebar/conditional-formatting/ConditionalFormatEditor.tsx b/packages/iris-grid/src/sidebar/conditional-formatting/ConditionalFormatEditor.tsx
index 2737d978f3..92514d9201 100644
--- a/packages/iris-grid/src/sidebar/conditional-formatting/ConditionalFormatEditor.tsx
+++ b/packages/iris-grid/src/sidebar/conditional-formatting/ConditionalFormatEditor.tsx
@@ -7,11 +7,11 @@ import { FormatColumnWhereIcon, FormatRowWhereIcon } from '../icons';
import ColumnFormatEditor from './ColumnFormatEditor';
import RowFormatEditor from './RowFormatEditor';
import {
- BaseFormatConfig,
+ type BaseFormatConfig,
FormatterType,
- FormattingRule,
+ type FormattingRule,
isSupportedColumn,
- ModelColumn,
+ type ModelColumn,
} from './ConditionalFormattingUtils';
import './ConditionalFormatEditor.scss';
diff --git a/packages/iris-grid/src/sidebar/conditional-formatting/ConditionalFormattingAPIUtils.ts b/packages/iris-grid/src/sidebar/conditional-formatting/ConditionalFormattingAPIUtils.ts
index e94260f8ed..524be7a158 100644
--- a/packages/iris-grid/src/sidebar/conditional-formatting/ConditionalFormattingAPIUtils.ts
+++ b/packages/iris-grid/src/sidebar/conditional-formatting/ConditionalFormattingAPIUtils.ts
@@ -1,6 +1,6 @@
import type { dh as DhType } from '@deephaven/jsapi-types';
import {
- BaseFormatConfig,
+ type BaseFormatConfig,
getConditionDBString,
getStyleDBString,
} from './ConditionalFormattingUtils';
diff --git a/packages/iris-grid/src/sidebar/conditional-formatting/ConditionalFormattingMenu.tsx b/packages/iris-grid/src/sidebar/conditional-formatting/ConditionalFormattingMenu.tsx
index d79bc7f3fe..cf95100d0e 100644
--- a/packages/iris-grid/src/sidebar/conditional-formatting/ConditionalFormattingMenu.tsx
+++ b/packages/iris-grid/src/sidebar/conditional-formatting/ConditionalFormattingMenu.tsx
@@ -3,7 +3,7 @@ import {
DragDropContext,
Draggable,
Droppable,
- DropResult,
+ type DropResult,
} from 'react-beautiful-dnd';
import classNames from 'classnames';
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
@@ -13,8 +13,8 @@ import { TableUtils } from '@deephaven/jsapi-utils';
import Log from '@deephaven/log';
import './ConditionalFormattingMenu.scss';
import {
- BaseFormatConfig,
- FormattingRule,
+ type BaseFormatConfig,
+ type FormattingRule,
FormatterType,
getBackgroundForStyleConfig,
getColorForStyleConfig,
@@ -23,7 +23,7 @@ import {
StringCondition,
DateCondition,
} from './ConditionalFormattingUtils';
-import { ColumnName } from '../../CommonTypes';
+import { type ColumnName } from '../../CommonTypes';
const log = Log.module('ConditionalFormattingMenu');
diff --git a/packages/iris-grid/src/sidebar/conditional-formatting/ConditionalFormattingUtils.test.ts b/packages/iris-grid/src/sidebar/conditional-formatting/ConditionalFormattingUtils.test.ts
index 493cbac805..c1bc8a78cb 100644
--- a/packages/iris-grid/src/sidebar/conditional-formatting/ConditionalFormattingUtils.test.ts
+++ b/packages/iris-grid/src/sidebar/conditional-formatting/ConditionalFormattingUtils.test.ts
@@ -5,7 +5,7 @@ import {
DateCondition,
FormatStyleType,
FormatterType,
- FormattingRule,
+ type FormattingRule,
getFormatColumns,
isDateConditionValid,
StringCondition,
diff --git a/packages/iris-grid/src/sidebar/conditional-formatting/ConditionalFormattingUtils.ts b/packages/iris-grid/src/sidebar/conditional-formatting/ConditionalFormattingUtils.ts
index 9e57181427..99b8903e6d 100644
--- a/packages/iris-grid/src/sidebar/conditional-formatting/ConditionalFormattingUtils.ts
+++ b/packages/iris-grid/src/sidebar/conditional-formatting/ConditionalFormattingUtils.ts
@@ -6,7 +6,7 @@ import {
makeRowFormatColumn,
makeTernaryFormatRule,
} from './ConditionalFormattingAPIUtils';
-import { ColumnName } from '../../CommonTypes';
+import { type ColumnName } from '../../CommonTypes';
const log = Log.module('ConditionalFormattingUtils');
diff --git a/packages/iris-grid/src/sidebar/conditional-formatting/RowFormatEditor.tsx b/packages/iris-grid/src/sidebar/conditional-formatting/RowFormatEditor.tsx
index ad2e438444..d6a8193008 100644
--- a/packages/iris-grid/src/sidebar/conditional-formatting/RowFormatEditor.tsx
+++ b/packages/iris-grid/src/sidebar/conditional-formatting/RowFormatEditor.tsx
@@ -3,12 +3,12 @@ import Log from '@deephaven/log';
import type { dh as DhType } from '@deephaven/jsapi-types';
import { ComboBox } from '@deephaven/components';
import {
- BaseFormatConfig,
- ChangeCallback,
+ type BaseFormatConfig,
+ type ChangeCallback,
getDefaultConditionConfigForType,
getConditionConfig,
getDefaultStyleConfig,
- ModelColumn,
+ type ModelColumn,
} from './ConditionalFormattingUtils';
import ConditionEditor from './ConditionEditor';
import StyleEditor from './StyleEditor';
diff --git a/packages/iris-grid/src/sidebar/conditional-formatting/StyleEditor.tsx b/packages/iris-grid/src/sidebar/conditional-formatting/StyleEditor.tsx
index 5ede1fb693..635f8c195d 100644
--- a/packages/iris-grid/src/sidebar/conditional-formatting/StyleEditor.tsx
+++ b/packages/iris-grid/src/sidebar/conditional-formatting/StyleEditor.tsx
@@ -13,7 +13,7 @@ import { Button, DropdownMenu } from '@deephaven/components';
import {
FormatStyleType,
getLabelForStyleType,
- FormatStyleConfig,
+ type FormatStyleConfig,
getBackgroundForStyleConfig,
getColorForStyleConfig,
} from './ConditionalFormattingUtils';
diff --git a/packages/iris-grid/src/sidebar/index.ts b/packages/iris-grid/src/sidebar/index.ts
index 855a96e96d..7da2c16fa9 100644
--- a/packages/iris-grid/src/sidebar/index.ts
+++ b/packages/iris-grid/src/sidebar/index.ts
@@ -9,7 +9,7 @@ import RollupRows from './RollupRows';
import TableCsvExporter from './TableCsvExporter';
import TableSaver from './TableSaver';
import VisibilityOrderingBuilder from './visibility-ordering-builder/VisibilityOrderingBuilder';
-import { FormattingRule } from './conditional-formatting/ConditionalFormattingUtils';
+import { type FormattingRule } from './conditional-formatting/ConditionalFormattingUtils';
import AdvancedSettingsType from './AdvancedSettingsType';
import DownloadServiceWorkerUtils from './DownloadServiceWorkerUtils';
diff --git a/packages/iris-grid/src/sidebar/visibility-ordering-builder/VisibilityOrderingBuilder.tsx b/packages/iris-grid/src/sidebar/visibility-ordering-builder/VisibilityOrderingBuilder.tsx
index 366276e596..5b113cffdc 100644
--- a/packages/iris-grid/src/sidebar/visibility-ordering-builder/VisibilityOrderingBuilder.tsx
+++ b/packages/iris-grid/src/sidebar/visibility-ordering-builder/VisibilityOrderingBuilder.tsx
@@ -1,10 +1,14 @@
-import React, { ChangeEvent, PureComponent, ReactElement } from 'react';
+import React, {
+ type ChangeEvent,
+ PureComponent,
+ type ReactElement,
+} from 'react';
import classNames from 'classnames';
import {
GridUtils,
- ModelIndex,
- MoveOperation,
- VisibleIndex,
+ type ModelIndex,
+ type MoveOperation,
+ type VisibleIndex,
} from '@deephaven/grid';
import { TextUtils, assertNotNull, DbNameValidator } from '@deephaven/utils';
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
@@ -29,18 +33,19 @@ import { Button, SearchInput } from '@deephaven/components';
import clamp from 'lodash.clamp';
import throttle from 'lodash.throttle';
import './VisibilityOrderingBuilder.scss';
-import IrisGridModel, { DisplayColumn } from '../../IrisGridModel';
-import { ColumnName } from '../../CommonTypes';
+import { type DisplayColumn } from '../../IrisGridModel';
+import type IrisGridModel from '../../IrisGridModel';
+import { type ColumnName } from '../../CommonTypes';
import ColumnHeaderGroup from '../../ColumnHeaderGroup';
import VisibilityOrderingItem from './VisibilityOrderingItem';
import {
- FlattenedIrisGridTreeItem,
+ type FlattenedIrisGridTreeItem,
flattenTree,
getTreeItems,
- IrisGridTreeItem,
+ type IrisGridTreeItem,
} from './sortable-tree/utilities';
import SortableTree from './sortable-tree/SortableTree';
-import { TreeItemRenderFn } from './sortable-tree/TreeItem';
+import { type TreeItemRenderFn } from './sortable-tree/TreeItem';
import {
moveItemsFromDrop,
moveToGroup,
diff --git a/packages/iris-grid/src/sidebar/visibility-ordering-builder/VisibilityOrderingBuilderUtils.test.ts b/packages/iris-grid/src/sidebar/visibility-ordering-builder/VisibilityOrderingBuilderUtils.test.ts
index 969d90e69f..6427752334 100644
--- a/packages/iris-grid/src/sidebar/visibility-ordering-builder/VisibilityOrderingBuilderUtils.test.ts
+++ b/packages/iris-grid/src/sidebar/visibility-ordering-builder/VisibilityOrderingBuilderUtils.test.ts
@@ -6,7 +6,7 @@ import {
moveToGroup,
} from './VisibilityOrderingBuilderUtils';
import {
- FlattenedIrisGridTreeItem,
+ type FlattenedIrisGridTreeItem,
flattenTree,
getProjection,
getTreeItems,
diff --git a/packages/iris-grid/src/sidebar/visibility-ordering-builder/VisibilityOrderingBuilderUtils.ts b/packages/iris-grid/src/sidebar/visibility-ordering-builder/VisibilityOrderingBuilderUtils.ts
index f9f6ceb069..b04d53c5e1 100644
--- a/packages/iris-grid/src/sidebar/visibility-ordering-builder/VisibilityOrderingBuilderUtils.ts
+++ b/packages/iris-grid/src/sidebar/visibility-ordering-builder/VisibilityOrderingBuilderUtils.ts
@@ -1,8 +1,8 @@
-import { GridUtils, MoveOperation } from '@deephaven/grid';
+import { GridUtils, type MoveOperation } from '@deephaven/grid';
import clamp from 'lodash.clamp';
import ColumnHeaderGroup from '../../ColumnHeaderGroup';
-import { FlattenedItem } from './sortable-tree/types';
-import { FlattenedIrisGridTreeItem } from './sortable-tree/utilities';
+import { type FlattenedItem } from './sortable-tree/types';
+import { type FlattenedIrisGridTreeItem } from './sortable-tree/utilities';
/**
* Moves an item as the result of drag and drop in the visibility ordering builder
diff --git a/packages/iris-grid/src/sidebar/visibility-ordering-builder/VisibilityOrderingItem.tsx b/packages/iris-grid/src/sidebar/visibility-ordering-builder/VisibilityOrderingItem.tsx
index 2624d08f05..9bdcd571e9 100644
--- a/packages/iris-grid/src/sidebar/visibility-ordering-builder/VisibilityOrderingItem.tsx
+++ b/packages/iris-grid/src/sidebar/visibility-ordering-builder/VisibilityOrderingItem.tsx
@@ -5,7 +5,7 @@ import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
import { dhEye, dhEyeSlash, vsGripper } from '@deephaven/icons';
import { Button, Tooltip } from '@deephaven/components';
import VisibilityOrderingGroup from './VisibilityOrderingGroup';
-import { FlattenedIrisGridTreeItem } from './sortable-tree/utilities';
+import { type FlattenedIrisGridTreeItem } from './sortable-tree/utilities';
import type ColumnHeaderGroup from '../../ColumnHeaderGroup';
type VisibilityOrderingItemProps = {
diff --git a/packages/iris-grid/src/sidebar/visibility-ordering-builder/sortable-tree/SortableTree.tsx b/packages/iris-grid/src/sidebar/visibility-ordering-builder/sortable-tree/SortableTree.tsx
index 6cc1c7f56e..c399dca2aa 100644
--- a/packages/iris-grid/src/sidebar/visibility-ordering-builder/sortable-tree/SortableTree.tsx
+++ b/packages/iris-grid/src/sidebar/visibility-ordering-builder/sortable-tree/SortableTree.tsx
@@ -11,10 +11,10 @@ import {
KeyboardSensor,
useSensor,
useSensors,
- DragStartEvent,
- DragMoveEvent,
- DragEndEvent,
- DragOverEvent,
+ type DragStartEvent,
+ type DragMoveEvent,
+ type DragEndEvent,
+ type DragOverEvent,
MeasuringStrategy,
} from '@dnd-kit/core';
import {
diff --git a/packages/iris-grid/src/sidebar/visibility-ordering-builder/sortable-tree/SortableTreeInner.tsx b/packages/iris-grid/src/sidebar/visibility-ordering-builder/sortable-tree/SortableTreeInner.tsx
index f91f782ce5..292f1579a8 100644
--- a/packages/iris-grid/src/sidebar/visibility-ordering-builder/sortable-tree/SortableTreeInner.tsx
+++ b/packages/iris-grid/src/sidebar/visibility-ordering-builder/sortable-tree/SortableTreeInner.tsx
@@ -3,8 +3,8 @@ import { createPortal } from 'react-dom';
import classNames from 'classnames';
import {
DragOverlay,
- DropAnimation,
- Modifier,
+ type DropAnimation,
+ type Modifier,
defaultDropAnimation,
useDndContext,
} from '@dnd-kit/core';
diff --git a/packages/iris-grid/src/sidebar/visibility-ordering-builder/sortable-tree/SortableTreeItem.tsx b/packages/iris-grid/src/sidebar/visibility-ordering-builder/sortable-tree/SortableTreeItem.tsx
index 621e706cea..653bfadc91 100644
--- a/packages/iris-grid/src/sidebar/visibility-ordering-builder/sortable-tree/SortableTreeItem.tsx
+++ b/packages/iris-grid/src/sidebar/visibility-ordering-builder/sortable-tree/SortableTreeItem.tsx
@@ -1,8 +1,8 @@
/* eslint-disable import/prefer-default-export */
-import React, { CSSProperties, useMemo } from 'react';
-import { AnimateLayoutChanges, useSortable } from '@dnd-kit/sortable';
+import React, { type CSSProperties, useMemo } from 'react';
+import { type AnimateLayoutChanges, useSortable } from '@dnd-kit/sortable';
import { CSS } from '@dnd-kit/utilities';
-import { TreeItem, Props as TreeItemProps } from './TreeItem';
+import { TreeItem, type Props as TreeItemProps } from './TreeItem';
export interface Props extends Omit, 'style'> {
id: string;
diff --git a/packages/iris-grid/src/sidebar/visibility-ordering-builder/sortable-tree/keyboardCoordinates.ts b/packages/iris-grid/src/sidebar/visibility-ordering-builder/sortable-tree/keyboardCoordinates.ts
index 2d38590b5b..a26b0cb8c0 100644
--- a/packages/iris-grid/src/sidebar/visibility-ordering-builder/sortable-tree/keyboardCoordinates.ts
+++ b/packages/iris-grid/src/sidebar/visibility-ordering-builder/sortable-tree/keyboardCoordinates.ts
@@ -3,8 +3,8 @@ import {
closestCorners,
getFirstCollision,
KeyboardCode,
- KeyboardCoordinateGetter,
- DroppableContainer,
+ type KeyboardCoordinateGetter,
+ type DroppableContainer,
} from '@dnd-kit/core';
import type { SensorContext } from './types';
import { getProjection } from './utilities';
diff --git a/packages/iris-grid/src/sidebar/visibility-ordering-builder/sortable-tree/utilities.ts b/packages/iris-grid/src/sidebar/visibility-ordering-builder/sortable-tree/utilities.ts
index a0ab240408..a0986aea94 100644
--- a/packages/iris-grid/src/sidebar/visibility-ordering-builder/sortable-tree/utilities.ts
+++ b/packages/iris-grid/src/sidebar/visibility-ordering-builder/sortable-tree/utilities.ts
@@ -1,8 +1,12 @@
import { arrayMove } from '@dnd-kit/sortable';
import type { dh } from '@deephaven/jsapi-types';
-import { GridUtils, ModelIndex, MoveOperation } from '@deephaven/grid';
+import {
+ GridUtils,
+ type ModelIndex,
+ type MoveOperation,
+} from '@deephaven/grid';
import type ColumnHeaderGroup from '../../../ColumnHeaderGroup';
-import { isFlattenedTreeItem, ReadonlyTreeItems } from './types';
+import { isFlattenedTreeItem, type ReadonlyTreeItems } from './types';
import type { FlattenedItem, TreeItem } from './types';
/**
diff --git a/packages/jsapi-bootstrap/src/ApiBootstrap.tsx b/packages/jsapi-bootstrap/src/ApiBootstrap.tsx
index d73580f003..f1d0dfc3d4 100644
--- a/packages/jsapi-bootstrap/src/ApiBootstrap.tsx
+++ b/packages/jsapi-bootstrap/src/ApiBootstrap.tsx
@@ -1,4 +1,4 @@
-import { createContext, ReactNode, useEffect, useState } from 'react';
+import { createContext, type ReactNode, useEffect, useState } from 'react';
import {
LoadingOverlay,
Modal,
diff --git a/packages/jsapi-bootstrap/src/useDeferredApi.test.ts b/packages/jsapi-bootstrap/src/useDeferredApi.test.ts
index 3c14cc0b75..5bb6b4475c 100644
--- a/packages/jsapi-bootstrap/src/useDeferredApi.test.ts
+++ b/packages/jsapi-bootstrap/src/useDeferredApi.test.ts
@@ -3,7 +3,7 @@ import type { dh as DhType } from '@deephaven/jsapi-types';
import { useContext } from 'react';
import { TestUtils } from '@deephaven/test-utils';
import { useDeferredApi } from './useDeferredApi';
-import { VariableDescriptor } from './useObjectFetcher';
+import { type VariableDescriptor } from './useObjectFetcher';
const { asMock, createMockProxy, flushPromises } = TestUtils;
diff --git a/packages/jsapi-bootstrap/src/useWidget.test.tsx b/packages/jsapi-bootstrap/src/useWidget.test.tsx
index 03338b5779..89c9bf1bc5 100644
--- a/packages/jsapi-bootstrap/src/useWidget.test.tsx
+++ b/packages/jsapi-bootstrap/src/useWidget.test.tsx
@@ -1,6 +1,6 @@
import React from 'react';
import { act, renderHook } from '@testing-library/react-hooks';
-import { dh } from '@deephaven/jsapi-types';
+import { type dh } from '@deephaven/jsapi-types';
import { TestUtils } from '@deephaven/test-utils';
import { useWidget } from './useWidget';
import { ObjectFetchManagerContext } from './useObjectFetch';
diff --git a/packages/jsapi-components/src/HookTestUtils.tsx b/packages/jsapi-components/src/HookTestUtils.tsx
index 8ca7a25e78..95cbe9081b 100644
--- a/packages/jsapi-components/src/HookTestUtils.tsx
+++ b/packages/jsapi-components/src/HookTestUtils.tsx
@@ -1,4 +1,4 @@
-import React, { ReactNode } from 'react';
+import React, { type ReactNode } from 'react';
import { ApiContext } from '@deephaven/jsapi-bootstrap';
import type { dh as DhType } from '@deephaven/jsapi-types';
diff --git a/packages/jsapi-components/src/TableDropdown.tsx b/packages/jsapi-components/src/TableDropdown.tsx
index 2e8e342abc..6e21767f23 100644
--- a/packages/jsapi-components/src/TableDropdown.tsx
+++ b/packages/jsapi-components/src/TableDropdown.tsx
@@ -1,7 +1,7 @@
import React, { useCallback, useEffect, useMemo, useState } from 'react';
import { Option, Select } from '@deephaven/components';
import { useApi } from '@deephaven/jsapi-bootstrap';
-import { dh as DhType } from '@deephaven/jsapi-types';
+import { type dh as DhType } from '@deephaven/jsapi-types';
import { EMPTY_ARRAY } from '@deephaven/utils';
type JavaObject = {
diff --git a/packages/jsapi-components/src/TableInput.tsx b/packages/jsapi-components/src/TableInput.tsx
index f1849d2ee7..680062574a 100644
--- a/packages/jsapi-components/src/TableInput.tsx
+++ b/packages/jsapi-components/src/TableInput.tsx
@@ -14,7 +14,11 @@ import {
import type { dh } from '@deephaven/jsapi-types';
import { PromiseUtils } from '@deephaven/utils';
import Log from '@deephaven/log';
-import { Formatter, FormatterUtils, Settings } from '@deephaven/jsapi-utils';
+import {
+ Formatter,
+ FormatterUtils,
+ type Settings,
+} from '@deephaven/jsapi-utils';
import { useApi } from '@deephaven/jsapi-bootstrap';
import useTableColumn from './useTableColumn';
diff --git a/packages/jsapi-components/src/spectrum/ComboBox.tsx b/packages/jsapi-components/src/spectrum/ComboBox.tsx
index 8c345a1029..c41a23b608 100644
--- a/packages/jsapi-components/src/spectrum/ComboBox.tsx
+++ b/packages/jsapi-components/src/spectrum/ComboBox.tsx
@@ -1,10 +1,10 @@
import {
ComboBoxNormalized,
- NormalizedItem,
- SpectrumComboBoxProps,
+ type NormalizedItem,
+ type SpectrumComboBoxProps,
} from '@deephaven/components';
import { useCallback } from 'react';
-import { PickerWithTableProps } from './PickerProps';
+import { type PickerWithTableProps } from './PickerProps';
import { usePickerProps } from './utils';
export type ComboBoxProps = PickerWithTableProps<
diff --git a/packages/jsapi-components/src/spectrum/ListView.tsx b/packages/jsapi-components/src/spectrum/ListView.tsx
index 92858c82b9..b22d69573a 100644
--- a/packages/jsapi-components/src/spectrum/ListView.tsx
+++ b/packages/jsapi-components/src/spectrum/ListView.tsx
@@ -1,12 +1,12 @@
import {
LIST_VIEW_ROW_HEIGHTS,
ListViewNormalized,
- ListViewNormalizedProps,
- NormalizedItemData,
+ type ListViewNormalizedProps,
+ type NormalizedItemData,
useSpectrumThemeProvider,
} from '@deephaven/components';
-import { dh as DhType } from '@deephaven/jsapi-types';
-import { Settings } from '@deephaven/jsapi-utils';
+import { type dh as DhType } from '@deephaven/jsapi-types';
+import { type Settings } from '@deephaven/jsapi-utils';
import useFormatter from '../useFormatter';
import useViewportData from '../useViewportData';
import { useItemRowDeserializer } from './utils';
diff --git a/packages/jsapi-components/src/spectrum/Picker.tsx b/packages/jsapi-components/src/spectrum/Picker.tsx
index 207ee81dee..e6a49f3481 100644
--- a/packages/jsapi-components/src/spectrum/Picker.tsx
+++ b/packages/jsapi-components/src/spectrum/Picker.tsx
@@ -1,5 +1,5 @@
import { PickerNormalized } from '@deephaven/components';
-import { PickerProps } from './PickerProps';
+import { type PickerProps } from './PickerProps';
import { usePickerProps } from './utils';
export function Picker(props: PickerProps): JSX.Element {
diff --git a/packages/jsapi-components/src/spectrum/PickerProps.ts b/packages/jsapi-components/src/spectrum/PickerProps.ts
index 7112e36468..8de8003c5f 100644
--- a/packages/jsapi-components/src/spectrum/PickerProps.ts
+++ b/packages/jsapi-components/src/spectrum/PickerProps.ts
@@ -1,10 +1,10 @@
import {
- NormalizedItem,
- PickerPropsT,
- SpectrumPickerProps,
+ type NormalizedItem,
+ type PickerPropsT,
+ type SpectrumPickerProps,
} from '@deephaven/components';
-import { dh as DhType } from '@deephaven/jsapi-types';
-import { Settings } from '@deephaven/jsapi-utils';
+import { type dh as DhType } from '@deephaven/jsapi-types';
+import { type Settings } from '@deephaven/jsapi-utils';
export type PickerWithTableProps = Omit<
PickerPropsT,
diff --git a/packages/jsapi-components/src/spectrum/utils/itemUtils.ts b/packages/jsapi-components/src/spectrum/utils/itemUtils.ts
index f43168b07e..bdf2b2530f 100644
--- a/packages/jsapi-components/src/spectrum/utils/itemUtils.ts
+++ b/packages/jsapi-components/src/spectrum/utils/itemUtils.ts
@@ -1,4 +1,4 @@
-import { dh } from '@deephaven/jsapi-types';
+import { type dh } from '@deephaven/jsapi-types';
/**
* Get the key column if column name is provided, otherwise use the first column.
diff --git a/packages/jsapi-components/src/spectrum/utils/useItemRowDeserializer.ts b/packages/jsapi-components/src/spectrum/utils/useItemRowDeserializer.ts
index 71b660bbaf..8c9d6b0cff 100644
--- a/packages/jsapi-components/src/spectrum/utils/useItemRowDeserializer.ts
+++ b/packages/jsapi-components/src/spectrum/utils/useItemRowDeserializer.ts
@@ -1,6 +1,6 @@
import { useCallback, useMemo } from 'react';
-import { NormalizedItemData } from '@deephaven/components';
-import { dh } from '@deephaven/jsapi-types';
+import { type NormalizedItemData } from '@deephaven/components';
+import { type dh } from '@deephaven/jsapi-types';
import { assertNotNull } from '@deephaven/utils';
import { getItemKeyColumn, getItemLabelColumn } from './itemUtils';
diff --git a/packages/jsapi-components/src/spectrum/utils/usePickerProps.ts b/packages/jsapi-components/src/spectrum/utils/usePickerProps.ts
index 0cebf29a39..fdd001feb9 100644
--- a/packages/jsapi-components/src/spectrum/utils/usePickerProps.ts
+++ b/packages/jsapi-components/src/spectrum/utils/usePickerProps.ts
@@ -1,8 +1,8 @@
import { useCallback, useEffect, useMemo, useState } from 'react';
import {
- ItemKey,
- NormalizedItem,
- NormalizedSection,
+ type ItemKey,
+ type NormalizedItem,
+ type NormalizedSection,
PICKER_TOP_OFFSET,
usePickerItemScale,
} from '@deephaven/components';
diff --git a/packages/jsapi-components/src/useBroadcastChannel.ts b/packages/jsapi-components/src/useBroadcastChannel.ts
index 302de41177..1d1eae6e48 100644
--- a/packages/jsapi-components/src/useBroadcastChannel.ts
+++ b/packages/jsapi-components/src/useBroadcastChannel.ts
@@ -1,7 +1,7 @@
import {
BROADCAST_CHANNEL_NAME,
isMessage,
- Message,
+ type Message,
} from '@deephaven/jsapi-utils';
import Log from '@deephaven/log';
import { EMPTY_FUNCTION } from '@deephaven/utils';
diff --git a/packages/jsapi-components/src/useBroadcastLoginListener.ts b/packages/jsapi-components/src/useBroadcastLoginListener.ts
index d38ff45300..5dc31793bb 100644
--- a/packages/jsapi-components/src/useBroadcastLoginListener.ts
+++ b/packages/jsapi-components/src/useBroadcastLoginListener.ts
@@ -1,9 +1,9 @@
import {
- BroadcastLoginMessage,
- BroadcastLogoutMessage,
+ type BroadcastLoginMessage,
+ type BroadcastLogoutMessage,
isBroadcastLoginMessage,
isBroadcastLogoutMessage,
- Message,
+ type Message,
} from '@deephaven/jsapi-utils';
import { useCallback } from 'react';
import useBroadcastChannel from './useBroadcastChannel';
diff --git a/packages/jsapi-components/src/useCheckIfExistsValue.test.ts b/packages/jsapi-components/src/useCheckIfExistsValue.test.ts
index 3172da4a59..8cb5a9a973 100644
--- a/packages/jsapi-components/src/useCheckIfExistsValue.test.ts
+++ b/packages/jsapi-components/src/useCheckIfExistsValue.test.ts
@@ -1,6 +1,6 @@
import { act, renderHook } from '@testing-library/react-hooks';
import type { Table } from '@deephaven/jsapi-types';
-import { TableUtils } from '@deephaven/jsapi-utils';
+import { type TableUtils } from '@deephaven/jsapi-utils';
import { TestUtils } from '@deephaven/test-utils';
import useCheckIfExistsValue from './useCheckIfExistsValue';
import useTableUtils from './useTableUtils';
diff --git a/packages/jsapi-components/src/useDebouncedViewportSearch.test.tsx b/packages/jsapi-components/src/useDebouncedViewportSearch.test.tsx
index 71d64572dd..c694da22be 100644
--- a/packages/jsapi-components/src/useDebouncedViewportSearch.test.tsx
+++ b/packages/jsapi-components/src/useDebouncedViewportSearch.test.tsx
@@ -6,12 +6,12 @@ import type {
Table,
} from '@deephaven/jsapi-types';
import dh from '@deephaven/jsapi-shim';
-import { TableUtils } from '@deephaven/jsapi-utils';
+import { type TableUtils } from '@deephaven/jsapi-utils';
import { TestUtils } from '@deephaven/test-utils';
import useDebouncedViewportSearch, {
DEBOUNCE_VIEWPORT_SEARCH_MS,
} from './useDebouncedViewportSearch';
-import { UseViewportDataResult } from './useViewportData';
+import { type UseViewportDataResult } from './useViewportData';
import { makeApiContextWrapper } from './HookTestUtils';
import useTableUtils from './useTableUtils';
diff --git a/packages/jsapi-components/src/useDebouncedViewportSearch.ts b/packages/jsapi-components/src/useDebouncedViewportSearch.ts
index 040c43c3c8..95fb09fbce 100644
--- a/packages/jsapi-components/src/useDebouncedViewportSearch.ts
+++ b/packages/jsapi-components/src/useDebouncedViewportSearch.ts
@@ -2,7 +2,7 @@ import debounce from 'lodash.debounce';
import type { dh } from '@deephaven/jsapi-types';
import Log from '@deephaven/log';
import { useEffect, useMemo } from 'react';
-import { UseViewportDataResult } from './useViewportData';
+import { type UseViewportDataResult } from './useViewportData';
import useTableUtils from './useTableUtils';
const log = Log.module('useDebouncedViewportSearch');
diff --git a/packages/jsapi-components/src/useDebouncedViewportSelectionFilter.test.ts b/packages/jsapi-components/src/useDebouncedViewportSelectionFilter.test.ts
index 67fed3d064..ac09a109a4 100644
--- a/packages/jsapi-components/src/useDebouncedViewportSelectionFilter.test.ts
+++ b/packages/jsapi-components/src/useDebouncedViewportSelectionFilter.test.ts
@@ -2,17 +2,17 @@ import { renderHook } from '@testing-library/react-hooks';
import {
createKeyedItemKey,
createSelectedValuesFilter,
- FilterConditionFactory,
- TableUtils,
+ type FilterConditionFactory,
+ type TableUtils,
} from '@deephaven/jsapi-utils';
import {
isSelectionMaybeInvertedEqual,
useDebouncedValue,
useIsEqualMemo,
useMappedSelection,
- WindowedListData,
+ type WindowedListData,
} from '@deephaven/react-hooks';
-import { KeyedItem } from '@deephaven/utils';
+import { type KeyedItem } from '@deephaven/utils';
import { TestUtils } from '@deephaven/test-utils';
import useDebouncedViewportSelectionFilter, {
DEBOUNCE_MS,
diff --git a/packages/jsapi-components/src/useDebouncedViewportSelectionFilter.ts b/packages/jsapi-components/src/useDebouncedViewportSelectionFilter.ts
index 593bdcdded..149d0abf89 100644
--- a/packages/jsapi-components/src/useDebouncedViewportSelectionFilter.ts
+++ b/packages/jsapi-components/src/useDebouncedViewportSelectionFilter.ts
@@ -1,16 +1,16 @@
import {
createKeyedItemKey,
createSelectedValuesFilter,
- FilterConditionFactory,
+ type FilterConditionFactory,
} from '@deephaven/jsapi-utils';
import {
isSelectionMaybeInvertedEqual,
useDebouncedValue,
useIsEqualMemo,
useMappedSelection,
- WindowedListData,
+ type WindowedListData,
} from '@deephaven/react-hooks';
-import { KeyedItem } from '@deephaven/utils';
+import { type KeyedItem } from '@deephaven/utils';
import { useMemo } from 'react';
import useTableUtils from './useTableUtils';
diff --git a/packages/jsapi-components/src/useFilterConditionFactories.test.ts b/packages/jsapi-components/src/useFilterConditionFactories.test.ts
index fa3ea29d99..609e2d863c 100644
--- a/packages/jsapi-components/src/useFilterConditionFactories.test.ts
+++ b/packages/jsapi-components/src/useFilterConditionFactories.test.ts
@@ -1,6 +1,6 @@
import { renderHook } from '@testing-library/react-hooks';
import type { FilterCondition, Table } from '@deephaven/jsapi-types';
-import { FilterConditionFactory } from '@deephaven/jsapi-utils';
+import { type FilterConditionFactory } from '@deephaven/jsapi-utils';
import { TestUtils } from '@deephaven/test-utils';
import useFilterConditionFactories from './useFilterConditionFactories';
diff --git a/packages/jsapi-components/src/useFilteredItemsWithDefaultValue.test.ts b/packages/jsapi-components/src/useFilteredItemsWithDefaultValue.test.ts
index d9fbfbc4c0..382abb17a8 100644
--- a/packages/jsapi-components/src/useFilteredItemsWithDefaultValue.test.ts
+++ b/packages/jsapi-components/src/useFilteredItemsWithDefaultValue.test.ts
@@ -1,5 +1,5 @@
import { renderHook } from '@testing-library/react-hooks';
-import { KeyedItem } from '@deephaven/jsapi-utils';
+import { type KeyedItem } from '@deephaven/jsapi-utils';
import useFilteredItemsWithDefaultValue from './useFilteredItemsWithDefaultValue';
beforeEach(() => {
diff --git a/packages/jsapi-components/src/useFilteredItemsWithDefaultValue.ts b/packages/jsapi-components/src/useFilteredItemsWithDefaultValue.ts
index 7f8d278ecb..d1c66dcd2e 100644
--- a/packages/jsapi-components/src/useFilteredItemsWithDefaultValue.ts
+++ b/packages/jsapi-components/src/useFilteredItemsWithDefaultValue.ts
@@ -1,5 +1,5 @@
import { useMemo, useRef } from 'react';
-import { KeyedItem } from '@deephaven/utils';
+import { type KeyedItem } from '@deephaven/utils';
/**
* Takes an array of items and adds a default item to the top of the list if:
diff --git a/packages/jsapi-components/src/useFormatter.test.ts b/packages/jsapi-components/src/useFormatter.test.ts
index ad1329b6bb..476a101115 100644
--- a/packages/jsapi-components/src/useFormatter.test.ts
+++ b/packages/jsapi-components/src/useFormatter.test.ts
@@ -3,8 +3,8 @@ import { bindAllMethods } from '@deephaven/utils';
import { TestUtils } from '@deephaven/test-utils';
import {
createFormatterFromSettings,
- Formatter,
- Settings,
+ type Formatter,
+ type Settings,
} from '@deephaven/jsapi-utils';
import type { dh as DhType } from '@deephaven/jsapi-types';
import { renderHook } from '@testing-library/react-hooks';
diff --git a/packages/jsapi-components/src/useFormatter.ts b/packages/jsapi-components/src/useFormatter.ts
index 0900b0a8c8..1e97db41f3 100644
--- a/packages/jsapi-components/src/useFormatter.ts
+++ b/packages/jsapi-components/src/useFormatter.ts
@@ -1,8 +1,8 @@
import { useApi } from '@deephaven/jsapi-bootstrap';
import {
createFormatterFromSettings,
- Formatter,
- Settings,
+ type Formatter,
+ type Settings,
} from '@deephaven/jsapi-utils';
import { bindAllMethods } from '@deephaven/utils';
import { useMemo } from 'react';
diff --git a/packages/jsapi-components/src/useGetItemIndexByValue.test.ts b/packages/jsapi-components/src/useGetItemIndexByValue.test.ts
index 8a9c6efdf0..9cee8bf8cc 100644
--- a/packages/jsapi-components/src/useGetItemIndexByValue.test.ts
+++ b/packages/jsapi-components/src/useGetItemIndexByValue.test.ts
@@ -1,6 +1,6 @@
import { renderHook } from '@testing-library/react-hooks';
-import { dh } from '@deephaven/jsapi-types';
-import { TableUtils } from '@deephaven/jsapi-utils';
+import { type dh } from '@deephaven/jsapi-types';
+import { type TableUtils } from '@deephaven/jsapi-utils';
import { TestUtils } from '@deephaven/test-utils';
import { useGetItemIndexByValue } from './useGetItemIndexByValue';
import { useTableUtils } from './useTableUtils';
diff --git a/packages/jsapi-components/src/useGetItemIndexByValue.ts b/packages/jsapi-components/src/useGetItemIndexByValue.ts
index 685c9cb622..0a3abc51e4 100644
--- a/packages/jsapi-components/src/useGetItemIndexByValue.ts
+++ b/packages/jsapi-components/src/useGetItemIndexByValue.ts
@@ -1,5 +1,5 @@
import { useCallback } from 'react';
-import { dh } from '@deephaven/jsapi-types';
+import { type dh } from '@deephaven/jsapi-types';
import { useTableUtils } from './useTableUtils';
/**
diff --git a/packages/jsapi-components/src/useGetItemPosition.test.ts b/packages/jsapi-components/src/useGetItemPosition.test.ts
index 201dc2f38a..a4b9f02b28 100644
--- a/packages/jsapi-components/src/useGetItemPosition.test.ts
+++ b/packages/jsapi-components/src/useGetItemPosition.test.ts
@@ -2,7 +2,7 @@ import { renderHook } from '@testing-library/react-hooks';
import type { Column, Table } from '@deephaven/jsapi-types';
import { TestUtils } from '@deephaven/test-utils';
import useGetItemPosition, {
- UseGetItemPositionOptions,
+ type UseGetItemPositionOptions,
} from './useGetItemPosition';
const { asMock, createMockProxy } = TestUtils;
diff --git a/packages/jsapi-components/src/useInitializeViewportData.test.ts b/packages/jsapi-components/src/useInitializeViewportData.test.ts
index 6ec1a30812..01359a5269 100644
--- a/packages/jsapi-components/src/useInitializeViewportData.test.ts
+++ b/packages/jsapi-components/src/useInitializeViewportData.test.ts
@@ -1,8 +1,8 @@
import { act, renderHook } from '@testing-library/react-hooks';
import type { dh } from '@deephaven/jsapi-types';
import { generateEmptyKeyedItems } from '@deephaven/jsapi-utils';
-import { WindowedListData } from '@deephaven/react-hooks';
-import { ITEM_KEY_PREFIX, KeyedItem } from '@deephaven/utils';
+import { type WindowedListData } from '@deephaven/react-hooks';
+import { ITEM_KEY_PREFIX, type KeyedItem } from '@deephaven/utils';
import { TestUtils } from '@deephaven/test-utils';
import useInitializeViewportData from './useInitializeViewportData';
import useTableSize from './useTableSize';
diff --git a/packages/jsapi-components/src/useInitializeViewportData.ts b/packages/jsapi-components/src/useInitializeViewportData.ts
index 7084c818de..93aaacab63 100644
--- a/packages/jsapi-components/src/useInitializeViewportData.ts
+++ b/packages/jsapi-components/src/useInitializeViewportData.ts
@@ -1,8 +1,11 @@
import { useEffect } from 'react';
import type { dh } from '@deephaven/jsapi-types';
import { generateEmptyKeyedItems } from '@deephaven/jsapi-utils';
-import { useWindowedListData, WindowedListData } from '@deephaven/react-hooks';
-import { KeyedItem } from '@deephaven/utils';
+import {
+ useWindowedListData,
+ type WindowedListData,
+} from '@deephaven/react-hooks';
+import { type KeyedItem } from '@deephaven/utils';
import Log from '@deephaven/log';
import useTableSize from './useTableSize';
diff --git a/packages/jsapi-components/src/useNotNullOrEmptyFilter.test.ts b/packages/jsapi-components/src/useNotNullOrEmptyFilter.test.ts
index 1c7a660a66..20a31367a6 100644
--- a/packages/jsapi-components/src/useNotNullOrEmptyFilter.test.ts
+++ b/packages/jsapi-components/src/useNotNullOrEmptyFilter.test.ts
@@ -3,8 +3,8 @@ import type { Column, FilterCondition } from '@deephaven/jsapi-types';
import {
createFilterConditionFactory,
createNotNullOrEmptyFilterCondition,
- FilterConditionFactory,
- TableUtils,
+ type FilterConditionFactory,
+ type TableUtils,
} from '@deephaven/jsapi-utils';
import { TestUtils } from '@deephaven/test-utils';
import useNotNullOrEmptyFilter from './useNotNullOrEmptyFilter';
diff --git a/packages/jsapi-components/src/useNotNullOrEmptyFilter.ts b/packages/jsapi-components/src/useNotNullOrEmptyFilter.ts
index 2080d4f01f..8112e1a8dd 100644
--- a/packages/jsapi-components/src/useNotNullOrEmptyFilter.ts
+++ b/packages/jsapi-components/src/useNotNullOrEmptyFilter.ts
@@ -2,7 +2,7 @@ import { useMemo } from 'react';
import {
createFilterConditionFactory,
createNotNullOrEmptyFilterCondition,
- FilterConditionFactory,
+ type FilterConditionFactory,
} from '@deephaven/jsapi-utils';
import useTableUtils from './useTableUtils';
diff --git a/packages/jsapi-components/src/usePickerWithSelectedValues.test.ts b/packages/jsapi-components/src/usePickerWithSelectedValues.test.ts
index ba0f51c3d1..afd94256e1 100644
--- a/packages/jsapi-components/src/usePickerWithSelectedValues.test.ts
+++ b/packages/jsapi-components/src/usePickerWithSelectedValues.test.ts
@@ -4,17 +4,17 @@ import { usePickerItemScale } from '@deephaven/components';
import {
createSearchTextFilter,
createSelectedValuesFilter,
- FilterConditionFactory,
- TableUtils,
+ type FilterConditionFactory,
+ type TableUtils,
} from '@deephaven/jsapi-utils';
import {
useDebouncedValue,
type WindowedListData,
} from '@deephaven/react-hooks';
-import { KeyedItem } from '@deephaven/utils';
+import { type KeyedItem } from '@deephaven/utils';
import { TestUtils } from '@deephaven/test-utils';
import usePickerWithSelectedValues from './usePickerWithSelectedValues';
-import useViewportData, { UseViewportDataResult } from './useViewportData';
+import useViewportData, { type UseViewportDataResult } from './useViewportData';
import useViewportFilter from './useViewportFilter';
import useFilterConditionFactories from './useFilterConditionFactories';
import useTableUtils from './useTableUtils';
diff --git a/packages/jsapi-components/src/usePickerWithSelectedValues.ts b/packages/jsapi-components/src/usePickerWithSelectedValues.ts
index 4b2bdac3da..d0c4ac591a 100644
--- a/packages/jsapi-components/src/usePickerWithSelectedValues.ts
+++ b/packages/jsapi-components/src/usePickerWithSelectedValues.ts
@@ -1,9 +1,9 @@
-import { Key, useCallback, useMemo, useState } from 'react';
+import { type Key, useCallback, useMemo, useState } from 'react';
import type { dh } from '@deephaven/jsapi-types';
import {
createSearchTextFilter,
createSelectedValuesFilter,
- FilterConditionFactory,
+ type FilterConditionFactory,
} from '@deephaven/jsapi-utils';
import {
useDebouncedCallback,
@@ -11,9 +11,9 @@ import {
usePromiseFactory,
} from '@deephaven/react-hooks';
import { usePickerItemScale } from '@deephaven/components';
-import { KeyedItem, SelectionT } from '@deephaven/utils';
+import { type KeyedItem, type SelectionT } from '@deephaven/utils';
import useFilterConditionFactories from './useFilterConditionFactories';
-import useViewportData, { UseViewportDataResult } from './useViewportData';
+import useViewportData, { type UseViewportDataResult } from './useViewportData';
import useViewportFilter from './useViewportFilter';
import useTableUtils from './useTableUtils';
import useTableClose from './useTableClose';
diff --git a/packages/jsapi-components/src/useSearchableViewportData.test.ts b/packages/jsapi-components/src/useSearchableViewportData.test.ts
index e10a72369f..24bfc0c8d1 100644
--- a/packages/jsapi-components/src/useSearchableViewportData.test.ts
+++ b/packages/jsapi-components/src/useSearchableViewportData.test.ts
@@ -4,13 +4,13 @@ import { TABLE_ROW_HEIGHT } from '@deephaven/components';
import type { dh as DhType } from '@deephaven/jsapi-types';
import {
createSearchTextFilter,
- FilterConditionFactory,
- TableUtils,
+ type FilterConditionFactory,
+ type TableUtils,
} from '@deephaven/jsapi-utils';
import { useDebouncedCallback } from '@deephaven/react-hooks';
import { TestUtils } from '@deephaven/test-utils';
import useSearchableViewportData from './useSearchableViewportData';
-import useViewportData, { UseViewportDataResult } from './useViewportData';
+import useViewportData, { type UseViewportDataResult } from './useViewportData';
import useTableUtils from './useTableUtils';
import useFilterConditionFactories from './useFilterConditionFactories';
import useViewportFilter from './useViewportFilter';
diff --git a/packages/jsapi-components/src/useSearchableViewportData.ts b/packages/jsapi-components/src/useSearchableViewportData.ts
index a0e2abd628..af007380b1 100644
--- a/packages/jsapi-components/src/useSearchableViewportData.ts
+++ b/packages/jsapi-components/src/useSearchableViewportData.ts
@@ -3,13 +3,13 @@ import { TABLE_ROW_HEIGHT } from '@deephaven/components';
import type { dh } from '@deephaven/jsapi-types';
import {
createSearchTextFilter,
- FilterConditionFactory,
+ type FilterConditionFactory,
} from '@deephaven/jsapi-utils';
import { useDebouncedCallback } from '@deephaven/react-hooks';
import { useTableUtils } from './useTableUtils';
import useViewportData, {
- UseViewportDataProps,
- UseViewportDataResult,
+ type UseViewportDataProps,
+ type UseViewportDataResult,
} from './useViewportData';
import useFilterConditionFactories from './useFilterConditionFactories';
import useViewportFilter from './useViewportFilter';
diff --git a/packages/jsapi-components/src/useShowOnlyEmptyFilter.test.ts b/packages/jsapi-components/src/useShowOnlyEmptyFilter.test.ts
index 36a6e1aa41..b89d39ffcf 100644
--- a/packages/jsapi-components/src/useShowOnlyEmptyFilter.test.ts
+++ b/packages/jsapi-components/src/useShowOnlyEmptyFilter.test.ts
@@ -3,7 +3,7 @@ import type { FilterCondition } from '@deephaven/jsapi-types';
import {
createFilterConditionFactory,
createShowOnlyEmptyFilterCondition,
- TableUtils,
+ type TableUtils,
} from '@deephaven/jsapi-utils';
import { TestUtils } from '@deephaven/test-utils';
import useShowOnlyEmptyFilter from './useShowOnlyEmptyFilter';
diff --git a/packages/jsapi-components/src/useShowOnlyEmptyFilter.ts b/packages/jsapi-components/src/useShowOnlyEmptyFilter.ts
index 267d307cf9..185fcf1c0a 100644
--- a/packages/jsapi-components/src/useShowOnlyEmptyFilter.ts
+++ b/packages/jsapi-components/src/useShowOnlyEmptyFilter.ts
@@ -2,7 +2,7 @@ import { useMemo } from 'react';
import {
createFilterConditionFactory,
createShowOnlyEmptyFilterCondition,
- FilterConditionFactory,
+ type FilterConditionFactory,
} from '@deephaven/jsapi-utils';
import useTableUtils from './useTableUtils';
diff --git a/packages/jsapi-components/src/useValueFilter.test.ts b/packages/jsapi-components/src/useValueFilter.test.ts
index 3855c101ac..663e6e791e 100644
--- a/packages/jsapi-components/src/useValueFilter.test.ts
+++ b/packages/jsapi-components/src/useValueFilter.test.ts
@@ -2,8 +2,8 @@ import { useMemo } from 'react';
import { renderHook } from '@testing-library/react-hooks';
import {
createValueFilter,
- FilterConditionFactory,
- TableUtils,
+ type FilterConditionFactory,
+ type TableUtils,
} from '@deephaven/jsapi-utils';
import { TestUtils } from '@deephaven/test-utils';
import useValueFilter from './useValueFilter';
diff --git a/packages/jsapi-components/src/useValueFilter.ts b/packages/jsapi-components/src/useValueFilter.ts
index b939392095..d1009e9438 100644
--- a/packages/jsapi-components/src/useValueFilter.ts
+++ b/packages/jsapi-components/src/useValueFilter.ts
@@ -1,7 +1,7 @@
import { useMemo } from 'react';
import {
createValueFilter,
- FilterConditionFactory,
+ type FilterConditionFactory,
} from '@deephaven/jsapi-utils';
import useTableUtils from './useTableUtils';
diff --git a/packages/jsapi-components/src/useViewportData.test.tsx b/packages/jsapi-components/src/useViewportData.test.tsx
index ccb2ac0581..2afe47dc0a 100644
--- a/packages/jsapi-components/src/useViewportData.test.tsx
+++ b/packages/jsapi-components/src/useViewportData.test.tsx
@@ -2,14 +2,14 @@ import { act, renderHook } from '@testing-library/react-hooks';
import type { dh as DhType } from '@deephaven/jsapi-types';
import dh from '@deephaven/jsapi-shim';
import {
- OnTableUpdatedEvent,
+ type OnTableUpdatedEvent,
generateEmptyKeyedItems,
isClosed,
ITEM_KEY_PREFIX,
} from '@deephaven/jsapi-utils';
import { useOnScrollOffsetChangeCallback } from '@deephaven/react-hooks';
import { TestUtils } from '@deephaven/test-utils';
-import useViewportData, { UseViewportDataProps } from './useViewportData';
+import useViewportData, { type UseViewportDataProps } from './useViewportData';
import { makeApiContextWrapper } from './HookTestUtils';
import { useTableSize } from './useTableSize';
import { useSetPaddedViewportCallback } from './useSetPaddedViewportCallback';
diff --git a/packages/jsapi-components/src/useViewportData.ts b/packages/jsapi-components/src/useViewportData.ts
index 92348fb73f..f3bbbf002c 100644
--- a/packages/jsapi-components/src/useViewportData.ts
+++ b/packages/jsapi-components/src/useViewportData.ts
@@ -1,19 +1,19 @@
import { useCallback, useEffect, useMemo, useRef } from 'react';
import type { dh } from '@deephaven/jsapi-types';
import {
- RowDeserializer,
+ type RowDeserializer,
defaultRowDeserializer,
isClosed,
createOnTableUpdatedHandler,
- OnTableUpdatedEvent,
+ type OnTableUpdatedEvent,
} from '@deephaven/jsapi-utils';
import Log from '@deephaven/log';
import { useApi } from '@deephaven/jsapi-bootstrap';
import {
useOnScrollOffsetChangeCallback,
- WindowedListData,
+ type WindowedListData,
} from '@deephaven/react-hooks';
-import { KeyedItem } from '@deephaven/utils';
+import { type KeyedItem } from '@deephaven/utils';
import useInitializeViewportData from './useInitializeViewportData';
import useSetPaddedViewportCallback from './useSetPaddedViewportCallback';
import useTableSize from './useTableSize';
diff --git a/packages/jsapi-components/src/useViewportFilter.test.ts b/packages/jsapi-components/src/useViewportFilter.test.ts
index 9d60b680ad..39f484dce2 100644
--- a/packages/jsapi-components/src/useViewportFilter.test.ts
+++ b/packages/jsapi-components/src/useViewportFilter.test.ts
@@ -1,7 +1,7 @@
import { renderHook } from '@testing-library/react-hooks';
import type { FilterCondition, Table } from '@deephaven/jsapi-types';
import useViewportFilter from './useViewportFilter';
-import { UseViewportDataResult } from './useViewportData';
+import { type UseViewportDataResult } from './useViewportData';
beforeEach(() => {
jest.clearAllMocks();
diff --git a/packages/jsapi-components/src/useViewportFilter.ts b/packages/jsapi-components/src/useViewportFilter.ts
index f4ef61b87e..68b884dc70 100644
--- a/packages/jsapi-components/src/useViewportFilter.ts
+++ b/packages/jsapi-components/src/useViewportFilter.ts
@@ -1,6 +1,6 @@
import { useEffect } from 'react';
import type { dh } from '@deephaven/jsapi-types';
-import { UseViewportDataResult } from './useViewportData';
+import { type UseViewportDataResult } from './useViewportData';
/**
* Applies a filter to a viewport.
diff --git a/packages/jsapi-utils/src/FilterUtils.test.ts b/packages/jsapi-utils/src/FilterUtils.test.ts
index 3514265287..e103341f4c 100644
--- a/packages/jsapi-utils/src/FilterUtils.test.ts
+++ b/packages/jsapi-utils/src/FilterUtils.test.ts
@@ -1,7 +1,7 @@
-import { Key } from 'react';
+import { type Key } from 'react';
import dh from '@deephaven/jsapi-shim';
import type { dh as DhType } from '@deephaven/jsapi-types';
-import { KeyedItem } from '@deephaven/utils';
+import { type KeyedItem } from '@deephaven/utils';
import { TestUtils } from '@deephaven/test-utils';
import {
createComboboxFilterArgs,
diff --git a/packages/jsapi-utils/src/FilterUtils.ts b/packages/jsapi-utils/src/FilterUtils.ts
index 9022130f56..c8575f468a 100644
--- a/packages/jsapi-utils/src/FilterUtils.ts
+++ b/packages/jsapi-utils/src/FilterUtils.ts
@@ -1,6 +1,6 @@
import type { dh } from '@deephaven/jsapi-types';
import type { SelectionT } from '@deephaven/utils';
-import TableUtils from './TableUtils';
+import type TableUtils from './TableUtils';
export interface FilterConditionFactory {
(
diff --git a/packages/jsapi-utils/src/Formatter.test.ts b/packages/jsapi-utils/src/Formatter.test.ts
index 9d6a5c50cc..c0fc6cb310 100644
--- a/packages/jsapi-utils/src/Formatter.test.ts
+++ b/packages/jsapi-utils/src/Formatter.test.ts
@@ -7,8 +7,8 @@ import {
DecimalColumnFormatter,
DefaultColumnFormatter,
IntegerColumnFormatter,
- TableColumnFormat,
- TableColumnFormatType,
+ type TableColumnFormat,
+ type TableColumnFormatType,
} from './formatters';
import TableUtils from './TableUtils';
diff --git a/packages/jsapi-utils/src/Formatter.ts b/packages/jsapi-utils/src/Formatter.ts
index ece2104b5b..3c67b9ecca 100644
--- a/packages/jsapi-utils/src/Formatter.ts
+++ b/packages/jsapi-utils/src/Formatter.ts
@@ -1,6 +1,6 @@
import type { dh as DhType } from '@deephaven/jsapi-types';
import { assertInstanceOf } from '@deephaven/utils';
-import TableUtils, { DataType } from './TableUtils';
+import TableUtils, { type DataType } from './TableUtils';
import {
BooleanColumnFormatter,
CharColumnFormatter,
@@ -9,8 +9,8 @@ import {
DefaultColumnFormatter,
IntegerColumnFormatter,
StringColumnFormatter,
- TableColumnFormat,
- TableColumnFormatter,
+ type TableColumnFormat,
+ type TableColumnFormatter,
} from './formatters';
export type ColumnName = string;
diff --git a/packages/jsapi-utils/src/FormatterUtils.test.ts b/packages/jsapi-utils/src/FormatterUtils.test.ts
index d0b7102e8d..7e2277cabc 100644
--- a/packages/jsapi-utils/src/FormatterUtils.test.ts
+++ b/packages/jsapi-utils/src/FormatterUtils.test.ts
@@ -1,21 +1,22 @@
import dh from '@deephaven/jsapi-shim';
import { TestUtils } from '@deephaven/test-utils';
-import Formatter, { FormattingRule } from './Formatter';
+import Formatter, { type FormattingRule } from './Formatter';
import FormatterUtils, {
createFormatterFromSettings,
getColumnFormats,
getDateTimeFormatterOptions,
} from './FormatterUtils';
import {
- TableColumnFormat,
+ type TableColumnFormat,
TableColumnFormatter,
- TableColumnFormatType,
+ type TableColumnFormatType,
} from './formatters';
import TableUtils from './TableUtils';
-import Settings, {
- ColumnFormatSettings,
- DateTimeFormatSettings,
+import {
+ type ColumnFormatSettings,
+ type DateTimeFormatSettings,
} from './Settings';
+import type Settings from './Settings';
jest.mock('./Formatter', () => {
const FormatterActual = jest.requireActual('./Formatter').default;
diff --git a/packages/jsapi-utils/src/FormatterUtils.ts b/packages/jsapi-utils/src/FormatterUtils.ts
index d25957a56d..450fb3e4e7 100644
--- a/packages/jsapi-utils/src/FormatterUtils.ts
+++ b/packages/jsapi-utils/src/FormatterUtils.ts
@@ -1,11 +1,15 @@
import type { dh as DhType } from '@deephaven/jsapi-types';
import type { FormattingRule } from './Formatter';
import Formatter from './Formatter';
-import { DateTimeColumnFormatter, TableColumnFormatter } from './formatters';
-import Settings, {
- ColumnFormatSettings,
- DateTimeFormatSettings,
+import {
+ type DateTimeColumnFormatter,
+ TableColumnFormatter,
+} from './formatters';
+import {
+ type ColumnFormatSettings,
+ type DateTimeFormatSettings,
} from './Settings';
+import type Settings from './Settings';
/**
* Instantiate a `Formatter` from the given settings.
diff --git a/packages/jsapi-utils/src/MessageUtils.test.ts b/packages/jsapi-utils/src/MessageUtils.test.ts
index 0c28368cf2..31c7a7a8d4 100644
--- a/packages/jsapi-utils/src/MessageUtils.test.ts
+++ b/packages/jsapi-utils/src/MessageUtils.test.ts
@@ -2,7 +2,7 @@ import { TestUtils } from '@deephaven/test-utils';
import {
makeMessage,
makeResponse,
- Message,
+ type Message,
requestParentResponse,
} from './MessageUtils';
diff --git a/packages/jsapi-utils/src/Settings.ts b/packages/jsapi-utils/src/Settings.ts
index 40f324021b..92d40c97b2 100644
--- a/packages/jsapi-utils/src/Settings.ts
+++ b/packages/jsapi-utils/src/Settings.ts
@@ -1,4 +1,4 @@
-import { FormattingRule } from './Formatter';
+import { type FormattingRule } from './Formatter';
export interface ColumnFormatSettings {
formatter?: FormattingRule[];
diff --git a/packages/jsapi-utils/src/TableUtils.test.ts b/packages/jsapi-utils/src/TableUtils.test.ts
index 91e67f6e25..8f0a46988f 100644
--- a/packages/jsapi-utils/src/TableUtils.test.ts
+++ b/packages/jsapi-utils/src/TableUtils.test.ts
@@ -4,16 +4,16 @@ import type { dh as DhType } from '@deephaven/jsapi-types';
import {
Operator as FilterOperator,
Type as FilterType,
- TypeValue as FilterTypeValue,
+ type TypeValue as FilterTypeValue,
} from '@deephaven/filters';
import { getAllMethodNames } from '@deephaven/utils';
import { TestUtils } from '@deephaven/test-utils';
-import TableUtils, { DataType, SortDirection } from './TableUtils';
+import TableUtils, { type DataType, type SortDirection } from './TableUtils';
import DateUtils from './DateUtils';
// eslint-disable-next-line import/no-relative-packages
import IrisGridTestUtils from '../../iris-grid/src/IrisGridTestUtils';
-import { ColumnName } from './Formatter';
-import { createValueFilter, FilterConditionFactory } from './FilterUtils';
+import { type ColumnName } from './Formatter';
+import { createValueFilter, type FilterConditionFactory } from './FilterUtils';
import { getSize } from './ViewportDataUtils';
type Column = DhType.Column;
diff --git a/packages/jsapi-utils/src/TableUtils.ts b/packages/jsapi-utils/src/TableUtils.ts
index 3903959ddf..6b16267c07 100644
--- a/packages/jsapi-utils/src/TableUtils.ts
+++ b/packages/jsapi-utils/src/TableUtils.ts
@@ -1,23 +1,23 @@
import {
Type as FilterType,
Operator as FilterOperator,
- TypeValue as FilterTypeValue,
- OperatorValue as FilterOperatorValue,
+ type TypeValue as FilterTypeValue,
+ type OperatorValue as FilterOperatorValue,
} from '@deephaven/filters';
import Log from '@deephaven/log';
import type { dh as DhType } from '@deephaven/jsapi-types';
import {
assertNotNull,
bindAllMethods,
- CancelablePromise,
+ type CancelablePromise,
PromiseUtils,
removeNullAndUndefined,
TextUtils,
TimeoutError,
} from '@deephaven/utils';
import DateUtils from './DateUtils';
-import { ColumnName } from './Formatter';
-import { createValueFilter, FilterConditionFactory } from './FilterUtils';
+import { type ColumnName } from './Formatter';
+import { createValueFilter, type FilterConditionFactory } from './FilterUtils';
import { getSize } from './ViewportDataUtils';
const log = Log.module('TableUtils');
diff --git a/packages/jsapi-utils/src/ViewportDataUtils.test.ts b/packages/jsapi-utils/src/ViewportDataUtils.test.ts
index d2a2abfcaf..5f1756172f 100644
--- a/packages/jsapi-utils/src/ViewportDataUtils.test.ts
+++ b/packages/jsapi-utils/src/ViewportDataUtils.test.ts
@@ -1,10 +1,10 @@
import { act } from '@testing-library/react-hooks';
-import { dh } from '@deephaven/jsapi-types';
+import { type dh } from '@deephaven/jsapi-types';
import { TestUtils } from '@deephaven/test-utils';
import {
ITEM_KEY_PREFIX,
- OnTableUpdatedEvent,
- RowDeserializer,
+ type OnTableUpdatedEvent,
+ type RowDeserializer,
createOnTableUpdatedHandler,
defaultRowDeserializer,
generateEmptyKeyedItems,
diff --git a/packages/jsapi-utils/src/ViewportDataUtils.ts b/packages/jsapi-utils/src/ViewportDataUtils.ts
index db833005e9..c0d55324c4 100644
--- a/packages/jsapi-utils/src/ViewportDataUtils.ts
+++ b/packages/jsapi-utils/src/ViewportDataUtils.ts
@@ -2,7 +2,7 @@ import type { Key } from 'react';
import clamp from 'lodash.clamp';
import type { dh } from '@deephaven/jsapi-types';
import Log from '@deephaven/log';
-import { KeyedItem, ValueOf } from '@deephaven/utils';
+import { type KeyedItem, type ValueOf } from '@deephaven/utils';
export const ITEM_KEY_PREFIX = 'DH_ITEM_KEY';
diff --git a/packages/jsapi-utils/src/formatters/DateTimeColumnFormatter.test.ts b/packages/jsapi-utils/src/formatters/DateTimeColumnFormatter.test.ts
index 519711c4f9..e42e100f16 100644
--- a/packages/jsapi-utils/src/formatters/DateTimeColumnFormatter.test.ts
+++ b/packages/jsapi-utils/src/formatters/DateTimeColumnFormatter.test.ts
@@ -1,7 +1,7 @@
import dh from '@deephaven/jsapi-shim';
import type { TimeZone } from '@deephaven/jsapi-types';
import DateTimeColumnFormatter from './DateTimeColumnFormatter';
-import { TableColumnFormat } from './TableColumnFormatter';
+import { type TableColumnFormat } from './TableColumnFormatter';
function makeFormatter({
timeZone,
diff --git a/packages/jsapi-utils/src/formatters/DateTimeColumnFormatter.ts b/packages/jsapi-utils/src/formatters/DateTimeColumnFormatter.ts
index 1b02120652..efde2a9e18 100644
--- a/packages/jsapi-utils/src/formatters/DateTimeColumnFormatter.ts
+++ b/packages/jsapi-utils/src/formatters/DateTimeColumnFormatter.ts
@@ -2,7 +2,7 @@
import type { dh as DhType } from '@deephaven/jsapi-types';
import Log from '@deephaven/log';
import TableColumnFormatter, {
- TableColumnFormat,
+ type TableColumnFormat,
} from './TableColumnFormatter';
const log = Log.module('DateTimeColumnFormatter');
diff --git a/packages/jsapi-utils/src/formatters/DecimalColumnFormatter.ts b/packages/jsapi-utils/src/formatters/DecimalColumnFormatter.ts
index de09a154d2..e6cba5d11f 100644
--- a/packages/jsapi-utils/src/formatters/DecimalColumnFormatter.ts
+++ b/packages/jsapi-utils/src/formatters/DecimalColumnFormatter.ts
@@ -2,7 +2,7 @@
import type { dh as DhType } from '@deephaven/jsapi-types';
import Log from '@deephaven/log';
import TableColumnFormatter, {
- TableColumnFormat,
+ type TableColumnFormat,
} from './TableColumnFormatter';
const log = Log.module('DecimalColumnFormatter');
diff --git a/packages/jsapi-utils/src/formatters/IntegerColumnFormatter.ts b/packages/jsapi-utils/src/formatters/IntegerColumnFormatter.ts
index 73cad020e7..1a1b04dae9 100644
--- a/packages/jsapi-utils/src/formatters/IntegerColumnFormatter.ts
+++ b/packages/jsapi-utils/src/formatters/IntegerColumnFormatter.ts
@@ -2,7 +2,7 @@
import type { dh as DhType } from '@deephaven/jsapi-types';
import Log from '@deephaven/log';
import TableColumnFormatter, {
- TableColumnFormat,
+ type TableColumnFormat,
} from './TableColumnFormatter';
const log = Log.module('IntegerColumnFormatter');
diff --git a/packages/jsapi-utils/src/formatters/NumberColumnFormatter.test.ts b/packages/jsapi-utils/src/formatters/NumberColumnFormatter.test.ts
index 6329895eb8..c20b0c74d4 100644
--- a/packages/jsapi-utils/src/formatters/NumberColumnFormatter.test.ts
+++ b/packages/jsapi-utils/src/formatters/NumberColumnFormatter.test.ts
@@ -1,7 +1,7 @@
import dh from '@deephaven/jsapi-shim';
import DecimalColumnFormatter from './DecimalColumnFormatter';
import IntegerColumnFormatter from './IntegerColumnFormatter';
-import { TableColumnFormat } from './TableColumnFormatter';
+import { type TableColumnFormat } from './TableColumnFormatter';
const numberColumnFormatters = [
{
diff --git a/packages/jsapi-utils/src/formatters/TableColumnFormatter.test.ts b/packages/jsapi-utils/src/formatters/TableColumnFormatter.test.ts
index b0934226e5..41ad8879cd 100644
--- a/packages/jsapi-utils/src/formatters/TableColumnFormatter.test.ts
+++ b/packages/jsapi-utils/src/formatters/TableColumnFormatter.test.ts
@@ -1,5 +1,5 @@
import TableColumnFormatter, {
- TableColumnFormat,
+ type TableColumnFormat,
} from './TableColumnFormatter';
const VALID_FORMAT: TableColumnFormat = {
diff --git a/packages/log/src/LogHistory.ts b/packages/log/src/LogHistory.ts
index 48510a2e49..985ba40fdb 100644
--- a/packages/log/src/LogHistory.ts
+++ b/packages/log/src/LogHistory.ts
@@ -1,4 +1,4 @@
-import { LogProxy, LOG_PROXY_TYPE } from './LogProxy';
+import { type LogProxy, LOG_PROXY_TYPE } from './LogProxy';
type HistoryItem = {
type: LOG_PROXY_TYPE;
diff --git a/packages/log/src/LogProxy.ts b/packages/log/src/LogProxy.ts
index 0d6ecc1f5b..eabe8caac3 100644
--- a/packages/log/src/LogProxy.ts
+++ b/packages/log/src/LogProxy.ts
@@ -1,5 +1,5 @@
/* eslint-disable no-console */
-import { EventTarget, Event } from 'event-target-shim';
+import { EventTarget, type Event } from 'event-target-shim';
import Log from './Log';
export enum LOG_PROXY_TYPE {
diff --git a/packages/plugin/src/PluginTypes.test.ts b/packages/plugin/src/PluginTypes.test.ts
index 4593ae1555..9236bdd5bc 100644
--- a/packages/plugin/src/PluginTypes.test.ts
+++ b/packages/plugin/src/PluginTypes.test.ts
@@ -5,7 +5,7 @@ import {
isTablePlugin,
isThemePlugin,
isWidgetPlugin,
- Plugin,
+ type Plugin,
isPlugin,
} from './PluginTypes';
diff --git a/packages/plugin/src/PluginUtils.test.tsx b/packages/plugin/src/PluginUtils.test.tsx
index af34950ac6..a600411f97 100644
--- a/packages/plugin/src/PluginUtils.test.tsx
+++ b/packages/plugin/src/PluginUtils.test.tsx
@@ -1,6 +1,6 @@
import React from 'react';
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
-import { ThemeData } from '@deephaven/components';
+import { type ThemeData } from '@deephaven/components';
import { dhTruck, vsPreview } from '@deephaven/icons';
import {
type DashboardPlugin,
diff --git a/packages/plugin/src/PluginUtils.tsx b/packages/plugin/src/PluginUtils.tsx
index a2ef110b6b..051aa3d5ed 100644
--- a/packages/plugin/src/PluginUtils.tsx
+++ b/packages/plugin/src/PluginUtils.tsx
@@ -6,8 +6,8 @@ import Log from '@deephaven/log';
import {
type PluginModule,
isWidgetPlugin,
- PluginModuleMap,
- ThemePlugin,
+ type PluginModuleMap,
+ type ThemePlugin,
isThemePlugin,
} from './PluginTypes';
diff --git a/packages/plugin/src/TablePlugin.ts b/packages/plugin/src/TablePlugin.ts
index 94a82ec3d4..83909414c2 100644
--- a/packages/plugin/src/TablePlugin.ts
+++ b/packages/plugin/src/TablePlugin.ts
@@ -5,7 +5,7 @@ import type {
IrisGridContextMenuData,
IrisGridModel,
} from '@deephaven/iris-grid';
-import { GridRange } from '@deephaven/grid';
+import { type GridRange } from '@deephaven/grid';
import type { ResolvableContextAction } from '@deephaven/components';
import type { dh } from '@deephaven/jsapi-types';
diff --git a/packages/plugin/src/useDashboardPlugins.tsx b/packages/plugin/src/useDashboardPlugins.tsx
index ffbd3350bb..7e952131b5 100644
--- a/packages/plugin/src/useDashboardPlugins.tsx
+++ b/packages/plugin/src/useDashboardPlugins.tsx
@@ -2,7 +2,7 @@ import { useMemo } from 'react';
import {
isDashboardPlugin,
isLegacyDashboardPlugin,
- PluginModuleMap,
+ type PluginModuleMap,
type DashboardPlugin,
type LegacyDashboardPlugin,
} from './PluginTypes';
diff --git a/packages/pouch-storage/src/PouchCommandHistoryCache.ts b/packages/pouch-storage/src/PouchCommandHistoryCache.ts
index b879dca5fb..2d71dea065 100644
--- a/packages/pouch-storage/src/PouchCommandHistoryCache.ts
+++ b/packages/pouch-storage/src/PouchCommandHistoryCache.ts
@@ -1,7 +1,7 @@
-import { CommandHistoryStorageItem } from '@deephaven/console';
+import { type CommandHistoryStorageItem } from '@deephaven/console';
import Log from '@deephaven/log';
-import PouchCommandHistoryTable from './PouchCommandHistoryTable';
-import { PouchStorageItem } from './PouchStorageTable';
+import type PouchCommandHistoryTable from './PouchCommandHistoryTable';
+import { type PouchStorageItem } from './PouchStorageTable';
type CommandHistoryStorageItemFindResponse = PouchDB.Find.FindResponse<
CommandHistoryStorageItem & PouchStorageItem
diff --git a/packages/pouch-storage/src/PouchCommandHistoryStorage.ts b/packages/pouch-storage/src/PouchCommandHistoryStorage.ts
index 39ab6d2e52..af0d00ed82 100644
--- a/packages/pouch-storage/src/PouchCommandHistoryStorage.ts
+++ b/packages/pouch-storage/src/PouchCommandHistoryStorage.ts
@@ -1,13 +1,13 @@
/* eslint-disable class-methods-use-this */
import Log from '@deephaven/log';
import {
- CommandHistoryStorage,
- CommandHistoryStorageData,
- CommandHistoryStorageItem,
+ type CommandHistoryStorage,
+ type CommandHistoryStorageData,
+ type CommandHistoryStorageItem,
} from '@deephaven/console';
import {
- StorageItemListener,
- StorageListenerRemover,
+ type StorageItemListener,
+ type StorageListenerRemover,
} from '@deephaven/storage';
import PouchCommandHistoryTable from './PouchCommandHistoryTable';
import PouchCommandHistoryCache from './PouchCommandHistoryCache';
diff --git a/packages/pouch-storage/src/PouchCommandHistoryTable.ts b/packages/pouch-storage/src/PouchCommandHistoryTable.ts
index f1ab0dedaf..68ad8e708a 100644
--- a/packages/pouch-storage/src/PouchCommandHistoryTable.ts
+++ b/packages/pouch-storage/src/PouchCommandHistoryTable.ts
@@ -1,20 +1,20 @@
import {
- CommandHistoryStorageItem,
- CommandHistoryTable,
+ type CommandHistoryStorageItem,
+ type CommandHistoryTable,
} from '@deephaven/console';
import { Type as FilterType } from '@deephaven/filters';
import Log from '@deephaven/log';
import {
- StorageTableViewport,
+ type StorageTableViewport,
StorageUtils,
- ViewportData,
+ type ViewportData,
} from '@deephaven/storage';
import { PromiseUtils } from '@deephaven/utils';
-import PouchCommandHistoryCache from './PouchCommandHistoryCache';
+import type PouchCommandHistoryCache from './PouchCommandHistoryCache';
import { siftPrunableItems } from './pouchCommandHistoryUtils';
import PouchStorageTable, {
- PouchDBSort,
- PouchStorageItem,
+ type PouchDBSort,
+ type PouchStorageItem,
} from './PouchStorageTable';
const COMMAND_HISTORY_ITEMS_MAX = 2500;
diff --git a/packages/pouch-storage/src/PouchStorageTable.ts b/packages/pouch-storage/src/PouchStorageTable.ts
index 5a174f9e8d..cf8682e4ac 100644
--- a/packages/pouch-storage/src/PouchStorageTable.ts
+++ b/packages/pouch-storage/src/PouchStorageTable.ts
@@ -6,20 +6,24 @@ import {
} from '@deephaven/filters';
import Log from '@deephaven/log';
import {
- FilterConfig,
- FilterValue,
- SortConfig,
- StorageItem,
- StorageTable,
- StorageListenerRemover,
- StorageTableViewport,
- StorageItemListener,
- StorageSnapshot,
- ViewportData,
- ViewportUpdateCallback,
- IndexRange,
+ type FilterConfig,
+ type FilterValue,
+ type SortConfig,
+ type StorageItem,
+ type StorageTable,
+ type StorageListenerRemover,
+ type StorageTableViewport,
+ type StorageItemListener,
+ type StorageSnapshot,
+ type ViewportData,
+ type ViewportUpdateCallback,
+ type IndexRange,
} from '@deephaven/storage';
-import { CancelablePromise, OnlyOneProp, PromiseUtils } from '@deephaven/utils';
+import {
+ type CancelablePromise,
+ type OnlyOneProp,
+ PromiseUtils,
+} from '@deephaven/utils';
const log = Log.module('PouchStorageTable');
diff --git a/packages/react-hooks/src/ElementUtils.test.tsx b/packages/react-hooks/src/ElementUtils.test.tsx
index 8c525841e8..f0dd8eb9bb 100644
--- a/packages/react-hooks/src/ElementUtils.test.tsx
+++ b/packages/react-hooks/src/ElementUtils.test.tsx
@@ -1,5 +1,5 @@
import { createElement } from 'react';
-import { ItemElement, Item, Text } from '@deephaven/components';
+import { type ItemElement, Item, Text } from '@deephaven/components';
import { isElementOfType } from './ElementUtils';
beforeEach(() => {
diff --git a/packages/react-hooks/src/ElementUtils.ts b/packages/react-hooks/src/ElementUtils.ts
index 52bf4e1274..0803e3b088 100644
--- a/packages/react-hooks/src/ElementUtils.ts
+++ b/packages/react-hooks/src/ElementUtils.ts
@@ -1,10 +1,10 @@
import {
- Component,
- FunctionComponent,
+ type Component,
+ type FunctionComponent,
isValidElement,
- JSXElementConstructor,
- ReactElement,
- ReactNode,
+ type JSXElementConstructor,
+ type ReactElement,
+ type ReactNode,
} from 'react';
/**
diff --git a/packages/react-hooks/src/SelectionUtils.ts b/packages/react-hooks/src/SelectionUtils.ts
index fae93a54f0..8bbf002d48 100644
--- a/packages/react-hooks/src/SelectionUtils.ts
+++ b/packages/react-hooks/src/SelectionUtils.ts
@@ -2,9 +2,9 @@ import type { Key } from 'react';
import type { Selection } from '@react-types/shared';
import {
generateRange,
- KeyedItem,
- SelectionMaybeInverted,
- SelectionT,
+ type KeyedItem,
+ type SelectionMaybeInverted,
+ type SelectionT,
} from '@deephaven/utils';
/**
diff --git a/packages/react-hooks/src/SpectrumUtils.test.ts b/packages/react-hooks/src/SpectrumUtils.test.ts
index ef2e9353d4..722c5f87d6 100644
--- a/packages/react-hooks/src/SpectrumUtils.test.ts
+++ b/packages/react-hooks/src/SpectrumUtils.test.ts
@@ -1,4 +1,4 @@
-import { KeyedItem } from '@deephaven/utils';
+import { type KeyedItem } from '@deephaven/utils';
import { TestUtils } from '@deephaven/test-utils';
import type { DOMRefValue } from '@react-types/shared';
import {
diff --git a/packages/react-hooks/src/SpectrumUtils.ts b/packages/react-hooks/src/SpectrumUtils.ts
index 451b00c2ed..a059a48494 100644
--- a/packages/react-hooks/src/SpectrumUtils.ts
+++ b/packages/react-hooks/src/SpectrumUtils.ts
@@ -1,6 +1,6 @@
// eslint-disable-next-line no-restricted-imports
import type { SpectrumTextFieldProps } from '@adobe/react-spectrum';
-import { KeyedItem } from '@deephaven/utils';
+import { type KeyedItem } from '@deephaven/utils';
import type { DOMRefValue } from '@react-types/shared';
/**
diff --git a/packages/react-hooks/src/useContextOrThrow.ts b/packages/react-hooks/src/useContextOrThrow.ts
index 90656b2c56..943db8ac04 100644
--- a/packages/react-hooks/src/useContextOrThrow.ts
+++ b/packages/react-hooks/src/useContextOrThrow.ts
@@ -1,4 +1,5 @@
-import React, { useContext } from 'react';
+import type React from 'react';
+import { useContext } from 'react';
/**
* Fetch a given context or throw an error if it is null or undefined.
diff --git a/packages/react-hooks/src/useEffectNTimesWhen.test.ts b/packages/react-hooks/src/useEffectNTimesWhen.test.ts
index f1e9e85f27..67c03485bf 100644
--- a/packages/react-hooks/src/useEffectNTimesWhen.test.ts
+++ b/packages/react-hooks/src/useEffectNTimesWhen.test.ts
@@ -1,5 +1,5 @@
import { renderHook } from '@testing-library/react-hooks';
-import { DependencyList } from 'react';
+import { type DependencyList } from 'react';
import { nanoid } from 'nanoid';
import useEffectNTimesWhen from './useEffectNTimesWhen';
diff --git a/packages/react-hooks/src/useEffectNTimesWhen.ts b/packages/react-hooks/src/useEffectNTimesWhen.ts
index caf33b53b9..9fe52db898 100644
--- a/packages/react-hooks/src/useEffectNTimesWhen.ts
+++ b/packages/react-hooks/src/useEffectNTimesWhen.ts
@@ -1,4 +1,9 @@
-import { DependencyList, EffectCallback, useEffect, useRef } from 'react';
+import {
+ type DependencyList,
+ type EffectCallback,
+ useEffect,
+ useRef,
+} from 'react';
/**
* Custom useEffect hook that runs an effect function up to `n` times as long
diff --git a/packages/react-hooks/src/useFormWithDetachedSubmitButton.ts b/packages/react-hooks/src/useFormWithDetachedSubmitButton.ts
index 0e4f1e9f03..a608c227e5 100644
--- a/packages/react-hooks/src/useFormWithDetachedSubmitButton.ts
+++ b/packages/react-hooks/src/useFormWithDetachedSubmitButton.ts
@@ -1,4 +1,4 @@
-import { FormEvent, useCallback, useMemo } from 'react';
+import { type FormEvent, useCallback, useMemo } from 'react';
import { nanoid } from 'nanoid';
import type { FocusableRefValue } from '@react-types/shared';
diff --git a/packages/react-hooks/src/useForwardedRef.ts b/packages/react-hooks/src/useForwardedRef.ts
index 462e530edc..6b9f25b982 100644
--- a/packages/react-hooks/src/useForwardedRef.ts
+++ b/packages/react-hooks/src/useForwardedRef.ts
@@ -1,4 +1,5 @@
-import React, { useEffect, useRef } from 'react';
+import type React from 'react';
+import { useEffect, useRef } from 'react';
/**
* Takes a ref from forwardRef and makes it safe to use.
diff --git a/packages/react-hooks/src/useMappedRef.test.ts b/packages/react-hooks/src/useMappedRef.test.ts
index c8eb954c69..ac4962673b 100644
--- a/packages/react-hooks/src/useMappedRef.test.ts
+++ b/packages/react-hooks/src/useMappedRef.test.ts
@@ -1,4 +1,4 @@
-import { MutableRefObject } from 'react';
+import { type MutableRefObject } from 'react';
import { renderHook } from '@testing-library/react-hooks';
import { TestUtils } from '@deephaven/test-utils';
import useMappedRef from './useMappedRef';
diff --git a/packages/react-hooks/src/useMappedRef.ts b/packages/react-hooks/src/useMappedRef.ts
index 2f0cb3b3b3..7c8c9276ae 100644
--- a/packages/react-hooks/src/useMappedRef.ts
+++ b/packages/react-hooks/src/useMappedRef.ts
@@ -1,4 +1,4 @@
-import { MutableRefObject, useCallback } from 'react';
+import { type MutableRefObject, useCallback } from 'react';
/**
* Returns a callback ref that will map it's argument
diff --git a/packages/react-hooks/src/useMappedSelection.test.ts b/packages/react-hooks/src/useMappedSelection.test.ts
index bbb8a9eb22..9dac681371 100644
--- a/packages/react-hooks/src/useMappedSelection.test.ts
+++ b/packages/react-hooks/src/useMappedSelection.test.ts
@@ -1,9 +1,9 @@
-import { Key } from 'react';
+import { type Key } from 'react';
import { renderHook } from '@testing-library/react-hooks';
-import { KeyedItem } from '@deephaven/utils';
+import { type KeyedItem } from '@deephaven/utils';
import { TestUtils } from '@deephaven/test-utils';
import { useMappedSelection } from './useMappedSelection';
-import { WindowedListData } from './useWindowedListData';
+import { type WindowedListData } from './useWindowedListData';
import { mapSelection, optimizeSelection } from './SelectionUtils';
const { asMock, createMockProxy } = TestUtils;
diff --git a/packages/react-hooks/src/useMappedSelection.ts b/packages/react-hooks/src/useMappedSelection.ts
index 12f43b8906..f9bf366551 100644
--- a/packages/react-hooks/src/useMappedSelection.ts
+++ b/packages/react-hooks/src/useMappedSelection.ts
@@ -1,5 +1,5 @@
import { useMemo } from 'react';
-import { KeyedItem, SelectionMaybeInverted } from '@deephaven/utils';
+import { type KeyedItem, type SelectionMaybeInverted } from '@deephaven/utils';
import { mapSelection, optimizeSelection } from './SelectionUtils';
import type { WindowedListData } from './useWindowedListData';
diff --git a/packages/react-hooks/src/useOnChange.ts b/packages/react-hooks/src/useOnChange.ts
index 54040f322e..3ad330f330 100644
--- a/packages/react-hooks/src/useOnChange.ts
+++ b/packages/react-hooks/src/useOnChange.ts
@@ -1,4 +1,4 @@
-import { DependencyList } from 'react';
+import { type DependencyList } from 'react';
import usePrevious from './usePrevious';
/**
diff --git a/packages/react-hooks/src/usePromiseFactory.test.ts b/packages/react-hooks/src/usePromiseFactory.test.ts
index 389f570099..6e95e888d4 100644
--- a/packages/react-hooks/src/usePromiseFactory.test.ts
+++ b/packages/react-hooks/src/usePromiseFactory.test.ts
@@ -1,6 +1,6 @@
import { act, renderHook } from '@testing-library/react-hooks';
import usePromiseFactory, {
- UsePromiseFactoryResult,
+ type UsePromiseFactoryResult,
} from './usePromiseFactory';
const defaultState: UsePromiseFactoryResult = {
diff --git a/packages/react-hooks/src/useSetAttributesCallback.test.ts b/packages/react-hooks/src/useSetAttributesCallback.test.ts
index baf1f8a847..1d8a8629db 100644
--- a/packages/react-hooks/src/useSetAttributesCallback.test.ts
+++ b/packages/react-hooks/src/useSetAttributesCallback.test.ts
@@ -1,5 +1,5 @@
import { renderHook } from '@testing-library/react-hooks';
-import { HTMLAttributes } from 'react';
+import { type HTMLAttributes } from 'react';
import { TestUtils } from '@deephaven/test-utils';
import useSetAttributesCallback from './useSetAttributesCallback';
diff --git a/packages/react-hooks/src/useSetAttributesCallback.ts b/packages/react-hooks/src/useSetAttributesCallback.ts
index 9584ebafa9..1c20d18989 100644
--- a/packages/react-hooks/src/useSetAttributesCallback.ts
+++ b/packages/react-hooks/src/useSetAttributesCallback.ts
@@ -1,4 +1,4 @@
-import { HTMLAttributes, useCallback } from 'react';
+import { type HTMLAttributes, useCallback } from 'react';
/**
* Returns a callback that sets attributes on elements based on given selectors.
diff --git a/packages/react-hooks/src/useSpectrumDisableSpellcheckRef.test.ts b/packages/react-hooks/src/useSpectrumDisableSpellcheckRef.test.ts
index 20a20c3d25..b0e3305ca3 100644
--- a/packages/react-hooks/src/useSpectrumDisableSpellcheckRef.test.ts
+++ b/packages/react-hooks/src/useSpectrumDisableSpellcheckRef.test.ts
@@ -1,5 +1,5 @@
import { renderHook } from '@testing-library/react-hooks';
-import { DOMRefValue } from '@react-types/shared';
+import { type DOMRefValue } from '@react-types/shared';
import { TestUtils } from '@deephaven/test-utils';
import useSetAttributesCallback from './useSetAttributesCallback';
import {
diff --git a/packages/react-hooks/src/useWindowedListData.test.ts b/packages/react-hooks/src/useWindowedListData.test.ts
index 4ce8767452..a8af8bab57 100644
--- a/packages/react-hooks/src/useWindowedListData.test.ts
+++ b/packages/react-hooks/src/useWindowedListData.test.ts
@@ -1,13 +1,13 @@
import {
act,
- Renderer,
+ type Renderer,
renderHook,
- RenderHookResult,
+ type RenderHookResult,
} from '@testing-library/react-hooks';
import { TestUtils } from '@deephaven/test-utils';
import useWindowedListData, {
defaultGetKey,
- WindowedListData,
+ type WindowedListData,
} from './useWindowedListData';
const { asMock } = TestUtils;
diff --git a/packages/react-hooks/src/useWindowedListData.ts b/packages/react-hooks/src/useWindowedListData.ts
index e8cc97a0b1..3cd17e968b 100644
--- a/packages/react-hooks/src/useWindowedListData.ts
+++ b/packages/react-hooks/src/useWindowedListData.ts
@@ -1,6 +1,6 @@
// eslint-disable-next-line no-restricted-imports
import type { ListData } from '@adobe/react-spectrum';
-import { Key, useCallback, useMemo, useState } from 'react';
+import { type Key, useCallback, useMemo, useState } from 'react';
/**
* Subset of React Stately ListData + bulkUpdate.
diff --git a/packages/redux/src/createMockStore.ts b/packages/redux/src/createMockStore.ts
index a7c96b286f..f8c2f6053a 100644
--- a/packages/redux/src/createMockStore.ts
+++ b/packages/redux/src/createMockStore.ts
@@ -1,4 +1,4 @@
-import store from './store';
+import type store from './store';
export function createMockStore(): typeof store {
return {
diff --git a/packages/redux/src/reducerRegistry.ts b/packages/redux/src/reducerRegistry.ts
index 99cf0f21f3..dee9890d21 100644
--- a/packages/redux/src/reducerRegistry.ts
+++ b/packages/redux/src/reducerRegistry.ts
@@ -1,4 +1,4 @@
-import { Reducer, ReducersMapObject } from 'redux';
+import { type Reducer, type ReducersMapObject } from 'redux';
export type ReducerRegistryListener = (reducers: ReducersMapObject) => void;
diff --git a/packages/storage/src/StorageUtils.ts b/packages/storage/src/StorageUtils.ts
index 3cce1add03..10d1cf3061 100644
--- a/packages/storage/src/StorageUtils.ts
+++ b/packages/storage/src/StorageUtils.ts
@@ -1,10 +1,10 @@
import { Operator as FilterOperator } from '@deephaven/filters';
import {
- FilterConfig,
- FilterConfigItem,
- FilterValue,
- SortConfig,
- SortDirection,
+ type FilterConfig,
+ type FilterConfigItem,
+ type FilterValue,
+ type SortConfig,
+ type SortDirection,
} from './Storage';
export class StorageUtils {
diff --git a/packages/test-utils/src/TestUtils.test.tsx b/packages/test-utils/src/TestUtils.test.tsx
index 3366aab273..5d0d1fd1f0 100644
--- a/packages/test-utils/src/TestUtils.test.tsx
+++ b/packages/test-utils/src/TestUtils.test.tsx
@@ -2,7 +2,7 @@ import React from 'react';
import { render, screen } from '@testing-library/react';
import userEvent from '@testing-library/user-event';
-import TestUtils, { ConsoleMethodName } from './TestUtils';
+import TestUtils, { type ConsoleMethodName } from './TestUtils';
import createMockProxy from './MockProxy';
beforeEach(() => {
diff --git a/packages/test-utils/src/TestUtils.ts b/packages/test-utils/src/TestUtils.ts
index 710cde65e7..cef6bea644 100644
--- a/packages/test-utils/src/TestUtils.ts
+++ b/packages/test-utils/src/TestUtils.ts
@@ -1,6 +1,6 @@
import type userEvent from '@testing-library/user-event';
import createMockProxy from './MockProxy';
-import { Tuple } from './TypeUtils';
+import { type Tuple } from './TypeUtils';
interface MockContext {
arc: jest.Mock;
diff --git a/packages/utils/src/Pending.ts b/packages/utils/src/Pending.ts
index 6d2e78c3a1..7e4c99f5ae 100644
--- a/packages/utils/src/Pending.ts
+++ b/packages/utils/src/Pending.ts
@@ -1,4 +1,4 @@
-import { PromiseUtils, CancelablePromise } from './PromiseUtils';
+import { PromiseUtils, type CancelablePromise } from './PromiseUtils';
/**
* Helper class for managing pending promises.
diff --git a/packages/utils/src/TimeUtils.test.ts b/packages/utils/src/TimeUtils.test.ts
index dba30cd878..0e9973e7d3 100644
--- a/packages/utils/src/TimeUtils.test.ts
+++ b/packages/utils/src/TimeUtils.test.ts
@@ -1,4 +1,4 @@
-import TimeUtils, { TimeString } from './TimeUtils';
+import TimeUtils, { type TimeString } from './TimeUtils';
describe('formatElapsedTime parsing tests', () => {
function testFormatElapsedTime(time: number, expectedResult: string) {
diff --git a/packages/utils/src/TypeUtils.test.ts b/packages/utils/src/TypeUtils.test.ts
index 729b0e2d77..ffd9e1bd65 100644
--- a/packages/utils/src/TypeUtils.test.ts
+++ b/packages/utils/src/TypeUtils.test.ts
@@ -1,4 +1,4 @@
-import { ValueOf } from './TypeUtils';
+import { type ValueOf } from './TypeUtils';
describe('ValueOf', () => {
it('should derive the value type', () => {