blob: 464fbc8f86b5083a0d94169dd52452ce003cfbb4 [file] [log] [blame]
/*!
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/
/* eslint-disable perfectionist/sort-objects */
/* eslint-disable max-lines */
import { createSystem, defaultConfig, defineConfig } from "@chakra-ui/react";
import type { CSSProperties } from "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;