@dxos/ui-theme 0.8.4-main.fbb7a13 → 0.8.4-main.fcc0d83b33

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 (384) hide show
  1. package/dist/lib/browser/index.mjs +762 -2803
  2. package/dist/lib/browser/index.mjs.map +4 -4
  3. package/dist/lib/browser/meta.json +1 -1
  4. package/dist/lib/node-esm/index.mjs +762 -2803
  5. package/dist/lib/node-esm/index.mjs.map +4 -4
  6. package/dist/lib/node-esm/meta.json +1 -1
  7. package/dist/plugin/node-cjs/main.css +1561 -0
  8. package/dist/plugin/node-cjs/main.css.map +7 -0
  9. package/dist/plugin/node-cjs/meta.json +1 -1
  10. package/dist/plugin/node-cjs/plugins/ThemePlugin.cjs +137 -0
  11. package/dist/plugin/node-cjs/plugins/ThemePlugin.cjs.map +7 -0
  12. package/dist/plugin/node-esm/main.css +1561 -0
  13. package/dist/plugin/node-esm/main.css.map +7 -0
  14. package/dist/plugin/node-esm/meta.json +1 -1
  15. package/dist/plugin/node-esm/plugins/ThemePlugin.mjs +105 -0
  16. package/dist/plugin/node-esm/plugins/ThemePlugin.mjs.map +7 -0
  17. package/dist/types/src/Theme.stories.d.ts +27 -0
  18. package/dist/types/src/Theme.stories.d.ts.map +1 -0
  19. package/dist/types/src/defs.d.ts +21 -0
  20. package/dist/types/src/defs.d.ts.map +1 -0
  21. package/dist/types/src/fragments/density.d.ts +4 -0
  22. package/dist/types/src/fragments/density.d.ts.map +1 -0
  23. package/dist/types/src/fragments/disabled.d.ts.map +1 -0
  24. package/dist/types/src/fragments/hover.d.ts +10 -0
  25. package/dist/types/src/fragments/hover.d.ts.map +1 -0
  26. package/dist/types/src/fragments/index.d.ts +5 -0
  27. package/dist/types/src/fragments/index.d.ts.map +1 -0
  28. package/dist/types/src/fragments/text.d.ts +2 -0
  29. package/dist/types/src/fragments/text.d.ts.map +1 -0
  30. package/dist/types/src/index.d.ts +3 -10
  31. package/dist/types/src/index.d.ts.map +1 -1
  32. package/dist/types/src/plugins/ThemePlugin.d.ts +16 -0
  33. package/dist/types/src/plugins/ThemePlugin.d.ts.map +1 -0
  34. package/dist/types/src/plugins/dark-mode.d.ts +1 -0
  35. package/dist/types/src/plugins/dark-mode.d.ts.map +1 -0
  36. package/dist/types/src/theme/components/avatar.d.ts.map +1 -0
  37. package/dist/types/src/theme/components/breadcrumb.d.ts.map +1 -0
  38. package/dist/types/src/theme/components/button.d.ts +15 -0
  39. package/dist/types/src/theme/components/button.d.ts.map +1 -0
  40. package/dist/types/src/theme/components/card.d.ts +12 -0
  41. package/dist/types/src/theme/components/card.d.ts.map +1 -0
  42. package/dist/types/src/{styles → theme}/components/dialog.d.ts +2 -0
  43. package/dist/types/src/theme/components/dialog.d.ts.map +1 -0
  44. package/dist/types/src/theme/components/focus.d.ts +6 -0
  45. package/dist/types/src/theme/components/focus.d.ts.map +1 -0
  46. package/dist/types/src/{styles → theme}/components/icon-button.d.ts +1 -0
  47. package/dist/types/src/theme/components/icon-button.d.ts.map +1 -0
  48. package/dist/types/src/{styles → theme}/components/icon.d.ts +3 -0
  49. package/dist/types/src/theme/components/icon.d.ts.map +1 -0
  50. package/dist/types/src/{styles → theme}/components/index.d.ts +4 -1
  51. package/dist/types/src/theme/components/index.d.ts.map +1 -0
  52. package/dist/types/src/{styles → theme}/components/input.d.ts +31 -27
  53. package/dist/types/src/theme/components/input.d.ts.map +1 -0
  54. package/dist/types/src/theme/components/link.d.ts.map +1 -0
  55. package/dist/types/src/theme/components/list.d.ts.map +1 -0
  56. package/dist/types/src/{styles → theme}/components/main.d.ts +2 -7
  57. package/dist/types/src/theme/components/main.d.ts.map +1 -0
  58. package/dist/types/src/{styles → theme}/components/menu.d.ts +1 -1
  59. package/dist/types/src/theme/components/menu.d.ts.map +1 -0
  60. package/dist/types/src/{styles → theme}/components/message.d.ts +1 -0
  61. package/dist/types/src/theme/components/message.d.ts.map +1 -0
  62. package/dist/types/src/{styles → theme}/components/popover.d.ts +1 -1
  63. package/dist/types/src/theme/components/popover.d.ts.map +1 -0
  64. package/dist/types/src/theme/components/scroll-area.d.ts +32 -0
  65. package/dist/types/src/theme/components/scroll-area.d.ts.map +1 -0
  66. package/dist/types/src/theme/components/select.d.ts.map +1 -0
  67. package/dist/types/src/theme/components/separator.d.ts.map +1 -0
  68. package/dist/types/src/theme/components/skeleton.d.ts +7 -0
  69. package/dist/types/src/theme/components/skeleton.d.ts.map +1 -0
  70. package/dist/types/src/theme/components/splitter.d.ts +4 -0
  71. package/dist/types/src/theme/components/splitter.d.ts.map +1 -0
  72. package/dist/types/src/{styles → theme}/components/status.d.ts +1 -1
  73. package/dist/types/src/theme/components/status.d.ts.map +1 -0
  74. package/dist/types/src/theme/components/tag.d.ts.map +1 -0
  75. package/dist/types/src/theme/components/toast.d.ts.map +1 -0
  76. package/dist/types/src/theme/components/toolbar.d.ts +11 -0
  77. package/dist/types/src/theme/components/toolbar.d.ts.map +1 -0
  78. package/dist/types/src/theme/components/tooltip.d.ts.map +1 -0
  79. package/dist/types/src/theme/components/treegrid.d.ts.map +1 -0
  80. package/dist/types/src/theme/index.d.ts +4 -0
  81. package/dist/types/src/theme/index.d.ts.map +1 -0
  82. package/dist/types/src/theme/primitives/column.d.ts +29 -0
  83. package/dist/types/src/theme/primitives/column.d.ts.map +1 -0
  84. package/dist/types/src/theme/primitives/index.d.ts +3 -0
  85. package/dist/types/src/theme/primitives/index.d.ts.map +1 -0
  86. package/dist/types/src/theme/primitives/panel.d.ts +13 -0
  87. package/dist/types/src/theme/primitives/panel.d.ts.map +1 -0
  88. package/dist/types/src/theme/theme.d.ts +5 -0
  89. package/dist/types/src/theme/theme.d.ts.map +1 -0
  90. package/dist/types/src/{styles/fragments → util}/elevation.d.ts +0 -6
  91. package/dist/types/src/util/elevation.d.ts.map +1 -0
  92. package/dist/types/src/util/hash-styles.d.ts +8 -5
  93. package/dist/types/src/util/hash-styles.d.ts.map +1 -1
  94. package/dist/types/src/util/index.d.ts +3 -0
  95. package/dist/types/src/util/index.d.ts.map +1 -1
  96. package/dist/types/src/util/mx.d.ts +56 -0
  97. package/dist/types/src/util/mx.d.ts.map +1 -1
  98. package/dist/types/src/util/size.d.ts +27 -0
  99. package/dist/types/src/util/size.d.ts.map +1 -0
  100. package/dist/types/src/util/valence.d.ts +4 -0
  101. package/dist/types/src/util/valence.d.ts.map +1 -0
  102. package/dist/types/tsconfig.tsbuildinfo +1 -1
  103. package/package.json +25 -35
  104. package/src/Theme.stories.tsx +224 -0
  105. package/src/css/base/base.css +43 -0
  106. package/src/{styles/layers → css/base}/typography.css +3 -5
  107. package/src/{styles/layers → css/components}/button.css +23 -14
  108. package/src/{styles/layers → css/components}/checkbox.css +12 -8
  109. package/src/{styles/layers → css/components}/dialog.css +16 -15
  110. package/src/{styles/layers/focus-ring.css → css/components/focus.css} +60 -41
  111. package/src/css/components/icon.css +9 -0
  112. package/src/css/components/link.css +9 -0
  113. package/src/css/components/panel.css +117 -0
  114. package/src/css/components/scrollbar.css +24 -0
  115. package/src/css/components/selected.css +30 -0
  116. package/src/css/components/surface.css +34 -0
  117. package/src/css/components/tag.css +132 -0
  118. package/src/css/components/text.css +124 -0
  119. package/src/css/integrations/codemirror.css +34 -0
  120. package/src/css/integrations/tldraw.css +14 -0
  121. package/src/css/layout/main.css +205 -0
  122. package/src/{styles/layers → css/layout}/native.css +6 -4
  123. package/src/css/layout/positioning.css +19 -0
  124. package/src/{styles/layers → css/layout}/size.css +129 -108
  125. package/src/css/theme/animation.css +260 -0
  126. package/src/css/theme/border.css +23 -0
  127. package/src/css/theme/palette.css +36 -0
  128. package/src/css/theme/semantic.css +116 -0
  129. package/src/css/theme/spacing.css +147 -0
  130. package/src/css/theme/styles.css +145 -0
  131. package/src/css/theme/text.css +37 -0
  132. package/src/css/utilities.css +118 -0
  133. package/src/defs.ts +48 -0
  134. package/src/fragments/AUDIT.md +57 -0
  135. package/src/fragments/density.ts +16 -0
  136. package/src/fragments/hover.ts +18 -0
  137. package/src/fragments/index.ts +10 -0
  138. package/src/fragments/text.ts +6 -0
  139. package/src/index.ts +3 -14
  140. package/src/main.css +87 -0
  141. package/src/plugins/ThemePlugin.ts +125 -0
  142. package/src/plugins/dark-mode.ts +22 -0
  143. package/src/plugins/main.css +45 -0
  144. package/src/{styles → theme}/components/avatar.ts +12 -13
  145. package/src/theme/components/button.ts +48 -0
  146. package/src/theme/components/card.ts +102 -0
  147. package/src/{styles → theme}/components/dialog.ts +19 -10
  148. package/src/theme/components/focus.ts +33 -0
  149. package/src/{styles → theme}/components/icon-button.ts +6 -5
  150. package/src/theme/components/icon.ts +28 -0
  151. package/src/{styles → theme}/components/index.ts +4 -1
  152. package/src/theme/components/input.ts +171 -0
  153. package/src/{styles → theme}/components/link.ts +3 -4
  154. package/src/{styles → theme}/components/list.ts +5 -5
  155. package/src/{styles → theme}/components/main.ts +2 -6
  156. package/src/{styles → theme}/components/menu.ts +11 -21
  157. package/src/{styles → theme}/components/message.ts +11 -7
  158. package/src/{styles → theme}/components/popover.ts +13 -12
  159. package/src/theme/components/scroll-area.ts +115 -0
  160. package/src/{styles → theme}/components/select.ts +8 -16
  161. package/src/{styles → theme}/components/separator.ts +3 -3
  162. package/src/theme/components/skeleton.ts +23 -0
  163. package/src/theme/components/splitter.ts +20 -0
  164. package/src/{styles → theme}/components/status.ts +7 -7
  165. package/src/{styles → theme}/components/tag.ts +1 -1
  166. package/src/{styles → theme}/components/toast.ts +6 -8
  167. package/src/theme/components/toolbar.ts +35 -0
  168. package/src/{styles → theme}/components/tooltip.ts +4 -6
  169. package/src/{styles → theme}/components/treegrid.ts +9 -9
  170. package/src/{styles → theme}/index.ts +2 -2
  171. package/src/theme/primitives/column.ts +71 -0
  172. package/src/theme/primitives/index.ts +6 -0
  173. package/src/theme/primitives/panel.ts +43 -0
  174. package/src/{styles → theme}/theme.ts +27 -9
  175. package/src/typings.d.ts +3 -1
  176. package/src/{styles/fragments → util}/elevation.ts +6 -8
  177. package/src/util/hash-styles.ts +118 -98
  178. package/src/util/index.ts +3 -0
  179. package/src/util/mx.ts +165 -43
  180. package/src/util/size.ts +103 -0
  181. package/src/util/valence.ts +33 -0
  182. package/dist/plugin/node-cjs/chunk-UUMDOU7E.cjs +0 -79
  183. package/dist/plugin/node-cjs/chunk-UUMDOU7E.cjs.map +0 -7
  184. package/dist/plugin/node-cjs/chunk-ZVALPM6U.cjs +0 -1619
  185. package/dist/plugin/node-cjs/chunk-ZVALPM6U.cjs.map +0 -7
  186. package/dist/plugin/node-cjs/config/tailwind.cjs +0 -29
  187. package/dist/plugin/node-cjs/config/tailwind.cjs.map +0 -7
  188. package/dist/plugin/node-cjs/plugins/esbuild-plugin.cjs +0 -90
  189. package/dist/plugin/node-cjs/plugins/esbuild-plugin.cjs.map +0 -7
  190. package/dist/plugin/node-cjs/plugins/plugin.cjs +0 -124
  191. package/dist/plugin/node-cjs/plugins/plugin.cjs.map +0 -7
  192. package/dist/plugin/node-cjs/theme.css +0 -1418
  193. package/dist/plugin/node-cjs/theme.css.map +0 -7
  194. package/dist/plugin/node-esm/chunk-AFRHJHP4.mjs +0 -49
  195. package/dist/plugin/node-esm/chunk-AFRHJHP4.mjs.map +0 -7
  196. package/dist/plugin/node-esm/chunk-HJE6EZWE.mjs +0 -1614
  197. package/dist/plugin/node-esm/chunk-HJE6EZWE.mjs.map +0 -7
  198. package/dist/plugin/node-esm/config/tailwind.mjs +0 -8
  199. package/dist/plugin/node-esm/config/tailwind.mjs.map +0 -7
  200. package/dist/plugin/node-esm/plugins/esbuild-plugin.mjs +0 -63
  201. package/dist/plugin/node-esm/plugins/esbuild-plugin.mjs.map +0 -7
  202. package/dist/plugin/node-esm/plugins/plugin.mjs +0 -98
  203. package/dist/plugin/node-esm/plugins/plugin.mjs.map +0 -7
  204. package/dist/plugin/node-esm/theme.css +0 -1418
  205. package/dist/plugin/node-esm/theme.css.map +0 -7
  206. package/dist/types/src/Tokens.stories.d.ts +0 -10
  207. package/dist/types/src/Tokens.stories.d.ts.map +0 -1
  208. package/dist/types/src/config/index.d.ts +0 -3
  209. package/dist/types/src/config/index.d.ts.map +0 -1
  210. package/dist/types/src/config/tailwind.d.ts +0 -9
  211. package/dist/types/src/config/tailwind.d.ts.map +0 -1
  212. package/dist/types/src/config/tokens/alias-colors.d.ts +0 -21
  213. package/dist/types/src/config/tokens/alias-colors.d.ts.map +0 -1
  214. package/dist/types/src/config/tokens/index.d.ts +0 -486
  215. package/dist/types/src/config/tokens/index.d.ts.map +0 -1
  216. package/dist/types/src/config/tokens/lengths.d.ts +0 -139
  217. package/dist/types/src/config/tokens/lengths.d.ts.map +0 -1
  218. package/dist/types/src/config/tokens/physical-colors.d.ts +0 -23
  219. package/dist/types/src/config/tokens/physical-colors.d.ts.map +0 -1
  220. package/dist/types/src/config/tokens/semantic-colors.d.ts +0 -187
  221. package/dist/types/src/config/tokens/semantic-colors.d.ts.map +0 -1
  222. package/dist/types/src/config/tokens/sememes-calls.d.ts +0 -3
  223. package/dist/types/src/config/tokens/sememes-calls.d.ts.map +0 -1
  224. package/dist/types/src/config/tokens/sememes-codemirror.d.ts +0 -43
  225. package/dist/types/src/config/tokens/sememes-codemirror.d.ts.map +0 -1
  226. package/dist/types/src/config/tokens/sememes-hue.d.ts +0 -4
  227. package/dist/types/src/config/tokens/sememes-hue.d.ts.map +0 -1
  228. package/dist/types/src/config/tokens/sememes-sheet.d.ts +0 -58
  229. package/dist/types/src/config/tokens/sememes-sheet.d.ts.map +0 -1
  230. package/dist/types/src/config/tokens/sememes-system.d.ts +0 -99
  231. package/dist/types/src/config/tokens/sememes-system.d.ts.map +0 -1
  232. package/dist/types/src/config/tokens/sizes.d.ts +0 -7
  233. package/dist/types/src/config/tokens/sizes.d.ts.map +0 -1
  234. package/dist/types/src/config/tokens/types.d.ts +0 -5
  235. package/dist/types/src/config/tokens/types.d.ts.map +0 -1
  236. package/dist/types/src/plugins/esbuild-plugin.d.ts +0 -9
  237. package/dist/types/src/plugins/esbuild-plugin.d.ts.map +0 -1
  238. package/dist/types/src/plugins/plugin.d.ts +0 -20
  239. package/dist/types/src/plugins/plugin.d.ts.map +0 -1
  240. package/dist/types/src/plugins/resolveContent.d.ts +0 -2
  241. package/dist/types/src/plugins/resolveContent.d.ts.map +0 -1
  242. package/dist/types/src/styles/components/anchored-overflow.d.ts +0 -6
  243. package/dist/types/src/styles/components/anchored-overflow.d.ts.map +0 -1
  244. package/dist/types/src/styles/components/avatar.d.ts.map +0 -1
  245. package/dist/types/src/styles/components/breadcrumb.d.ts.map +0 -1
  246. package/dist/types/src/styles/components/button.d.ts +0 -19
  247. package/dist/types/src/styles/components/button.d.ts.map +0 -1
  248. package/dist/types/src/styles/components/dialog.d.ts.map +0 -1
  249. package/dist/types/src/styles/components/icon-button.d.ts.map +0 -1
  250. package/dist/types/src/styles/components/icon.d.ts.map +0 -1
  251. package/dist/types/src/styles/components/index.d.ts.map +0 -1
  252. package/dist/types/src/styles/components/input.d.ts.map +0 -1
  253. package/dist/types/src/styles/components/link.d.ts.map +0 -1
  254. package/dist/types/src/styles/components/list.d.ts.map +0 -1
  255. package/dist/types/src/styles/components/main.d.ts.map +0 -1
  256. package/dist/types/src/styles/components/menu.d.ts.map +0 -1
  257. package/dist/types/src/styles/components/message.d.ts.map +0 -1
  258. package/dist/types/src/styles/components/popover.d.ts.map +0 -1
  259. package/dist/types/src/styles/components/scroll-area.d.ts +0 -9
  260. package/dist/types/src/styles/components/scroll-area.d.ts.map +0 -1
  261. package/dist/types/src/styles/components/select.d.ts.map +0 -1
  262. package/dist/types/src/styles/components/separator.d.ts.map +0 -1
  263. package/dist/types/src/styles/components/status.d.ts.map +0 -1
  264. package/dist/types/src/styles/components/tag.d.ts.map +0 -1
  265. package/dist/types/src/styles/components/toast.d.ts.map +0 -1
  266. package/dist/types/src/styles/components/toolbar.d.ts +0 -11
  267. package/dist/types/src/styles/components/toolbar.d.ts.map +0 -1
  268. package/dist/types/src/styles/components/tooltip.d.ts.map +0 -1
  269. package/dist/types/src/styles/components/treegrid.d.ts.map +0 -1
  270. package/dist/types/src/styles/fragments/density.d.ts +0 -13
  271. package/dist/types/src/styles/fragments/density.d.ts.map +0 -1
  272. package/dist/types/src/styles/fragments/dimension.d.ts +0 -5
  273. package/dist/types/src/styles/fragments/dimension.d.ts.map +0 -1
  274. package/dist/types/src/styles/fragments/disabled.d.ts.map +0 -1
  275. package/dist/types/src/styles/fragments/elevation.d.ts.map +0 -1
  276. package/dist/types/src/styles/fragments/focus.d.ts +0 -6
  277. package/dist/types/src/styles/fragments/focus.d.ts.map +0 -1
  278. package/dist/types/src/styles/fragments/group.d.ts +0 -5
  279. package/dist/types/src/styles/fragments/group.d.ts.map +0 -1
  280. package/dist/types/src/styles/fragments/hover.d.ts +0 -17
  281. package/dist/types/src/styles/fragments/hover.d.ts.map +0 -1
  282. package/dist/types/src/styles/fragments/index.d.ts +0 -17
  283. package/dist/types/src/styles/fragments/index.d.ts.map +0 -1
  284. package/dist/types/src/styles/fragments/layout.d.ts +0 -3
  285. package/dist/types/src/styles/fragments/layout.d.ts.map +0 -1
  286. package/dist/types/src/styles/fragments/motion.d.ts +0 -2
  287. package/dist/types/src/styles/fragments/motion.d.ts.map +0 -1
  288. package/dist/types/src/styles/fragments/ornament.d.ts +0 -5
  289. package/dist/types/src/styles/fragments/ornament.d.ts.map +0 -1
  290. package/dist/types/src/styles/fragments/selected.d.ts +0 -13
  291. package/dist/types/src/styles/fragments/selected.d.ts.map +0 -1
  292. package/dist/types/src/styles/fragments/shimmer.d.ts +0 -3
  293. package/dist/types/src/styles/fragments/shimmer.d.ts.map +0 -1
  294. package/dist/types/src/styles/fragments/size.d.ts +0 -9
  295. package/dist/types/src/styles/fragments/size.d.ts.map +0 -1
  296. package/dist/types/src/styles/fragments/surface.d.ts +0 -9
  297. package/dist/types/src/styles/fragments/surface.d.ts.map +0 -1
  298. package/dist/types/src/styles/fragments/text.d.ts +0 -7
  299. package/dist/types/src/styles/fragments/text.d.ts.map +0 -1
  300. package/dist/types/src/styles/fragments/valence.d.ts +0 -13
  301. package/dist/types/src/styles/fragments/valence.d.ts.map +0 -1
  302. package/dist/types/src/styles/index.d.ts +0 -4
  303. package/dist/types/src/styles/index.d.ts.map +0 -1
  304. package/dist/types/src/styles/theme.d.ts +0 -5
  305. package/dist/types/src/styles/theme.d.ts.map +0 -1
  306. package/dist/types/src/tailwind.d.ts +0 -3
  307. package/dist/types/src/tailwind.d.ts.map +0 -1
  308. package/dist/types/src/types.d.ts +0 -3
  309. package/dist/types/src/types.d.ts.map +0 -1
  310. package/dist/types/src/util/withLogical.d.ts +0 -164
  311. package/dist/types/src/util/withLogical.d.ts.map +0 -1
  312. package/src/Tokens.stories.tsx +0 -88
  313. package/src/config/index.ts +0 -6
  314. package/src/config/tailwind.ts +0 -264
  315. package/src/config/tokens/alias-colors.ts +0 -39
  316. package/src/config/tokens/index.ts +0 -92
  317. package/src/config/tokens/lengths.ts +0 -97
  318. package/src/config/tokens/physical-colors.ts +0 -125
  319. package/src/config/tokens/semantic-colors.ts +0 -27
  320. package/src/config/tokens/sememes-calls.ts +0 -17
  321. package/src/config/tokens/sememes-codemirror.ts +0 -50
  322. package/src/config/tokens/sememes-hue.ts +0 -54
  323. package/src/config/tokens/sememes-sheet.ts +0 -62
  324. package/src/config/tokens/sememes-system.ts +0 -302
  325. package/src/config/tokens/sizes.ts +0 -10
  326. package/src/config/tokens/types.ts +0 -9
  327. package/src/docs/theme.drawio.svg +0 -635
  328. package/src/plugins/esbuild-plugin.ts +0 -65
  329. package/src/plugins/plugin.ts +0 -130
  330. package/src/plugins/resolveContent.ts +0 -51
  331. package/src/styles/components/README.md +0 -6
  332. package/src/styles/components/anchored-overflow.ts +0 -20
  333. package/src/styles/components/button.ts +0 -48
  334. package/src/styles/components/icon.ts +0 -19
  335. package/src/styles/components/input.ts +0 -177
  336. package/src/styles/components/scroll-area.ts +0 -43
  337. package/src/styles/components/toolbar.ts +0 -29
  338. package/src/styles/fragments/density.ts +0 -17
  339. package/src/styles/fragments/dimension.ts +0 -8
  340. package/src/styles/fragments/focus.ts +0 -16
  341. package/src/styles/fragments/group.ts +0 -12
  342. package/src/styles/fragments/hover.ts +0 -25
  343. package/src/styles/fragments/index.ts +0 -20
  344. package/src/styles/fragments/layout.ts +0 -7
  345. package/src/styles/fragments/motion.ts +0 -6
  346. package/src/styles/fragments/ornament.ts +0 -10
  347. package/src/styles/fragments/selected.ts +0 -45
  348. package/src/styles/fragments/shimmer.ts +0 -9
  349. package/src/styles/fragments/size.ts +0 -117
  350. package/src/styles/fragments/surface.ts +0 -29
  351. package/src/styles/fragments/text.ts +0 -12
  352. package/src/styles/fragments/valence.ts +0 -46
  353. package/src/styles/layers/README.md +0 -15
  354. package/src/styles/layers/anchored-overflow.css +0 -9
  355. package/src/styles/layers/animation.css +0 -17
  356. package/src/styles/layers/attention.css +0 -8
  357. package/src/styles/layers/base.css +0 -25
  358. package/src/styles/layers/can-scroll.css +0 -26
  359. package/src/styles/layers/drag-preview.css +0 -18
  360. package/src/styles/layers/hues.css +0 -110
  361. package/src/styles/layers/index.css +0 -26
  362. package/src/styles/layers/main.css +0 -227
  363. package/src/styles/layers/positioning.css +0 -23
  364. package/src/styles/layers/surfaces.css +0 -31
  365. package/src/styles/layers/tag.css +0 -132
  366. package/src/styles/layers/tldraw.css +0 -91
  367. package/src/styles/layers/tokens.css +0 -46
  368. package/src/tailwind.ts +0 -7
  369. package/src/theme.css +0 -9
  370. package/src/types.ts +0 -7
  371. package/src/util/withLogical.ts +0 -114
  372. /package/dist/types/src/{styles/fragments → fragments}/disabled.d.ts +0 -0
  373. /package/dist/types/src/{styles → theme}/components/avatar.d.ts +0 -0
  374. /package/dist/types/src/{styles → theme}/components/breadcrumb.d.ts +0 -0
  375. /package/dist/types/src/{styles → theme}/components/link.d.ts +0 -0
  376. /package/dist/types/src/{styles → theme}/components/list.d.ts +0 -0
  377. /package/dist/types/src/{styles → theme}/components/select.d.ts +0 -0
  378. /package/dist/types/src/{styles → theme}/components/separator.d.ts +0 -0
  379. /package/dist/types/src/{styles → theme}/components/tag.d.ts +0 -0
  380. /package/dist/types/src/{styles → theme}/components/toast.d.ts +0 -0
  381. /package/dist/types/src/{styles → theme}/components/tooltip.d.ts +0 -0
  382. /package/dist/types/src/{styles → theme}/components/treegrid.d.ts +0 -0
  383. /package/src/{styles/fragments → fragments}/disabled.ts +0 -0
  384. /package/src/{styles → theme}/components/breadcrumb.ts +0 -0
