This is an automated email from the ASF dual-hosted git repository.
pierrejeambrun pushed a commit to branch v3-1-test
in repository https://gitbox.apache.org/repos/asf/airflow.git
The following commit(s) were added to refs/heads/v3-1-test by this push:
new d2dfb9497e1 Inherit core theme in React plugins (#60256) (#60405)
d2dfb9497e1 is described below
commit d2dfb9497e1ce85ea6922991207cadab5f0e097a
Author: Pierre Jeambrun <[email protected]>
AuthorDate: Mon Jan 12 13:00:45 2026 +0100
Inherit core theme in React plugins (#60256) (#60405)
(cherry picked from commit 3e57f1e5ce627050c4cb1bcdcb9735f251bc33c2)
---
airflow-core/src/airflow/ui/src/theme.ts | 3 +
.../react_plugin_template/README.md | 2 +
.../src/{main.tsx => global.d.ts} | 27 +-
.../react_plugin_template/src/main.tsx | 8 +-
.../react_plugin_template/src/theme.ts | 405 +--------------------
5 files changed, 17 insertions(+), 428 deletions(-)
diff --git a/airflow-core/src/airflow/ui/src/theme.ts
b/airflow-core/src/airflow/ui/src/theme.ts
index bd8206c11d3..b818e914d67 100644
--- a/airflow-core/src/airflow/ui/src/theme.ts
+++ b/airflow-core/src/airflow/ui/src/theme.ts
@@ -399,6 +399,9 @@ export const customConfig = defineConfig({
export const system = createSystem(defaultConfig, customConfig);
+// Once the system is created, make it globally available to dynamically
imported React plugins.
+Reflect.set(globalThis, "ChakraUISystem", system);
+
// Utility function to resolve CSS variables to their computed values
// See: https://github.com/chakra-ui/panda/discussions/2200
export const getComputedCSSVariableValue = (variable: string): string =>
diff --git a/dev/react-plugin-tools/react_plugin_template/README.md
b/dev/react-plugin-tools/react_plugin_template/README.md
index 8d9488ec777..2b2ad55cb22 100644
--- a/dev/react-plugin-tools/react_plugin_template/README.md
+++ b/dev/react-plugin-tools/react_plugin_template/README.md
@@ -72,6 +72,8 @@ For development and testing, use `pnpm dev` which will:
- Start a development server on port 5173
- Load the component using `src/dev.tsx` entry point
- Enable hot module replacement
+- Chakra Theme provided for local development is the default one, but in
production when the plugin is loaded into the Airflow Core UI,
+ it will inherit the main application theme for a consistent look and feel.
### Library Configuration
diff --git a/dev/react-plugin-tools/react_plugin_template/src/main.tsx
b/dev/react-plugin-tools/react_plugin_template/src/global.d.ts
similarity index 57%
copy from dev/react-plugin-tools/react_plugin_template/src/main.tsx
copy to dev/react-plugin-tools/react_plugin_template/src/global.d.ts
index 8ee670c0dac..bbad8db170e 100644
--- a/dev/react-plugin-tools/react_plugin_template/src/main.tsx
+++ b/dev/react-plugin-tools/react_plugin_template/src/global.d.ts
@@ -17,29 +17,8 @@
* under the License.
*/
-import { ChakraProvider } from "@chakra-ui/react";
-import { FC } from "react";
+export interface global {}
-import { ColorModeProvider } from "src/context/colorMode";
-import { HomePage } from "src/pages/HomePage";
-
-import { system } from "./theme";
-
-export interface PluginComponentProps {
- // Add any props your plugin component needs
+declare global {
+ var ChakraUISystem: SystemContext | undefined
}
-
-/**
- * Main plugin component
- */
-const PluginComponent: FC<PluginComponentProps> = (props) => {
- return (
- <ChakraProvider value={system}>
- <ColorModeProvider>
- <HomePage />
- </ColorModeProvider>
- </ChakraProvider>
- );
-};
-
-export default PluginComponent;
diff --git a/dev/react-plugin-tools/react_plugin_template/src/main.tsx
b/dev/react-plugin-tools/react_plugin_template/src/main.tsx
index 8ee670c0dac..c44ade0e57e 100644
--- a/dev/react-plugin-tools/react_plugin_template/src/main.tsx
+++ b/dev/react-plugin-tools/react_plugin_template/src/main.tsx
@@ -23,7 +23,7 @@ import { FC } from "react";
import { ColorModeProvider } from "src/context/colorMode";
import { HomePage } from "src/pages/HomePage";
-import { system } from "./theme";
+import { localSystem } from "./theme";
export interface PluginComponentProps {
// Add any props your plugin component needs
@@ -33,6 +33,12 @@ export interface PluginComponentProps {
* Main plugin component
*/
const PluginComponent: FC<PluginComponentProps> = (props) => {
+
+ // Use the globalChakraUISystem provided by the Airflow Core UI,
+ // so the plugin has a consistent theming with the host Airflow UI,
+ // fallback to localSystem for local development.
+ const system = (globalThis.ChakraUISystem) ?? localSystem;
+
return (
<ChakraProvider value={system}>
<ColorModeProvider>
diff --git a/dev/react-plugin-tools/react_plugin_template/src/theme.ts
b/dev/react-plugin-tools/react_plugin_template/src/theme.ts
index 464fbc8f86b..9f993216ca8 100644
--- a/dev/react-plugin-tools/react_plugin_template/src/theme.ts
+++ b/dev/react-plugin-tools/react_plugin_template/src/theme.ts
@@ -20,407 +20,6 @@
/* eslint-disable perfectionist/sort-objects */
/* eslint-disable max-lines */
-import { createSystem, defaultConfig, defineConfig } from "@chakra-ui/react";
-import type { CSSProperties } from "react";
+import { createSystem, defaultConfig } from "@chakra-ui/react";
-const generateSemanticTokens = (color: string, darkContrast: string = "white")
=> ({
- solid: { value: `{colors.${color}.600}` },
- contrast: { value: { _light: "white", _dark: darkContrast } },
- fg: { value: { _light: `{colors.${color}.800}`, _dark:
`{colors.${color}.200}` } },
- muted: { value: { _light: `{colors.${color}.200}`, _dark:
`{colors.${color}.800}` } },
- subtle: { value: { _light: `{colors.${color}.100}`, _dark:
`{colors.${color}.900}` } },
- emphasized: { value: { _light: `{colors.${color}.300}`, _dark:
`{colors.${color}.700}` } },
- focusRing: { value: { _light: `{colors.${color}.800}`, _dark:
`{colors.${color}.200}` } },
-});
-
-export const customConfig = defineConfig({
- // See https://chakra-ui.com/docs/theming/colors for more information on the
colors used here.
- theme: {
- tokens: {
- colors: {
- black: { value: "oklch(0.23185 0.0323 266.44)" }, // Custom value for
dark mode
- brand: {
- "50": { value: "oklch(0.98 0.006 248.717)" },
- "100": { value: "oklch(0.962 0.012 249.460)" },
- "200": { value: "oklch(0.923 0.023 255.082)" },
- "300": { value: "oklch(0.865 0.039 252.420)" },
- "400": { value: "oklch(0.705 0.066 256.378)" },
- "500": { value: "oklch(0.575 0.08 257.759)" },
- "600": { value: "oklch(0.469 0.084 257.657)" },
- "700": { value: "oklch(0.399 0.084 257.850)" },
- "800": { value: "oklch(0.324 0.072 260.329)" },
- "900": { value: "oklch(0.259 0.062 265.566)" },
- "950": { value: "oklch(0.179 0.05 265.487)" },
- },
- gray: {
- // Values modified from original Tailwind to improve contrast in
Chakra UI
- "50": { value: "oklch(0.985 0.004 253)" }, // Original: oklch(0.985
0.002 247.839)
- "100": { value: "oklch(0.955 0.006 253)" }, // Original: oklch(0.967
0.003 264.542)
- "200": { value: "oklch(0.915 0.01 253)" }, // Original: oklch(0.928
0.006 264.531)
- "300": { value: "oklch(0.85 0.016 253)" }, // Original: oklch(0.872
0.01 258.338)
- "400": { value: "oklch(0.75 0.025 252)" }, // Original: oklch(0.707
0.022 261.325)
- "500": { value: "oklch(0.63, 0.04, 252)" }, // Original: oklch(0.551
0.027 264.364)
- "600": { value: "oklch(0.45 0.055 251)" }, // Original: oklch(0.446
0.03 256.802)
- "700": { value: "oklch(0.35 0.045 251)" }, // Original: oklch(0.373
0.034 259.733)
- "800": { value: "oklch(0.28 0.035 251)" }, // Original: oklch(0.278
0.033 256.848)
- "900": { value: "oklch(0.18 0.03 251)" }, // Original: oklch(0.21
0.034 264.665)
- "950": { value: "oklch(0.11 0.025 251)" }, // Original: oklch(0.13
0.028 261.692)
- },
- // TAILWIND 4.0 COLORS
- // See https://tailwindcss.com/docs/colors for more information on the
colors used here.
- red: {
- "50": { value: "oklch(0.971 0.013 17.38)" },
- "100": { value: "oklch(0.936 0.032 17.717)" },
- "200": { value: "oklch(0.885 0.062 18.334)" },
- "300": { value: "oklch(0.808 0.114 19.571)" },
- "400": { value: "oklch(0.704 0.191 22.216)" },
- "500": { value: "oklch(0.637 0.237 25.331)" },
- "600": { value: "oklch(0.577 0.245 27.325)" },
- "700": { value: "oklch(0.505 0.213 27.518)" },
- "800": { value: "oklch(0.444 0.177 26.899)" },
- "900": { value: "oklch(0.396 0.141 25.723)" },
- "950": { value: "oklch(0.258 0.092 26.042)" },
- },
- // Values modified from original Tailwind to improve contrast in
Chakra UI
- orange: {
- "50": { value: "oklch(0.982 0.013 83.915)" },
- "100": { value: "oklch(0.961 0.033 82.320)" },
- "200": { value: "oklch(0.918 0.065 79.975)" },
- "300": { value: "oklch(0.857 0.118 76.815)" },
- "400": { value: "oklch(0.7492 0.1439 62.081)" }, // Original:
oklch(0.774 0.186 71.555)
- "500": { value: "oklch(0.6462 0.1979 43.792)" }, // Original:
oklch(0.705 0.213 47.604)
- "600": { value: "oklch(0.5902 0.198 35.93)" }, // Original:
oklch(0.632 0.214 41.185)
- "700": { value: "oklch(0.553 0.184 41.777)" },
- "800": { value: "oklch(0.469 0.144 45.164)" },
- "900": { value: "oklch(0.414 0.110 48.717)" },
- "950": { value: "oklch(0.271 0.069 52.345)" },
- },
- amber: {
- "50": { value: "oklch(0.987 0.022 95.277)" },
- "100": { value: "oklch(0.962 0.059 95.617)" },
- "200": { value: "oklch(0.924 0.12 95.746)" },
- "300": { value: "oklch(0.879 0.169 91.605)" },
- "400": { value: "oklch(0.828 0.189 84.429)" },
- "500": { value: "oklch(0.769 0.188 70.08)" },
- "600": { value: "oklch(0.666 0.179 58.318)" },
- "700": { value: "oklch(0.555 0.163 48.998)" },
- "800": { value: "oklch(0.473 0.137 46.201)" },
- "900": { value: "oklch(0.414 0.112 45.904)" },
- "950": { value: "oklch(0.279 0.077 45.635)" },
- },
- yellow: {
- "50": { value: "oklch(0.987 0.026 102.212)" },
- "100": { value: "oklch(0.973 0.071 103.193)" },
- "200": { value: "oklch(0.945 0.129 101.54)" },
- "300": { value: "oklch(0.905 0.182 98.111)" },
- "400": { value: "oklch(0.852 0.199 91.936)" },
- "500": { value: "oklch(0.795 0.184 86.047)" },
- "600": { value: "oklch(0.681 0.162 75.834)" },
- "700": { value: "oklch(0.554 0.135 66.442)" },
- "800": { value: "oklch(0.476 0.114 61.907)" },
- "900": { value: "oklch(0.421 0.095 57.708)" },
- "950": { value: "oklch(0.286 0.066 53.813)" },
- },
- lime: {
- "50": { value: "oklch(0.986 0.031 120.757)" },
- "100": { value: "oklch(0.967 0.067 122.328)" },
- "200": { value: "oklch(0.938 0.127 124.321)" },
- "300": { value: "oklch(0.897 0.196 126.665)" },
- "400": { value: "oklch(0.841 0.238 128.85)" },
- "500": { value: "oklch(0.768 0.233 130.85)" },
- "600": { value: "oklch(0.648 0.2 131.684)" },
- "700": { value: "oklch(0.532 0.157 131.589)" },
- "800": { value: "oklch(0.453 0.124 130.933)" },
- "900": { value: "oklch(0.405 0.101 131.063)" },
- "950": { value: "oklch(0.274 0.072 132.109)" },
- },
- green: {
- // Values modified from original Tailwind to improve contrast in
Chakra UI
- "50": { value: "oklch(0.982 0.018 155.826)" },
- "100": { value: "oklch(0.962 0.044 156.743)" },
- "200": { value: "oklch(0.925 0.084 155.995)" },
- "300": { value: "oklch(0.75 0.18 153.0)" }, // Original: oklch(0.871
0.15 154.449)
- "400": { value: "oklch(0.625 0.209 150.0)" }, // Original:
oklch(0.792 0.209 151.711)
- "500": { value: "oklch(0.528 0.219 149.579)" }, // Original:
oklch(0.723 0.219 149.579)
- "600": { value: "oklch(0.47 0.20 149.0)" }, // Original: oklch(0.627
0.194 149.214)
- "700": { value: "oklch(0.40 0.16 149.5)" }, // Original: oklch(0.527
0.154 150.069)
- "800": { value: "oklch(0.448 0.119 151.328)" },
- "900": { value: "oklch(0.393 0.095 152.535)" },
- "950": { value: "oklch(0.266 0.065 152.934)" },
- },
- emerald: {
- "50": { value: "oklch(0.979 0.021 166.113)" },
- "100": { value: "oklch(0.95 0.052 163.051)" },
- "200": { value: "oklch(0.905 0.093 164.15)" },
- "300": { value: "oklch(0.845 0.143 164.978)" },
- "400": { value: "oklch(0.765 0.177 163.223)" },
- "500": { value: "oklch(0.696 0.17 162.48)" },
- "600": { value: "oklch(0.596 0.145 163.225)" },
- "700": { value: "oklch(0.508 0.118 165.612)" },
- "800": { value: "oklch(0.432 0.095 166.913)" },
- "900": { value: "oklch(0.378 0.077 168.94)" },
- "950": { value: "oklch(0.262 0.051 172.552)" },
- },
- teal: {
- "50": { value: "oklch(0.984 0.014 180.72)" },
- "100": { value: "oklch(0.953 0.051 180.801)" },
- "200": { value: "oklch(0.91 0.096 180.426)" },
- "300": { value: "oklch(0.855 0.138 181.071)" },
- "400": { value: "oklch(0.777 0.152 181.912)" },
- "500": { value: "oklch(0.704 0.14 182.503)" },
- "600": { value: "oklch(0.6 0.118 184.704)" },
- "700": { value: "oklch(0.511 0.096 186.391)" },
- "800": { value: "oklch(0.437 0.078 188.216)" },
- "900": { value: "oklch(0.386 0.063 188.416)" },
- "950": { value: "oklch(0.277 0.046 192.524)" },
- },
- cyan: {
- "50": { value: "oklch(0.984 0.019 200.873)" },
- "100": { value: "oklch(0.956 0.045 203.388)" },
- "200": { value: "oklch(0.917 0.08 205.041)" },
- "300": { value: "oklch(0.865 0.127 207.078)" },
- "400": { value: "oklch(0.789 0.154 211.53)" },
- "500": { value: "oklch(0.715 0.143 215.221)" },
- "600": { value: "oklch(0.609 0.126 221.723)" },
- "700": { value: "oklch(0.52 0.105 223.128)" },
- "800": { value: "oklch(0.45 0.085 224.283)" },
- "900": { value: "oklch(0.398 0.07 227.392)" },
- "950": { value: "oklch(0.302 0.056 229.695)" },
- },
- sky: {
- "50": { value: "oklch(0.977 0.013 236.62)" },
- "100": { value: "oklch(0.951 0.026 236.824)" },
- "200": { value: "oklch(0.901 0.058 230.902)" },
- "300": { value: "oklch(0.828 0.111 230.318)" },
- "400": { value: "oklch(0.746 0.16 232.661)" },
- "500": { value: "oklch(0.685 0.169 237.323)" },
- "600": { value: "oklch(0.588 0.158 241.966)" },
- "700": { value: "oklch(0.5 0.134 242.749)" },
- "800": { value: "oklch(0.443 0.11 240.79)" },
- "900": { value: "oklch(0.391 0.09 240.876)" },
- "950": { value: "oklch(0.293 0.066 243.157)" },
- },
- blue: {
- "50": { value: "oklch(0.97 0.014 254.604)" },
- "100": { value: "oklch(0.932 0.032 255.585)" },
- "200": { value: "oklch(0.882 0.059 254.128)" },
- "300": { value: "oklch(0.809 0.105 251.813)" },
- "400": { value: "oklch(0.707 0.165 254.624)" },
- "500": { value: "oklch(0.623 0.214 259.815)" },
- "600": { value: "oklch(0.546 0.245 262.881)" },
- "700": { value: "oklch(0.488 0.243 264.376)" },
- "800": { value: "oklch(0.424 0.199 265.638)" },
- "900": { value: "oklch(0.379 0.146 265.522)" },
- "950": { value: "oklch(0.282 0.091 267.935)" },
- },
- indigo: {
- "50": { value: "oklch(0.962 0.018 272.314)" },
- "100": { value: "oklch(0.93 0.034 272.788)" },
- "200": { value: "oklch(0.87 0.065 274.039)" },
- "300": { value: "oklch(0.785 0.115 274.713)" },
- "400": { value: "oklch(0.673 0.182 276.935)" },
- "500": { value: "oklch(0.585 0.233 277.117)" },
- "600": { value: "oklch(0.511 0.262 276.966)" },
- "700": { value: "oklch(0.457 0.24 277.023)" },
- "800": { value: "oklch(0.398 0.195 277.366)" },
- "900": { value: "oklch(0.359 0.144 278.697)" },
- "950": { value: "oklch(0.257 0.09 281.288)" },
- },
- violet: {
- "50": { value: "oklch(0.969 0.016 293.756)" },
- "100": { value: "oklch(0.943 0.029 294.588)" },
- "200": { value: "oklch(0.894 0.057 293.283)" },
- "300": { value: "oklch(0.811 0.111 293.571)" },
- "400": { value: "oklch(0.702 0.183 293.541)" },
- "500": { value: "oklch(0.606 0.25 292.717)" },
- "600": { value: "oklch(0.541 0.281 293.009)" },
- "700": { value: "oklch(0.491 0.27 292.581)" },
- "800": { value: "oklch(0.432 0.232 292.759)" },
- "900": { value: "oklch(0.38 0.189 293.745)" },
- "950": { value: "oklch(0.283 0.141 291.089)" },
- },
- purple: {
- "50": { value: "oklch(0.977 0.014 308.299)" },
- "100": { value: "oklch(0.946 0.033 307.174)" },
- "200": { value: "oklch(0.902 0.063 306.703)" },
- "300": { value: "oklch(0.827 0.119 306.383)" },
- "400": { value: "oklch(0.714 0.203 305.504)" },
- "500": { value: "oklch(0.627 0.265 303.9)" },
- "600": { value: "oklch(0.558 0.288 302.321)" },
- "700": { value: "oklch(0.496 0.265 301.924)" },
- "800": { value: "oklch(0.438 0.218 303.724)" },
- "900": { value: "oklch(0.381 0.176 304.987)" },
- "950": { value: "oklch(0.291 0.149 302.717)" },
- },
- fuchsia: {
- "50": { value: "oklch(0.977 0.017 320.058)" },
- "100": { value: "oklch(0.952 0.037 318.852)" },
- "200": { value: "oklch(0.903 0.076 319.62)" },
- "300": { value: "oklch(0.833 0.145 321.434)" },
- "400": { value: "oklch(0.74 0.238 322.16)" },
- "500": { value: "oklch(0.667 0.295 322.15)" },
- "600": { value: "oklch(0.591 0.293 322.896)" },
- "700": { value: "oklch(0.518 0.253 323.949)" },
- "800": { value: "oklch(0.452 0.211 324.591)" },
- "900": { value: "oklch(0.401 0.17 325.612)" },
- "950": { value: "oklch(0.293 0.136 325.661)" },
- },
- pink: {
- "50": { value: "oklch(0.971 0.014 343.198)" },
- "100": { value: "oklch(0.948 0.028 342.258)" },
- "200": { value: "oklch(0.899 0.061 343.231)" },
- "300": { value: "oklch(0.823 0.12 346.018)" },
- "400": { value: "oklch(0.718 0.202 349.761)" },
- "500": { value: "oklch(0.656 0.241 354.308)" },
- "600": { value: "oklch(0.592 0.249 0.584)" },
- "700": { value: "oklch(0.525 0.223 3.958)" },
- "800": { value: "oklch(0.459 0.187 3.815)" },
- "900": { value: "oklch(0.408 0.153 2.432)" },
- "950": { value: "oklch(0.284 0.109 3.907)" },
- },
- rose: {
- "50": { value: "oklch(0.969 0.015 12.422)" },
- "100": { value: "oklch(0.941 0.03 12.58)" },
- "200": { value: "oklch(0.892 0.058 10.001)" },
- "300": { value: "oklch(0.81 0.117 11.638)" },
- "400": { value: "oklch(0.712 0.194 13.428)" },
- "500": { value: "oklch(0.645 0.246 16.439)" },
- "600": { value: "oklch(0.586 0.253 17.585)" },
- "700": { value: "oklch(0.514 0.222 16.935)" },
- "800": { value: "oklch(0.455 0.188 13.697)" },
- "900": { value: "oklch(0.41 0.159 10.272)" },
- "950": { value: "oklch(0.271 0.105 12.094)" },
- },
- slate: {
- "50": { value: "oklch(0.984 0.003 247.858)" },
- "100": { value: "oklch(0.968 0.007 247.896)" },
- "200": { value: "oklch(0.929 0.013 255.508)" },
- "300": { value: "oklch(0.869 0.022 252.894)" },
- "400": { value: "oklch(0.704 0.04 256.788)" },
- "500": { value: "oklch(0.554 0.046 257.417)" },
- "600": { value: "oklch(0.446 0.043 257.281)" },
- "700": { value: "oklch(0.372 0.044 257.287)" },
- "800": { value: "oklch(0.279 0.041 260.031)" },
- "900": { value: "oklch(0.208 0.042 265.755)" },
- "950": { value: "oklch(0.129 0.042 264.695)" },
- },
- zinc: {
- "50": { value: "oklch(0.985 0 0)" },
- "100": { value: "oklch(0.967 0.001 286.375)" },
- "200": { value: "oklch(0.92 0.004 286.32)" },
- "300": { value: "oklch(0.871 0.006 286.286)" },
- "400": { value: "oklch(0.705 0.015 286.067)" },
- "500": { value: "oklch(0.552 0.016 285.938)" },
- "600": { value: "oklch(0.442 0.017 285.786)" },
- "700": { value: "oklch(0.37 0.013 285.805)" },
- "800": { value: "oklch(0.274 0.006 286.033)" },
- "900": { value: "oklch(0.21 0.006 285.885)" },
- "950": { value: "oklch(0.141 0.005 285.823)" },
- },
- neutral: {
- "50": { value: "oklch(0.985 0 0)" },
- "100": { value: "oklch(0.97 0 0)" },
- "200": { value: "oklch(0.922 0 0)" },
- "300": { value: "oklch(0.87 0 0)" },
- "400": { value: "oklch(0.708 0 0)" },
- "500": { value: "oklch(0.556 0 0)" },
- "600": { value: "oklch(0.439 0 0)" },
- "700": { value: "oklch(0.371 0 0)" },
- "800": { value: "oklch(0.269 0 0)" },
- "900": { value: "oklch(0.205 0 0)" },
- "950": { value: "oklch(0.145 0 0)" },
- },
- stone: {
- "50": { value: "oklch(0.985 0.001 106.423)" },
- "100": { value: "oklch(0.97 0.001 106.424)" },
- "200": { value: "oklch(0.923 0.003 48.717)" },
- "300": { value: "oklch(0.869 0.005 56.366)" },
- "400": { value: "oklch(0.709 0.01 56.259)" },
- "500": { value: "oklch(0.553 0.013 58.071)" },
- "600": { value: "oklch(0.444 0.011 73.639)" },
- "700": { value: "oklch(0.374 0.01 67.558)" },
- "800": { value: "oklch(0.268 0.007 34.298)" },
- "900": { value: "oklch(0.216 0.006 56.043)" },
- "950": { value: "oklch(0.147 0.004 49.25)" },
- },
- },
- },
- semanticTokens: {
- colors: {
- // Brand colors for consistent theming
- brand: generateSemanticTokens("brand"),
- // GENERIC STATE
- danger: generateSemanticTokens("red"),
- info: generateSemanticTokens("blue"),
- warning: generateSemanticTokens("amber"),
- error: generateSemanticTokens("red"),
- // AIRFLOW TASK STATE
- active: generateSemanticTokens("blue"),
- success: generateSemanticTokens("green"),
- failed: generateSemanticTokens("red"),
- queued: generateSemanticTokens("stone"),
- skipped: generateSemanticTokens("pink"),
- up_for_reschedule: generateSemanticTokens("sky"),
- up_for_retry: generateSemanticTokens("yellow"),
- upstream_failed: generateSemanticTokens("orange"),
- running: generateSemanticTokens("cyan"),
- restarting: generateSemanticTokens("violet"),
- deferred: generateSemanticTokens("purple"),
- scheduled: generateSemanticTokens("zinc"),
- none: generateSemanticTokens("gray"),
- removed: generateSemanticTokens("slate"),
- // TAILWIND 4.0 COLORS
- red: generateSemanticTokens("red"),
- orange: generateSemanticTokens("orange"),
- amber: generateSemanticTokens("amber"),
- yellow: generateSemanticTokens("yellow"),
- lime: generateSemanticTokens("lime"),
- green: generateSemanticTokens("green"),
- emerald: generateSemanticTokens("emerald"),
- teal: generateSemanticTokens("teal"),
- cyan: generateSemanticTokens("cyan"),
- sky: generateSemanticTokens("sky"),
- blue: generateSemanticTokens("blue"),
- indigo: generateSemanticTokens("indigo"),
- violet: generateSemanticTokens("violet"),
- purple: generateSemanticTokens("purple"),
- fuchsia: generateSemanticTokens("fuchsia"),
- pink: generateSemanticTokens("pink"),
- rose: generateSemanticTokens("rose"),
- slate: generateSemanticTokens("slate"),
- gray: generateSemanticTokens("gray"),
- zinc: generateSemanticTokens("zinc"),
- neutral: generateSemanticTokens("neutral"),
- stone: generateSemanticTokens("stone"),
- },
- },
- },
-});
-
-export const system = createSystem(defaultConfig, customConfig);
-
-// Utility function to resolve CSS variables to their computed values
-// See: https://github.com/chakra-ui/panda/discussions/2200
-export const getComputedCSSVariableValue = (variable: string): string =>
- getComputedStyle(document.documentElement)
- .getPropertyValue(variable.slice(4, variable.length - 1))
- .trim();
-
-// Returns ReactFlow style props using Chakra UI CSS variables
-export const getReactFlowThemeStyle = (colorMode: "dark" | "light"):
CSSProperties =>
- ({
- // Background
- "--xy-background-color":
- colorMode === "dark" ? "var(--chakra-colors-brand-950)" :
"var(--chakra-colors-brand-50)",
- "--xy-background-pattern-color":
- colorMode === "dark" ? "var(--chakra-colors-gray-200)" :
"var(--chakra-colors-gray-800)",
-
- // Controls
- "--xy-controls-button-background-color":
- colorMode === "dark" ? "var(--chakra-colors-gray-800)" :
"var(--chakra-colors-white)",
- "--xy-controls-button-background-color-hover":
- colorMode === "dark" ? "var(--chakra-colors-gray-700)" :
"var(--chakra-colors-gray-100)",
-
- // MiniMap
- "--xy-minimap-background-color": "var(--chakra-colors-bg)",
- }) as CSSProperties;
+export const localSystem = createSystem(defaultConfig);