@hanzogui/themes 2.0.0

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 (324) hide show
  1. package/LICENSE +21 -0
  2. package/dist/cjs/componentThemeDefinitions.cjs +124 -0
  3. package/dist/cjs/componentThemeDefinitions.native.js +127 -0
  4. package/dist/cjs/componentThemeDefinitions.native.js.map +1 -0
  5. package/dist/cjs/generated-new.cjs +2021 -0
  6. package/dist/cjs/generated-new.native.js +2040 -0
  7. package/dist/cjs/generated-new.native.js.map +1 -0
  8. package/dist/cjs/generated-v3.cjs +1099 -0
  9. package/dist/cjs/generated-v3.native.js +1118 -0
  10. package/dist/cjs/generated-v3.native.js.map +1 -0
  11. package/dist/cjs/generated-v4-gui.cjs +933 -0
  12. package/dist/cjs/generated-v4-gui.native.js +952 -0
  13. package/dist/cjs/generated-v4-gui.native.js.map +1 -0
  14. package/dist/cjs/generated-v4.cjs +391 -0
  15. package/dist/cjs/generated-v4.native.js +410 -0
  16. package/dist/cjs/generated-v4.native.js.map +1 -0
  17. package/dist/cjs/generated-v5-subtle.cjs +549 -0
  18. package/dist/cjs/generated-v5-subtle.native.js +568 -0
  19. package/dist/cjs/generated-v5-subtle.native.js.map +1 -0
  20. package/dist/cjs/generated-v5.cjs +549 -0
  21. package/dist/cjs/generated-v5.native.js +568 -0
  22. package/dist/cjs/generated-v5.native.js.map +1 -0
  23. package/dist/cjs/helpers.cjs +34 -0
  24. package/dist/cjs/helpers.native.js +39 -0
  25. package/dist/cjs/helpers.native.js.map +1 -0
  26. package/dist/cjs/index.cjs +25 -0
  27. package/dist/cjs/index.native.js +28 -0
  28. package/dist/cjs/index.native.js.map +1 -0
  29. package/dist/cjs/opacify.cjs +96 -0
  30. package/dist/cjs/opacify.native.js +106 -0
  31. package/dist/cjs/opacify.native.js.map +1 -0
  32. package/dist/cjs/palettes.cjs +52 -0
  33. package/dist/cjs/palettes.native.js +63 -0
  34. package/dist/cjs/palettes.native.js.map +1 -0
  35. package/dist/cjs/shadows.cjs +43 -0
  36. package/dist/cjs/shadows.native.js +46 -0
  37. package/dist/cjs/shadows.native.js.map +1 -0
  38. package/dist/cjs/subtleChildrenThemes.cjs +65 -0
  39. package/dist/cjs/subtleChildrenThemes.native.js +74 -0
  40. package/dist/cjs/subtleChildrenThemes.native.js.map +1 -0
  41. package/dist/cjs/templates.cjs +118 -0
  42. package/dist/cjs/templates.native.js +121 -0
  43. package/dist/cjs/templates.native.js.map +1 -0
  44. package/dist/cjs/themes-new.cjs +86 -0
  45. package/dist/cjs/themes-new.native.js +88 -0
  46. package/dist/cjs/themes-new.native.js.map +1 -0
  47. package/dist/cjs/themes-old.cjs +284 -0
  48. package/dist/cjs/themes-old.native.js +303 -0
  49. package/dist/cjs/themes-old.native.js.map +1 -0
  50. package/dist/cjs/themes.cjs +26 -0
  51. package/dist/cjs/themes.native.js +29 -0
  52. package/dist/cjs/themes.native.js.map +1 -0
  53. package/dist/cjs/tokens.cjs +155 -0
  54. package/dist/cjs/tokens.native.js +167 -0
  55. package/dist/cjs/tokens.native.js.map +1 -0
  56. package/dist/cjs/utils.cjs +40 -0
  57. package/dist/cjs/utils.native.js +46 -0
  58. package/dist/cjs/utils.native.js.map +1 -0
  59. package/dist/cjs/v3-themes.cjs +472 -0
  60. package/dist/cjs/v3-themes.native.js +487 -0
  61. package/dist/cjs/v3-themes.native.js.map +1 -0
  62. package/dist/cjs/v3-tokens.cjs +99 -0
  63. package/dist/cjs/v3-tokens.native.js +108 -0
  64. package/dist/cjs/v3-tokens.native.js.map +1 -0
  65. package/dist/cjs/v3.cjs +52 -0
  66. package/dist/cjs/v3.native.js +55 -0
  67. package/dist/cjs/v3.native.js.map +1 -0
  68. package/dist/cjs/v4-default.cjs +167 -0
  69. package/dist/cjs/v4-default.native.js +170 -0
  70. package/dist/cjs/v4-default.native.js.map +1 -0
  71. package/dist/cjs/v4-gui.cjs +235 -0
  72. package/dist/cjs/v4-gui.native.js +243 -0
  73. package/dist/cjs/v4-gui.native.js.map +1 -0
  74. package/dist/cjs/v4-tokens.cjs +99 -0
  75. package/dist/cjs/v4-tokens.native.js +108 -0
  76. package/dist/cjs/v4-tokens.native.js.map +1 -0
  77. package/dist/cjs/v4.cjs +32 -0
  78. package/dist/cjs/v4.native.js +35 -0
  79. package/dist/cjs/v4.native.js.map +1 -0
  80. package/dist/cjs/v5-subtle.cjs +34 -0
  81. package/dist/cjs/v5-subtle.native.js +37 -0
  82. package/dist/cjs/v5-subtle.native.js.map +1 -0
  83. package/dist/cjs/v5-templates.cjs +110 -0
  84. package/dist/cjs/v5-templates.native.js +126 -0
  85. package/dist/cjs/v5-templates.native.js.map +1 -0
  86. package/dist/cjs/v5-themes-subtle.cjs +37 -0
  87. package/dist/cjs/v5-themes-subtle.native.js +40 -0
  88. package/dist/cjs/v5-themes-subtle.native.js.map +1 -0
  89. package/dist/cjs/v5-themes.cjs +400 -0
  90. package/dist/cjs/v5-themes.native.js +445 -0
  91. package/dist/cjs/v5-themes.native.js.map +1 -0
  92. package/dist/cjs/v5-tokens.cjs +99 -0
  93. package/dist/cjs/v5-tokens.native.js +108 -0
  94. package/dist/cjs/v5-tokens.native.js.map +1 -0
  95. package/dist/cjs/v5.cjs +34 -0
  96. package/dist/cjs/v5.native.js +37 -0
  97. package/dist/cjs/v5.native.js.map +1 -0
  98. package/dist/esm/componentThemeDefinitions.mjs +100 -0
  99. package/dist/esm/componentThemeDefinitions.mjs.map +1 -0
  100. package/dist/esm/componentThemeDefinitions.native.js +100 -0
  101. package/dist/esm/componentThemeDefinitions.native.js.map +1 -0
  102. package/dist/esm/generated-new.mjs +1997 -0
  103. package/dist/esm/generated-new.mjs.map +1 -0
  104. package/dist/esm/generated-new.native.js +2013 -0
  105. package/dist/esm/generated-new.native.js.map +1 -0
  106. package/dist/esm/generated-v3.mjs +1075 -0
  107. package/dist/esm/generated-v3.mjs.map +1 -0
  108. package/dist/esm/generated-v3.native.js +1091 -0
  109. package/dist/esm/generated-v3.native.js.map +1 -0
  110. package/dist/esm/generated-v4-gui.mjs +909 -0
  111. package/dist/esm/generated-v4-gui.mjs.map +1 -0
  112. package/dist/esm/generated-v4-gui.native.js +925 -0
  113. package/dist/esm/generated-v4-gui.native.js.map +1 -0
  114. package/dist/esm/generated-v4.mjs +367 -0
  115. package/dist/esm/generated-v4.mjs.map +1 -0
  116. package/dist/esm/generated-v4.native.js +383 -0
  117. package/dist/esm/generated-v4.native.js.map +1 -0
  118. package/dist/esm/generated-v5-subtle.mjs +525 -0
  119. package/dist/esm/generated-v5-subtle.mjs.map +1 -0
  120. package/dist/esm/generated-v5-subtle.native.js +541 -0
  121. package/dist/esm/generated-v5-subtle.native.js.map +1 -0
  122. package/dist/esm/generated-v5.mjs +525 -0
  123. package/dist/esm/generated-v5.mjs.map +1 -0
  124. package/dist/esm/generated-v5.native.js +541 -0
  125. package/dist/esm/generated-v5.native.js.map +1 -0
  126. package/dist/esm/helpers.mjs +9 -0
  127. package/dist/esm/helpers.mjs.map +1 -0
  128. package/dist/esm/helpers.native.js +11 -0
  129. package/dist/esm/helpers.native.js.map +1 -0
  130. package/dist/esm/index.js +9 -0
  131. package/dist/esm/index.js.map +1 -0
  132. package/dist/esm/index.mjs +9 -0
  133. package/dist/esm/index.mjs.map +1 -0
  134. package/dist/esm/index.native.js +9 -0
  135. package/dist/esm/index.native.js.map +1 -0
  136. package/dist/esm/opacify.mjs +72 -0
  137. package/dist/esm/opacify.mjs.map +1 -0
  138. package/dist/esm/opacify.native.js +79 -0
  139. package/dist/esm/opacify.native.js.map +1 -0
  140. package/dist/esm/palettes.mjs +29 -0
  141. package/dist/esm/palettes.mjs.map +1 -0
  142. package/dist/esm/palettes.native.js +37 -0
  143. package/dist/esm/palettes.native.js.map +1 -0
  144. package/dist/esm/shadows.mjs +20 -0
  145. package/dist/esm/shadows.mjs.map +1 -0
  146. package/dist/esm/shadows.native.js +20 -0
  147. package/dist/esm/shadows.native.js.map +1 -0
  148. package/dist/esm/subtleChildrenThemes.mjs +41 -0
  149. package/dist/esm/subtleChildrenThemes.mjs.map +1 -0
  150. package/dist/esm/subtleChildrenThemes.native.js +47 -0
  151. package/dist/esm/subtleChildrenThemes.native.js.map +1 -0
  152. package/dist/esm/templates.mjs +94 -0
  153. package/dist/esm/templates.mjs.map +1 -0
  154. package/dist/esm/templates.native.js +94 -0
  155. package/dist/esm/templates.native.js.map +1 -0
  156. package/dist/esm/themes-new.mjs +63 -0
  157. package/dist/esm/themes-new.mjs.map +1 -0
  158. package/dist/esm/themes-new.native.js +62 -0
  159. package/dist/esm/themes-new.native.js.map +1 -0
  160. package/dist/esm/themes-old.mjs +261 -0
  161. package/dist/esm/themes-old.mjs.map +1 -0
  162. package/dist/esm/themes-old.native.js +277 -0
  163. package/dist/esm/themes-old.native.js.map +1 -0
  164. package/dist/esm/themes.mjs +3 -0
  165. package/dist/esm/themes.mjs.map +1 -0
  166. package/dist/esm/themes.native.js +3 -0
  167. package/dist/esm/themes.native.js.map +1 -0
  168. package/dist/esm/tokens.mjs +124 -0
  169. package/dist/esm/tokens.mjs.map +1 -0
  170. package/dist/esm/tokens.native.js +133 -0
  171. package/dist/esm/tokens.native.js.map +1 -0
  172. package/dist/esm/utils.mjs +14 -0
  173. package/dist/esm/utils.mjs.map +1 -0
  174. package/dist/esm/utils.native.js +17 -0
  175. package/dist/esm/utils.native.js.map +1 -0
  176. package/dist/esm/v3-themes.mjs +444 -0
  177. package/dist/esm/v3-themes.mjs.map +1 -0
  178. package/dist/esm/v3-themes.native.js +456 -0
  179. package/dist/esm/v3-themes.native.js.map +1 -0
  180. package/dist/esm/v3-tokens.mjs +70 -0
  181. package/dist/esm/v3-tokens.mjs.map +1 -0
  182. package/dist/esm/v3-tokens.native.js +76 -0
  183. package/dist/esm/v3-tokens.native.js.map +1 -0
  184. package/dist/esm/v3.mjs +12 -0
  185. package/dist/esm/v3.mjs.map +1 -0
  186. package/dist/esm/v3.native.js +12 -0
  187. package/dist/esm/v3.native.js.map +1 -0
  188. package/dist/esm/v4-default.mjs +133 -0
  189. package/dist/esm/v4-default.mjs.map +1 -0
  190. package/dist/esm/v4-default.native.js +133 -0
  191. package/dist/esm/v4-default.native.js.map +1 -0
  192. package/dist/esm/v4-gui.mjs +201 -0
  193. package/dist/esm/v4-gui.mjs.map +1 -0
  194. package/dist/esm/v4-gui.native.js +206 -0
  195. package/dist/esm/v4-gui.native.js.map +1 -0
  196. package/dist/esm/v4-tokens.mjs +70 -0
  197. package/dist/esm/v4-tokens.mjs.map +1 -0
  198. package/dist/esm/v4-tokens.native.js +76 -0
  199. package/dist/esm/v4-tokens.native.js.map +1 -0
  200. package/dist/esm/v4.mjs +6 -0
  201. package/dist/esm/v4.mjs.map +1 -0
  202. package/dist/esm/v4.native.js +6 -0
  203. package/dist/esm/v4.native.js.map +1 -0
  204. package/dist/esm/v5-subtle.mjs +7 -0
  205. package/dist/esm/v5-subtle.mjs.map +1 -0
  206. package/dist/esm/v5-subtle.native.js +7 -0
  207. package/dist/esm/v5-subtle.native.js.map +1 -0
  208. package/dist/esm/v5-templates.mjs +87 -0
  209. package/dist/esm/v5-templates.mjs.map +1 -0
  210. package/dist/esm/v5-templates.native.js +100 -0
  211. package/dist/esm/v5-templates.native.js.map +1 -0
  212. package/dist/esm/v5-themes-subtle.mjs +13 -0
  213. package/dist/esm/v5-themes-subtle.mjs.map +1 -0
  214. package/dist/esm/v5-themes-subtle.native.js +13 -0
  215. package/dist/esm/v5-themes-subtle.native.js.map +1 -0
  216. package/dist/esm/v5-themes.mjs +361 -0
  217. package/dist/esm/v5-themes.mjs.map +1 -0
  218. package/dist/esm/v5-themes.native.js +403 -0
  219. package/dist/esm/v5-themes.native.js.map +1 -0
  220. package/dist/esm/v5-tokens.mjs +70 -0
  221. package/dist/esm/v5-tokens.mjs.map +1 -0
  222. package/dist/esm/v5-tokens.native.js +76 -0
  223. package/dist/esm/v5-tokens.native.js.map +1 -0
  224. package/dist/esm/v5.mjs +7 -0
  225. package/dist/esm/v5.mjs.map +1 -0
  226. package/dist/esm/v5.native.js +7 -0
  227. package/dist/esm/v5.native.js.map +1 -0
  228. package/package.json +95 -0
  229. package/src/componentThemeDefinitions.tsx +129 -0
  230. package/src/generated-new.ts +2571 -0
  231. package/src/generated-v3.ts +1826 -0
  232. package/src/generated-v4-gui.ts +2200 -0
  233. package/src/generated-v4.ts +1004 -0
  234. package/src/generated-v5-subtle.ts +2170 -0
  235. package/src/generated-v5.ts +2188 -0
  236. package/src/helpers.ts +44 -0
  237. package/src/index.tsx +8 -0
  238. package/src/opacify.ts +125 -0
  239. package/src/palettes.tsx +91 -0
  240. package/src/shadows.tsx +19 -0
  241. package/src/subtleChildrenThemes.ts +54 -0
  242. package/src/templates.tsx +104 -0
  243. package/src/themes-new.ts +74 -0
  244. package/src/themes-old.tsx +378 -0
  245. package/src/themes.tsx +1 -0
  246. package/src/tokens.tsx +199 -0
  247. package/src/utils.ts +51 -0
  248. package/src/v3-themes.ts +650 -0
  249. package/src/v3-tokens.ts +103 -0
  250. package/src/v3.tsx +12 -0
  251. package/src/v4-default.ts +191 -0
  252. package/src/v4-gui.ts +287 -0
  253. package/src/v4-tokens.ts +105 -0
  254. package/src/v4.tsx +4 -0
  255. package/src/v5-subtle.tsx +11 -0
  256. package/src/v5-templates.ts +126 -0
  257. package/src/v5-themes-subtle.ts +18 -0
  258. package/src/v5-themes.ts +626 -0
  259. package/src/v5-tokens.ts +107 -0
  260. package/src/v5.tsx +11 -0
  261. package/tests/v5-themes.test.ts +215 -0
  262. package/tsconfig.json +43 -0
  263. package/types/componentThemeDefinitions.d.ts +771 -0
  264. package/types/generated-new.d.ts +135 -0
  265. package/types/generated-v3.d.ts +144 -0
  266. package/types/generated-v4-gui.d.ts +190 -0
  267. package/types/generated-v4.d.ts +137 -0
  268. package/types/generated-v5-subtle.d.ts +244 -0
  269. package/types/generated-v5.d.ts +244 -0
  270. package/types/helpers.d.ts +24 -0
  271. package/types/index.d.ts +9 -0
  272. package/types/opacify.d.ts +9 -0
  273. package/types/palettes.d.ts +21 -0
  274. package/types/shadows.d.ts +15 -0
  275. package/types/subtleChildrenThemes.d.ts +305 -0
  276. package/types/templates.d.ts +155 -0
  277. package/types/themes-new.d.ts +42243 -0
  278. package/types/themes-old.d.ts +51411 -0
  279. package/types/themes.d.ts +2 -0
  280. package/types/tokens.d.ts +1308 -0
  281. package/types/utils.d.ts +21 -0
  282. package/types/v3-themes.d.ts +16304 -0
  283. package/types/v3-tokens.d.ts +184 -0
  284. package/types/v3.d.ts +11 -0
  285. package/types/v4-default.d.ts +274 -0
  286. package/types/v4-gui.d.ts +195 -0
  287. package/types/v4-tokens.d.ts +184 -0
  288. package/types/v4.d.ts +5 -0
  289. package/types/v5-subtle.d.ts +8 -0
  290. package/types/v5-templates.d.ts +42 -0
  291. package/types/v5-themes-subtle.d.ts +250 -0
  292. package/types/v5-themes.d.ts +752 -0
  293. package/types/v5-tokens.d.ts +185 -0
  294. package/types/v5.d.ts +8 -0
  295. package/v3/index.cjs +2 -0
  296. package/v3/index.js +2 -0
  297. package/v3/index.native.cjs +2 -0
  298. package/v3/index.native.js +2 -0
  299. package/v3-themes/index.cjs +2 -0
  300. package/v3-themes/index.js +2 -0
  301. package/v3-themes/index.native.cjs +2 -0
  302. package/v3-themes/index.native.js +2 -0
  303. package/v3-themes.cjs +1 -0
  304. package/v3-themes.d.ts +1 -0
  305. package/v3.cjs +1 -0
  306. package/v3.d.ts +1 -0
  307. package/v4/index.cjs +2 -0
  308. package/v4/index.js +2 -0
  309. package/v4/index.native.cjs +2 -0
  310. package/v4/index.native.js +2 -0
  311. package/v4.cjs +1 -0
  312. package/v4.d.ts +1 -0
  313. package/v5/index.cjs +2 -0
  314. package/v5/index.js +2 -0
  315. package/v5/index.native.cjs +2 -0
  316. package/v5/index.native.js +2 -0
  317. package/v5-subtle/index.cjs +2 -0
  318. package/v5-subtle/index.js +2 -0
  319. package/v5-subtle/index.native.cjs +2 -0
  320. package/v5-subtle/index.native.js +2 -0
  321. package/v5-subtle.cjs +1 -0
  322. package/v5-subtle.d.ts +1 -0
  323. package/v5.cjs +1 -0
  324. package/v5.d.ts +1 -0
