@opencode-ai/ui 0.0.0-beta-202606251302
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/package.json +110 -0
- package/src/assets/audio/alert-01.aac +0 -0
- package/src/assets/audio/alert-01.mp3 +0 -0
- package/src/assets/audio/alert-02.aac +0 -0
- package/src/assets/audio/alert-02.mp3 +0 -0
- package/src/assets/audio/alert-03.aac +0 -0
- package/src/assets/audio/alert-03.mp3 +0 -0
- package/src/assets/audio/alert-04.aac +0 -0
- package/src/assets/audio/alert-04.mp3 +0 -0
- package/src/assets/audio/alert-05.aac +0 -0
- package/src/assets/audio/alert-05.mp3 +0 -0
- package/src/assets/audio/alert-06.aac +0 -0
- package/src/assets/audio/alert-06.mp3 +0 -0
- package/src/assets/audio/alert-07.aac +0 -0
- package/src/assets/audio/alert-07.mp3 +0 -0
- package/src/assets/audio/alert-08.aac +0 -0
- package/src/assets/audio/alert-08.mp3 +0 -0
- package/src/assets/audio/alert-09.aac +0 -0
- package/src/assets/audio/alert-09.mp3 +0 -0
- package/src/assets/audio/alert-10.aac +0 -0
- package/src/assets/audio/alert-10.mp3 +0 -0
- package/src/assets/audio/bip-bop-01.aac +0 -0
- package/src/assets/audio/bip-bop-01.mp3 +0 -0
- package/src/assets/audio/bip-bop-02.aac +0 -0
- package/src/assets/audio/bip-bop-02.mp3 +0 -0
- package/src/assets/audio/bip-bop-03.aac +0 -0
- package/src/assets/audio/bip-bop-03.mp3 +0 -0
- package/src/assets/audio/bip-bop-04.aac +0 -0
- package/src/assets/audio/bip-bop-04.mp3 +0 -0
- package/src/assets/audio/bip-bop-05.aac +0 -0
- package/src/assets/audio/bip-bop-05.mp3 +0 -0
- package/src/assets/audio/bip-bop-06.aac +0 -0
- package/src/assets/audio/bip-bop-06.mp3 +0 -0
- package/src/assets/audio/bip-bop-07.aac +0 -0
- package/src/assets/audio/bip-bop-07.mp3 +0 -0
- package/src/assets/audio/bip-bop-08.aac +0 -0
- package/src/assets/audio/bip-bop-08.mp3 +0 -0
- package/src/assets/audio/bip-bop-09.aac +0 -0
- package/src/assets/audio/bip-bop-09.mp3 +0 -0
- package/src/assets/audio/bip-bop-10.aac +0 -0
- package/src/assets/audio/bip-bop-10.mp3 +0 -0
- package/src/assets/audio/nope-01.aac +0 -0
- package/src/assets/audio/nope-01.mp3 +0 -0
- package/src/assets/audio/nope-02.aac +0 -0
- package/src/assets/audio/nope-02.mp3 +0 -0
- package/src/assets/audio/nope-03.aac +0 -0
- package/src/assets/audio/nope-03.mp3 +0 -0
- package/src/assets/audio/nope-04.aac +0 -0
- package/src/assets/audio/nope-04.mp3 +0 -0
- package/src/assets/audio/nope-05.aac +0 -0
- package/src/assets/audio/nope-05.mp3 +0 -0
- package/src/assets/audio/nope-06.aac +0 -0
- package/src/assets/audio/nope-06.mp3 +0 -0
- package/src/assets/audio/nope-07.aac +0 -0
- package/src/assets/audio/nope-07.mp3 +0 -0
- package/src/assets/audio/nope-08.aac +0 -0
- package/src/assets/audio/nope-08.mp3 +0 -0
- package/src/assets/audio/nope-09.aac +0 -0
- package/src/assets/audio/nope-09.mp3 +0 -0
- package/src/assets/audio/nope-10.aac +0 -0
- package/src/assets/audio/nope-10.mp3 +0 -0
- package/src/assets/audio/nope-11.aac +0 -0
- package/src/assets/audio/nope-11.mp3 +0 -0
- package/src/assets/audio/nope-12.aac +0 -0
- package/src/assets/audio/nope-12.mp3 +0 -0
- package/src/assets/audio/staplebops-01.aac +0 -0
- package/src/assets/audio/staplebops-01.mp3 +0 -0
- package/src/assets/audio/staplebops-02.aac +0 -0
- package/src/assets/audio/staplebops-02.mp3 +0 -0
- package/src/assets/audio/staplebops-03.aac +0 -0
- package/src/assets/audio/staplebops-03.mp3 +0 -0
- package/src/assets/audio/staplebops-04.aac +0 -0
- package/src/assets/audio/staplebops-04.mp3 +0 -0
- package/src/assets/audio/staplebops-05.aac +0 -0
- package/src/assets/audio/staplebops-05.mp3 +0 -0
- package/src/assets/audio/staplebops-06.aac +0 -0
- package/src/assets/audio/staplebops-06.mp3 +0 -0
- package/src/assets/audio/staplebops-07.aac +0 -0
- package/src/assets/audio/staplebops-07.mp3 +0 -0
- package/src/assets/audio/yup-01.aac +0 -0
- package/src/assets/audio/yup-01.mp3 +0 -0
- package/src/assets/audio/yup-02.aac +0 -0
- package/src/assets/audio/yup-02.mp3 +0 -0
- package/src/assets/audio/yup-03.aac +0 -0
- package/src/assets/audio/yup-03.mp3 +0 -0
- package/src/assets/audio/yup-04.aac +0 -0
- package/src/assets/audio/yup-04.mp3 +0 -0
- package/src/assets/audio/yup-05.aac +0 -0
- package/src/assets/audio/yup-05.mp3 +0 -0
- package/src/assets/audio/yup-06.aac +0 -0
- package/src/assets/audio/yup-06.mp3 +0 -0
- package/src/assets/fonts/Inter.ttf +0 -0
- package/src/assets/fonts/JetBrainsMonoNerdFontMono-Regular.woff2 +0 -0
- package/src/assets/icons/app/android-studio.svg +369 -0
- package/src/assets/icons/app/antigravity.svg +97 -0
- package/src/assets/icons/app/cursor.svg +16 -0
- package/src/assets/icons/app/file-explorer.svg +20 -0
- package/src/assets/icons/app/finder.png +0 -0
- package/src/assets/icons/app/ghostty.svg +13 -0
- package/src/assets/icons/app/iterm2.svg +13 -0
- package/src/assets/icons/app/powershell.svg +14 -0
- package/src/assets/icons/app/sublimetext.svg +17 -0
- package/src/assets/icons/app/terminal.png +0 -0
- package/src/assets/icons/app/textmate.png +0 -0
- package/src/assets/icons/app/vscode.svg +39 -0
- package/src/assets/icons/app/warp.png +0 -0
- package/src/assets/icons/app/xcode.png +0 -0
- package/src/assets/icons/app/zed-dark.svg +15 -0
- package/src/assets/icons/app/zed.svg +15 -0
- package/src/components/accordion.css +123 -0
- package/src/components/accordion.tsx +92 -0
- package/src/components/animated-number.css +75 -0
- package/src/components/animated-number.tsx +109 -0
- package/src/components/app-icon.css +5 -0
- package/src/components/app-icon.tsx +85 -0
- package/src/components/app-icons/sprite.svg +114 -0
- package/src/components/app-icons/types.ts +21 -0
- package/src/components/avatar.css +49 -0
- package/src/components/avatar.tsx +55 -0
- package/src/components/button.css +194 -0
- package/src/components/button.tsx +33 -0
- package/src/components/card.css +94 -0
- package/src/components/card.tsx +123 -0
- package/src/components/checkbox.css +131 -0
- package/src/components/checkbox.tsx +43 -0
- package/src/components/collapsible.css +148 -0
- package/src/components/collapsible.tsx +48 -0
- package/src/components/context-menu.css +134 -0
- package/src/components/context-menu.tsx +308 -0
- package/src/components/dialog.css +181 -0
- package/src/components/dialog.tsx +72 -0
- package/src/components/diff-changes.css +42 -0
- package/src/components/diff-changes.tsx +115 -0
- package/src/components/dock-surface.css +23 -0
- package/src/components/dock-surface.tsx +54 -0
- package/src/components/dropdown-menu.css +135 -0
- package/src/components/dropdown-menu.tsx +308 -0
- package/src/components/favicon.tsx +13 -0
- package/src/components/file-icon.css +26 -0
- package/src/components/file-icon.tsx +588 -0
- package/src/components/file-icons/sprite.svg +11707 -0
- package/src/components/file-icons/types.ts +1095 -0
- package/src/components/font.tsx +1 -0
- package/src/components/hover-card.css +61 -0
- package/src/components/hover-card.tsx +32 -0
- package/src/components/icon-button.css +181 -0
- package/src/components/icon-button.tsx +29 -0
- package/src/components/icon.css +34 -0
- package/src/components/icon.tsx +169 -0
- package/src/components/image-preview.css +63 -0
- package/src/components/image-preview.tsx +32 -0
- package/src/components/inline-input.css +17 -0
- package/src/components/inline-input.tsx +22 -0
- package/src/components/keybind.css +18 -0
- package/src/components/keybind.tsx +20 -0
- package/src/components/list.css +331 -0
- package/src/components/list.tsx +394 -0
- package/src/components/logo.css +4 -0
- package/src/components/logo.tsx +62 -0
- package/src/components/motion-spring.tsx +58 -0
- package/src/components/popover.css +98 -0
- package/src/components/popover.tsx +153 -0
- package/src/components/progress-circle.css +12 -0
- package/src/components/progress-circle.tsx +57 -0
- package/src/components/progress.css +63 -0
- package/src/components/progress.tsx +39 -0
- package/src/components/provider-icon.css +5 -0
- package/src/components/provider-icon.tsx +25 -0
- package/src/components/provider-icons/sprite.svg +1135 -0
- package/src/components/provider-icons/types.ts +105 -0
- package/src/components/radio-group.css +187 -0
- package/src/components/radio-group.tsx +83 -0
- package/src/components/resize-handle.css +58 -0
- package/src/components/resize-handle.tsx +82 -0
- package/src/components/scroll-view.css +66 -0
- package/src/components/scroll-view.tsx +250 -0
- package/src/components/select.css +202 -0
- package/src/components/select.tsx +174 -0
- package/src/components/spinner.css +6 -0
- package/src/components/spinner.tsx +52 -0
- package/src/components/sticky-accordion-header.css +6 -0
- package/src/components/sticky-accordion-header.tsx +18 -0
- package/src/components/switch.css +132 -0
- package/src/components/switch.tsx +29 -0
- package/src/components/tabs.css +635 -0
- package/src/components/tabs.tsx +125 -0
- package/src/components/tag.css +37 -0
- package/src/components/tag.tsx +22 -0
- package/src/components/text-field.css +134 -0
- package/src/components/text-field.tsx +128 -0
- package/src/components/text-reveal.css +150 -0
- package/src/components/text-reveal.tsx +143 -0
- package/src/components/text-shimmer.css +119 -0
- package/src/components/text-shimmer.tsx +62 -0
- package/src/components/text-strikethrough.css +27 -0
- package/src/components/text-strikethrough.tsx +84 -0
- package/src/components/toast.css +236 -0
- package/src/components/toast.tsx +185 -0
- package/src/components/tooltip.css +74 -0
- package/src/components/tooltip.tsx +161 -0
- package/src/components/typewriter.css +14 -0
- package/src/components/typewriter.tsx +55 -0
- package/src/context/dialog.tsx +197 -0
- package/src/context/file.tsx +10 -0
- package/src/context/helper.tsx +38 -0
- package/src/context/i18n.tsx +38 -0
- package/src/context/index.ts +4 -0
- package/src/context/marked.tsx +522 -0
- package/src/context/worker-pool.tsx +20 -0
- package/src/custom-elements.d.ts +17 -0
- package/src/hooks/create-auto-scroll.tsx +237 -0
- package/src/hooks/index.ts +2 -0
- package/src/hooks/use-filtered-list.tsx +134 -0
- package/src/i18n/ar.ts +168 -0
- package/src/i18n/br.ts +168 -0
- package/src/i18n/bs.ts +172 -0
- package/src/i18n/da.ts +167 -0
- package/src/i18n/de.ts +173 -0
- package/src/i18n/en.ts +176 -0
- package/src/i18n/es.ts +168 -0
- package/src/i18n/fr.ts +168 -0
- package/src/i18n/ja.ts +167 -0
- package/src/i18n/ko.ts +168 -0
- package/src/i18n/no.ts +171 -0
- package/src/i18n/pl.ts +167 -0
- package/src/i18n/ru.ts +167 -0
- package/src/i18n/th.ts +169 -0
- package/src/i18n/tr.ts +174 -0
- package/src/i18n/uk.ts +167 -0
- package/src/i18n/zh.ts +171 -0
- package/src/i18n/zht.ts +171 -0
- package/src/storybook/fixtures.ts +51 -0
- package/src/storybook/scaffold.tsx +62 -0
- package/src/styles/animations.css +141 -0
- package/src/styles/base.css +404 -0
- package/src/styles/colors.css +772 -0
- package/src/styles/index.css +53 -0
- package/src/styles/tailwind/colors.css +285 -0
- package/src/styles/tailwind/index.css +78 -0
- package/src/styles/tailwind/utilities.css +131 -0
- package/src/styles/theme.css +609 -0
- package/src/styles/utilities.css +118 -0
- package/src/theme/color.ts +299 -0
- package/src/theme/context.tsx +370 -0
- package/src/theme/default-themes.ts +116 -0
- package/src/theme/index.ts +78 -0
- package/src/theme/loader.ts +112 -0
- package/src/theme/resolve.ts +540 -0
- package/src/theme/themes/amoled.json +49 -0
- package/src/theme/themes/aura.json +51 -0
- package/src/theme/themes/ayu.json +51 -0
- package/src/theme/themes/carbonfox.json +53 -0
- package/src/theme/themes/catppuccin-frappe.json +85 -0
- package/src/theme/themes/catppuccin-macchiato.json +85 -0
- package/src/theme/themes/catppuccin.json +45 -0
- package/src/theme/themes/cobalt2.json +87 -0
- package/src/theme/themes/cursor.json +91 -0
- package/src/theme/themes/dracula.json +49 -0
- package/src/theme/themes/everforest.json +89 -0
- package/src/theme/themes/flexoki.json +86 -0
- package/src/theme/themes/github.json +85 -0
- package/src/theme/themes/gruvbox.json +45 -0
- package/src/theme/themes/kanagawa.json +89 -0
- package/src/theme/themes/lucent-orng.json +87 -0
- package/src/theme/themes/material.json +87 -0
- package/src/theme/themes/matrix.json +113 -0
- package/src/theme/themes/mercury.json +86 -0
- package/src/theme/themes/monokai.json +49 -0
- package/src/theme/themes/nightowl.json +46 -0
- package/src/theme/themes/nord.json +46 -0
- package/src/theme/themes/oc-2.json +468 -0
- package/src/theme/themes/one-dark.json +89 -0
- package/src/theme/themes/onedarkpro.json +45 -0
- package/src/theme/themes/opencode.json +89 -0
- package/src/theme/themes/orng.json +87 -0
- package/src/theme/themes/osaka-jade.json +88 -0
- package/src/theme/themes/palenight.json +85 -0
- package/src/theme/themes/rosepine.json +85 -0
- package/src/theme/themes/shadesofpurple.json +51 -0
- package/src/theme/themes/solarized.json +49 -0
- package/src/theme/themes/synthwave84.json +87 -0
- package/src/theme/themes/tokyonight.json +47 -0
- package/src/theme/themes/vercel.json +90 -0
- package/src/theme/themes/vesper.json +51 -0
- package/src/theme/themes/zenburn.json +87 -0
- package/src/theme/types.ts +75 -0
- package/src/theme/v2/avatar.ts +48 -0
- package/src/theme/v2/default-primitives.ts +114 -0
- package/src/theme/v2/foreground.ts +60 -0
- package/src/theme/v2/mapping.ts +138 -0
- package/src/theme/v2/resolve.ts +153 -0
- package/src/v2/components/accordion-v2.css +139 -0
- package/src/v2/components/accordion-v2.tsx +86 -0
- package/src/v2/components/avatar-v2.css +70 -0
- package/src/v2/components/avatar-v2.tsx +59 -0
- package/src/v2/components/badge-v2.css +27 -0
- package/src/v2/components/badge-v2.tsx +20 -0
- package/src/v2/components/button-v2.css +186 -0
- package/src/v2/components/button-v2.tsx +35 -0
- package/src/v2/components/checkbox-v2.css +184 -0
- package/src/v2/components/checkbox-v2.tsx +65 -0
- package/src/v2/components/dialog-v2.css +150 -0
- package/src/v2/components/dialog-v2.tsx +93 -0
- package/src/v2/components/diff-changes-v2.css +24 -0
- package/src/v2/components/diff-changes-v2.tsx +28 -0
- package/src/v2/components/field-v2.css +94 -0
- package/src/v2/components/field-v2.tsx +265 -0
- package/src/v2/components/icon-button-v2.css +155 -0
- package/src/v2/components/icon-button-v2.tsx +37 -0
- package/src/v2/components/icon.tsx +129 -0
- package/src/v2/components/inline-input-v2.css +218 -0
- package/src/v2/components/inline-input-v2.tsx +90 -0
- package/src/v2/components/keybind-v2.css +76 -0
- package/src/v2/components/keybind-v2.tsx +30 -0
- package/src/v2/components/line-comment-v2.css +204 -0
- package/src/v2/components/line-comment-v2.tsx +155 -0
- package/src/v2/components/menu-v2.css +190 -0
- package/src/v2/components/menu-v2.tsx +225 -0
- package/src/v2/components/project-avatar-v2.css +126 -0
- package/src/v2/components/project-avatar-v2.tsx +64 -0
- package/src/v2/components/radio-v2.css +202 -0
- package/src/v2/components/radio-v2.tsx +72 -0
- package/src/v2/components/segmented-control-v2.css +80 -0
- package/src/v2/components/segmented-control-v2.tsx +208 -0
- package/src/v2/components/select-v2.css +285 -0
- package/src/v2/components/select-v2.tsx +208 -0
- package/src/v2/components/switch-v2.css +154 -0
- package/src/v2/components/switch-v2.tsx +28 -0
- package/src/v2/components/tab-state-indicator.tsx +37 -0
- package/src/v2/components/tabs-v2.css +225 -0
- package/src/v2/components/tabs-v2.tsx +147 -0
- package/src/v2/components/text-input-v2.css +145 -0
- package/src/v2/components/text-input-v2.tsx +67 -0
- package/src/v2/components/text-shimmer-v2.css +125 -0
- package/src/v2/components/text-shimmer-v2.tsx +63 -0
- package/src/v2/components/textarea-v2.css +78 -0
- package/src/v2/components/textarea-v2.tsx +31 -0
- package/src/v2/components/toast-v2.css +215 -0
- package/src/v2/components/toast-v2.tsx +144 -0
- package/src/v2/components/tooltip-v2.css +53 -0
- package/src/v2/components/tooltip-v2.tsx +146 -0
- package/src/v2/components/wordmark-v2.tsx +92 -0
- package/src/v2/styles/colors.css +172 -0
- package/src/v2/styles/tailwind.css +2 -0
- package/src/v2/styles/theme.css +441 -0
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
{
|
|
2
|
+
"$schema": "https://opencode.ai/desktop-theme.json",
|
|
3
|
+
"name": "Vercel",
|
|
4
|
+
"id": "vercel",
|
|
5
|
+
"light": {
|
|
6
|
+
"palette": {
|
|
7
|
+
"neutral": "#FFFFFF",
|
|
8
|
+
"ink": "#171717",
|
|
9
|
+
"primary": "#0070F3",
|
|
10
|
+
"accent": "#8E4EC6",
|
|
11
|
+
"success": "#388E3C",
|
|
12
|
+
"warning": "#FF9500",
|
|
13
|
+
"error": "#DC3545",
|
|
14
|
+
"info": "#0070F3",
|
|
15
|
+
"diffAdd": "#46A758",
|
|
16
|
+
"diffDelete": "#E5484D"
|
|
17
|
+
},
|
|
18
|
+
"overrides": {
|
|
19
|
+
"text-weak": "#666666",
|
|
20
|
+
"syntax-comment": "#888888",
|
|
21
|
+
"syntax-keyword": "#E93D82",
|
|
22
|
+
"syntax-string": "#46A758",
|
|
23
|
+
"syntax-primitive": "#8E4EC6",
|
|
24
|
+
"syntax-variable": "#0070F3",
|
|
25
|
+
"syntax-property": "#12A594",
|
|
26
|
+
"syntax-type": "#12A594",
|
|
27
|
+
"syntax-constant": "#FFB224",
|
|
28
|
+
"syntax-operator": "#E93D82",
|
|
29
|
+
"syntax-punctuation": "#171717",
|
|
30
|
+
"syntax-object": "#0070F3",
|
|
31
|
+
"markdown-heading": "#8E4EC6",
|
|
32
|
+
"markdown-text": "#171717",
|
|
33
|
+
"markdown-link": "#0070F3",
|
|
34
|
+
"markdown-link-text": "#12A594",
|
|
35
|
+
"markdown-code": "#46A758",
|
|
36
|
+
"markdown-block-quote": "#666666",
|
|
37
|
+
"markdown-emph": "#FFB224",
|
|
38
|
+
"markdown-strong": "#E93D82",
|
|
39
|
+
"markdown-horizontal-rule": "#999999",
|
|
40
|
+
"markdown-list-item": "#171717",
|
|
41
|
+
"markdown-list-enumeration": "#0070F3",
|
|
42
|
+
"markdown-image": "#12A594",
|
|
43
|
+
"markdown-image-text": "#12A594",
|
|
44
|
+
"markdown-code-block": "#171717"
|
|
45
|
+
}
|
|
46
|
+
},
|
|
47
|
+
"dark": {
|
|
48
|
+
"palette": {
|
|
49
|
+
"neutral": "#000000",
|
|
50
|
+
"ink": "#EDEDED",
|
|
51
|
+
"primary": "#0070F3",
|
|
52
|
+
"accent": "#8E4EC6",
|
|
53
|
+
"success": "#46A758",
|
|
54
|
+
"warning": "#FFB224",
|
|
55
|
+
"error": "#E5484D",
|
|
56
|
+
"info": "#52A8FF",
|
|
57
|
+
"interactive": "#52A8FF",
|
|
58
|
+
"diffAdd": "#63C46D",
|
|
59
|
+
"diffDelete": "#FF6166"
|
|
60
|
+
},
|
|
61
|
+
"overrides": {
|
|
62
|
+
"text-weak": "#878787",
|
|
63
|
+
"syntax-comment": "#878787",
|
|
64
|
+
"syntax-keyword": "#F75590",
|
|
65
|
+
"syntax-string": "#63C46D",
|
|
66
|
+
"syntax-primitive": "#BF7AF0",
|
|
67
|
+
"syntax-variable": "#52A8FF",
|
|
68
|
+
"syntax-property": "#0AC7AC",
|
|
69
|
+
"syntax-type": "#0AC7AC",
|
|
70
|
+
"syntax-constant": "#F2A700",
|
|
71
|
+
"syntax-operator": "#F75590",
|
|
72
|
+
"syntax-punctuation": "#EDEDED",
|
|
73
|
+
"syntax-object": "#52A8FF",
|
|
74
|
+
"markdown-heading": "#BF7AF0",
|
|
75
|
+
"markdown-text": "#EDEDED",
|
|
76
|
+
"markdown-link": "#52A8FF",
|
|
77
|
+
"markdown-link-text": "#0AC7AC",
|
|
78
|
+
"markdown-code": "#63C46D",
|
|
79
|
+
"markdown-block-quote": "#878787",
|
|
80
|
+
"markdown-emph": "#F2A700",
|
|
81
|
+
"markdown-strong": "#F75590",
|
|
82
|
+
"markdown-horizontal-rule": "#454545",
|
|
83
|
+
"markdown-list-item": "#EDEDED",
|
|
84
|
+
"markdown-list-enumeration": "#52A8FF",
|
|
85
|
+
"markdown-image": "#0AC7AC",
|
|
86
|
+
"markdown-image-text": "#50E3C2",
|
|
87
|
+
"markdown-code-block": "#EDEDED"
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
{
|
|
2
|
+
"$schema": "https://opencode.ai/desktop-theme.json",
|
|
3
|
+
"name": "Vesper",
|
|
4
|
+
"id": "vesper",
|
|
5
|
+
"light": {
|
|
6
|
+
"palette": {
|
|
7
|
+
"neutral": "#F0F0F0",
|
|
8
|
+
"ink": "#101010",
|
|
9
|
+
"primary": "#FFC799",
|
|
10
|
+
"accent": "#B30000",
|
|
11
|
+
"success": "#99FFE4",
|
|
12
|
+
"warning": "#FFC799",
|
|
13
|
+
"error": "#FF8080",
|
|
14
|
+
"info": "#FFC799",
|
|
15
|
+
"diffAdd": "#99FFE4",
|
|
16
|
+
"diffDelete": "#FF8080"
|
|
17
|
+
},
|
|
18
|
+
"overrides": {
|
|
19
|
+
"syntax-comment": "#7a7a7a",
|
|
20
|
+
"syntax-keyword": "#6e6e6e",
|
|
21
|
+
"syntax-string": "#117e69",
|
|
22
|
+
"syntax-primitive": "#8d541c",
|
|
23
|
+
"syntax-property": "#101010",
|
|
24
|
+
"syntax-type": "#8d541c",
|
|
25
|
+
"syntax-constant": "#8d541c"
|
|
26
|
+
}
|
|
27
|
+
},
|
|
28
|
+
"dark": {
|
|
29
|
+
"palette": {
|
|
30
|
+
"neutral": "#101010",
|
|
31
|
+
"ink": "#FFF",
|
|
32
|
+
"primary": "#FFC799",
|
|
33
|
+
"accent": "#FF8080",
|
|
34
|
+
"success": "#99FFE4",
|
|
35
|
+
"warning": "#FFC799",
|
|
36
|
+
"error": "#FF8080",
|
|
37
|
+
"info": "#FFC799",
|
|
38
|
+
"diffAdd": "#99FFE4",
|
|
39
|
+
"diffDelete": "#FF8080"
|
|
40
|
+
},
|
|
41
|
+
"overrides": {
|
|
42
|
+
"syntax-comment": "#8b8b8b",
|
|
43
|
+
"syntax-keyword": "#a0a0a0",
|
|
44
|
+
"syntax-string": "#99ffe4",
|
|
45
|
+
"syntax-primitive": "#ffc799",
|
|
46
|
+
"syntax-property": "#ffffff",
|
|
47
|
+
"syntax-type": "#ffc799",
|
|
48
|
+
"syntax-constant": "#ffc799"
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
}
|
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
{
|
|
2
|
+
"$schema": "https://opencode.ai/desktop-theme.json",
|
|
3
|
+
"name": "Zenburn",
|
|
4
|
+
"id": "zenburn",
|
|
5
|
+
"light": {
|
|
6
|
+
"palette": {
|
|
7
|
+
"neutral": "#ffffef",
|
|
8
|
+
"ink": "#3f3f3f",
|
|
9
|
+
"primary": "#5f7f8f",
|
|
10
|
+
"accent": "#5f8f8f",
|
|
11
|
+
"success": "#5f8f5f",
|
|
12
|
+
"warning": "#8f8f5f",
|
|
13
|
+
"error": "#8f5f5f",
|
|
14
|
+
"info": "#8f7f5f"
|
|
15
|
+
},
|
|
16
|
+
"overrides": {
|
|
17
|
+
"text-weak": "#6f6f6f",
|
|
18
|
+
"syntax-comment": "#5f7f5f",
|
|
19
|
+
"syntax-keyword": "#8f8f5f",
|
|
20
|
+
"syntax-string": "#8f5f5f",
|
|
21
|
+
"syntax-primitive": "#5f7f8f",
|
|
22
|
+
"syntax-variable": "#3f3f3f",
|
|
23
|
+
"syntax-property": "#5f8f8f",
|
|
24
|
+
"syntax-type": "#5f8f8f",
|
|
25
|
+
"syntax-constant": "#5f8f5f",
|
|
26
|
+
"syntax-operator": "#8f8f5f",
|
|
27
|
+
"syntax-punctuation": "#3f3f3f",
|
|
28
|
+
"syntax-object": "#3f3f3f",
|
|
29
|
+
"markdown-heading": "#8f8f5f",
|
|
30
|
+
"markdown-text": "#3f3f3f",
|
|
31
|
+
"markdown-link": "#5f7f8f",
|
|
32
|
+
"markdown-link-text": "#5f8f8f",
|
|
33
|
+
"markdown-code": "#5f8f5f",
|
|
34
|
+
"markdown-block-quote": "#6f6f6f",
|
|
35
|
+
"markdown-emph": "#8f8f5f",
|
|
36
|
+
"markdown-strong": "#8f7f5f",
|
|
37
|
+
"markdown-horizontal-rule": "#6f6f6f",
|
|
38
|
+
"markdown-list-item": "#5f7f8f",
|
|
39
|
+
"markdown-list-enumeration": "#5f8f8f",
|
|
40
|
+
"markdown-image": "#5f7f8f",
|
|
41
|
+
"markdown-image-text": "#5f8f8f",
|
|
42
|
+
"markdown-code-block": "#3f3f3f"
|
|
43
|
+
}
|
|
44
|
+
},
|
|
45
|
+
"dark": {
|
|
46
|
+
"palette": {
|
|
47
|
+
"neutral": "#3f3f3f",
|
|
48
|
+
"ink": "#dcdccc",
|
|
49
|
+
"primary": "#8cd0d3",
|
|
50
|
+
"accent": "#93e0e3",
|
|
51
|
+
"success": "#7f9f7f",
|
|
52
|
+
"warning": "#f0dfaf",
|
|
53
|
+
"error": "#cc9393",
|
|
54
|
+
"info": "#dfaf8f",
|
|
55
|
+
"diffAdd": "#8fb28f",
|
|
56
|
+
"diffDelete": "#dca3a3"
|
|
57
|
+
},
|
|
58
|
+
"overrides": {
|
|
59
|
+
"text-weak": "#9f9f9f",
|
|
60
|
+
"syntax-comment": "#7f9f7f",
|
|
61
|
+
"syntax-keyword": "#f0dfaf",
|
|
62
|
+
"syntax-string": "#cc9393",
|
|
63
|
+
"syntax-primitive": "#8cd0d3",
|
|
64
|
+
"syntax-variable": "#dcdccc",
|
|
65
|
+
"syntax-property": "#93e0e3",
|
|
66
|
+
"syntax-type": "#93e0e3",
|
|
67
|
+
"syntax-constant": "#8fb28f",
|
|
68
|
+
"syntax-operator": "#f0dfaf",
|
|
69
|
+
"syntax-punctuation": "#dcdccc",
|
|
70
|
+
"syntax-object": "#dcdccc",
|
|
71
|
+
"markdown-heading": "#f0dfaf",
|
|
72
|
+
"markdown-text": "#dcdccc",
|
|
73
|
+
"markdown-link": "#8cd0d3",
|
|
74
|
+
"markdown-link-text": "#93e0e3",
|
|
75
|
+
"markdown-code": "#7f9f7f",
|
|
76
|
+
"markdown-block-quote": "#9f9f9f",
|
|
77
|
+
"markdown-emph": "#e0cf9f",
|
|
78
|
+
"markdown-strong": "#dfaf8f",
|
|
79
|
+
"markdown-horizontal-rule": "#9f9f9f",
|
|
80
|
+
"markdown-list-item": "#8cd0d3",
|
|
81
|
+
"markdown-list-enumeration": "#93e0e3",
|
|
82
|
+
"markdown-image": "#8cd0d3",
|
|
83
|
+
"markdown-image-text": "#93e0e3",
|
|
84
|
+
"markdown-code-block": "#dcdccc"
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
}
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
export type HexColor = `#${string}`
|
|
2
|
+
|
|
3
|
+
export interface OklchColor {
|
|
4
|
+
l: number // Lightness 0-1
|
|
5
|
+
c: number // Chroma 0-0.4+
|
|
6
|
+
h: number // Hue 0-360
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
export interface ThemeSeedColors {
|
|
10
|
+
neutral: HexColor
|
|
11
|
+
primary: HexColor
|
|
12
|
+
success: HexColor
|
|
13
|
+
warning: HexColor
|
|
14
|
+
error: HexColor
|
|
15
|
+
info: HexColor
|
|
16
|
+
interactive: HexColor
|
|
17
|
+
diffAdd: HexColor
|
|
18
|
+
diffDelete: HexColor
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
export interface ThemePaletteColors {
|
|
22
|
+
neutral: HexColor
|
|
23
|
+
ink: HexColor
|
|
24
|
+
primary: HexColor
|
|
25
|
+
success: HexColor
|
|
26
|
+
warning: HexColor
|
|
27
|
+
error: HexColor
|
|
28
|
+
info: HexColor
|
|
29
|
+
accent?: HexColor
|
|
30
|
+
interactive?: HexColor
|
|
31
|
+
diffAdd?: HexColor
|
|
32
|
+
diffDelete?: HexColor
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
type ThemeVariantBase = {
|
|
36
|
+
overrides?: Record<string, ColorValue>
|
|
37
|
+
v2Overrides?: Record<string, V2ColorValue>
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
export type ThemeVariant =
|
|
41
|
+
| ({ seeds: ThemeSeedColors; palette?: never } & ThemeVariantBase)
|
|
42
|
+
| ({ palette: ThemePaletteColors; seeds?: never } & ThemeVariantBase)
|
|
43
|
+
|
|
44
|
+
export interface DesktopTheme {
|
|
45
|
+
$schema?: string
|
|
46
|
+
name: string
|
|
47
|
+
id: string
|
|
48
|
+
light: ThemeVariant
|
|
49
|
+
dark: ThemeVariant
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
export type TokenCategory =
|
|
53
|
+
| "background"
|
|
54
|
+
| "surface"
|
|
55
|
+
| "text"
|
|
56
|
+
| "border"
|
|
57
|
+
| "icon"
|
|
58
|
+
| "input"
|
|
59
|
+
| "button"
|
|
60
|
+
| "syntax"
|
|
61
|
+
| "markdown"
|
|
62
|
+
| "diff"
|
|
63
|
+
| "avatar"
|
|
64
|
+
|
|
65
|
+
export type ThemeToken = string
|
|
66
|
+
|
|
67
|
+
export type CssVarRef = `var(--${string})`
|
|
68
|
+
|
|
69
|
+
export type ColorValue = HexColor | CssVarRef
|
|
70
|
+
|
|
71
|
+
export type V2ColorValue = HexColor | CssVarRef | string
|
|
72
|
+
|
|
73
|
+
export type ResolvedTheme = Record<ThemeToken, ColorValue>
|
|
74
|
+
|
|
75
|
+
export type ResolvedV2Theme = Record<string, V2ColorValue>
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import type { V2ColorValue } from "../types"
|
|
2
|
+
|
|
3
|
+
/** Fixed project avatar colors (OC-2); theme-independent like v1 `avatar-background-*`. */
|
|
4
|
+
export const V2_AVATAR_FG = "#ffffffff"
|
|
5
|
+
|
|
6
|
+
export const V2_AVATAR_LIGHT: Record<string, V2ColorValue> = {
|
|
7
|
+
"v2-avatar-fg": V2_AVATAR_FG,
|
|
8
|
+
"v2-avatar-bg-orange": "#ee7330ff",
|
|
9
|
+
"v2-avatar-border-orange": "#d16427ff",
|
|
10
|
+
"v2-avatar-bg-yellow": "#e7af36ff",
|
|
11
|
+
"v2-avatar-border-yellow": "#cb9f34ff",
|
|
12
|
+
"v2-avatar-bg-cyan": "#0096b8ff",
|
|
13
|
+
"v2-avatar-border-cyan": "#007d9bff",
|
|
14
|
+
"v2-avatar-bg-green": "#2eaf5aff",
|
|
15
|
+
"v2-avatar-border-green": "#198b43ff",
|
|
16
|
+
"v2-avatar-bg-red": "#d92e3cff",
|
|
17
|
+
"v2-avatar-border-red": "#b82d35ff",
|
|
18
|
+
"v2-avatar-bg-pink": "#e4429eff",
|
|
19
|
+
"v2-avatar-border-pink": "#c83d8bff",
|
|
20
|
+
"v2-avatar-bg-blue": "#3250dfff",
|
|
21
|
+
"v2-avatar-border-blue": "#2c47c8ff",
|
|
22
|
+
"v2-avatar-bg-purple": "#623be2ff",
|
|
23
|
+
"v2-avatar-border-purple": "#5230c2ff",
|
|
24
|
+
"v2-avatar-bg-gray": "#5c5c5cff",
|
|
25
|
+
"v2-avatar-border-gray": "#3a3a3aff",
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
export const V2_AVATAR_DARK: Record<string, V2ColorValue> = {
|
|
29
|
+
"v2-avatar-fg": V2_AVATAR_FG,
|
|
30
|
+
"v2-avatar-bg-orange": "#723d22ff",
|
|
31
|
+
"v2-avatar-border-orange": "#ff8648ff",
|
|
32
|
+
"v2-avatar-bg-yellow": "#68552bff",
|
|
33
|
+
"v2-avatar-border-yellow": "#e7af36ff",
|
|
34
|
+
"v2-avatar-bg-cyan": "#005a6eff",
|
|
35
|
+
"v2-avatar-border-cyan": "#0096b8ff",
|
|
36
|
+
"v2-avatar-bg-green": "#196130ff",
|
|
37
|
+
"v2-avatar-border-green": "#49c970ff",
|
|
38
|
+
"v2-avatar-bg-red": "#7a1f23ff",
|
|
39
|
+
"v2-avatar-border-red": "#d92e3cff",
|
|
40
|
+
"v2-avatar-bg-pink": "#8c2d61ff",
|
|
41
|
+
"v2-avatar-border-pink": "#e4429eff",
|
|
42
|
+
"v2-avatar-bg-blue": "#263fa9ff",
|
|
43
|
+
"v2-avatar-border-blue": "#7698fdff",
|
|
44
|
+
"v2-avatar-bg-purple": "#361f83ff",
|
|
45
|
+
"v2-avatar-border-purple": "#7152f4ff",
|
|
46
|
+
"v2-avatar-bg-gray": "#5c5c5cff",
|
|
47
|
+
"v2-avatar-border-gray": "#aeaeaeff",
|
|
48
|
+
}
|
|
@@ -0,0 +1,114 @@
|
|
|
1
|
+
import type { V2ColorValue } from "../types"
|
|
2
|
+
|
|
3
|
+
/** Default v2 hue ramps from `v2/styles/colors.css` (OC-2). Alpha ramps live in CSS only. */
|
|
4
|
+
export const V2_PRIMITIVES_DEFAULT: Record<string, V2ColorValue> = {
|
|
5
|
+
"v2-grey-50": "#ffffffff",
|
|
6
|
+
"v2-grey-100": "#fafafaff",
|
|
7
|
+
"v2-grey-200": "#f2f2f2ff",
|
|
8
|
+
"v2-grey-300": "#eeeeeeff",
|
|
9
|
+
"v2-grey-400": "#dbdbdbff",
|
|
10
|
+
"v2-grey-500": "#aeaeaeff",
|
|
11
|
+
"v2-grey-600": "#808080ff",
|
|
12
|
+
"v2-grey-700": "#5c5c5cff",
|
|
13
|
+
"v2-grey-800": "#3a3a3aff",
|
|
14
|
+
"v2-grey-900": "#2e2e2eff",
|
|
15
|
+
"v2-grey-1000": "#242424ff",
|
|
16
|
+
"v2-grey-1100": "#161616ff",
|
|
17
|
+
"v2-grey-1200": "#080808ff",
|
|
18
|
+
"v2-red-100": "#fcecebff",
|
|
19
|
+
"v2-red-200": "#f6d5d3ff",
|
|
20
|
+
"v2-red-300": "#f2bbb7ff",
|
|
21
|
+
"v2-red-400": "#f29b96ff",
|
|
22
|
+
"v2-red-500": "#f17471ff",
|
|
23
|
+
"v2-red-600": "#f1484fff",
|
|
24
|
+
"v2-red-700": "#d92e3cff",
|
|
25
|
+
"v2-red-800": "#b82d35ff",
|
|
26
|
+
"v2-red-900": "#97252bff",
|
|
27
|
+
"v2-red-1000": "#7a1f23ff",
|
|
28
|
+
"v2-red-1100": "#5f1a1cff",
|
|
29
|
+
"v2-red-1200": "#461516ff",
|
|
30
|
+
"v2-orange-100": "#fdf2edff",
|
|
31
|
+
"v2-orange-200": "#ffe7dcff",
|
|
32
|
+
"v2-orange-300": "#ffd8c6ff",
|
|
33
|
+
"v2-orange-400": "#ffc1a4ff",
|
|
34
|
+
"v2-orange-500": "#ffa478ff",
|
|
35
|
+
"v2-orange-600": "#ff8648ff",
|
|
36
|
+
"v2-orange-700": "#ee7330ff",
|
|
37
|
+
"v2-orange-800": "#d16427ff",
|
|
38
|
+
"v2-orange-900": "#b35624ff",
|
|
39
|
+
"v2-orange-1000": "#954c27ff",
|
|
40
|
+
"v2-orange-1100": "#723d22ff",
|
|
41
|
+
"v2-orange-1200": "#5a2c14ff",
|
|
42
|
+
"v2-yellow-100": "#fefaecff",
|
|
43
|
+
"v2-yellow-200": "#fcefd0ff",
|
|
44
|
+
"v2-yellow-300": "#f7e5b5ff",
|
|
45
|
+
"v2-yellow-400": "#f3da9bff",
|
|
46
|
+
"v2-yellow-500": "#f2cf76ff",
|
|
47
|
+
"v2-yellow-600": "#f6c251ff",
|
|
48
|
+
"v2-yellow-700": "#e7af36ff",
|
|
49
|
+
"v2-yellow-800": "#cb9f34ff",
|
|
50
|
+
"v2-yellow-900": "#ac8833ff",
|
|
51
|
+
"v2-yellow-1000": "#8e7231ff",
|
|
52
|
+
"v2-yellow-1100": "#68552bff",
|
|
53
|
+
"v2-yellow-1200": "#4b4025ff",
|
|
54
|
+
"v2-green-100": "#e7f9eaff",
|
|
55
|
+
"v2-green-200": "#d0f0d5ff",
|
|
56
|
+
"v2-green-300": "#b8e9c1ff",
|
|
57
|
+
"v2-green-400": "#96e3a6ff",
|
|
58
|
+
"v2-green-500": "#6bd586ff",
|
|
59
|
+
"v2-green-600": "#49c970ff",
|
|
60
|
+
"v2-green-700": "#2eaf5aff",
|
|
61
|
+
"v2-green-800": "#198b43ff",
|
|
62
|
+
"v2-green-900": "#1d783cff",
|
|
63
|
+
"v2-green-1000": "#196130ff",
|
|
64
|
+
"v2-green-1100": "#164c26ff",
|
|
65
|
+
"v2-green-1200": "#14361dff",
|
|
66
|
+
"v2-cyan-100": "#e2f7fbff",
|
|
67
|
+
"v2-cyan-200": "#c4edf4ff",
|
|
68
|
+
"v2-cyan-300": "#a3e4efff",
|
|
69
|
+
"v2-cyan-400": "#65d9ebff",
|
|
70
|
+
"v2-cyan-500": "#00c5dfff",
|
|
71
|
+
"v2-cyan-600": "#00abcfff",
|
|
72
|
+
"v2-cyan-700": "#0096b8ff",
|
|
73
|
+
"v2-cyan-800": "#007d9bff",
|
|
74
|
+
"v2-cyan-900": "#006c85ff",
|
|
75
|
+
"v2-cyan-1000": "#005a6eff",
|
|
76
|
+
"v2-cyan-1100": "#004756ff",
|
|
77
|
+
"v2-cyan-1200": "#00353fff",
|
|
78
|
+
"v2-blue-100": "#ecf1feff",
|
|
79
|
+
"v2-blue-200": "#d7e2fcff",
|
|
80
|
+
"v2-blue-300": "#c3d4fdff",
|
|
81
|
+
"v2-blue-400": "#a2bcffff",
|
|
82
|
+
"v2-blue-500": "#7698fdff",
|
|
83
|
+
"v2-blue-600": "#3b5cf6ff",
|
|
84
|
+
"v2-blue-700": "#3250dfff",
|
|
85
|
+
"v2-blue-800": "#2c47c8ff",
|
|
86
|
+
"v2-blue-900": "#263fa9ff",
|
|
87
|
+
"v2-blue-1000": "#22388fff",
|
|
88
|
+
"v2-blue-1100": "#1c2e70ff",
|
|
89
|
+
"v2-blue-1200": "#1b2852ff",
|
|
90
|
+
"v2-purple-100": "#ebecfeff",
|
|
91
|
+
"v2-purple-200": "#d5d5fcff",
|
|
92
|
+
"v2-purple-300": "#b9b8f5ff",
|
|
93
|
+
"v2-purple-400": "#9e99f7ff",
|
|
94
|
+
"v2-purple-500": "#8271f8ff",
|
|
95
|
+
"v2-purple-600": "#7152f4ff",
|
|
96
|
+
"v2-purple-700": "#623be2ff",
|
|
97
|
+
"v2-purple-800": "#5230c2ff",
|
|
98
|
+
"v2-purple-900": "#442aa1ff",
|
|
99
|
+
"v2-purple-1000": "#361f83ff",
|
|
100
|
+
"v2-purple-1100": "#2b1b6aff",
|
|
101
|
+
"v2-purple-1200": "#221358ff",
|
|
102
|
+
"v2-pink-100": "#fdecf3ff",
|
|
103
|
+
"v2-pink-200": "#f7d5e4ff",
|
|
104
|
+
"v2-pink-300": "#fabcd8ff",
|
|
105
|
+
"v2-pink-400": "#f799c6ff",
|
|
106
|
+
"v2-pink-500": "#f26cb2ff",
|
|
107
|
+
"v2-pink-600": "#f64aabff",
|
|
108
|
+
"v2-pink-700": "#e4429eff",
|
|
109
|
+
"v2-pink-800": "#c83d8bff",
|
|
110
|
+
"v2-pink-900": "#aa3576ff",
|
|
111
|
+
"v2-pink-1000": "#8c2d61ff",
|
|
112
|
+
"v2-pink-1100": "#6f284fff",
|
|
113
|
+
"v2-pink-1200": "#5c1d3fff",
|
|
114
|
+
}
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
import { blend, contrastRatio, hexToOklch, shift } from "../color"
|
|
2
|
+
import { mapV2Semantics } from "./mapping"
|
|
3
|
+
import type { ColorValue, HexColor, V2ColorValue } from "../types"
|
|
4
|
+
|
|
5
|
+
const GREY_STEPS = [100, 200, 300, 400, 500, 600, 700, 800, 900, 1000, 1100, 1200] as const
|
|
6
|
+
|
|
7
|
+
const greyRef = (step: number): V2ColorValue => `var(--v2-grey-${step})`
|
|
8
|
+
|
|
9
|
+
function greyHex(primitives: Record<string, V2ColorValue>, step: number) {
|
|
10
|
+
const hex = primitives[`v2-grey-${step}`]
|
|
11
|
+
if (typeof hex === "string" && hex.startsWith("#")) return hex as HexColor
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
function resolveGreyRef(value: V2ColorValue, primitives: Record<string, V2ColorValue>) {
|
|
15
|
+
const step = value.match(/^var\(--v2-grey-(\d+)\)$/)?.[1]
|
|
16
|
+
if (!step) throw new Error(`Expected grey primitive ref, got ${value}`)
|
|
17
|
+
const hex = greyHex(primitives, Number(step))
|
|
18
|
+
if (!hex) throw new Error(`Missing grey primitive v2-grey-${step}`)
|
|
19
|
+
return hex
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
function pickGrey(primitives: Record<string, V2ColorValue>, background: HexColor, minContrast: number, target: number) {
|
|
23
|
+
const matches = GREY_STEPS.filter((step) => {
|
|
24
|
+
const hex = greyHex(primitives, step)
|
|
25
|
+
return hex && contrastRatio(hex, background) >= minContrast
|
|
26
|
+
})
|
|
27
|
+
if (matches.length === 0) return target
|
|
28
|
+
return matches.reduce((best, step) => (Math.abs(step - target) < Math.abs(best - target) ? step : best))
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
export function mapV2Foreground(
|
|
32
|
+
ink: HexColor,
|
|
33
|
+
isDark: boolean,
|
|
34
|
+
primitives: Record<string, V2ColorValue>,
|
|
35
|
+
overrides: Record<string, ColorValue> = {},
|
|
36
|
+
): Record<string, V2ColorValue> {
|
|
37
|
+
const tint = hexToOklch(ink)
|
|
38
|
+
const body = shift(ink, {
|
|
39
|
+
l: isDark ? Math.max(0, 0.88 - tint.l) * 0.4 : -Math.max(0, tint.l - 0.18) * 0.24,
|
|
40
|
+
c: isDark ? 1.04 : 1.02,
|
|
41
|
+
})
|
|
42
|
+
|
|
43
|
+
const semantics = mapV2Semantics(isDark)
|
|
44
|
+
const bgBase = resolveGreyRef(semantics["v2-background-bg-base"], primitives)
|
|
45
|
+
const bgContrast = resolveGreyRef(semantics["v2-background-bg-contrast"], primitives)
|
|
46
|
+
const bgInverse = resolveGreyRef(semantics["v2-background-bg-inverse"], primitives)
|
|
47
|
+
const inverseTarget = hexToOklch(bgInverse).l > 0.55 ? 1100 : greyHex(primitives, 50) ? 50 : 100
|
|
48
|
+
|
|
49
|
+
return {
|
|
50
|
+
"v2-text-text-base": isDark ? blend("#ffffff", body, 0.9) : shift(body, { l: -0.07, c: 1.04 }),
|
|
51
|
+
"v2-text-text-muted": overrides["text-weak"] ?? shift(body, { l: isDark ? -0.11 : 0.11, c: 0.9 }),
|
|
52
|
+
"v2-text-text-faint": shift(body, { l: isDark ? -0.2 : 0.21, c: isDark ? 0.78 : 0.72 }),
|
|
53
|
+
"v2-icon-icon-base": greyRef(pickGrey(primitives, bgBase, 7, isDark ? 400 : 800)),
|
|
54
|
+
"v2-icon-icon-muted": greyRef(pickGrey(primitives, bgBase, 3, 600)),
|
|
55
|
+
"v2-icon-icon-inverse": greyRef(pickGrey(primitives, bgInverse, 7, inverseTarget)),
|
|
56
|
+
"v2-icon-icon-contrast": greyRef(pickGrey(primitives, bgContrast, 7, 100)),
|
|
57
|
+
"v2-icon-icon-accent": isDark ? "var(--v2-blue-400)" : "var(--v2-blue-600)",
|
|
58
|
+
"v2-icon-icon-accent-hover": isDark ? "var(--v2-blue-300)" : "var(--v2-blue-700)",
|
|
59
|
+
}
|
|
60
|
+
}
|
|
@@ -0,0 +1,138 @@
|
|
|
1
|
+
import type { V2ColorValue } from "../types"
|
|
2
|
+
import { V2_AVATAR_DARK, V2_AVATAR_LIGHT } from "./avatar"
|
|
3
|
+
|
|
4
|
+
const ref = (name: string): V2ColorValue => `var(--${name})`
|
|
5
|
+
|
|
6
|
+
const light: Record<string, V2ColorValue> = {
|
|
7
|
+
"v2-background-bg-base": ref("v2-grey-100"),
|
|
8
|
+
"v2-background-bg-deep": ref("v2-grey-200"),
|
|
9
|
+
"v2-background-bg-layer-01": ref("v2-grey-300"),
|
|
10
|
+
"v2-background-bg-layer-02": ref("v2-grey-400"),
|
|
11
|
+
"v2-background-bg-layer-03": ref("v2-grey-500"),
|
|
12
|
+
"v2-background-bg-layer-04": ref("v2-grey-600"),
|
|
13
|
+
"v2-background-bg-inverse": ref("v2-grey-1000"),
|
|
14
|
+
"v2-background-bg-contrast": ref("v2-grey-900"),
|
|
15
|
+
"v2-background-bg-button-neutral": ref("v2-grey-100"),
|
|
16
|
+
"v2-background-bg-accent": ref("v2-blue-600"),
|
|
17
|
+
"v2-text-text-inverse": ref("v2-grey-100"),
|
|
18
|
+
"v2-text-text-contrast": ref("v2-grey-100"),
|
|
19
|
+
"v2-text-text-accent": ref("v2-blue-600"),
|
|
20
|
+
"v2-text-text-accent-hover": ref("v2-blue-700"),
|
|
21
|
+
"v2-border-border-muted": ref("v2-alpha-dark-8"),
|
|
22
|
+
"v2-border-border-base": ref("v2-alpha-dark-10"),
|
|
23
|
+
"v2-border-border-strong": ref("v2-alpha-dark-20"),
|
|
24
|
+
"v2-border-border-inverse": ref("v2-grey-1000"),
|
|
25
|
+
"v2-border-border-focus": ref("v2-blue-500"),
|
|
26
|
+
"v2-overlay-simple-overlay-hover": ref("v2-alpha-dark-4"),
|
|
27
|
+
"v2-overlay-simple-overlay-pressed": ref("v2-alpha-dark-8"),
|
|
28
|
+
"v2-overlay-simple-overlay-contrast-hover": ref("v2-alpha-light-12"),
|
|
29
|
+
"v2-overlay-simple-overlay-contrast-pressed": ref("v2-alpha-light-24"),
|
|
30
|
+
"v2-overlay-simple-overlay-scrim": ref("v2-alpha-dark-40"),
|
|
31
|
+
"v2-overlay-gradient-depth-overlay-depth-top": ref("v2-alpha-light-100"),
|
|
32
|
+
"v2-overlay-gradient-depth-overlay-depth-bot": ref("v2-alpha-light-0"),
|
|
33
|
+
"v2-overlay-simple-tab-active-scrim": "#fafafa00",
|
|
34
|
+
"v2-overlay-simple-tab-hover-scrim": "#eeeeee00",
|
|
35
|
+
"v2-overlay-simple-tab-scrim": "#fafafa00",
|
|
36
|
+
"v2-state-bg-success": ref("v2-green-100"),
|
|
37
|
+
"v2-state-fg-success": ref("v2-green-800"),
|
|
38
|
+
"v2-state-border-success": ref("v2-green-300"),
|
|
39
|
+
"v2-state-bg-warning": ref("v2-yellow-100"),
|
|
40
|
+
"v2-state-fg-warning": ref("v2-yellow-800"),
|
|
41
|
+
"v2-state-border-warning": ref("v2-yellow-300"),
|
|
42
|
+
"v2-state-bg-danger": ref("v2-red-100"),
|
|
43
|
+
"v2-state-fg-danger": ref("v2-red-800"),
|
|
44
|
+
"v2-state-border-danger": ref("v2-red-300"),
|
|
45
|
+
"v2-state-bg-info": ref("v2-blue-100"),
|
|
46
|
+
"v2-state-fg-info": ref("v2-blue-800"),
|
|
47
|
+
"v2-state-border-info": ref("v2-blue-300"),
|
|
48
|
+
...V2_AVATAR_LIGHT,
|
|
49
|
+
"v2-elevation-raised":
|
|
50
|
+
"0px 2px 4px 0px var(--v2-alpha-dark-4), 0px 1px 2px -1px var(--v2-alpha-dark-8), 0px 0px 0px 0.5px var(--v2-alpha-dark-12), 0px 0px 0px 0px var(--v2-alpha-dark-0)",
|
|
51
|
+
"v2-elevation-floating":
|
|
52
|
+
"0px 8px 16px 0px var(--v2-alpha-dark-4), 0px 4px 8px 0px var(--v2-alpha-dark-8), 0px 0px 0px 0.5px var(--v2-alpha-dark-12), 0px 0px 0px 0px var(--v2-alpha-dark-0)",
|
|
53
|
+
"v2-elevation-overlay":
|
|
54
|
+
"0px 16px 32px 0px var(--v2-alpha-dark-4), 0px 8px 16px 0px var(--v2-alpha-dark-8), 0px 0px 0px 0.5px var(--v2-alpha-dark-12), 0px 0px 0px 0px var(--v2-alpha-dark-0)",
|
|
55
|
+
"v2-elevation-button-neutral":
|
|
56
|
+
"0px 1px 1.5px 0px var(--v2-alpha-dark-10), 0px 0px 0px 0.5px var(--v2-alpha-dark-14), 0px 0px 0px 0px var(--v2-alpha-dark-0)",
|
|
57
|
+
"v2-elevation-button-contrast":
|
|
58
|
+
"0px 1px 1.5px 0px var(--v2-alpha-dark-20), 0px 0px 0px 0.5px var(--v2-grey-800), inset 0px 1px 2px 0px var(--v2-alpha-light-14), inset 0px -1px 2px 0px var(--v2-alpha-dark-6), 0px 0px 0px 0px var(--v2-alpha-dark-0)",
|
|
59
|
+
"v2-elevation-elements": "0px 0.5px 0.5px 0px var(--v2-alpha-dark-40)",
|
|
60
|
+
"v2-elevation-switch-off":
|
|
61
|
+
"inset 0px 1px 1px 0px var(--v2-alpha-dark-8), inset 0px 0.5px 0.5px 0px var(--v2-alpha-dark-8), inset 0px 0px 0px 0.5px var(--v2-alpha-dark-10)",
|
|
62
|
+
"v2-elevation-switch-on":
|
|
63
|
+
"inset 0px 2px 2px 0px var(--v2-alpha-dark-10), inset 0px 1px 1px 0px var(--v2-alpha-dark-10), inset 0px 0px 0px 0.5px var(--v2-alpha-dark-20)",
|
|
64
|
+
"v2-illustration-illustration-layer-01": ref("v2-grey-300"),
|
|
65
|
+
"v2-illustration-illustration-layer-02": ref("v2-grey-400"),
|
|
66
|
+
"v2-illustration-illustration-layer-03": ref("v2-grey-500"),
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
const dark: Record<string, V2ColorValue> = {
|
|
70
|
+
"v2-background-bg-base": ref("v2-grey-1000"),
|
|
71
|
+
"v2-background-bg-deep": ref("v2-grey-1100"),
|
|
72
|
+
"v2-background-bg-layer-01": ref("v2-grey-800"),
|
|
73
|
+
"v2-background-bg-layer-02": ref("v2-grey-600"),
|
|
74
|
+
"v2-background-bg-layer-03": ref("v2-grey-500"),
|
|
75
|
+
"v2-background-bg-layer-04": ref("v2-grey-400"),
|
|
76
|
+
"v2-background-bg-inverse": ref("v2-grey-100"),
|
|
77
|
+
"v2-background-bg-contrast": ref("v2-grey-700"),
|
|
78
|
+
"v2-background-bg-button-neutral": ref("v2-alpha-light-6"),
|
|
79
|
+
"v2-background-bg-accent": ref("v2-blue-600"),
|
|
80
|
+
"v2-text-text-inverse": ref("v2-grey-1000"),
|
|
81
|
+
"v2-text-text-contrast": ref("v2-grey-100"),
|
|
82
|
+
"v2-text-text-accent": ref("v2-blue-400"),
|
|
83
|
+
"v2-text-text-accent-hover": ref("v2-blue-300"),
|
|
84
|
+
"v2-border-border-muted": ref("v2-alpha-light-8"),
|
|
85
|
+
"v2-border-border-base": ref("v2-alpha-light-10"),
|
|
86
|
+
"v2-border-border-strong": ref("v2-alpha-light-20"),
|
|
87
|
+
"v2-border-border-inverse": ref("v2-grey-100"),
|
|
88
|
+
"v2-border-border-focus": ref("v2-blue-500"),
|
|
89
|
+
"v2-overlay-simple-overlay-hover": ref("v2-alpha-light-6"),
|
|
90
|
+
"v2-overlay-simple-overlay-pressed": ref("v2-alpha-light-10"),
|
|
91
|
+
"v2-overlay-simple-overlay-contrast-hover": ref("v2-alpha-dark-24"),
|
|
92
|
+
"v2-overlay-simple-overlay-contrast-pressed": ref("v2-alpha-dark-40"),
|
|
93
|
+
"v2-overlay-simple-overlay-scrim": ref("v2-alpha-dark-60"),
|
|
94
|
+
"v2-overlay-gradient-depth-overlay-depth-top": ref("v2-alpha-light-100"),
|
|
95
|
+
"v2-overlay-gradient-depth-overlay-depth-bot": ref("v2-alpha-light-0"),
|
|
96
|
+
"v2-overlay-simple-tab-active-scrim": "#24242400",
|
|
97
|
+
"v2-overlay-simple-tab-hover-scrim": "#3a3a3a00",
|
|
98
|
+
"v2-overlay-simple-tab-scrim": "#08080800",
|
|
99
|
+
"v2-state-bg-success": ref("v2-green-1200"),
|
|
100
|
+
"v2-state-fg-success": ref("v2-green-500"),
|
|
101
|
+
"v2-state-border-success": ref("v2-green-900"),
|
|
102
|
+
"v2-state-bg-warning": ref("v2-yellow-1200"),
|
|
103
|
+
"v2-state-fg-warning": ref("v2-yellow-500"),
|
|
104
|
+
"v2-state-border-warning": ref("v2-yellow-900"),
|
|
105
|
+
"v2-state-bg-danger": ref("v2-red-1200"),
|
|
106
|
+
"v2-state-fg-danger": ref("v2-red-500"),
|
|
107
|
+
"v2-state-border-danger": ref("v2-red-900"),
|
|
108
|
+
"v2-state-bg-info": ref("v2-blue-1200"),
|
|
109
|
+
"v2-state-fg-info": ref("v2-blue-500"),
|
|
110
|
+
"v2-state-border-info": ref("v2-blue-900"),
|
|
111
|
+
...V2_AVATAR_DARK,
|
|
112
|
+
"v2-elevation-raised":
|
|
113
|
+
"0px 2px 4px 0px var(--v2-alpha-dark-30), 0px 1px 2px 0px var(--v2-alpha-dark-30), 0px 0px 0px 0.5px var(--v2-alpha-light-16), 0px -0.5px 0px 0px var(--v2-alpha-light-6)",
|
|
114
|
+
"v2-elevation-floating":
|
|
115
|
+
"0px 8px 16px 0px var(--v2-alpha-dark-30), 0px 4px 8px 0px var(--v2-alpha-dark-30), 0px 0px 0px 0.5px var(--v2-alpha-light-16), 0px -0.5px 0px 0px var(--v2-alpha-light-6)",
|
|
116
|
+
"v2-elevation-overlay":
|
|
117
|
+
"0px 16px 32px 0px var(--v2-alpha-dark-30), 0px 8px 16px 0px var(--v2-alpha-dark-30), 0px 0px 0px 0.5px var(--v2-alpha-light-16), 0px -0.5px 0px 0px var(--v2-alpha-light-6)",
|
|
118
|
+
"v2-elevation-button-neutral":
|
|
119
|
+
"0px 1px 2px 0px var(--v2-alpha-dark-40), 0px 0px 0px 0.5px var(--v2-alpha-light-20), 0px -0.5px 0px 0px var(--v2-alpha-light-10)",
|
|
120
|
+
"v2-elevation-button-contrast":
|
|
121
|
+
"0px 1px 2px 0px var(--v2-alpha-dark-40), 0px 0px 0px 0.5px var(--v2-alpha-light-40), inset 0px 0px 0px 0px var(--v2-alpha-light-0), inset 0px 0px 0px 0px var(--v2-alpha-light-0), 0px -0.5px 0px 0px var(--v2-alpha-light-30)",
|
|
122
|
+
"v2-elevation-elements": "0px 0.5px 0.5px 0px var(--v2-alpha-dark-40)",
|
|
123
|
+
"v2-elevation-switch-off":
|
|
124
|
+
"inset 0px -0.5px 0px 0px var(--v2-alpha-light-10), inset 0px 0px 0px 0px var(--v2-alpha-light-0), inset 0px 0px 0px 0.5px var(--v2-alpha-light-16)",
|
|
125
|
+
"v2-elevation-switch-on":
|
|
126
|
+
"inset 0px -0.5px 0px 0px var(--v2-alpha-light-10), inset 0px 0px 0px 0px var(--v2-alpha-light-0), inset 0px 0px 0px 0.5px var(--v2-alpha-light-16)",
|
|
127
|
+
"v2-illustration-illustration-layer-01": ref("v2-grey-900"),
|
|
128
|
+
"v2-illustration-illustration-layer-02": ref("v2-grey-800"),
|
|
129
|
+
"v2-illustration-illustration-layer-03": ref("v2-grey-700"),
|
|
130
|
+
}
|
|
131
|
+
|
|
132
|
+
export function mapV2Semantics(isDark: boolean): Record<string, V2ColorValue> {
|
|
133
|
+
return isDark ? dark : light
|
|
134
|
+
}
|
|
135
|
+
|
|
136
|
+
export function mergeV2Tokens(...layers: Record<string, V2ColorValue>[]): Record<string, V2ColorValue> {
|
|
137
|
+
return Object.assign({}, ...layers)
|
|
138
|
+
}
|