From d5c901b7260ce3f8ec55e22fbb85a8e8460a137a Mon Sep 17 00:00:00 2001
From: Isaac Hellendag <2823852+hellendag@users.noreply.github.com>
Date: Mon, 9 Dec 2024 16:41:22 -0600
Subject: [PATCH] [ui] Move CodeMirror-based components out of main
ui-components export (#26304)
## Summary & Motivation
The CodeMirror-based components in `ui-components` are adding quite a bit of CSS bloat via automatic imports, and the implicit use of `navigator` breaks static rendering in Next.js apps.
Split them out into an `editor` export, which can be used via `@dagster-io/ui-components/lib/editor`.
It would probably be good to split the library up further, but this is at least a step in the right direction.
## How I Tested These Changes
TS, lint, jest. `yarn build` for the component library, verify that it builds correctly and that CM-based components are split out of `index`.
---
.../dagster-ui/packages/app-oss/tsconfig.json | 1 +
.../packages/ui-components/CHANGES.md | 4 +
.../packages/ui-components/package.json | 2 +-
.../packages/ui-components/rollup.config.js | 106 ++++++++++--------
.../packages/ui-components/src/editor.ts | 4 +
.../packages/ui-components/src/index.ts | 4 -
.../packages/ui-core/jest.config.js | 1 +
.../CodeLocationOverviewRoot.tsx | 2 +-
.../src/configeditor/ConfigEditorUtils.tsx | 2 +-
.../src/instance/InstanceConcurrency.tsx | 2 +-
.../ui-core/src/instance/InstanceConfig.tsx | 2 +-
.../ui-core/src/launchpad/LaunchpadRoot.tsx | 3 +-
.../src/launchpad/LaunchpadSession.tsx | 12 +-
.../packages/ui-core/src/plugins/sql.tsx | 3 +-
.../ui-core/src/runs/RunConfigDialog.tsx | 11 +-
.../src/schedules/SchedulesNextTicks.tsx | 2 +-
.../src/workspace/CodeLocationMenu.tsx | 2 +-
.../dagster-ui/packages/ui-core/tsconfig.json | 1 +
18 files changed, 92 insertions(+), 72 deletions(-)
create mode 100644 js_modules/dagster-ui/packages/ui-components/src/editor.ts
diff --git a/js_modules/dagster-ui/packages/app-oss/tsconfig.json b/js_modules/dagster-ui/packages/app-oss/tsconfig.json
index fc2d305c048ae..5345f969e6b42 100644
--- a/js_modules/dagster-ui/packages/app-oss/tsconfig.json
+++ b/js_modules/dagster-ui/packages/app-oss/tsconfig.json
@@ -3,6 +3,7 @@
"paths": {
"@dagster-io/ui-core/*": ["../ui-core/src/*"],
"@dagster-io/ui-components": ["../ui-components/src"],
+ "@dagster-io/ui-components/editor": ["../ui-components/src/editor"],
"shared/*": ["../ui-core/src/*"]
},
"module": "esnext",
diff --git a/js_modules/dagster-ui/packages/ui-components/CHANGES.md b/js_modules/dagster-ui/packages/ui-components/CHANGES.md
index 17f3c1cdafd7d..52e39450f4a98 100644
--- a/js_modules/dagster-ui/packages/ui-components/CHANGES.md
+++ b/js_modules/dagster-ui/packages/ui-components/CHANGES.md
@@ -1,3 +1,7 @@
+# 1.2.1 (December 5, 2024)
+
+- Split CodeMirror-based components out of main index export
+
# 1.2.0 (December 5, 2024)
- Migrate styled-components to v6
diff --git a/js_modules/dagster-ui/packages/ui-components/package.json b/js_modules/dagster-ui/packages/ui-components/package.json
index b178ac7801105..ca29def1f1bc4 100644
--- a/js_modules/dagster-ui/packages/ui-components/package.json
+++ b/js_modules/dagster-ui/packages/ui-components/package.json
@@ -1,6 +1,6 @@
{
"name": "@dagster-io/ui-components",
- "version": "1.2.0",
+ "version": "1.2.1",
"description": "Dagster UI Component Library",
"license": "Apache-2.0",
"main": "lib/index.js",
diff --git a/js_modules/dagster-ui/packages/ui-components/rollup.config.js b/js_modules/dagster-ui/packages/ui-components/rollup.config.js
index 10d98f392aca3..c20bcb32acb23 100644
--- a/js_modules/dagster-ui/packages/ui-components/rollup.config.js
+++ b/js_modules/dagster-ui/packages/ui-components/rollup.config.js
@@ -11,52 +11,68 @@ import styles from 'rollup-plugin-styles';
const extensions = ['.js', '.jsx', '.ts', '.tsx', '.css', '.svg'];
-export default {
- input: {
- index: './src/index.ts',
+const sharedPlugins = [
+ styles({
+ extract: true,
+ }),
+ json(),
+ url(),
+ image(),
+ babel({
+ babelHelpers: 'bundled',
+ exclude: 'node_modules/**',
+ extensions: ['.js', '.jsx', '.ts', '.tsx'],
+ }),
+ commonjs(),
+ polyfills(),
+ resolve({extensions, preferBuiltins: false}),
+];
- // Our core fonts, usable as global style components, e.g. ``.
- 'fonts/GlobalGeistMono': './src/fonts/GlobalGeistMono.tsx',
- 'fonts/GlobalGeist': './src/fonts/GlobalGeist.tsx',
+const sharedExternals = [
+ '@blueprintjs/core',
+ '@blueprintjs/popover2',
+ '@blueprintjs/select',
+ 'react',
+ 'react-dom',
+ 'react-is',
+ 'styled-components',
+ 'stylis',
+];
- // Components are listed here individually so that they may be imported
- // without pulling in the entire library.
- 'components/Box': './src/components/Box.tsx',
- 'components/Button': './src/components/Button.tsx',
- 'components/Color': './src/components/Color.tsx',
- 'components/Icon': './src/components/Icon.tsx',
+export default [
+ {
+ input: {
+ index: './src/index.ts',
+
+ // Our core fonts, usable as global style components, e.g. ``.
+ 'fonts/GlobalGeistMono': './src/fonts/GlobalGeistMono.tsx',
+ 'fonts/GlobalGeist': './src/fonts/GlobalGeist.tsx',
+
+ // Components are listed here individually so that they may be imported
+ // without pulling in the entire library.
+ 'components/Box': './src/components/Box.tsx',
+ 'components/Button': './src/components/Button.tsx',
+ 'components/Color': './src/components/Color.tsx',
+ 'components/Icon': './src/components/Icon.tsx',
+ },
+ output: {
+ dir: 'lib',
+ exports: 'named',
+ format: 'cjs',
+ sourcemap: true,
+ },
+ plugins: sharedPlugins,
+ external: [...sharedExternals, '@tanstack/react-virtual'],
},
- output: {
- dir: 'lib',
- exports: 'named',
- format: 'cjs',
- sourcemap: true,
+ {
+ input: './src/editor.ts',
+ output: {
+ dir: 'lib',
+ exports: 'named',
+ format: 'cjs',
+ sourcemap: true,
+ },
+ plugins: sharedPlugins,
+ external: sharedExternals,
},
- plugins: [
- styles({
- extract: true,
- }),
- json(),
- url(),
- image(),
- babel({
- babelHelpers: 'bundled',
- exclude: 'node_modules/**',
- extensions: ['.js', '.jsx', '.ts', '.tsx'],
- }),
- commonjs(),
- polyfills(),
- resolve({extensions, preferBuiltins: false}),
- ],
- external: [
- '@blueprintjs/core',
- '@blueprintjs/popover2',
- '@blueprintjs/select',
- '@tanstack/react-virtual',
- 'react',
- 'react-dom',
- 'react-is',
- 'styled-components',
- 'stylis',
- ],
-};
+];
diff --git a/js_modules/dagster-ui/packages/ui-components/src/editor.ts b/js_modules/dagster-ui/packages/ui-components/src/editor.ts
new file mode 100644
index 0000000000000..62a654c369f70
--- /dev/null
+++ b/js_modules/dagster-ui/packages/ui-components/src/editor.ts
@@ -0,0 +1,4 @@
+export * from './components/ConfigEditorDialog';
+export * from './components/ConfigEditorWithSchema';
+export * from './components/NewConfigEditor';
+export * from './components/StyledRawCodeMirror';
diff --git a/js_modules/dagster-ui/packages/ui-components/src/index.ts b/js_modules/dagster-ui/packages/ui-components/src/index.ts
index 1224d069e9637..ba72a801271cf 100644
--- a/js_modules/dagster-ui/packages/ui-components/src/index.ts
+++ b/js_modules/dagster-ui/packages/ui-components/src/index.ts
@@ -7,8 +7,6 @@ export * from './components/ButtonGroup';
export * from './components/ButtonLink';
export * from './components/Checkbox';
export * from './components/CollapsibleSection';
-export * from './components/ConfigEditorDialog';
-export * from './components/ConfigEditorWithSchema';
export * from './components/ConfigTypeSchema';
export * from './components/Countdown';
export * from './components/CursorControls';
@@ -25,7 +23,6 @@ export * from './components/MainContent';
export * from './components/Menu';
export * from './components/MetadataTable';
export * from './components/MiddleTruncate';
-export * from './components/NewConfigEditor';
export * from './components/NonIdealState';
export * from './components/Page';
export * from './components/PageHeader';
@@ -41,7 +38,6 @@ export * from './components/Spinner';
export * from './components/SpinnerWithText';
export * from './components/SplitPanelContainer';
export * from './components/StyledButton';
-export * from './components/StyledRawCodeMirror';
export * from './components/SubwayDot';
export * from './components/Suggest';
export * from './components/Table';
diff --git a/js_modules/dagster-ui/packages/ui-core/jest.config.js b/js_modules/dagster-ui/packages/ui-core/jest.config.js
index 3039f576f7a91..543a7785cd2aa 100644
--- a/js_modules/dagster-ui/packages/ui-core/jest.config.js
+++ b/js_modules/dagster-ui/packages/ui-core/jest.config.js
@@ -78,6 +78,7 @@ module.exports = {
'\\.(css|less)$': 'identity-obj-proxy',
'^worker-loader(.*)/workers/(.*)$': '/jest/mocks/$2',
'^@dagster-io/ui-components$': '/../ui-components/src/index',
+ '^@dagster-io/ui-components/editor$': '/../ui-components/src/editor',
'^shared/(.*)$': '/src/$1',
},
diff --git a/js_modules/dagster-ui/packages/ui-core/src/code-location/CodeLocationOverviewRoot.tsx b/js_modules/dagster-ui/packages/ui-core/src/code-location/CodeLocationOverviewRoot.tsx
index 1f998022e2330..8ddff35ccc7e7 100644
--- a/js_modules/dagster-ui/packages/ui-core/src/code-location/CodeLocationOverviewRoot.tsx
+++ b/js_modules/dagster-ui/packages/ui-core/src/code-location/CodeLocationOverviewRoot.tsx
@@ -5,9 +5,9 @@ import {
MiddleTruncate,
Mono,
SpinnerWithText,
- StyledRawCodeMirror,
Table,
} from '@dagster-io/ui-components';
+import {StyledRawCodeMirror} from '@dagster-io/ui-components/editor';
import {useContext, useMemo} from 'react';
import {CodeLocationPageHeader} from 'shared/code-location/CodeLocationPageHeader.oss';
import {CodeLocationServerSection} from 'shared/code-location/CodeLocationServerSection.oss';
diff --git a/js_modules/dagster-ui/packages/ui-core/src/configeditor/ConfigEditorUtils.tsx b/js_modules/dagster-ui/packages/ui-core/src/configeditor/ConfigEditorUtils.tsx
index 8e8e256b5013c..81b2e24323da5 100644
--- a/js_modules/dagster-ui/packages/ui-core/src/configeditor/ConfigEditorUtils.tsx
+++ b/js_modules/dagster-ui/packages/ui-core/src/configeditor/ConfigEditorUtils.tsx
@@ -1,4 +1,4 @@
-import {YamlModeValidationResult} from '@dagster-io/ui-components';
+import {YamlModeValidationResult} from '@dagster-io/ui-components/editor';
import yaml from 'yaml';
import {gql} from '../apollo-client';
diff --git a/js_modules/dagster-ui/packages/ui-core/src/instance/InstanceConcurrency.tsx b/js_modules/dagster-ui/packages/ui-core/src/instance/InstanceConcurrency.tsx
index f38e3f27114b1..3e72fa1ddc767 100644
--- a/js_modules/dagster-ui/packages/ui-core/src/instance/InstanceConcurrency.tsx
+++ b/js_modules/dagster-ui/packages/ui-core/src/instance/InstanceConcurrency.tsx
@@ -17,13 +17,13 @@ import {
PageHeader,
Popover,
Spinner,
- StyledRawCodeMirror,
Subheading,
Table,
Tag,
TextInput,
Tooltip,
} from '@dagster-io/ui-components';
+import {StyledRawCodeMirror} from '@dagster-io/ui-components/editor';
import * as React from 'react';
import {Link} from 'react-router-dom';
diff --git a/js_modules/dagster-ui/packages/ui-core/src/instance/InstanceConfig.tsx b/js_modules/dagster-ui/packages/ui-core/src/instance/InstanceConfig.tsx
index 237c3ab20ddf2..71fca00ebf2d9 100644
--- a/js_modules/dagster-ui/packages/ui-core/src/instance/InstanceConfig.tsx
+++ b/js_modules/dagster-ui/packages/ui-core/src/instance/InstanceConfig.tsx
@@ -7,9 +7,9 @@ import {
Heading,
PageHeader,
Spinner,
- StyledRawCodeMirror,
Subheading,
} from '@dagster-io/ui-components';
+import {StyledRawCodeMirror} from '@dagster-io/ui-components/editor';
import CodeMirror from 'codemirror';
import {memo, useContext, useMemo} from 'react';
import {createGlobalStyle} from 'styled-components';
diff --git a/js_modules/dagster-ui/packages/ui-core/src/launchpad/LaunchpadRoot.tsx b/js_modules/dagster-ui/packages/ui-core/src/launchpad/LaunchpadRoot.tsx
index c5aa0ccb46657..55843af536a40 100644
--- a/js_modules/dagster-ui/packages/ui-core/src/launchpad/LaunchpadRoot.tsx
+++ b/js_modules/dagster-ui/packages/ui-core/src/launchpad/LaunchpadRoot.tsx
@@ -1,4 +1,5 @@
-import {CodeMirrorInDialogStyle, Dialog, DialogHeader} from '@dagster-io/ui-components';
+import {Dialog, DialogHeader} from '@dagster-io/ui-components';
+import {CodeMirrorInDialogStyle} from '@dagster-io/ui-components/editor';
import {Redirect, useParams} from 'react-router-dom';
import {LaunchpadAllowedRoot} from './LaunchpadAllowedRoot';
diff --git a/js_modules/dagster-ui/packages/ui-core/src/launchpad/LaunchpadSession.tsx b/js_modules/dagster-ui/packages/ui-core/src/launchpad/LaunchpadSession.tsx
index cbb164baf6422..6a64493550537 100644
--- a/js_modules/dagster-ui/packages/ui-core/src/launchpad/LaunchpadSession.tsx
+++ b/js_modules/dagster-ui/packages/ui-core/src/launchpad/LaunchpadSession.tsx
@@ -5,19 +5,21 @@ import {
ButtonLink,
Checkbox,
Colors,
- ConfigEditorHandle,
- ConfigEditorHelp,
- ConfigEditorHelpContext,
Dialog,
DialogFooter,
Group,
Icon,
- NewConfigEditor,
SplitPanelContainer,
SplitPanelContainerHandle,
TextInput,
- isHelpContextEqual,
} from '@dagster-io/ui-components';
+import {
+ ConfigEditorHandle,
+ ConfigEditorHelp,
+ ConfigEditorHelpContext,
+ NewConfigEditor,
+ isHelpContextEqual,
+} from '@dagster-io/ui-components/editor';
import uniqBy from 'lodash/uniqBy';
import * as React from 'react';
import {LaunchRootExecutionButton} from 'shared/launchpad/LaunchRootExecutionButton.oss';
diff --git a/js_modules/dagster-ui/packages/ui-core/src/plugins/sql.tsx b/js_modules/dagster-ui/packages/ui-core/src/plugins/sql.tsx
index dca45836ffdd2..a1234d42ba834 100644
--- a/js_modules/dagster-ui/packages/ui-core/src/plugins/sql.tsx
+++ b/js_modules/dagster-ui/packages/ui-core/src/plugins/sql.tsx
@@ -1,4 +1,5 @@
-import {Button, Dialog, DialogFooter, Icon, StyledRawCodeMirror} from '@dagster-io/ui-components';
+import {Button, Dialog, DialogFooter, Icon} from '@dagster-io/ui-components';
+import {StyledRawCodeMirror} from '@dagster-io/ui-components/editor';
import {useEffect, useState} from 'react';
import {IPluginSidebarProps} from '../plugins';
diff --git a/js_modules/dagster-ui/packages/ui-core/src/runs/RunConfigDialog.tsx b/js_modules/dagster-ui/packages/ui-core/src/runs/RunConfigDialog.tsx
index a302013baefb6..7dad84a6c971d 100644
--- a/js_modules/dagster-ui/packages/ui-core/src/runs/RunConfigDialog.tsx
+++ b/js_modules/dagster-ui/packages/ui-core/src/runs/RunConfigDialog.tsx
@@ -1,12 +1,5 @@
-import {
- Box,
- Button,
- Dialog,
- DialogFooter,
- Icon,
- StyledRawCodeMirror,
- Subheading,
-} from '@dagster-io/ui-components';
+import {Box, Button, Dialog, DialogFooter, Icon, Subheading} from '@dagster-io/ui-components';
+import {StyledRawCodeMirror} from '@dagster-io/ui-components/editor';
import styled from 'styled-components';
import {RunTags} from './RunTags';
diff --git a/js_modules/dagster-ui/packages/ui-core/src/schedules/SchedulesNextTicks.tsx b/js_modules/dagster-ui/packages/ui-core/src/schedules/SchedulesNextTicks.tsx
index 9f6c89ceb6abd..9b2a14e373016 100644
--- a/js_modules/dagster-ui/packages/ui-core/src/schedules/SchedulesNextTicks.tsx
+++ b/js_modules/dagster-ui/packages/ui-core/src/schedules/SchedulesNextTicks.tsx
@@ -14,10 +14,10 @@ import {
NonIdealState,
Popover,
Spinner,
- StyledRawCodeMirror,
Subheading,
Table,
} from '@dagster-io/ui-components';
+import {StyledRawCodeMirror} from '@dagster-io/ui-components/editor';
import qs from 'qs';
import {memo, useEffect, useState} from 'react';
import {Link} from 'react-router-dom';
diff --git a/js_modules/dagster-ui/packages/ui-core/src/workspace/CodeLocationMenu.tsx b/js_modules/dagster-ui/packages/ui-core/src/workspace/CodeLocationMenu.tsx
index ac60eb02aa210..78846b9667bb8 100644
--- a/js_modules/dagster-ui/packages/ui-core/src/workspace/CodeLocationMenu.tsx
+++ b/js_modules/dagster-ui/packages/ui-core/src/workspace/CodeLocationMenu.tsx
@@ -6,9 +6,9 @@ import {
Menu,
MenuItem,
Popover,
- StyledRawCodeMirror,
Table,
} from '@dagster-io/ui-components';
+import {StyledRawCodeMirror} from '@dagster-io/ui-components/editor';
import {useMemo, useState} from 'react';
import * as yaml from 'yaml';
diff --git a/js_modules/dagster-ui/packages/ui-core/tsconfig.json b/js_modules/dagster-ui/packages/ui-core/tsconfig.json
index 542426ae2e138..91b6df638a3a0 100644
--- a/js_modules/dagster-ui/packages/ui-core/tsconfig.json
+++ b/js_modules/dagster-ui/packages/ui-core/tsconfig.json
@@ -2,6 +2,7 @@
"compilerOptions": {
"paths": {
"@dagster-io/ui-components": ["../ui-components/src"],
+ "@dagster-io/ui-components/editor": ["../ui-components/src/editor"],
"shared/*": ["./src/*"]
},
"module": "es2022",