@@ -0,0 +1,400 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
3
+ var __getOwnPropNames = Object.getOwnPropertyNames;
4
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
5
+ var __export = (target, all) => {
6
+ for (var name in all) __defProp(target, name, {
7
+ get: all[name],
8
+ enumerable: !0
9
+ });
10
+ },
11
+ __copyProps = (to, from, except, desc) => {
12
+ if (from && typeof from == "object" || typeof from == "function") for (let key of __getOwnPropNames(from)) !__hasOwnProp.call(to, key) && key !== except && __defProp(to, key, {
13
+ get: () => from[key],
14
+ enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable
15
+ });
16
+ return to;
17
+ };
18
+ var __toCommonJS = mod => __copyProps(__defProp({}, "__esModule", {
19
+ value: !0
20
+ }), mod);
21
+ var v5_themes_exports = {};
22
+ __export(v5_themes_exports, {
23
+ V5_BG_OFFSET: () => V5_BG_OFFSET,
24
+ adjustPalette: () => adjustPalette,
25
+ adjustPalettes: () => adjustPalettes,
26
+ createV5Theme: () => createV5Theme,
27
+ defaultChildrenThemes: () => defaultChildrenThemes,
28
+ defaultDarkPalette: () => darkPalette,
29
+ defaultLightPalette: () => lightPalette,
30
+ hslToString: () => hslToString,
31
+ interpolateColor: () => import_opacify2.interpolateColor,
32
+ opacify: () => import_opacify2.opacify,
33
+ parseColor: () => parseColor,
34
+ parseHSL: () => parseHSL,
35
+ parseHex: () => parseHex,
36
+ themes: () => themes,
37
+ v5ComponentThemes: () => v5ComponentThemes,
38
+ v5ComponentThemesWithInverses: () => v5ComponentThemesWithInverses,
39
+ v5GrandchildrenThemes: () => v5GrandchildrenThemes
40
+ });
41
+ module.exports = __toCommonJS(v5_themes_exports);
42
+ var import_colors = require("@hanzogui/colors"),
43
+ import_theme_builder = require("@hanzogui/theme-builder"),
44
+ import_opacify = require("./opacify.cjs"),
45
+ import_v5_templates = require("./v5-templates.cjs"),
46
+ import_opacify2 = require("./opacify.cjs");
47
+ const V5_BG_OFFSET = 7,
48
+ v5ComponentThemes = {
49
+ Button: {
50
+ template: "surface2"
51
+ },
52
+ Input: {
53
+ template: "surface1"
54
+ },
55
+ Progress: {
56
+ template: "surface1"
57
+ },
58
+ ProgressIndicator: {
59
+ template: "surface3"
60
+ },
61
+ Slider: {
62
+ template: "surface1"
63
+ },
64
+ SliderActive: {
65
+ template: "surface3"
66
+ },
67
+ SliderThumb: {
68
+ template: "surface2"
69
+ },
70
+ Switch: {
71
+ template: "surface2"
72
+ },
73
+ TextArea: {
74
+ template: "surface1"
75
+ },
76
+ Tooltip: {
77
+ template: "accent"
78
+ },
79
+ SwitchThumb: {
80
+ template: "accent"
81
+ }
82
+ },
83
+ v5ComponentThemesWithInverses = {
84
+ ...v5ComponentThemes,
85
+ ProgressIndicator: {
86
+ template: "accent"
87
+ },
88
+ SliderThumb: {
89
+ template: "accent"
90
+ },
91
+ Tooltip: {
92
+ template: "accent"
93
+ }
94
+ },
95
+ v5GrandchildrenThemes = {
96
+ accent: {
97
+ template: "accent"
98
+ },
99
+ surface1: {
100
+ template: "surface1"
101
+ },
102
+ surface2: {
103
+ template: "surface2"
104
+ }
105
+ };
106
+ function parseHSL(str) {
107
+ const m = str.match(/hsl\((\d+(?:\.\d+)?),\s*(\d+(?:\.\d+)?)%,\s*(\d+(?:\.\d+)?)%\)/);
108
+ return m ? {
109
+ h: +m[1],
110
+ s: +m[2],
111
+ l: +m[3]
112
+ } : null;
113
+ }
114
+ function parseHex(str) {
115
+ if (!str.startsWith("#")) return null;
116
+ let hex = str.slice(1);
117
+ if (hex.length === 3 && (hex = hex.split("").map(c => c + c).join("")), hex.length !== 6) return null;
118
+ const r = Number.parseInt(hex.slice(0, 2), 16) / 255,
119
+ g = Number.parseInt(hex.slice(2, 4), 16) / 255,
120
+ b = Number.parseInt(hex.slice(4, 6), 16) / 255,
121
+ max = Math.max(r, g, b),
122
+ min = Math.min(r, g, b),
123
+ l = (max + min) / 2;
124
+ if (max === min) return {
125
+ h: 0,
126
+ s: 0,
127
+ l: l * 100
128
+ };
129
+ const d = max - min,
130
+ s = l > 0.5 ? d / (2 - max - min) : d / (max + min);
131
+ let h = 0;
132
+ return max === r ? h = ((g - b) / d + (g < b ? 6 : 0)) / 6 : max === g ? h = ((b - r) / d + 2) / 6 : h = ((r - g) / d + 4) / 6, {
133
+ h: Math.round(h * 360),
134
+ s: s * 100,
135
+ l: l * 100
136
+ };
137
+ }
138
+ function parseColor(str) {
139
+ return parseHSL(str) ?? parseHex(str);
140
+ }
141
+ function hslToString(hsl) {
142
+ return `hsl(${hsl.h}, ${Math.round(Math.min(100, Math.max(0, hsl.s)))}%, ${Math.round(Math.min(100, Math.max(0, hsl.l)))}%)`;
143
+ }
144
+ function adjustPalette(palette, fn) {
145
+ const out = {},
146
+ keys = Object.keys(palette);
147
+ for (let i = 0; i < keys.length; i++) {
148
+ const key = keys[i],
149
+ parsed = parseColor(palette[key]);
150
+ if (!parsed) {
151
+ out[key] = palette[key];
152
+ continue;
153
+ }
154
+ out[key] = hslToString(fn(parsed, i + 1));
155
+ }
156
+ return out;
157
+ }
158
+ const identity = hsl => hsl;
159
+ function adjustPalettes(themes2, adjustments) {
160
+ const result = {};
161
+ for (const [name, theme] of Object.entries(themes2)) {
162
+ const adj = adjustments[name] ?? adjustments.default;
163
+ if (!adj) {
164
+ result[name] = theme;
165
+ continue;
166
+ }
167
+ result[name] = {
168
+ light: adjustPalette(theme.light, adj.light ?? identity),
169
+ dark: adjustPalette(theme.dark, adj.dark ?? identity)
170
+ };
171
+ }
172
+ return result;
173
+ }
174
+ function paletteToNamedColors(name, palette) {
175
+ return Object.fromEntries(palette.map((color, i) => [`${name}${i + 1}`, color]));
176
+ }
177
+ const darkPalette = ["#090909", "#151515", "#191919", "#232323", "#333", "#444", "#666", "#777", "#858585", "#aaa", "#ccc", "#ffffff"],
178
+ lightPalette = ["#fff", "#f8f8f8", "hsl(0, 0%, 93%)", "hsl(0, 0%, 85%)", "hsl(0, 0%, 80%)", "hsl(0, 0%, 70%)", "hsl(0, 0%, 59%)", "hsl(0, 0%, 45%)", "hsl(0, 0%, 30%)", "hsl(0, 0%, 20%)", "hsl(0, 0%, 14%)", "hsl(0, 0%, 2%)"],
179
+ neutralPalette = ["hsl(0, 0%, 68%)", "hsl(0, 0%, 65%)", "hsl(0, 0%, 62%)", "hsl(0, 0%, 59%)", "hsl(0, 0%, 56%)", "hsl(0, 0%, 53%)", "hsl(0, 0%, 50%)", "hsl(0, 0%, 47%)", "hsl(0, 0%, 44%)", "hsl(0, 0%, 41%)", "hsl(0, 0%, 38%)", "hsl(0, 0%, 32%)"],
180
+ neutral = paletteToNamedColors("neutral", neutralPalette),
181
+ whiteBlack = {
182
+ white: "rgba(255,255,255,1)",
183
+ white0: "rgba(255,255,255,0)",
184
+ white02: "rgba(255,255,255,0.2)",
185
+ white04: "rgba(255,255,255,0.4)",
186
+ white06: "rgba(255,255,255,0.6)",
187
+ white08: "rgba(255,255,255,0.8)",
188
+ black: "rgba(0,0,0,1)",
189
+ black0: "rgba(0,0,0,0)",
190
+ black02: "rgba(0,0,0,0.2)",
191
+ black04: "rgba(0,0,0,0.4)",
192
+ black06: "rgba(0,0,0,0.6)",
193
+ black08: "rgba(0,0,0,0.8)"
194
+ },
195
+ darkShadows = {
196
+ shadow1: "rgba(0,0,0,0.15)",
197
+ shadow2: "rgba(0,0,0,0.23)",
198
+ shadow3: "rgba(0,0,0,0.33)",
199
+ shadow4: "rgba(0,0,0,0.45)",
200
+ shadow5: "rgba(0,0,0,0.65)",
201
+ shadow6: "rgba(0,0,0,0.8)",
202
+ shadow7: "rgba(0,0,0,0.9)",
203
+ shadow8: "rgba(0,0,0,1)"
204
+ },
205
+ lightShadows = {
206
+ shadow1: "rgba(0,0,0,0.04)",
207
+ shadow2: "rgba(0,0,0,0.08)",
208
+ shadow3: "rgba(0,0,0,0.12)",
209
+ shadow4: "rgba(0,0,0,0.22)",
210
+ shadow5: "rgba(0,0,0,0.33)",
211
+ shadow6: "rgba(0,0,0,0.44)",
212
+ shadow7: "rgba(0,0,0,0.6)",
213
+ shadow8: "rgba(0,0,0,0.75)"
214
+ },
215
+ darkHighlights = {
216
+ highlight1: "rgba(255,255,255,0.1)",
217
+ highlight2: "rgba(255,255,255,0.2)",
218
+ highlight3: "rgba(255,255,255,0.3)",
219
+ highlight4: "rgba(255,255,255,0.45)",
220
+ highlight5: "rgba(255,255,255,0.65)",
221
+ highlight6: "rgba(255,255,255,0.85)",
222
+ highlight7: "rgba(255,255,255,0.95)",
223
+ highlight8: "rgba(255,255,255,1)"
224
+ },
225
+ lightHighlights = {
226
+ highlight1: "rgba(255,255,255,0.05)",
227
+ highlight2: "rgba(255,255,255,0.1)",
228
+ highlight3: "rgba(255,255,255,0.15)",
229
+ highlight4: "rgba(255,255,255,0.3)",
230
+ highlight5: "rgba(255,255,255,0.4)",
231
+ highlight6: "rgba(255,255,255,0.55)",
232
+ highlight7: "rgba(255,255,255,0.7)",
233
+ highlight8: "rgba(255,255,255,0.85)"
234
+ };
235
+ const defaultChildrenThemes = {
236
+ gray: {
237
+ light: import_colors.gray,
238
+ dark: import_colors.grayDark
239
+ },
240
+ blue: {
241
+ light: import_colors.blue,
242
+ dark: import_colors.blueDark
243
+ },
244
+ red: {
245
+ light: import_colors.red,
246
+ dark: import_colors.redDark
247
+ },
248
+ yellow: {
249
+ light: import_colors.yellow,
250
+ dark: import_colors.yellowDark
251
+ },
252
+ green: {
253
+ light: import_colors.green,
254
+ dark: import_colors.greenDark
255
+ },
256
+ orange: {
257
+ light: import_colors.orange,
258
+ dark: import_colors.orangeDark
259
+ },
260
+ pink: {
261
+ light: import_colors.pink,
262
+ dark: import_colors.pinkDark
263
+ },
264
+ purple: {
265
+ light: import_colors.purple,
266
+ dark: import_colors.purpleDark
267
+ },
268
+ teal: {
269
+ light: import_colors.teal,
270
+ dark: import_colors.tealDark
271
+ },
272
+ neutral: {
273
+ light: neutral,
274
+ dark: neutral
275
+ }
276
+ };
277
+ function getDefaultV5ThemeValues({
278
+ palette
279
+ }) {
280
+ if (!palette || palette.length < 3) throw new Error(`invalid palette: ${JSON.stringify(palette)}`);
281
+ const bgColor = palette[V5_BG_OFFSET],
282
+ fgColor = palette[palette.length - 2];
283
+ return {
284
+ color01: (0, import_opacify.opacify)(fgColor, 0.1),
285
+ color0075: (0, import_opacify.opacify)(fgColor, 0.075),
286
+ color005: (0, import_opacify.opacify)(fgColor, 0.05),
287
+ color0025: (0, import_opacify.opacify)(fgColor, 0.025),
288
+ color002: (0, import_opacify.opacify)(fgColor, 0.02),
289
+ color001: (0, import_opacify.opacify)(fgColor, 0.01),
290
+ background01: (0, import_opacify.opacify)(bgColor, 0.1),
291
+ background0075: (0, import_opacify.opacify)(bgColor, 0.075),
292
+ background005: (0, import_opacify.opacify)(bgColor, 0.05),
293
+ background0025: (0, import_opacify.opacify)(bgColor, 0.025),
294
+ background002: (0, import_opacify.opacify)(bgColor, 0.02),
295
+ background001: (0, import_opacify.opacify)(bgColor, 0.01),
296
+ background02: (0, import_opacify.opacify)(bgColor, 0.2),
297
+ background04: (0, import_opacify.opacify)(bgColor, 0.4),
298
+ background06: (0, import_opacify.opacify)(bgColor, 0.6),
299
+ background08: (0, import_opacify.opacify)(bgColor, 0.8),
300
+ outlineColor: (0, import_opacify.opacify)(palette[V5_BG_OFFSET + 4], 0.6)
301
+ };
302
+ }
303
+ function createV5Theme(options = {}) {
304
+ const {
305
+ darkPalette: customDarkPalette = darkPalette,
306
+ lightPalette: customLightPalette = lightPalette,
307
+ accent: customAccent,
308
+ childrenThemes = defaultChildrenThemes,
309
+ grandChildrenThemes = v5GrandchildrenThemes,
310
+ componentThemes: customComponentThemes = v5ComponentThemes,
311
+ getTheme: userGetTheme
312
+ } = options,
313
+ blackColors = paletteToNamedColors("black", customDarkPalette),
314
+ whiteColors = paletteToNamedColors("white", customLightPalette),
315
+ extraBase = {
316
+ ...blackColors,
317
+ ...whiteColors,
318
+ ...whiteBlack
319
+ },
320
+ lightExtraBase = {
321
+ ...extraBase,
322
+ ...lightShadows,
323
+ ...lightHighlights,
324
+ shadowColor: lightShadows.shadow3
325
+ },
326
+ darkExtraBase = {
327
+ ...extraBase,
328
+ ...darkShadows,
329
+ ...darkHighlights,
330
+ shadowColor: darkShadows.shadow3
331
+ },
332
+ lightExtra = {
333
+ ...lightExtraBase
334
+ },
335
+ darkExtra = {
336
+ ...darkExtraBase
337
+ };
338
+ for (const theme of Object.values(childrenThemes)) theme.light && Object.assign(lightExtra, theme.light), theme.dark && Object.assign(darkExtra, theme.dark);
339
+ const childrenWithPalettes = {
340
+ // Always include black/white for theme generation
341
+ black: {
342
+ palette: {
343
+ dark: Object.values(blackColors),
344
+ light: Object.values(blackColors)
345
+ }
346
+ },
347
+ white: {
348
+ palette: {
349
+ dark: Object.values(whiteColors),
350
+ light: Object.values(whiteColors)
351
+ }
352
+ },
353
+ ...Object.fromEntries(Object.entries(childrenThemes).map(([name, theme]) => [name, {
354
+ palette: {
355
+ light: Object.values(theme.light),
356
+ dark: Object.values(theme.dark)
357
+ }
358
+ }]))
359
+ };
360
+ return (0, import_theme_builder.createThemes)({
361
+ // componentThemes: false disables them, undefined/truthy values enable them
362
+ componentThemes: customComponentThemes,
363
+ templates: import_v5_templates.v5Templates,
364
+ base: {
365
+ palette: {
366
+ dark: customDarkPalette,
367
+ light: customLightPalette
368
+ },
369
+ extra: {
370
+ light: lightExtra,
371
+ dark: darkExtra
372
+ }
373
+ },
374
+ accent: {
375
+ palette: customAccent ? {
376
+ light: Object.values(customAccent.light),
377
+ dark: Object.values(customAccent.dark)
378
+ } : {
379
+ dark: customLightPalette,
380
+ light: customDarkPalette
381
+ }
382
+ },
383
+ childrenThemes: childrenWithPalettes,
384
+ grandChildrenThemes,
385
+ getTheme: props => {
386
+ const builtInTheme = getDefaultV5ThemeValues(props),
387
+ customTheme = userGetTheme?.(props);
388
+ return customTheme ? {
389
+ ...builtInTheme,
390
+ ...customTheme
391
+ } : builtInTheme;
392
+ }
393
+ });
394
+ }
395
+ const themes = createV5Theme();
396
+ themes.dark.background0075;
397
+ themes.dark_yellow.background0075;
398
+ themes.dark.background;
399
+ themes.dark.accent1;
400
+ themes.dark.nonValid;