@@ -6,163 +6,183 @@ import { type ChromaticPalette } from '@dxos/ui-types';
6
6
 
7
7
  export type Hue = ChromaticPalette | 'neutral';
8
8
 
9
- // TODO(burdon): Rename?
9
+ // TODO(burdon): Reconcile with ui-theme/theme/roles.css
10
10
  export type ColorStyles = {
11
11
  hue: Hue;
12
- text: string;
13
- icon: string;
14
- bg: string;
15
- surface: string;
16
- border: string;
12
+ fill: string; // -fill
13
+ surface: string; // -surface
14
+ surfaceText: string; // -surface-text
15
+ text: string; // -text
16
+ border: string; // -border
17
17
  };
18
18
 
19
- const neutralColor: ColorStyles = {
19
+ const neutral: ColorStyles = {
20
20
  hue: 'neutral',
21
- text: 'text-neutralFill',
22
- icon: 'text-neutralSurfaceText',
23
- bg: 'bg-neutralFill',
24
- surface: 'bg-neutralSurface',
25
- border: 'border-neutralFill',
21
+ fill: 'bg-neutral-fill',
22
+ surface: 'bg-neutral-surface',
23
+ surfaceText: 'text-neutral-surface-text',
24
+ text: 'text-neutral-text',
25
+ border: 'border-neutral-border',
26
26
  };
27
27
 
28
- // NOTE: Don't include blue/red which are used as system colors.
29
- // NOTE: Cordinated with `tag.css`.
28
+ // NOTE: Coordinated with `tag.css`.
30
29
  // https://github.com/dxos/dxos/blob/main/packages/ui/react-ui-theme/src/styles/layers/tag.css
31
- export const styles: ColorStyles[] = [
30
+ const styles: ColorStyles[] = [
31
+ {
32
+ hue: 'red',
33
+ fill: 'bg-red-fill',
34
+ surface: 'bg-red-surface',
35
+ surfaceText: 'text-red-surface-text',
36
+ text: 'text-red-text',
37
+ border: 'border-red-border',
38
+ },
32
39
  {
33
40
  hue: 'orange',
34
- text: 'text-orangeFill',
35
- icon: 'text-orangeSurfaceText',
36
- bg: 'bg-orangeFill',
37
- surface: 'bg-orangeSurface',
38
- border: 'border-orangeFill',
41
+ fill: 'bg-orange-fill',
42
+ surface: 'bg-orange-surface',
43
+ surfaceText: 'text-orange-surface-text',
44
+ text: 'text-orange-text',
45
+ border: 'border-orange-border',
39
46
  },
40
47
  {
41
48
  hue: 'amber',
42
- text: 'text-amberFill',
43
- icon: 'text-amberSurfaceText',
44
- bg: 'bg-amberFill',
45
- surface: 'bg-amberSurface',
46
- border: 'border-amberFill',
49
+ fill: 'bg-amber-fill',
50
+ surface: 'bg-amber-surface',
51
+ surfaceText: 'text-amber-surface-text',
52
+ text: 'text-amber-text',
53
+ border: 'border-amber-border',
47
54
  },
48
55
  {
49
56
  hue: 'yellow',
50
- text: 'text-yellowFill',
51
- icon: 'text-yellowSurfaceText',
52
- bg: 'bg-yellowFill',
53
- surface: 'bg-yellowSurface',
54
- border: 'border-yellowFill',
57
+ fill: 'bg-yellow-fill',
58
+ surface: 'bg-yellow-surface',
59
+ surfaceText: 'text-yellow-surface-text',
60
+ text: 'text-yellow-text',
61
+ border: 'border-yellow-border',
55
62
  },
56
63
  {
57
64
  hue: 'lime',
58
- text: 'text-limeFill',
59
- icon: 'text-limeSurfaceText',
60
- bg: 'bg-limeFill',
61
- surface: 'bg-limeSurface',
62
- border: 'border-limeFill',
65
+ fill: 'bg-lime-fill',
66
+ surface: 'bg-lime-surface',
67
+ surfaceText: 'text-lime-surface-text',
68
+ text: 'text-lime-text',
69
+ border: 'border-lime-border',
63
70
  },
64
71
  {
65
72
  hue: 'green',
66
- text: 'text-greenFill',
67
- icon: 'text-greenSurfaceText',
68
- bg: 'bg-greenFill',
69
- surface: 'bg-greenSurface',
70
- border: 'border-greenFill',
73
+ fill: 'bg-green-fill',
74
+ surface: 'bg-green-surface',
75
+ surfaceText: 'text-green-surface-text',
76
+ text: 'text-green-text',
77
+ border: 'border-green-border',
71
78
  },
72
79
  {
73
80
  hue: 'emerald',
74
- text: 'text-emeraldFill',
75
- icon: 'text-emeraldSurfaceText',
76
- bg: 'bg-emeraldFill',
77
- surface: 'bg-emeraldSurface',
78
- border: 'border-emeraldFill',
81
+ fill: 'bg-emerald-fill',
82
+ surface: 'bg-emerald-surface',
83
+ surfaceText: 'text-emerald-surface-text',
84
+ text: 'text-emerald-text',
85
+ border: 'border-emerald-border',
79
86
  },
80
87
  {
81
88
  hue: 'teal',
82
- text: 'text-tealFill',
83
- icon: 'text-tealSurfaceText',
84
- bg: 'bg-tealFill',
85
- surface: 'bg-tealSurface',
86
- border: 'border-tealFill',
89
+ fill: 'bg-teal-fill',
90
+ surface: 'bg-teal-surface',
91
+ surfaceText: 'text-teal-surface-text',
92
+ text: 'text-teal-text',
93
+ border: 'border-teal-border',
87
94
  },
88
95
  {
89
96
  hue: 'cyan',
90
- text: 'text-cyanFill',
91
- icon: 'text-cyanSurfaceText',
92
- bg: 'bg-cyanFill',
93
- surface: 'bg-cyanSurface',
94
- border: 'border-cyanFill',
97
+ fill: 'bg-cyan-fill',
98
+ surface: 'bg-cyan-surface',
99
+ surfaceText: 'text-cyan-surface-text',
100
+ text: 'text-cyan-text',
101
+ border: 'border-cyan-border',
95
102
  },
96
103
  {
97
104
  hue: 'sky',
98
- text: 'text-skyFill',
99
- icon: 'text-skySurfaceText',
100
- bg: 'bg-skyFill',
101
- surface: 'bg-skySurface',
102
- border: 'border-skyFill',
105
+ fill: 'bg-sky-fill',
106
+ surface: 'bg-sky-surface',
107
+ surfaceText: 'text-sky-surface-text',
108
+ text: 'text-sky-text',
109
+ border: 'border-sky-border',
110
+ },
111
+ {
112
+ hue: 'blue',
113
+ fill: 'bg-blue-fill',
114
+ surface: 'bg-blue-surface',
115
+ surfaceText: 'text-blue-surface-text',
116
+ text: 'text-blue-text',
117
+ border: 'border-blue-border',
103
118
  },
104
119
  {
105
120
  hue: 'indigo',
106
- text: 'text-indigoFill',
107
- icon: 'text-indigoSurfaceText',
108
- bg: 'bg-indigoFill',
109
- surface: 'bg-indigoSurface',
110
- border: 'border-indigoFill',
121
+ fill: 'bg-indigo-fill',
122
+ surface: 'bg-indigo-surface',
123
+ surfaceText: 'text-indigo-surface-text',
124
+ text: 'text-indigo-text',
125
+ border: 'border-indigo-border',
111
126
  },
112
127
  {
113
128
  hue: 'violet',
114
- text: 'text-violetFill',
115
- icon: 'text-violetSurfaceText',
116
- bg: 'bg-violetFill',
117
- surface: 'bg-violetSurface',
118
- border: 'border-violetFill',
129
+ fill: 'bg-violet-fill',
130
+ surface: 'bg-violet-surface',
131
+ surfaceText: 'text-violet-surface-text',
132
+ text: 'text-violet-text',
133
+ border: 'border-violet-border',
119
134
  },
120
135
  {
121
136
  hue: 'purple',
122
- text: 'text-purpleFill',
123
- icon: 'text-purpleSurfaceText',
124
- bg: 'bg-purpleFill',
125
- surface: 'bg-purpleSurface',
126
- border: 'border-purpleFill',
137
+ fill: 'bg-purple-fill',
138
+ surface: 'bg-purple-surface',
139
+ surfaceText: 'text-purple-surface-text',
140
+ text: 'text-purple-text',
141
+ border: 'border-purple-border',
127
142
  },
128
143
  {
129
144
  hue: 'fuchsia',
130
- text: 'text-fuchsiaFill',
131
- icon: 'text-fuchsiaSurfaceText',
132
- bg: 'bg-fuchsiaFill',
133
- surface: 'bg-fuchsiaSurface',
134
- border: 'border-fuchsiaFill',
145
+ fill: 'bg-fuchsia-fill',
146
+ surface: 'bg-fuchsia-surface',
147
+ surfaceText: 'text-fuchsia-surface-text',
148
+ text: 'text-fuchsia-text',
149
+ border: 'border-fuchsia-border',
135
150
  },
136
151
  {
137
- hue: 'rose',
138
- text: 'text-roseFill',
139
- icon: 'text-roseSurfaceText',
140
- bg: 'bg-roseFill',
141
- surface: 'bg-roseSurface',
142
- border: 'border-roseFill',
152
+ hue: 'pink',
153
+ fill: 'bg-pink-fill',
154
+ surface: 'bg-pink-surface',
155
+ surfaceText: 'text-pink-surface-text',
156
+ text: 'text-pink-text',
157
+ border: 'border-pink-border',
143
158
  },
144
159
  {
145
- hue: 'pink',
146
- text: 'text-pinkFill',
147
- icon: 'text-pinkSurfaceText',
148
- bg: 'bg-pinkFill',
149
- surface: 'bg-pinkSurface',
150
- border: 'border-pinkFill',
160
+ hue: 'rose',
161
+ fill: 'bg-rose-fill',
162
+ surface: 'bg-rose-surface',
163
+ surfaceText: 'text-rose-surface-text',
164
+ text: 'text-rose-text',
165
+ border: 'border-rose-border',
151
166
  },
152
167
  ];
153
168
 
154
- export const getStyles = (hue: string): ColorStyles => {
155
- return styles.find((color) => color.hue === hue) || neutralColor;
169
+ export const palette = {
170
+ neutral,
171
+ hues: styles,
156
172
  };
157
173
 
158
- export const getHashHue = (id: string | undefined): Hue => {
159
- return id ? styles[getHash(id) % styles.length].hue : 'neutral';
174
+ // TODO(burdon): Rename getClassNames.
175
+ export const getStyles = (hue: string): ColorStyles => {
176
+ return styles.find((color) => color.hue === hue) || neutral;
160
177
  };
161
178
 
162
179
  // TODO(thure): Reconcile with `to-fallback.ts` which exports `toHue` which overlaps a lot.
163
180
  export const getHashStyles = (id: string | undefined): ColorStyles => {
164
- const hue = getHashHue(id);
165
- return getStyles(hue);
181
+ return getStyles(getHashHue(id));
182
+ };
183
+
184
+ export const getHashHue = (id: string | undefined): Hue => {
185
+ return id ? styles[getHash(id) % styles.length].hue : 'neutral';
166
186
  };
167
187
 
168
188
  const getHash = (id: string): number => id.split('').reduce((acc, char) => acc + char.charCodeAt(0), 0);
package/src/util/index.ts CHANGED
@@ -2,5 +2,8 @@
2
2
  // Copyright 2022 DXOS.org
3
3
  //
4
4
 
5
+ export * from './elevation';
5
6
  export * from './hash-styles';
6
7
  export * from './mx';
8
+ export * from './size';
9
+ export * from './valence';
package/src/util/mx.ts CHANGED
@@ -2,50 +2,172 @@
2
2
  // Copyright 2022 DXOS.org
3
3
  //
4
4
 
5
+ import {
6
+ Children,
7
+ createElement,
8
+ forwardRef,
9
+ type ForwardRefExoticComponent,
10
+ type ForwardedRef,
11
+ type HTMLAttributes,
12
+ isValidElement,
13
+ type ReactNode,
14
+ type RefAttributes,
15
+ CSSProperties,
16
+ } from 'react';
5
17
  import { extendTailwindMerge, validators } from 'tailwind-merge';
6
18
 
7
- import { type WithLogicalClassGroups, withLogical } from './withLogical';
8
-
9
- type AdditionalClassGroups = 'density' | 'dx-focus-ring' | WithLogicalClassGroups;
10
-
11
- export const mx = extendTailwindMerge<AdditionalClassGroups>(
12
- {
13
- extend: {
14
- classGroups: {
15
- 'font-family': ['font-body', 'font-mono'],
16
- 'font-weight': [
17
- // App weights
18
- 'font-thin',
19
- 'font-extralight',
20
- 'font-light',
21
- 'font-normal',
22
- 'font-medium',
23
- 'font-semibold',
24
- 'font-bold',
25
- 'font-extrabold',
26
- 'font-black',
27
- // Arbitrary numbers
28
- validators.isArbitraryNumber,
29
- ],
30
- density: ['density-fine', 'density-coarse'],
31
- 'dx-focus-ring': [
32
- 'dx-focus-ring',
33
- 'dx-focus-ring-inset',
34
- 'dx-focus-ring-always',
35
- 'dx-focus-ring-inset-always',
36
- 'dx-focus-ring-group',
37
- 'dx-focus-ring-group-x',
38
- 'dx-focus-ring-group-y',
39
- 'dx-focus-ring-group-always',
40
- 'dx-focus-ring-group-x-always',
41
- 'dx-focus-ring-group-y-always',
42
- 'dx-focus-ring-inset-over-all',
43
- 'dx-focus-ring-inset-over-all-always',
44
- 'dx-focus-ring-main',
45
- 'dx-focus-ring-main-always',
46
- ],
47
- },
19
+ import { log } from '@dxos/log';
20
+ import { ThemedClassName, type ComposableProps, type SlottableProps } from '@dxos/ui-types';
21
+
22
+ type AdditionalClassGroups = 'density' | 'dx-focus-ring';
23
+
24
+ export const mx = extendTailwindMerge<AdditionalClassGroups>({
25
+ extend: {
26
+ classGroups: {
27
+ 'font-family': ['font-body', 'font-mono'],
28
+ 'font-weight': [
29
+ // App weights
30
+ 'font-thin',
31
+ 'font-extralight',
32
+ 'font-light',
33
+ 'font-normal',
34
+ 'font-medium',
35
+ 'font-semibold',
36
+ 'font-bold',
37
+ 'font-extrabold',
38
+ 'font-black',
39
+ // Arbitrary numbers
40
+ validators.isArbitraryNumber,
41
+ ],
42
+
43
+ density: ['dx-density-fine', 'dx-density-coarse'],
44
+
45
+ 'dx-focus-ring': [
46
+ 'dx-focus-ring',
47
+ 'dx-focus-ring-inset',
48
+ 'dx-focus-ring-always',
49
+ 'dx-focus-ring-inset-always',
50
+ 'dx-focus-ring-group',
51
+ 'dx-focus-ring-group-x',
52
+ 'dx-focus-ring-group-y',
53
+ 'dx-focus-ring-group-always',
54
+ 'dx-focus-ring-group-x-always',
55
+ 'dx-focus-ring-group-y-always',
56
+ 'dx-focus-ring-inset-over-all',
57
+ 'dx-focus-ring-inset-over-all-always',
58
+ 'dx-focus-ring-main',
59
+ 'dx-focus-ring-main-always',
60
+ ],
48
61
  },
49
62
  },
50
- withLogical,
51
- );
63
+ });
64
+
65
+ /**
66
+ * Reconciles className properties from a parent slot.
67
+ * - `className` is set by the Slot merge mechanism.
68
+ * - `classNames` is the consumer-facing prop for theming overrides.
69
+ * Use `composableProps` to reconcile both into a single `className`.
70
+ */
71
+ // TODO(burdon): Move to react-ui.
72
+ export const composableProps = <P extends HTMLElement = HTMLElement>(
73
+ { className, classNames, role, style, ...props }: ComposableProps,
74
+ { classNames: defaultClassNames, ...defaults }: ThemedClassName<Partial<HTMLAttributes<P>>> | undefined = {},
75
+ ) => ({
76
+ // Default props.
77
+ ...(defaults as object),
78
+
79
+ // Spread supplied props.
80
+ ...props,
81
+
82
+ // Prefer explicit role, then defaults role, then 'none'.
83
+ role: role ?? defaults.role ?? 'none',
84
+
85
+ // Merge styles.
86
+ style: { ...defaults.style, ...style } as CSSProperties,
87
+
88
+ // Compose classnames.
89
+ className: mx(defaultClassNames, className, classNames),
90
+ });
91
+
92
+ /** Symbol used to mark components created by `composable()` or `slottable()`. */
93
+ const COMPOSABLE = Symbol.for('dxos.composable');
94
+
95
+ /**
96
+ * Factory for slottable components.
97
+ * The implementation receives full `HTMLAttributes<E>` so it can destructure `role`, `style`, etc.
98
+ * Consumers see only `SlottableProps<P>` — a narrow type exposing `classNames`, `className`,
99
+ * `children`, `asChild`, and the custom props `P`.
100
+ *
101
+ * @example
102
+ * ```tsx
103
+ * const MyPanel = slottable<HTMLDivElement, { border?: boolean }>(
104
+ * ({ children, asChild, border, ...props }, forwardedRef) => {
105
+ * const Comp = asChild ? Slot : Primitive.div;
106
+ * return (
107
+ * <Comp {...composableProps(props, { classNames: border && 'border' })} ref={forwardedRef}>
108
+ * {children}
109
+ * </Comp>
110
+ * );
111
+ * },
112
+ * );
113
+ * ```
114
+ */
115
+ export function slottable<E extends HTMLElement, P extends object = {}>(
116
+ render: (props: SlottableProps<P> & HTMLAttributes<E>, forwardedRef: ForwardedRef<E>) => ReactNode,
117
+ ): ForwardRefExoticComponent<SlottableProps<P> & RefAttributes<E>> {
118
+ const wrapped = (props: SlottableProps<P> & HTMLAttributes<E>, forwardedRef: ForwardedRef<E>) => {
119
+ let warn = false;
120
+ if (props.asChild) {
121
+ try {
122
+ const child = Children.only(props.children);
123
+ if (isValidElement(child) && typeof child.type !== 'string' && !(child.type as any)[COMPOSABLE]) {
124
+ warn = true;
125
+ log.warn('slot child is not composable; create it with composable() or slottable()', {
126
+ child: (child.type as any).displayName ?? (child.type as any).name,
127
+ });
128
+ }
129
+ } catch {
130
+ // Children.only throws if not exactly one child — Slot handles this.
131
+ }
132
+ }
133
+
134
+ const result = render(props, forwardedRef);
135
+ if (warn) {
136
+ return createElement('div', { role: 'none', className: 'dx-slot-warning' }, result);
137
+ }
138
+
139
+ return result;
140
+ };
141
+
142
+ const component = forwardRef(wrapped as any) as any;
143
+ (component as any)[COMPOSABLE] = true;
144
+ return component;
145
+ }
146
+
147
+ /**
148
+ * Factory for composable (leaf) components.
149
+ * The implementation receives full `HTMLAttributes<E>` so it can destructure `role`, `style`, etc.
150
+ * Consumers see only `ComposableProps<P>` — a narrow type exposing `classNames`, `className`,
151
+ * `children`, and the custom props `P`.
152
+ *
153
+ * For generic components, use `any` for the type parameter inside `composable` and
154
+ * cast the result to restore the generic signature for consumers.
155
+ *
156
+ * @example
157
+ * ```tsx
158
+ * const Leaf = composable<HTMLButtonElement>(({ children, ...props }, forwardedRef) => {
159
+ * return (
160
+ * <button {...composableProps(props, { classNames: 'btn' })} ref={forwardedRef}>
161
+ * {children}
162
+ * </button>
163
+ * );
164
+ * });
165
+ * ```
166
+ */
167
+ export function composable<E extends HTMLElement, P extends object = {}>(
168
+ render: (props: ComposableProps<P> & HTMLAttributes<E>, forwardedRef: ForwardedRef<E>) => ReactNode,
169
+ ): ForwardRefExoticComponent<ComposableProps<P> & RefAttributes<E>> {
170
+ const component = forwardRef(render as any) as any;
171
+ (component as any)[COMPOSABLE] = true;
172
+ return component;
173
+ }
@@ -0,0 +1,103 @@
1
+ //
2
+ // Copyright 2022 DXOS.org
3
+ //
4
+
5
+ import { type CSSProperties } from 'react';
6
+
7
+ import { type Size } from '@dxos/ui-types';
8
+
9
+ import { mx } from '../util';
10
+
11
+ // NOTE: Class names must be fully-specified string literals so Tailwind's static scanner can detect them.
12
+ const sizeMap: Record<string, { w: string; h: string }> = {
13
+ 0: { w: 'w-0', h: 'h-0' },
14
+ px: { w: 'w-px', h: 'h-px' },
15
+ 0.5: { w: 'w-0.5', h: 'h-0.5' },
16
+ 1: { w: 'w-1', h: 'h-1' },
17
+ 1.5: { w: 'w-1.5', h: 'h-1.5' },
18
+ 2: { w: 'w-2', h: 'h-2' },
19
+ 2.5: { w: 'w-2.5', h: 'h-2.5' },
20
+ 3: { w: 'w-3', h: 'h-3' },
21
+ 3.5: { w: 'w-3.5', h: 'h-3.5' },
22
+ 4: { w: 'w-4', h: 'h-4' },
23
+ 5: { w: 'w-5', h: 'h-5' },
24
+ 6: { w: 'w-6', h: 'h-6' },
25
+ 7: { w: 'w-7', h: 'h-7' },
26
+ 8: { w: 'w-8', h: 'h-8' },
27
+ 9: { w: 'w-9', h: 'h-9' },
28
+ 10: { w: 'w-10', h: 'h-10' },
29
+ 11: { w: 'w-11', h: 'h-11' },
30
+ 12: { w: 'w-12', h: 'h-12' },
31
+ 14: { w: 'w-14', h: 'h-14' },
32
+ 16: { w: 'w-16', h: 'h-16' },
33
+ 20: { w: 'w-20', h: 'h-20' },
34
+ 24: { w: 'w-24', h: 'h-24' },
35
+ 28: { w: 'w-28', h: 'h-28' },
36
+ 32: { w: 'w-32', h: 'h-32' },
37
+ 36: { w: 'w-36', h: 'h-36' },
38
+ 40: { w: 'w-40', h: 'h-40' },
39
+ 44: { w: 'w-44', h: 'h-44' },
40
+ 48: { w: 'w-48', h: 'h-48' },
41
+ 52: { w: 'w-52', h: 'h-52' },
42
+ 56: { w: 'w-56', h: 'h-56' },
43
+ 60: { w: 'w-60', h: 'h-60' },
44
+ 64: { w: 'w-64', h: 'h-64' },
45
+ 72: { w: 'w-72', h: 'h-72' },
46
+ 80: { w: 'w-80', h: 'h-80' },
47
+ 96: { w: 'w-96', h: 'h-96' },
48
+ };
49
+
50
+ const SIZE_VALUES: Size[] = Object.keys(sizeMap).map((key) => (key === 'px' ? 'px' : (Number(key) as Size)));
51
+
52
+ export const getHeight = (size: Size) => sizeMap[size]?.h;
53
+ export const getWidth = (size: Size) => sizeMap[size]?.w;
54
+ export const getSize = (size: Size) => mx(getHeight(size), getWidth(size));
55
+
56
+ export const sizeValue = (size: Size): number => (size === 'px' ? 1 : size);
57
+ export const sizeToRem = (size: Size): string => (size === 'px' ? '1px' : `${(size as number) * 0.25}rem`);
58
+
59
+ export const iconSize = (size: Size | null): CSSProperties =>
60
+ ({ '--icon-size': size ? sizeToRem(size) : 'initial' }) as CSSProperties;
61
+
62
+ /**
63
+ * Snaps an arbitrary numeric value to the nearest valid Tailwind size token.
64
+ *
65
+ * The function tries progressively coarser series in order until a match is found:
66
+ * 1. Exact match — returns the value as-is if it is already a valid `Size`.
67
+ * 2. Zero or negative — clamps to `0`.
68
+ * 3. Sub-half values (`< 0.5`) — maps to the `'px'` token (1 px).
69
+ * 4. Half-step series (0.5 increments, e.g. 1.5, 2.5 …).
70
+ * 5. Whole-number series (1, 2, 3 …).
71
+ * 6. Double series (even numbers: 2, 4, 6 …).
72
+ * 7. Quadruple series (multiples of 4: 4, 8, 12 …).
73
+ * 8. Falls back to `defaultSize` if no series matches.
74
+ *
75
+ * @param value - Numeric size to snap (in Tailwind spacing units, where 1 unit = 0.25 rem).
76
+ * @param defaultSize - Fallback `Size` token used when no series produces a valid match.
77
+ * @returns The nearest valid `Size` token.
78
+ */
79
+ export const snapSize = (value: number, defaultSize: Size): Size => {
80
+ if (SIZE_VALUES.includes(value as Size)) {
81
+ return value as Size;
82
+ } else if (value <= 0) {
83
+ return 0;
84
+ } else if (value < 0.5) {
85
+ return 'px';
86
+ } else {
87
+ const wholeSeries = Math.floor(value);
88
+ const halfSeries = Math.floor(value * 2) / 2;
89
+ const doubleSeries = Math.floor(value / 2) * 2;
90
+ const quadrupleSeries = Math.floor(value / 4) * 4;
91
+ if (SIZE_VALUES.includes(halfSeries as Size)) {
92
+ return halfSeries as Size;
93
+ } else if (SIZE_VALUES.includes(wholeSeries as Size)) {
94
+ return wholeSeries as Size;
95
+ } else if (SIZE_VALUES.includes(doubleSeries as Size)) {
96
+ return doubleSeries as Size;
97
+ } else if (SIZE_VALUES.includes(quadrupleSeries as Size)) {
98
+ return quadrupleSeries as Size;
99
+ } else {
100
+ return defaultSize;
101
+ }
102
+ }
103
+ };
@@ -0,0 +1,33 @@
1
+ //
2
+ // Copyright 2022 DXOS.org
3
+ //
4
+
5
+ import { type MessageValence } from '@dxos/ui-types';
6
+
7
+ export const textValence = (valence?: MessageValence) => {
8
+ switch (valence) {
9
+ case 'success':
10
+ return 'font-medium text-success-text';
11
+ case 'info':
12
+ return 'font-medium text-info-text';
13
+ case 'warning':
14
+ return 'font-medium text-warning-text';
15
+ case 'error':
16
+ return 'font-medium text-error-text';
17
+ }
18
+ };
19
+
20
+ export const messageValence = (valence?: MessageValence) => {
21
+ switch (valence) {
22
+ case 'success':
23
+ return 'font-medium text-success-text border-success-text bg-success-surface';
24
+ case 'info':
25
+ return 'font-medium text-info-text border-info-text bg-info-surface';
26
+ case 'warning':
27
+ return 'font-medium text-warning-text border-warning-text bg-warning-surface';
28
+ case 'error':
29
+ return 'font-medium text-error-text border-error-text bg-error-surface';
30
+ default:
31
+ return 'font-medium text-neutral-text border-neutral-text bg-neutral-surface';
32
+ }
33
+ };