@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.
Files changed (346) hide show
  1. package/LICENSE +21 -0
  2. package/package.json +110 -0
  3. package/src/assets/audio/alert-01.aac +0 -0
  4. package/src/assets/audio/alert-01.mp3 +0 -0
  5. package/src/assets/audio/alert-02.aac +0 -0
  6. package/src/assets/audio/alert-02.mp3 +0 -0
  7. package/src/assets/audio/alert-03.aac +0 -0
  8. package/src/assets/audio/alert-03.mp3 +0 -0
  9. package/src/assets/audio/alert-04.aac +0 -0
  10. package/src/assets/audio/alert-04.mp3 +0 -0
  11. package/src/assets/audio/alert-05.aac +0 -0
  12. package/src/assets/audio/alert-05.mp3 +0 -0
  13. package/src/assets/audio/alert-06.aac +0 -0
  14. package/src/assets/audio/alert-06.mp3 +0 -0
  15. package/src/assets/audio/alert-07.aac +0 -0
  16. package/src/assets/audio/alert-07.mp3 +0 -0
  17. package/src/assets/audio/alert-08.aac +0 -0
  18. package/src/assets/audio/alert-08.mp3 +0 -0
  19. package/src/assets/audio/alert-09.aac +0 -0
  20. package/src/assets/audio/alert-09.mp3 +0 -0
  21. package/src/assets/audio/alert-10.aac +0 -0
  22. package/src/assets/audio/alert-10.mp3 +0 -0
  23. package/src/assets/audio/bip-bop-01.aac +0 -0
  24. package/src/assets/audio/bip-bop-01.mp3 +0 -0
  25. package/src/assets/audio/bip-bop-02.aac +0 -0
  26. package/src/assets/audio/bip-bop-02.mp3 +0 -0
  27. package/src/assets/audio/bip-bop-03.aac +0 -0
  28. package/src/assets/audio/bip-bop-03.mp3 +0 -0
  29. package/src/assets/audio/bip-bop-04.aac +0 -0
  30. package/src/assets/audio/bip-bop-04.mp3 +0 -0
  31. package/src/assets/audio/bip-bop-05.aac +0 -0
  32. package/src/assets/audio/bip-bop-05.mp3 +0 -0
  33. package/src/assets/audio/bip-bop-06.aac +0 -0
  34. package/src/assets/audio/bip-bop-06.mp3 +0 -0
  35. package/src/assets/audio/bip-bop-07.aac +0 -0
  36. package/src/assets/audio/bip-bop-07.mp3 +0 -0
  37. package/src/assets/audio/bip-bop-08.aac +0 -0
  38. package/src/assets/audio/bip-bop-08.mp3 +0 -0
  39. package/src/assets/audio/bip-bop-09.aac +0 -0
  40. package/src/assets/audio/bip-bop-09.mp3 +0 -0
  41. package/src/assets/audio/bip-bop-10.aac +0 -0
  42. package/src/assets/audio/bip-bop-10.mp3 +0 -0
  43. package/src/assets/audio/nope-01.aac +0 -0
  44. package/src/assets/audio/nope-01.mp3 +0 -0
  45. package/src/assets/audio/nope-02.aac +0 -0
  46. package/src/assets/audio/nope-02.mp3 +0 -0
  47. package/src/assets/audio/nope-03.aac +0 -0
  48. package/src/assets/audio/nope-03.mp3 +0 -0
  49. package/src/assets/audio/nope-04.aac +0 -0
  50. package/src/assets/audio/nope-04.mp3 +0 -0
  51. package/src/assets/audio/nope-05.aac +0 -0
  52. package/src/assets/audio/nope-05.mp3 +0 -0
  53. package/src/assets/audio/nope-06.aac +0 -0
  54. package/src/assets/audio/nope-06.mp3 +0 -0
  55. package/src/assets/audio/nope-07.aac +0 -0
  56. package/src/assets/audio/nope-07.mp3 +0 -0
  57. package/src/assets/audio/nope-08.aac +0 -0
  58. package/src/assets/audio/nope-08.mp3 +0 -0
  59. package/src/assets/audio/nope-09.aac +0 -0
  60. package/src/assets/audio/nope-09.mp3 +0 -0
  61. package/src/assets/audio/nope-10.aac +0 -0
  62. package/src/assets/audio/nope-10.mp3 +0 -0
  63. package/src/assets/audio/nope-11.aac +0 -0
  64. package/src/assets/audio/nope-11.mp3 +0 -0
  65. package/src/assets/audio/nope-12.aac +0 -0
  66. package/src/assets/audio/nope-12.mp3 +0 -0
  67. package/src/assets/audio/staplebops-01.aac +0 -0
  68. package/src/assets/audio/staplebops-01.mp3 +0 -0
  69. package/src/assets/audio/staplebops-02.aac +0 -0
  70. package/src/assets/audio/staplebops-02.mp3 +0 -0
  71. package/src/assets/audio/staplebops-03.aac +0 -0
  72. package/src/assets/audio/staplebops-03.mp3 +0 -0
  73. package/src/assets/audio/staplebops-04.aac +0 -0
  74. package/src/assets/audio/staplebops-04.mp3 +0 -0
  75. package/src/assets/audio/staplebops-05.aac +0 -0
  76. package/src/assets/audio/staplebops-05.mp3 +0 -0
  77. package/src/assets/audio/staplebops-06.aac +0 -0
  78. package/src/assets/audio/staplebops-06.mp3 +0 -0
  79. package/src/assets/audio/staplebops-07.aac +0 -0
  80. package/src/assets/audio/staplebops-07.mp3 +0 -0
  81. package/src/assets/audio/yup-01.aac +0 -0
  82. package/src/assets/audio/yup-01.mp3 +0 -0
  83. package/src/assets/audio/yup-02.aac +0 -0
  84. package/src/assets/audio/yup-02.mp3 +0 -0
  85. package/src/assets/audio/yup-03.aac +0 -0
  86. package/src/assets/audio/yup-03.mp3 +0 -0
  87. package/src/assets/audio/yup-04.aac +0 -0
  88. package/src/assets/audio/yup-04.mp3 +0 -0
  89. package/src/assets/audio/yup-05.aac +0 -0
  90. package/src/assets/audio/yup-05.mp3 +0 -0
  91. package/src/assets/audio/yup-06.aac +0 -0
  92. package/src/assets/audio/yup-06.mp3 +0 -0
  93. package/src/assets/fonts/Inter.ttf +0 -0
  94. package/src/assets/fonts/JetBrainsMonoNerdFontMono-Regular.woff2 +0 -0
  95. package/src/assets/icons/app/android-studio.svg +369 -0
  96. package/src/assets/icons/app/antigravity.svg +97 -0
  97. package/src/assets/icons/app/cursor.svg +16 -0
  98. package/src/assets/icons/app/file-explorer.svg +20 -0
  99. package/src/assets/icons/app/finder.png +0 -0
  100. package/src/assets/icons/app/ghostty.svg +13 -0
  101. package/src/assets/icons/app/iterm2.svg +13 -0
  102. package/src/assets/icons/app/powershell.svg +14 -0
  103. package/src/assets/icons/app/sublimetext.svg +17 -0
  104. package/src/assets/icons/app/terminal.png +0 -0
  105. package/src/assets/icons/app/textmate.png +0 -0
  106. package/src/assets/icons/app/vscode.svg +39 -0
  107. package/src/assets/icons/app/warp.png +0 -0
  108. package/src/assets/icons/app/xcode.png +0 -0
  109. package/src/assets/icons/app/zed-dark.svg +15 -0
  110. package/src/assets/icons/app/zed.svg +15 -0
  111. package/src/components/accordion.css +123 -0
  112. package/src/components/accordion.tsx +92 -0
  113. package/src/components/animated-number.css +75 -0
  114. package/src/components/animated-number.tsx +109 -0
  115. package/src/components/app-icon.css +5 -0
  116. package/src/components/app-icon.tsx +85 -0
  117. package/src/components/app-icons/sprite.svg +114 -0
  118. package/src/components/app-icons/types.ts +21 -0
  119. package/src/components/avatar.css +49 -0
  120. package/src/components/avatar.tsx +55 -0
  121. package/src/components/button.css +194 -0
  122. package/src/components/button.tsx +33 -0
  123. package/src/components/card.css +94 -0
  124. package/src/components/card.tsx +123 -0
  125. package/src/components/checkbox.css +131 -0
  126. package/src/components/checkbox.tsx +43 -0
  127. package/src/components/collapsible.css +148 -0
  128. package/src/components/collapsible.tsx +48 -0
  129. package/src/components/context-menu.css +134 -0
  130. package/src/components/context-menu.tsx +308 -0
  131. package/src/components/dialog.css +181 -0
  132. package/src/components/dialog.tsx +72 -0
  133. package/src/components/diff-changes.css +42 -0
  134. package/src/components/diff-changes.tsx +115 -0
  135. package/src/components/dock-surface.css +23 -0
  136. package/src/components/dock-surface.tsx +54 -0
  137. package/src/components/dropdown-menu.css +135 -0
  138. package/src/components/dropdown-menu.tsx +308 -0
  139. package/src/components/favicon.tsx +13 -0
  140. package/src/components/file-icon.css +26 -0
  141. package/src/components/file-icon.tsx +588 -0
  142. package/src/components/file-icons/sprite.svg +11707 -0
  143. package/src/components/file-icons/types.ts +1095 -0
  144. package/src/components/font.tsx +1 -0
  145. package/src/components/hover-card.css +61 -0
  146. package/src/components/hover-card.tsx +32 -0
  147. package/src/components/icon-button.css +181 -0
  148. package/src/components/icon-button.tsx +29 -0
  149. package/src/components/icon.css +34 -0
  150. package/src/components/icon.tsx +169 -0
  151. package/src/components/image-preview.css +63 -0
  152. package/src/components/image-preview.tsx +32 -0
  153. package/src/components/inline-input.css +17 -0
  154. package/src/components/inline-input.tsx +22 -0
  155. package/src/components/keybind.css +18 -0
  156. package/src/components/keybind.tsx +20 -0
  157. package/src/components/list.css +331 -0
  158. package/src/components/list.tsx +394 -0
  159. package/src/components/logo.css +4 -0
  160. package/src/components/logo.tsx +62 -0
  161. package/src/components/motion-spring.tsx +58 -0
  162. package/src/components/popover.css +98 -0
  163. package/src/components/popover.tsx +153 -0
  164. package/src/components/progress-circle.css +12 -0
  165. package/src/components/progress-circle.tsx +57 -0
  166. package/src/components/progress.css +63 -0
  167. package/src/components/progress.tsx +39 -0
  168. package/src/components/provider-icon.css +5 -0
  169. package/src/components/provider-icon.tsx +25 -0
  170. package/src/components/provider-icons/sprite.svg +1135 -0
  171. package/src/components/provider-icons/types.ts +105 -0
  172. package/src/components/radio-group.css +187 -0
  173. package/src/components/radio-group.tsx +83 -0
  174. package/src/components/resize-handle.css +58 -0
  175. package/src/components/resize-handle.tsx +82 -0
  176. package/src/components/scroll-view.css +66 -0
  177. package/src/components/scroll-view.tsx +250 -0
  178. package/src/components/select.css +202 -0
  179. package/src/components/select.tsx +174 -0
  180. package/src/components/spinner.css +6 -0
  181. package/src/components/spinner.tsx +52 -0
  182. package/src/components/sticky-accordion-header.css +6 -0
  183. package/src/components/sticky-accordion-header.tsx +18 -0
  184. package/src/components/switch.css +132 -0
  185. package/src/components/switch.tsx +29 -0
  186. package/src/components/tabs.css +635 -0
  187. package/src/components/tabs.tsx +125 -0
  188. package/src/components/tag.css +37 -0
  189. package/src/components/tag.tsx +22 -0
  190. package/src/components/text-field.css +134 -0
  191. package/src/components/text-field.tsx +128 -0
  192. package/src/components/text-reveal.css +150 -0
  193. package/src/components/text-reveal.tsx +143 -0
  194. package/src/components/text-shimmer.css +119 -0
  195. package/src/components/text-shimmer.tsx +62 -0
  196. package/src/components/text-strikethrough.css +27 -0
  197. package/src/components/text-strikethrough.tsx +84 -0
  198. package/src/components/toast.css +236 -0
  199. package/src/components/toast.tsx +185 -0
  200. package/src/components/tooltip.css +74 -0
  201. package/src/components/tooltip.tsx +161 -0
  202. package/src/components/typewriter.css +14 -0
  203. package/src/components/typewriter.tsx +55 -0
  204. package/src/context/dialog.tsx +197 -0
  205. package/src/context/file.tsx +10 -0
  206. package/src/context/helper.tsx +38 -0
  207. package/src/context/i18n.tsx +38 -0
  208. package/src/context/index.ts +4 -0
  209. package/src/context/marked.tsx +522 -0
  210. package/src/context/worker-pool.tsx +20 -0
  211. package/src/custom-elements.d.ts +17 -0
  212. package/src/hooks/create-auto-scroll.tsx +237 -0
  213. package/src/hooks/index.ts +2 -0
  214. package/src/hooks/use-filtered-list.tsx +134 -0
  215. package/src/i18n/ar.ts +168 -0
  216. package/src/i18n/br.ts +168 -0
  217. package/src/i18n/bs.ts +172 -0
  218. package/src/i18n/da.ts +167 -0
  219. package/src/i18n/de.ts +173 -0
  220. package/src/i18n/en.ts +176 -0
  221. package/src/i18n/es.ts +168 -0
  222. package/src/i18n/fr.ts +168 -0
  223. package/src/i18n/ja.ts +167 -0
  224. package/src/i18n/ko.ts +168 -0
  225. package/src/i18n/no.ts +171 -0
  226. package/src/i18n/pl.ts +167 -0
  227. package/src/i18n/ru.ts +167 -0
  228. package/src/i18n/th.ts +169 -0
  229. package/src/i18n/tr.ts +174 -0
  230. package/src/i18n/uk.ts +167 -0
  231. package/src/i18n/zh.ts +171 -0
  232. package/src/i18n/zht.ts +171 -0
  233. package/src/storybook/fixtures.ts +51 -0
  234. package/src/storybook/scaffold.tsx +62 -0
  235. package/src/styles/animations.css +141 -0
  236. package/src/styles/base.css +404 -0
  237. package/src/styles/colors.css +772 -0
  238. package/src/styles/index.css +53 -0
  239. package/src/styles/tailwind/colors.css +285 -0
  240. package/src/styles/tailwind/index.css +78 -0
  241. package/src/styles/tailwind/utilities.css +131 -0
  242. package/src/styles/theme.css +609 -0
  243. package/src/styles/utilities.css +118 -0
  244. package/src/theme/color.ts +299 -0
  245. package/src/theme/context.tsx +370 -0
  246. package/src/theme/default-themes.ts +116 -0
  247. package/src/theme/index.ts +78 -0
  248. package/src/theme/loader.ts +112 -0
  249. package/src/theme/resolve.ts +540 -0
  250. package/src/theme/themes/amoled.json +49 -0
  251. package/src/theme/themes/aura.json +51 -0
  252. package/src/theme/themes/ayu.json +51 -0
  253. package/src/theme/themes/carbonfox.json +53 -0
  254. package/src/theme/themes/catppuccin-frappe.json +85 -0
  255. package/src/theme/themes/catppuccin-macchiato.json +85 -0
  256. package/src/theme/themes/catppuccin.json +45 -0
  257. package/src/theme/themes/cobalt2.json +87 -0
  258. package/src/theme/themes/cursor.json +91 -0
  259. package/src/theme/themes/dracula.json +49 -0
  260. package/src/theme/themes/everforest.json +89 -0
  261. package/src/theme/themes/flexoki.json +86 -0
  262. package/src/theme/themes/github.json +85 -0
  263. package/src/theme/themes/gruvbox.json +45 -0
  264. package/src/theme/themes/kanagawa.json +89 -0
  265. package/src/theme/themes/lucent-orng.json +87 -0
  266. package/src/theme/themes/material.json +87 -0
  267. package/src/theme/themes/matrix.json +113 -0
  268. package/src/theme/themes/mercury.json +86 -0
  269. package/src/theme/themes/monokai.json +49 -0
  270. package/src/theme/themes/nightowl.json +46 -0
  271. package/src/theme/themes/nord.json +46 -0
  272. package/src/theme/themes/oc-2.json +468 -0
  273. package/src/theme/themes/one-dark.json +89 -0
  274. package/src/theme/themes/onedarkpro.json +45 -0
  275. package/src/theme/themes/opencode.json +89 -0
  276. package/src/theme/themes/orng.json +87 -0
  277. package/src/theme/themes/osaka-jade.json +88 -0
  278. package/src/theme/themes/palenight.json +85 -0
  279. package/src/theme/themes/rosepine.json +85 -0
  280. package/src/theme/themes/shadesofpurple.json +51 -0
  281. package/src/theme/themes/solarized.json +49 -0
  282. package/src/theme/themes/synthwave84.json +87 -0
  283. package/src/theme/themes/tokyonight.json +47 -0
  284. package/src/theme/themes/vercel.json +90 -0
  285. package/src/theme/themes/vesper.json +51 -0
  286. package/src/theme/themes/zenburn.json +87 -0
  287. package/src/theme/types.ts +75 -0
  288. package/src/theme/v2/avatar.ts +48 -0
  289. package/src/theme/v2/default-primitives.ts +114 -0
  290. package/src/theme/v2/foreground.ts +60 -0
  291. package/src/theme/v2/mapping.ts +138 -0
  292. package/src/theme/v2/resolve.ts +153 -0
  293. package/src/v2/components/accordion-v2.css +139 -0
  294. package/src/v2/components/accordion-v2.tsx +86 -0
  295. package/src/v2/components/avatar-v2.css +70 -0
  296. package/src/v2/components/avatar-v2.tsx +59 -0
  297. package/src/v2/components/badge-v2.css +27 -0
  298. package/src/v2/components/badge-v2.tsx +20 -0
  299. package/src/v2/components/button-v2.css +186 -0
  300. package/src/v2/components/button-v2.tsx +35 -0
  301. package/src/v2/components/checkbox-v2.css +184 -0
  302. package/src/v2/components/checkbox-v2.tsx +65 -0
  303. package/src/v2/components/dialog-v2.css +150 -0
  304. package/src/v2/components/dialog-v2.tsx +93 -0
  305. package/src/v2/components/diff-changes-v2.css +24 -0
  306. package/src/v2/components/diff-changes-v2.tsx +28 -0
  307. package/src/v2/components/field-v2.css +94 -0
  308. package/src/v2/components/field-v2.tsx +265 -0
  309. package/src/v2/components/icon-button-v2.css +155 -0
  310. package/src/v2/components/icon-button-v2.tsx +37 -0
  311. package/src/v2/components/icon.tsx +129 -0
  312. package/src/v2/components/inline-input-v2.css +218 -0
  313. package/src/v2/components/inline-input-v2.tsx +90 -0
  314. package/src/v2/components/keybind-v2.css +76 -0
  315. package/src/v2/components/keybind-v2.tsx +30 -0
  316. package/src/v2/components/line-comment-v2.css +204 -0
  317. package/src/v2/components/line-comment-v2.tsx +155 -0
  318. package/src/v2/components/menu-v2.css +190 -0
  319. package/src/v2/components/menu-v2.tsx +225 -0
  320. package/src/v2/components/project-avatar-v2.css +126 -0
  321. package/src/v2/components/project-avatar-v2.tsx +64 -0
  322. package/src/v2/components/radio-v2.css +202 -0
  323. package/src/v2/components/radio-v2.tsx +72 -0
  324. package/src/v2/components/segmented-control-v2.css +80 -0
  325. package/src/v2/components/segmented-control-v2.tsx +208 -0
  326. package/src/v2/components/select-v2.css +285 -0
  327. package/src/v2/components/select-v2.tsx +208 -0
  328. package/src/v2/components/switch-v2.css +154 -0
  329. package/src/v2/components/switch-v2.tsx +28 -0
  330. package/src/v2/components/tab-state-indicator.tsx +37 -0
  331. package/src/v2/components/tabs-v2.css +225 -0
  332. package/src/v2/components/tabs-v2.tsx +147 -0
  333. package/src/v2/components/text-input-v2.css +145 -0
  334. package/src/v2/components/text-input-v2.tsx +67 -0
  335. package/src/v2/components/text-shimmer-v2.css +125 -0
  336. package/src/v2/components/text-shimmer-v2.tsx +63 -0
  337. package/src/v2/components/textarea-v2.css +78 -0
  338. package/src/v2/components/textarea-v2.tsx +31 -0
  339. package/src/v2/components/toast-v2.css +215 -0
  340. package/src/v2/components/toast-v2.tsx +144 -0
  341. package/src/v2/components/tooltip-v2.css +53 -0
  342. package/src/v2/components/tooltip-v2.tsx +146 -0
  343. package/src/v2/components/wordmark-v2.tsx +92 -0
  344. package/src/v2/styles/colors.css +172 -0
  345. package/src/v2/styles/tailwind.css +2 -0
  346. 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
+ }