@jakubmazanec/ui 0.1.0-unstable.0c19abe

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 (357) hide show
  1. package/README.md +40 -0
  2. package/build/components/Button.d.ts +24 -0
  3. package/build/components/Button.js +51 -0
  4. package/build/components/Button.js.map +7 -0
  5. package/build/components/Card.d.ts +5 -0
  6. package/build/components/Card.js +7 -0
  7. package/build/components/Card.js.map +7 -0
  8. package/build/components/Checkbox.d.ts +24 -0
  9. package/build/components/Checkbox.js +63 -0
  10. package/build/components/Checkbox.js.map +7 -0
  11. package/build/components/CheckboxField.d.ts +11 -0
  12. package/build/components/CheckboxField.js +14 -0
  13. package/build/components/CheckboxField.js.map +7 -0
  14. package/build/components/Combobox.d.ts +33 -0
  15. package/build/components/Combobox.js +121 -0
  16. package/build/components/Combobox.js.map +7 -0
  17. package/build/components/ConfirmDialog.d.ts +23 -0
  18. package/build/components/ConfirmDialog.js +40 -0
  19. package/build/components/ConfirmDialog.js.map +7 -0
  20. package/build/components/Dialog.d.ts +18 -0
  21. package/build/components/Dialog.js +21 -0
  22. package/build/components/Dialog.js.map +7 -0
  23. package/build/components/DialogPanel.d.ts +10 -0
  24. package/build/components/DialogPanel.js +10 -0
  25. package/build/components/DialogPanel.js.map +7 -0
  26. package/build/components/DialogTitle.d.ts +10 -0
  27. package/build/components/DialogTitle.js +10 -0
  28. package/build/components/DialogTitle.js.map +7 -0
  29. package/build/components/Error.d.ts +10 -0
  30. package/build/components/Error.js +14 -0
  31. package/build/components/Error.js.map +7 -0
  32. package/build/components/Field.d.ts +11 -0
  33. package/build/components/Field.js +14 -0
  34. package/build/components/Field.js.map +7 -0
  35. package/build/components/Form.d.ts +13 -0
  36. package/build/components/Form.js +11 -0
  37. package/build/components/Form.js.map +7 -0
  38. package/build/components/Input.d.ts +42 -0
  39. package/build/components/Input.js +129 -0
  40. package/build/components/Input.js.map +7 -0
  41. package/build/components/Label.d.ts +10 -0
  42. package/build/components/Label.js +10 -0
  43. package/build/components/Label.js.map +7 -0
  44. package/build/components/Listbox.d.ts +32 -0
  45. package/build/components/Listbox.js +75 -0
  46. package/build/components/Listbox.js.map +7 -0
  47. package/build/components/Menu.d.ts +10 -0
  48. package/build/components/Menu.js +10 -0
  49. package/build/components/Menu.js.map +7 -0
  50. package/build/components/MenuButton.d.ts +10 -0
  51. package/build/components/MenuButton.js +10 -0
  52. package/build/components/MenuButton.js.map +7 -0
  53. package/build/components/MenuItem.d.ts +10 -0
  54. package/build/components/MenuItem.js +10 -0
  55. package/build/components/MenuItem.js.map +7 -0
  56. package/build/components/MenuItems.d.ts +10 -0
  57. package/build/components/MenuItems.js +10 -0
  58. package/build/components/MenuItems.js.map +7 -0
  59. package/build/components/Popover.d.ts +10 -0
  60. package/build/components/Popover.js +10 -0
  61. package/build/components/Popover.js.map +7 -0
  62. package/build/components/PopoverButton.d.ts +13 -0
  63. package/build/components/PopoverButton.js +28 -0
  64. package/build/components/PopoverButton.js.map +7 -0
  65. package/build/components/PopoverPanel.d.ts +16 -0
  66. package/build/components/PopoverPanel.js +24 -0
  67. package/build/components/PopoverPanel.js.map +7 -0
  68. package/build/components/Radio.d.ts +24 -0
  69. package/build/components/Radio.js +39 -0
  70. package/build/components/Radio.js.map +7 -0
  71. package/build/components/RadioField.d.ts +10 -0
  72. package/build/components/RadioField.js +14 -0
  73. package/build/components/RadioField.js.map +7 -0
  74. package/build/components/RadioGroupField.d.ts +20 -0
  75. package/build/components/RadioGroupField.js +82 -0
  76. package/build/components/RadioGroupField.js.map +7 -0
  77. package/build/components/Spinner.d.ts +7 -0
  78. package/build/components/Spinner.js +52 -0
  79. package/build/components/Spinner.js.map +7 -0
  80. package/build/components/Table.d.ts +16 -0
  81. package/build/components/Table.js +20 -0
  82. package/build/components/Table.js.map +7 -0
  83. package/build/components/TableCell.d.ts +10 -0
  84. package/build/components/TableCell.js +9 -0
  85. package/build/components/TableCell.js.map +7 -0
  86. package/build/components/TableHeader.d.ts +10 -0
  87. package/build/components/TableHeader.js +8 -0
  88. package/build/components/TableHeader.js.map +7 -0
  89. package/build/components/TableHeaderCell.d.ts +10 -0
  90. package/build/components/TableHeaderCell.js +9 -0
  91. package/build/components/TableHeaderCell.js.map +7 -0
  92. package/build/components/TableRow.d.ts +10 -0
  93. package/build/components/TableRow.js +9 -0
  94. package/build/components/TableRow.js.map +7 -0
  95. package/build/components/Textarea.d.ts +39 -0
  96. package/build/components/Textarea.js +104 -0
  97. package/build/components/Textarea.js.map +7 -0
  98. package/build/components/internals/fieldNameContext.d.ts +2 -0
  99. package/build/components/internals/fieldNameContext.js +4 -0
  100. package/build/components/internals/fieldNameContext.js.map +7 -0
  101. package/build/components/internals/formContext.d.ts +3 -0
  102. package/build/components/internals/formContext.js +4 -0
  103. package/build/components/internals/formContext.js.map +7 -0
  104. package/build/components/internals/useField.d.ts +6 -0
  105. package/build/components/internals/useField.js +18 -0
  106. package/build/components/internals/useField.js.map +7 -0
  107. package/build/components/internals/useFieldName.d.ts +1 -0
  108. package/build/components/internals/useFieldName.js +7 -0
  109. package/build/components/internals/useFieldName.js.map +7 -0
  110. package/build/components/internals/useForm.d.ts +1 -0
  111. package/build/components/internals/useForm.js +7 -0
  112. package/build/components/internals/useForm.js.map +7 -0
  113. package/build/components/internals.d.ts +5 -0
  114. package/build/components/internals.js +7 -0
  115. package/build/components/internals.js.map +7 -0
  116. package/build/components.d.ts +32 -0
  117. package/build/components.js +34 -0
  118. package/build/components.js.map +7 -0
  119. package/build/development/createTailwindConfig.d.ts +18 -0
  120. package/build/development/createTailwindConfig.js +125 -0
  121. package/build/development/createTailwindConfig.js.map +7 -0
  122. package/build/development/createTailwindMerge.d.ts +2 -0
  123. package/build/development/createTailwindMerge.js +74 -0
  124. package/build/development/createTailwindMerge.js.map +7 -0
  125. package/build/development/defaultTailwindConfig.d.ts +72 -0
  126. package/build/development/defaultTailwindConfig.js +45 -0
  127. package/build/development/defaultTailwindConfig.js.map +7 -0
  128. package/build/development/internals/PaletteConfig.d.ts +6 -0
  129. package/build/development/internals/PaletteConfig.js +2 -0
  130. package/build/development/internals/PaletteConfig.js.map +7 -0
  131. package/build/development/internals/SwatchValue.d.ts +9 -0
  132. package/build/development/internals/SwatchValue.js +2 -0
  133. package/build/development/internals/SwatchValue.js.map +7 -0
  134. package/build/development/internals/clamp.d.ts +1 -0
  135. package/build/development/internals/clamp.js +5 -0
  136. package/build/development/internals/clamp.js.map +7 -0
  137. package/build/development/internals/constants.d.ts +2 -0
  138. package/build/development/internals/constants.js +22 -0
  139. package/build/development/internals/constants.js.map +7 -0
  140. package/build/development/internals/createDisplayColor.d.ts +1 -0
  141. package/build/development/internals/createDisplayColor.js +24 -0
  142. package/build/development/internals/createDisplayColor.js.map +7 -0
  143. package/build/development/internals/createDistributionValues.d.ts +4 -0
  144. package/build/development/internals/createDistributionValues.js +32 -0
  145. package/build/development/internals/createDistributionValues.js.map +7 -0
  146. package/build/development/internals/createHueScale.d.ts +4 -0
  147. package/build/development/internals/createHueScale.js +15 -0
  148. package/build/development/internals/createHueScale.js.map +7 -0
  149. package/build/development/internals/createPalette.d.ts +16 -0
  150. package/build/development/internals/createPalette.js +36 -0
  151. package/build/development/internals/createPalette.js.map +7 -0
  152. package/build/development/internals/createSaturationScale.d.ts +4 -0
  153. package/build/development/internals/createSaturationScale.js +18 -0
  154. package/build/development/internals/createSaturationScale.js.map +7 -0
  155. package/build/development/internals/createSwatches.d.ts +10 -0
  156. package/build/development/internals/createSwatches.js +31 -0
  157. package/build/development/internals/createSwatches.js.map +7 -0
  158. package/build/development/internals/hexToHsl.d.ts +5 -0
  159. package/build/development/internals/hexToHsl.js +37 -0
  160. package/build/development/internals/hexToHsl.js.map +7 -0
  161. package/build/development/internals/hexToRgb.d.ts +5 -0
  162. package/build/development/internals/hexToRgb.js +21 -0
  163. package/build/development/internals/hexToRgb.js.map +7 -0
  164. package/build/development/internals/hslToHex.d.ts +1 -0
  165. package/build/development/internals/hslToHex.js +19 -0
  166. package/build/development/internals/hslToHex.js.map +7 -0
  167. package/build/development/internals/hslToRgb.d.ts +5 -0
  168. package/build/development/internals/hslToRgb.js +42 -0
  169. package/build/development/internals/hslToRgb.js.map +7 -0
  170. package/build/development/internals/isHex.d.ts +1 -0
  171. package/build/development/internals/isHex.js +7 -0
  172. package/build/development/internals/isHex.js.map +7 -0
  173. package/build/development/internals/resolveModule.d.ts +1 -0
  174. package/build/development/internals/resolveModule.js +9 -0
  175. package/build/development/internals/resolveModule.js.map +7 -0
  176. package/build/development/internals/round.d.ts +1 -0
  177. package/build/development/internals/round.js +6 -0
  178. package/build/development/internals/round.js.map +7 -0
  179. package/build/development/internals/unsignedModulo.d.ts +1 -0
  180. package/build/development/internals/unsignedModulo.js +5 -0
  181. package/build/development/internals/unsignedModulo.js.map +7 -0
  182. package/build/development/internals.d.ts +1 -0
  183. package/build/development/internals.js +3 -0
  184. package/build/development/internals.js.map +7 -0
  185. package/build/development.d.ts +3 -0
  186. package/build/development.js +5 -0
  187. package/build/development.js.map +7 -0
  188. package/build/fonts.css +15 -0
  189. package/build/fonts.css.map +7 -0
  190. package/build/inter-variable-75YQYCJN.woff2 +0 -0
  191. package/build/inter-variable-italic-54HMV74W.woff2 +0 -0
  192. package/build/inter-variable-italic.js +2 -0
  193. package/build/inter-variable-italic.js.map +7 -0
  194. package/build/inter-variable.js +2 -0
  195. package/build/inter-variable.js.map +7 -0
  196. package/build/main.d.ts +5 -0
  197. package/build/main.js +7 -0
  198. package/build/main.js.map +7 -0
  199. package/build/theme/Theme.d.ts +40 -0
  200. package/build/theme/Theme.js +2 -0
  201. package/build/theme/Theme.js.map +7 -0
  202. package/build/theme/ThemeProvider.d.ts +6 -0
  203. package/build/theme/ThemeProvider.js +7 -0
  204. package/build/theme/ThemeProvider.js.map +7 -0
  205. package/build/theme/defaultTheme.d.ts +2 -0
  206. package/build/theme/defaultTheme.js +331 -0
  207. package/build/theme/defaultTheme.js.map +7 -0
  208. package/build/theme/internals/ClassName.d.ts +1 -0
  209. package/build/theme/internals/ClassName.js +2 -0
  210. package/build/theme/internals/ClassName.js.map +7 -0
  211. package/build/theme/internals/ComponentProps.d.ts +7 -0
  212. package/build/theme/internals/ComponentProps.js +2 -0
  213. package/build/theme/internals/ComponentProps.js.map +7 -0
  214. package/build/theme/internals/ComponentTheme.d.ts +25 -0
  215. package/build/theme/internals/ComponentTheme.js +2 -0
  216. package/build/theme/internals/ComponentTheme.js.map +7 -0
  217. package/build/theme/internals/ComponentThemeCompoundVariants.d.ts +12 -0
  218. package/build/theme/internals/ComponentThemeCompoundVariants.js +2 -0
  219. package/build/theme/internals/ComponentThemeCompoundVariants.js.map +7 -0
  220. package/build/theme/internals/ComponentThemeDefinition.d.ts +6 -0
  221. package/build/theme/internals/ComponentThemeDefinition.js +2 -0
  222. package/build/theme/internals/ComponentThemeDefinition.js.map +7 -0
  223. package/build/theme/internals/ComponentThemeDefinitionElements.d.ts +1 -0
  224. package/build/theme/internals/ComponentThemeDefinitionElements.js +2 -0
  225. package/build/theme/internals/ComponentThemeDefinitionElements.js.map +7 -0
  226. package/build/theme/internals/ComponentThemeDefinitionVariants.d.ts +3 -0
  227. package/build/theme/internals/ComponentThemeDefinitionVariants.js +2 -0
  228. package/build/theme/internals/ComponentThemeDefinitionVariants.js.map +7 -0
  229. package/build/theme/internals/ComponentThemeProps.d.ts +5 -0
  230. package/build/theme/internals/ComponentThemeProps.js +2 -0
  231. package/build/theme/internals/ComponentThemeProps.js.map +7 -0
  232. package/build/theme/internals/ComponentThemeVariants.d.ts +14 -0
  233. package/build/theme/internals/ComponentThemeVariants.js +2 -0
  234. package/build/theme/internals/ComponentThemeVariants.js.map +7 -0
  235. package/build/theme/internals/UseComponentTheme.d.ts +21 -0
  236. package/build/theme/internals/UseComponentTheme.js +2 -0
  237. package/build/theme/internals/UseComponentTheme.js.map +7 -0
  238. package/build/theme/internals/UseComponentThemeReturn.d.ts +6 -0
  239. package/build/theme/internals/UseComponentThemeReturn.js +2 -0
  240. package/build/theme/internals/UseComponentThemeReturn.js.map +7 -0
  241. package/build/theme/internals/booleanToString.d.ts +1 -0
  242. package/build/theme/internals/booleanToString.js +5 -0
  243. package/build/theme/internals/booleanToString.js.map +7 -0
  244. package/build/theme/internals/createComponentTheme.d.ts +3 -0
  245. package/build/theme/internals/createComponentTheme.js +36 -0
  246. package/build/theme/internals/createComponentTheme.js.map +7 -0
  247. package/build/theme/internals/createUseComponentThemeReturn.d.ts +15 -0
  248. package/build/theme/internals/createUseComponentThemeReturn.js +51 -0
  249. package/build/theme/internals/createUseComponentThemeReturn.js.map +7 -0
  250. package/build/theme/internals/cx.d.ts +2 -0
  251. package/build/theme/internals/cx.js +6 -0
  252. package/build/theme/internals/cx.js.map +7 -0
  253. package/build/theme/internals/pickPropertyIfExists.d.ts +4 -0
  254. package/build/theme/internals/pickPropertyIfExists.js +11 -0
  255. package/build/theme/internals/pickPropertyIfExists.js.map +7 -0
  256. package/build/theme/internals/themeContext.d.ts +217 -0
  257. package/build/theme/internals/themeContext.js +4 -0
  258. package/build/theme/internals/themeContext.js.map +7 -0
  259. package/build/theme/internals/useTheme.d.ts +216 -0
  260. package/build/theme/internals/useTheme.js +7 -0
  261. package/build/theme/internals/useTheme.js.map +7 -0
  262. package/build/theme/internals.d.ts +18 -0
  263. package/build/theme/internals.js +20 -0
  264. package/build/theme/internals.js.map +7 -0
  265. package/build/theme.d.ts +3 -0
  266. package/build/theme.js +5 -0
  267. package/build/theme.js.map +7 -0
  268. package/package.json +93 -0
  269. package/source/components/Button.ts +74 -0
  270. package/source/components/Card.tsx +10 -0
  271. package/source/components/Checkbox.tsx +75 -0
  272. package/source/components/CheckboxField.tsx +28 -0
  273. package/source/components/Combobox.tsx +160 -0
  274. package/source/components/ConfirmDialog.tsx +67 -0
  275. package/source/components/Dialog.tsx +34 -0
  276. package/source/components/DialogPanel.tsx +18 -0
  277. package/source/components/DialogTitle.tsx +18 -0
  278. package/source/components/Error.tsx +27 -0
  279. package/source/components/Field.tsx +28 -0
  280. package/source/components/Form.tsx +30 -0
  281. package/source/components/Input.tsx +176 -0
  282. package/source/components/Label.tsx +18 -0
  283. package/source/components/Listbox.tsx +113 -0
  284. package/source/components/Menu.tsx +19 -0
  285. package/source/components/MenuButton.tsx +18 -0
  286. package/source/components/MenuItem.tsx +19 -0
  287. package/source/components/MenuItems.tsx +18 -0
  288. package/source/components/Popover.tsx +18 -0
  289. package/source/components/PopoverButton.tsx +45 -0
  290. package/source/components/PopoverPanel.tsx +37 -0
  291. package/source/components/Radio.tsx +46 -0
  292. package/source/components/RadioField.tsx +34 -0
  293. package/source/components/RadioGroupField.tsx +101 -0
  294. package/source/components/Spinner.tsx +46 -0
  295. package/source/components/Table.tsx +31 -0
  296. package/source/components/TableCell.tsx +17 -0
  297. package/source/components/TableHeader.tsx +19 -0
  298. package/source/components/TableHeaderCell.tsx +17 -0
  299. package/source/components/TableRow.tsx +17 -0
  300. package/source/components/Textarea.tsx +142 -0
  301. package/source/components/internals/fieldNameContext.ts +3 -0
  302. package/source/components/internals/formContext.ts +4 -0
  303. package/source/components/internals/useField.ts +19 -0
  304. package/source/components/internals/useFieldName.ts +7 -0
  305. package/source/components/internals/useForm.ts +7 -0
  306. package/source/components/internals.ts +5 -0
  307. package/source/components.ts +32 -0
  308. package/source/development/createTailwindConfig.ts +153 -0
  309. package/source/development/createTailwindMerge.ts +101 -0
  310. package/source/development/defaultTailwindConfig.ts +45 -0
  311. package/source/development/internals/PaletteConfig.ts +6 -0
  312. package/source/development/internals/SwatchValue.ts +9 -0
  313. package/source/development/internals/clamp.ts +3 -0
  314. package/source/development/internals/constants.ts +4 -0
  315. package/source/development/internals/createDisplayColor.ts +29 -0
  316. package/source/development/internals/createDistributionValues.ts +38 -0
  317. package/source/development/internals/createHueScale.ts +17 -0
  318. package/source/development/internals/createPalette.ts +54 -0
  319. package/source/development/internals/createSaturationScale.ts +21 -0
  320. package/source/development/internals/createSwatches.ts +34 -0
  321. package/source/development/internals/hexToHsl.ts +45 -0
  322. package/source/development/internals/hexToRgb.ts +23 -0
  323. package/source/development/internals/hslToHex.ts +23 -0
  324. package/source/development/internals/hslToRgb.ts +43 -0
  325. package/source/development/internals/isHex.ts +7 -0
  326. package/source/development/internals/resolveModule.ts +9 -0
  327. package/source/development/internals/round.ts +5 -0
  328. package/source/development/internals/unsignedModulo.ts +3 -0
  329. package/source/development/internals.ts +1 -0
  330. package/source/development.ts +3 -0
  331. package/source/fonts.css +15 -0
  332. package/source/inter-variable-italic.woff2 +0 -0
  333. package/source/inter-variable.woff2 +0 -0
  334. package/source/main.ts +8 -0
  335. package/source/theme/Theme.ts +72 -0
  336. package/source/theme/ThemeProvider.tsx +12 -0
  337. package/source/theme/defaultTheme.ts +370 -0
  338. package/source/theme/internals/ClassName.ts +1 -0
  339. package/source/theme/internals/ComponentProps.ts +13 -0
  340. package/source/theme/internals/ComponentTheme.ts +33 -0
  341. package/source/theme/internals/ComponentThemeCompoundVariants.ts +20 -0
  342. package/source/theme/internals/ComponentThemeDefinition.ts +7 -0
  343. package/source/theme/internals/ComponentThemeDefinitionElements.ts +1 -0
  344. package/source/theme/internals/ComponentThemeDefinitionVariants.ts +3 -0
  345. package/source/theme/internals/ComponentThemeProps.ts +11 -0
  346. package/source/theme/internals/ComponentThemeVariants.ts +24 -0
  347. package/source/theme/internals/UseComponentTheme.ts +22 -0
  348. package/source/theme/internals/UseComponentThemeReturn.ts +15 -0
  349. package/source/theme/internals/booleanToString.ts +6 -0
  350. package/source/theme/internals/createComponentTheme.ts +67 -0
  351. package/source/theme/internals/createUseComponentThemeReturn.ts +87 -0
  352. package/source/theme/internals/cx.ts +10 -0
  353. package/source/theme/internals/pickPropertyIfExists.ts +24 -0
  354. package/source/theme/internals/themeContext.ts +5 -0
  355. package/source/theme/internals/useTheme.ts +7 -0
  356. package/source/theme/internals.ts +18 -0
  357. package/source/theme.ts +3 -0
@@ -0,0 +1,74 @@
1
+ "use strict";
2
+ import { extendTailwindMerge, twMerge } from "tailwind-merge";
3
+ const THEME_SCALES = [
4
+ "colors",
5
+ "spacing",
6
+ "blur",
7
+ "brightness",
8
+ "borderColor",
9
+ "borderRadius",
10
+ "borderSpacing",
11
+ "borderWidth",
12
+ "contrast",
13
+ "grayscale",
14
+ "hueRotate",
15
+ "invert",
16
+ "gap",
17
+ "gradientColorStops",
18
+ "gradientColorStopPositions",
19
+ "inset",
20
+ "margin",
21
+ "opacity",
22
+ "padding",
23
+ "saturate",
24
+ "scale",
25
+ "sepia",
26
+ "skew",
27
+ "space",
28
+ "translate"
29
+ ];
30
+ export function createTailwindMerge(tailwindConfig) {
31
+ if (!tailwindConfig.theme) {
32
+ return twMerge;
33
+ }
34
+ let tailwindMergeConfig = {
35
+ override: { theme: {} },
36
+ extend: { theme: {} }
37
+ };
38
+ for (let scale of THEME_SCALES) {
39
+ if (!tailwindMergeConfig.override?.theme || !tailwindMergeConfig.extend?.theme) {
40
+ throw new Error("Creating Tailwind merge failed!");
41
+ }
42
+ if (tailwindConfig.theme[scale]) {
43
+ let tailwindConfigScale = tailwindConfig.theme[scale];
44
+ let keys = Object.keys(tailwindConfigScale);
45
+ let combinedKeys = [];
46
+ for (let key of keys) {
47
+ if (tailwindConfigScale[key] !== void 0 && tailwindConfigScale[key] !== null && typeof tailwindConfigScale[key] === "object") {
48
+ combinedKeys.push(
49
+ ...Object.keys(tailwindConfigScale[key]).filter((value) => value !== "DEFAULT").map((value) => `${key}-${value}`)
50
+ );
51
+ } else {
52
+ combinedKeys.push(key);
53
+ }
54
+ }
55
+ tailwindMergeConfig.override.theme[scale] = combinedKeys;
56
+ } else if (tailwindConfig.theme.extend?.[scale]) {
57
+ let tailwindConfigScale = tailwindConfig.theme.extend[scale];
58
+ let keys = Object.keys(tailwindConfigScale);
59
+ let combinedKeys = [];
60
+ for (let key of keys) {
61
+ if (tailwindConfigScale[key] !== void 0 && tailwindConfigScale[key] !== null && typeof tailwindConfigScale[key] === "object") {
62
+ combinedKeys.push(
63
+ ...Object.keys(tailwindConfigScale[key]).filter((value) => value !== "DEFAULT").map((value) => `${key}-${value}`)
64
+ );
65
+ } else {
66
+ combinedKeys.push(key);
67
+ }
68
+ }
69
+ tailwindMergeConfig.extend.theme[scale] = combinedKeys;
70
+ }
71
+ }
72
+ return extendTailwindMerge(tailwindMergeConfig);
73
+ }
74
+ //# sourceMappingURL=createTailwindMerge.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../source/development/createTailwindMerge.ts"],
4
+ "sourcesContent": ["import {extendTailwindMerge, twMerge} from 'tailwind-merge';\nimport {type Config as TailwindConfig} from 'tailwindcss';\n\nconst THEME_SCALES = [\n 'colors',\n 'spacing',\n 'blur',\n 'brightness',\n 'borderColor',\n 'borderRadius',\n 'borderSpacing',\n 'borderWidth',\n 'contrast',\n 'grayscale',\n 'hueRotate',\n 'invert',\n 'gap',\n 'gradientColorStops',\n 'gradientColorStopPositions',\n 'inset',\n 'margin',\n 'opacity',\n 'padding',\n 'saturate',\n 'scale',\n 'sepia',\n 'skew',\n 'space',\n 'translate',\n];\n\nexport function createTailwindMerge(tailwindConfig: TailwindConfig) {\n if (!tailwindConfig.theme) {\n return twMerge;\n }\n\n let tailwindMergeConfig: Parameters<typeof extendTailwindMerge>[0] = {\n override: {theme: {}},\n extend: {theme: {}},\n };\n\n for (let scale of THEME_SCALES) {\n if (!tailwindMergeConfig.override?.theme || !tailwindMergeConfig.extend?.theme) {\n throw new Error('Creating Tailwind merge failed!');\n }\n\n if (tailwindConfig.theme[scale]) {\n let tailwindConfigScale = tailwindConfig.theme[scale] as Record<\n string,\n Record<string, string | unknown> | unknown\n >;\n let keys = Object.keys(tailwindConfigScale);\n let combinedKeys = [];\n\n for (let key of keys) {\n if (\n tailwindConfigScale[key] !== undefined &&\n tailwindConfigScale[key] !== null &&\n typeof tailwindConfigScale[key] === 'object'\n ) {\n combinedKeys.push(\n ...Object.keys(tailwindConfigScale[key] as object)\n .filter((value) => value !== 'DEFAULT')\n .map((value) => `${key}-${value}`),\n );\n } else {\n combinedKeys.push(key);\n }\n }\n\n tailwindMergeConfig.override.theme[scale] = combinedKeys;\n } else if (tailwindConfig.theme.extend?.[scale]) {\n let tailwindConfigScale = tailwindConfig.theme.extend[scale] as Record<\n string,\n Record<string, string | unknown> | unknown\n >;\n let keys = Object.keys(tailwindConfigScale);\n let combinedKeys = [];\n\n for (let key of keys) {\n if (\n tailwindConfigScale[key] !== undefined &&\n tailwindConfigScale[key] !== null &&\n typeof tailwindConfigScale[key] === 'object'\n ) {\n combinedKeys.push(\n ...Object.keys(tailwindConfigScale[key] as object)\n .filter((value) => value !== 'DEFAULT')\n .map((value) => `${key}-${value}`),\n );\n } else {\n combinedKeys.push(key);\n }\n }\n\n tailwindMergeConfig.extend.theme[scale] = combinedKeys;\n }\n }\n\n return extendTailwindMerge(tailwindMergeConfig);\n}\n"],
5
+ "mappings": ";AAAA,SAAQ,qBAAqB,eAAc;AAG3C,MAAM,eAAe;AAAA,EACnB;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF;AAEO,gBAAS,oBAAoB,gBAAgC;AAClE,MAAI,CAAC,eAAe,OAAO;AACzB,WAAO;AAAA,EACT;AAEA,MAAI,sBAAiE;AAAA,IACnE,UAAU,EAAC,OAAO,CAAC,EAAC;AAAA,IACpB,QAAQ,EAAC,OAAO,CAAC,EAAC;AAAA,EACpB;AAEA,WAAS,SAAS,cAAc;AAC9B,QAAI,CAAC,oBAAoB,UAAU,SAAS,CAAC,oBAAoB,QAAQ,OAAO;AAC9E,YAAM,IAAI,MAAM,iCAAiC;AAAA,IACnD;AAEA,QAAI,eAAe,MAAM,KAAK,GAAG;AAC/B,UAAI,sBAAsB,eAAe,MAAM,KAAK;AAIpD,UAAI,OAAO,OAAO,KAAK,mBAAmB;AAC1C,UAAI,eAAe,CAAC;AAEpB,eAAS,OAAO,MAAM;AACpB,YACE,oBAAoB,GAAG,MAAM,UAC7B,oBAAoB,GAAG,MAAM,QAC7B,OAAO,oBAAoB,GAAG,MAAM,UACpC;AACA,uBAAa;AAAA,YACX,GAAG,OAAO,KAAK,oBAAoB,GAAG,CAAW,EAC9C,OAAO,CAAC,UAAU,UAAU,SAAS,EACrC,IAAI,CAAC,UAAU,GAAG,GAAG,IAAI,KAAK,EAAE;AAAA,UACrC;AAAA,QACF,OAAO;AACL,uBAAa,KAAK,GAAG;AAAA,QACvB;AAAA,MACF;AAEA,0BAAoB,SAAS,MAAM,KAAK,IAAI;AAAA,IAC9C,WAAW,eAAe,MAAM,SAAS,KAAK,GAAG;AAC/C,UAAI,sBAAsB,eAAe,MAAM,OAAO,KAAK;AAI3D,UAAI,OAAO,OAAO,KAAK,mBAAmB;AAC1C,UAAI,eAAe,CAAC;AAEpB,eAAS,OAAO,MAAM;AACpB,YACE,oBAAoB,GAAG,MAAM,UAC7B,oBAAoB,GAAG,MAAM,QAC7B,OAAO,oBAAoB,GAAG,MAAM,UACpC;AACA,uBAAa;AAAA,YACX,GAAG,OAAO,KAAK,oBAAoB,GAAG,CAAW,EAC9C,OAAO,CAAC,UAAU,UAAU,SAAS,EACrC,IAAI,CAAC,UAAU,GAAG,GAAG,IAAI,KAAK,EAAE;AAAA,UACrC;AAAA,QACF,OAAO;AACL,uBAAa,KAAK,GAAG;AAAA,QACvB;AAAA,MACF;AAEA,0BAAoB,OAAO,MAAM,KAAK,IAAI;AAAA,IAC5C;AAAA,EACF;AAEA,SAAO,oBAAoB,mBAAmB;AAChD;",
6
+ "names": []
7
+ }
@@ -0,0 +1,72 @@
1
+ export declare const defaultTailwindConfig: {
2
+ content: string[];
3
+ colors: {
4
+ gray: string;
5
+ red: string;
6
+ orange: {
7
+ hex: string;
8
+ hueShift: number;
9
+ };
10
+ yellow: {
11
+ swatches: ({
12
+ hex: string;
13
+ stop: 10;
14
+ } | {
15
+ hex: string;
16
+ stop: 25;
17
+ } | {
18
+ hex: string;
19
+ stop: 50;
20
+ } | {
21
+ hex: string;
22
+ stop: 100;
23
+ } | {
24
+ hex: string;
25
+ stop: 200;
26
+ } | {
27
+ hex: string;
28
+ stop: 300;
29
+ } | {
30
+ hex: string;
31
+ stop: 400;
32
+ } | {
33
+ hex: string;
34
+ stop: 500;
35
+ } | {
36
+ hex: string;
37
+ stop: 600;
38
+ } | {
39
+ hex: string;
40
+ stop: 700;
41
+ } | {
42
+ hex: string;
43
+ stop: 800;
44
+ } | {
45
+ hex: string;
46
+ stop: 900;
47
+ } | {
48
+ hex: string;
49
+ stop: 950;
50
+ } | {
51
+ hex: string;
52
+ stop: 975;
53
+ } | {
54
+ hex: string;
55
+ stop: 990;
56
+ })[];
57
+ hex: string;
58
+ hueShift: number;
59
+ };
60
+ green: string;
61
+ teal: {
62
+ hex: string;
63
+ hueShift: number;
64
+ };
65
+ blue: string;
66
+ violet: string;
67
+ pink: {
68
+ hex: string;
69
+ hueShift: number;
70
+ };
71
+ };
72
+ };
@@ -0,0 +1,45 @@
1
+ "use strict";
2
+ export const defaultTailwindConfig = {
3
+ content: ["./{.storybook,app,source,stories}/**/*.{js,jsx,ts,tsx,mdx}", "@jakubmazanec/ui"],
4
+ colors: {
5
+ gray: "#6c6e79",
6
+ red: "#d1002f",
7
+ orange: {
8
+ hex: "#c33909",
9
+ hueShift: 1
10
+ },
11
+ yellow: {
12
+ swatches: [
13
+ { hex: "#fffffa", stop: 10 },
14
+ { hex: "#fffef0", stop: 25 },
15
+ { hex: "#fffbdb", stop: 50 },
16
+ { hex: "#fff3b8", stop: 100 },
17
+ { hex: "#ffe06f", stop: 200 },
18
+ { hex: "#ffc72d", stop: 300 },
19
+ { hex: "#e69d00", stop: 400 },
20
+ { hex: "#9e6300", stop: 500 },
21
+ { hex: "#805701", stop: 600 },
22
+ { hex: "#614700", stop: 700 },
23
+ { hex: "#3d3000", stop: 800 },
24
+ { hex: "#1f1a00", stop: 900 },
25
+ { hex: "#0f0e00", stop: 950 },
26
+ { hex: "#0a0a00", stop: 975 },
27
+ { hex: "#050500", stop: 990 }
28
+ ],
29
+ hex: "#9e6300",
30
+ hueShift: 3
31
+ },
32
+ green: "#0a7e22",
33
+ teal: {
34
+ hex: "#007c65",
35
+ hueShift: 5
36
+ },
37
+ blue: "#006dca",
38
+ violet: "#8649e1",
39
+ pink: {
40
+ hex: "#b229b9",
41
+ hueShift: 10
42
+ }
43
+ }
44
+ };
45
+ //# sourceMappingURL=defaultTailwindConfig.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../source/development/defaultTailwindConfig.ts"],
4
+ "sourcesContent": ["import {type CreateTailwindConfigOptions} from './createTailwindConfig.js';\n\nexport const defaultTailwindConfig = {\n content: ['./{.storybook,app,source,stories}/**/*.{js,jsx,ts,tsx,mdx}', '@jakubmazanec/ui'],\n colors: {\n gray: '#6c6e79',\n red: '#d1002f',\n orange: {\n hex: '#c33909',\n hueShift: 1,\n },\n yellow: {\n swatches: [\n {hex: '#fffffa', stop: 10},\n {hex: '#fffef0', stop: 25},\n {hex: '#fffbdb', stop: 50},\n {hex: '#fff3b8', stop: 100},\n {hex: '#ffe06f', stop: 200},\n {hex: '#ffc72d', stop: 300},\n {hex: '#e69d00', stop: 400},\n {hex: '#9e6300', stop: 500},\n {hex: '#805701', stop: 600},\n {hex: '#614700', stop: 700},\n {hex: '#3d3000', stop: 800},\n {hex: '#1f1a00', stop: 900},\n {hex: '#0f0e00', stop: 950},\n {hex: '#0a0a00', stop: 975},\n {hex: '#050500', stop: 990},\n ],\n hex: '#9e6300',\n hueShift: 3,\n },\n green: '#0a7e22',\n teal: {\n hex: '#007c65',\n hueShift: 5,\n },\n blue: '#006dca',\n violet: '#8649e1',\n pink: {\n hex: '#b229b9',\n hueShift: 10,\n },\n },\n} satisfies CreateTailwindConfigOptions;\n"],
5
+ "mappings": ";AAEO,aAAM,wBAAwB;AAAA,EACnC,SAAS,CAAC,8DAA8D,kBAAkB;AAAA,EAC1F,QAAQ;AAAA,IACN,MAAM;AAAA,IACN,KAAK;AAAA,IACL,QAAQ;AAAA,MACN,KAAK;AAAA,MACL,UAAU;AAAA,IACZ;AAAA,IACA,QAAQ;AAAA,MACN,UAAU;AAAA,QACR,EAAC,KAAK,WAAW,MAAM,GAAE;AAAA,QACzB,EAAC,KAAK,WAAW,MAAM,GAAE;AAAA,QACzB,EAAC,KAAK,WAAW,MAAM,GAAE;AAAA,QACzB,EAAC,KAAK,WAAW,MAAM,IAAG;AAAA,QAC1B,EAAC,KAAK,WAAW,MAAM,IAAG;AAAA,QAC1B,EAAC,KAAK,WAAW,MAAM,IAAG;AAAA,QAC1B,EAAC,KAAK,WAAW,MAAM,IAAG;AAAA,QAC1B,EAAC,KAAK,WAAW,MAAM,IAAG;AAAA,QAC1B,EAAC,KAAK,WAAW,MAAM,IAAG;AAAA,QAC1B,EAAC,KAAK,WAAW,MAAM,IAAG;AAAA,QAC1B,EAAC,KAAK,WAAW,MAAM,IAAG;AAAA,QAC1B,EAAC,KAAK,WAAW,MAAM,IAAG;AAAA,QAC1B,EAAC,KAAK,WAAW,MAAM,IAAG;AAAA,QAC1B,EAAC,KAAK,WAAW,MAAM,IAAG;AAAA,QAC1B,EAAC,KAAK,WAAW,MAAM,IAAG;AAAA,MAC5B;AAAA,MACA,KAAK;AAAA,MACL,UAAU;AAAA,IACZ;AAAA,IACA,OAAO;AAAA,IACP,MAAM;AAAA,MACJ,KAAK;AAAA,MACL,UAAU;AAAA,IACZ;AAAA,IACA,MAAM;AAAA,IACN,QAAQ;AAAA,IACR,MAAM;AAAA,MACJ,KAAK;AAAA,MACL,UAAU;AAAA,IACZ;AAAA,EACF;AACF;",
6
+ "names": []
7
+ }
@@ -0,0 +1,6 @@
1
+ export type PaletteConfig = {
2
+ value: string;
3
+ valueStop: number;
4
+ h: number;
5
+ s: number;
6
+ };
@@ -0,0 +1,2 @@
1
+ "use strict";
2
+ //# sourceMappingURL=PaletteConfig.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": [],
4
+ "sourcesContent": [],
5
+ "mappings": "",
6
+ "names": []
7
+ }
@@ -0,0 +1,9 @@
1
+ export type SwatchValue = {
2
+ hex: string;
3
+ stop: number;
4
+ h: number;
5
+ hScale: number;
6
+ s: number;
7
+ sScale: number;
8
+ l: number;
9
+ };
@@ -0,0 +1,2 @@
1
+ "use strict";
2
+ //# sourceMappingURL=SwatchValue.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": [],
4
+ "sourcesContent": [],
5
+ "mappings": "",
6
+ "names": []
7
+ }
@@ -0,0 +1 @@
1
+ export declare function clamp(x: number, min: number, max: number): number;
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+ export function clamp(x, min, max) {
3
+ return Math.min(Math.max(x, min), max);
4
+ }
5
+ //# sourceMappingURL=clamp.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../source/development/internals/clamp.ts"],
4
+ "sourcesContent": ["export function clamp(x: number, min: number, max: number) {\n return Math.min(Math.max(x, min), max);\n}\n"],
5
+ "mappings": ";AAAO,gBAAS,MAAM,GAAW,KAAa,KAAa;AACzD,SAAO,KAAK,IAAI,KAAK,IAAI,GAAG,GAAG,GAAG,GAAG;AACvC;",
6
+ "names": []
7
+ }
@@ -0,0 +1,2 @@
1
+ export declare const DEFAULT_STOP = 500;
2
+ export declare const DEFAULT_STOPS: readonly [0, 10, 25, 50, 100, 200, 300, 400, 500, 600, 700, 800, 900, 950, 975, 990, 1000];
@@ -0,0 +1,22 @@
1
+ "use strict";
2
+ export const DEFAULT_STOP = 500;
3
+ export const DEFAULT_STOPS = [
4
+ 0,
5
+ 10,
6
+ 25,
7
+ 50,
8
+ 100,
9
+ 200,
10
+ 300,
11
+ 400,
12
+ 500,
13
+ 600,
14
+ 700,
15
+ 800,
16
+ 900,
17
+ 950,
18
+ 975,
19
+ 990,
20
+ 1e3
21
+ ];
22
+ //# sourceMappingURL=constants.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../source/development/internals/constants.ts"],
4
+ "sourcesContent": ["export const DEFAULT_STOP = 500;\nexport const DEFAULT_STOPS = [\n 0, 10, 25, 50, 100, 200, 300, 400, 500, 600, 700, 800, 900, 950, 975, 990, 1000,\n] as const;\n"],
5
+ "mappings": ";AAAO,aAAM,eAAe;AACrB,aAAM,gBAAgB;AAAA,EAC3B;AAAA,EAAG;AAAA,EAAI;AAAA,EAAI;AAAA,EAAI;AAAA,EAAK;AAAA,EAAK;AAAA,EAAK;AAAA,EAAK;AAAA,EAAK;AAAA,EAAK;AAAA,EAAK;AAAA,EAAK;AAAA,EAAK;AAAA,EAAK;AAAA,EAAK;AAAA,EAAK;AAC7E;",
6
+ "names": []
7
+ }
@@ -0,0 +1 @@
1
+ export declare function createDisplayColor(hexColor: string, alphaPlaceholder?: boolean): string | null;
@@ -0,0 +1,24 @@
1
+ "use strict";
2
+ import { oklch } from "culori";
3
+ import { isHex } from "./isHex.js";
4
+ import { round } from "./round.js";
5
+ export function createDisplayColor(hexColor, alphaPlaceholder) {
6
+ if (!hexColor || !isHex(hexColor)) {
7
+ return null;
8
+ }
9
+ let display = null;
10
+ let oklchColor = oklch(hexColor);
11
+ if (!oklchColor) {
12
+ throw new Error(`Couldn't convert "${hexColor}" to OKLCH!`);
13
+ }
14
+ let { l, c, h = 0 } = oklchColor;
15
+ display = `oklch(${[
16
+ `${round(l * 100, 2)}%`,
17
+ round(c, 3),
18
+ round(h, 2),
19
+ `/`,
20
+ alphaPlaceholder ? `<alpha-value>` : 1
21
+ ].join(` `)})`;
22
+ return display;
23
+ }
24
+ //# sourceMappingURL=createDisplayColor.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../source/development/internals/createDisplayColor.ts"],
4
+ "sourcesContent": ["import {oklch} from 'culori';\n\nimport {isHex} from './isHex.js';\nimport {round} from './round.js';\n\nexport function createDisplayColor(hexColor: string, alphaPlaceholder?: boolean): string | null {\n if (!hexColor || !isHex(hexColor)) {\n return null;\n }\n\n let display = null;\n let oklchColor = oklch(hexColor);\n\n if (!oklchColor) {\n throw new Error(`Couldn't convert \"${hexColor}\" to OKLCH!`);\n }\n\n let {l, c, h = 0} = oklchColor;\n\n display = `oklch(${[\n `${round(l * 100, 2)}%`,\n round(c, 3),\n round(h, 2),\n `/`,\n alphaPlaceholder ? `<alpha-value>` : 1,\n ].join(` `)})`;\n\n return display;\n}\n"],
5
+ "mappings": ";AAAA,SAAQ,aAAY;AAEpB,SAAQ,aAAY;AACpB,SAAQ,aAAY;AAEb,gBAAS,mBAAmB,UAAkB,kBAA2C;AAC9F,MAAI,CAAC,YAAY,CAAC,MAAM,QAAQ,GAAG;AACjC,WAAO;AAAA,EACT;AAEA,MAAI,UAAU;AACd,MAAI,aAAa,MAAM,QAAQ;AAE/B,MAAI,CAAC,YAAY;AACf,UAAM,IAAI,MAAM,qBAAqB,QAAQ,aAAa;AAAA,EAC5D;AAEA,MAAI,EAAC,GAAG,GAAG,IAAI,EAAC,IAAI;AAEpB,YAAU,SAAS;AAAA,IACjB,GAAG,MAAM,IAAI,KAAK,CAAC,CAAC;AAAA,IACpB,MAAM,GAAG,CAAC;AAAA,IACV,MAAM,GAAG,CAAC;AAAA,IACV;AAAA,IACA,mBAAmB,kBAAkB;AAAA,EACvC,EAAE,KAAK,GAAG,CAAC;AAEX,SAAO;AACT;",
6
+ "names": []
7
+ }
@@ -0,0 +1,4 @@
1
+ export declare function createDistributionValues(lightness: number, stop?: number): {
2
+ stop: number;
3
+ value: number;
4
+ }[];
@@ -0,0 +1,32 @@
1
+ "use strict";
2
+ import { DEFAULT_STOP, DEFAULT_STOPS } from "./constants.js";
3
+ const MIN = 0;
4
+ const MAX = 100;
5
+ export function createDistributionValues(lightness, stop = DEFAULT_STOP) {
6
+ let stops = [...DEFAULT_STOPS].sort();
7
+ let newValues = [
8
+ { stop: 0, value: MAX },
9
+ { stop, value: lightness },
10
+ { stop: 1e3, value: MIN }
11
+ ];
12
+ let stopIndex = stops.indexOf(stop);
13
+ let firstHalf = stops.slice(0, stopIndex + 1);
14
+ let secondHalf = stops.slice(stopIndex);
15
+ for (let stopValue of firstHalf) {
16
+ if (stopValue !== 0 && stopValue !== stop) {
17
+ let percentage = (stopValue - 0) / (stop - 0);
18
+ let value = MAX - percentage * (MAX - lightness);
19
+ newValues.push({ stop: stopValue, value: Math.round(value) });
20
+ }
21
+ }
22
+ for (let stopValue of secondHalf) {
23
+ if (stopValue !== 1e3 && stopValue !== stop) {
24
+ let percentage = (stopValue - stop) / (1e3 - stop);
25
+ let value = lightness - percentage * (lightness - MIN);
26
+ newValues.push({ stop: stopValue, value: Math.round(value) });
27
+ }
28
+ }
29
+ newValues.sort((a, b) => a.stop - b.stop);
30
+ return newValues;
31
+ }
32
+ //# sourceMappingURL=createDistributionValues.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../source/development/internals/createDistributionValues.ts"],
4
+ "sourcesContent": ["import {DEFAULT_STOP, DEFAULT_STOPS} from './constants.js';\n\nconst MIN = 0;\nconst MAX = 100;\n\nexport function createDistributionValues(lightness: number, stop: number = DEFAULT_STOP) {\n let stops: number[] = [...DEFAULT_STOPS].sort() as unknown as number[];\n let newValues = [\n {stop: 0, value: MAX},\n {stop, value: lightness},\n {stop: 1000, value: MIN},\n ];\n let stopIndex = stops.indexOf(stop);\n let firstHalf = stops.slice(0, stopIndex + 1);\n let secondHalf = stops.slice(stopIndex);\n\n for (let stopValue of firstHalf) {\n if (stopValue !== 0 && stopValue !== stop) {\n let percentage = (stopValue - 0) / (stop - 0);\n let value = MAX - percentage * (MAX - lightness);\n\n newValues.push({stop: stopValue, value: Math.round(value)});\n }\n }\n\n for (let stopValue of secondHalf) {\n if (stopValue !== 1000 && stopValue !== stop) {\n let percentage = (stopValue - stop) / (1000 - stop);\n let value = lightness - percentage * (lightness - MIN);\n\n newValues.push({stop: stopValue, value: Math.round(value)});\n }\n }\n\n newValues.sort((a, b) => a.stop - b.stop);\n\n return newValues;\n}\n"],
5
+ "mappings": ";AAAA,SAAQ,cAAc,qBAAoB;AAE1C,MAAM,MAAM;AACZ,MAAM,MAAM;AAEL,gBAAS,yBAAyB,WAAmB,OAAe,cAAc;AACvF,MAAI,QAAkB,CAAC,GAAG,aAAa,EAAE,KAAK;AAC9C,MAAI,YAAY;AAAA,IACd,EAAC,MAAM,GAAG,OAAO,IAAG;AAAA,IACpB,EAAC,MAAM,OAAO,UAAS;AAAA,IACvB,EAAC,MAAM,KAAM,OAAO,IAAG;AAAA,EACzB;AACA,MAAI,YAAY,MAAM,QAAQ,IAAI;AAClC,MAAI,YAAY,MAAM,MAAM,GAAG,YAAY,CAAC;AAC5C,MAAI,aAAa,MAAM,MAAM,SAAS;AAEtC,WAAS,aAAa,WAAW;AAC/B,QAAI,cAAc,KAAK,cAAc,MAAM;AACzC,UAAI,cAAc,YAAY,MAAM,OAAO;AAC3C,UAAI,QAAQ,MAAM,cAAc,MAAM;AAEtC,gBAAU,KAAK,EAAC,MAAM,WAAW,OAAO,KAAK,MAAM,KAAK,EAAC,CAAC;AAAA,IAC5D;AAAA,EACF;AAEA,WAAS,aAAa,YAAY;AAChC,QAAI,cAAc,OAAQ,cAAc,MAAM;AAC5C,UAAI,cAAc,YAAY,SAAS,MAAO;AAC9C,UAAI,QAAQ,YAAY,cAAc,YAAY;AAElD,gBAAU,KAAK,EAAC,MAAM,WAAW,OAAO,KAAK,MAAM,KAAK,EAAC,CAAC;AAAA,IAC5D;AAAA,EACF;AAEA,YAAU,KAAK,CAAC,GAAG,MAAM,EAAE,OAAO,EAAE,IAAI;AAExC,SAAO;AACT;",
6
+ "names": []
7
+ }
@@ -0,0 +1,4 @@
1
+ export declare function createHueScale(tweak?: number, stop?: number): {
2
+ stop: number;
3
+ tweak: number;
4
+ }[];
@@ -0,0 +1,15 @@
1
+ "use strict";
2
+ import { DEFAULT_STOP, DEFAULT_STOPS } from "./constants.js";
3
+ export function createHueScale(tweak = 0, stop = DEFAULT_STOP) {
4
+ let stops = DEFAULT_STOPS;
5
+ let index = stops.indexOf(stop);
6
+ if (index === -1) {
7
+ throw new Error(`Invalid parameter value: ${stop}`);
8
+ }
9
+ return stops.map((stop2) => {
10
+ let diff = Math.abs(stops.indexOf(stop2) - index);
11
+ let tweakValue = tweak ? diff * tweak : 0;
12
+ return { stop: stop2, tweak: tweakValue };
13
+ });
14
+ }
15
+ //# sourceMappingURL=createHueScale.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../source/development/internals/createHueScale.ts"],
4
+ "sourcesContent": ["import {DEFAULT_STOP, DEFAULT_STOPS} from './constants.js';\n\nexport function createHueScale(tweak = 0, stop: number = DEFAULT_STOP) {\n let stops: number[] = DEFAULT_STOPS as unknown as number[];\n let index = stops.indexOf(stop);\n\n if (index === -1) {\n throw new Error(`Invalid parameter value: ${stop}`);\n }\n\n return stops.map((stop) => {\n let diff = Math.abs(stops.indexOf(stop) - index);\n let tweakValue = tweak ? diff * tweak : 0;\n\n return {stop, tweak: tweakValue};\n });\n}\n"],
5
+ "mappings": ";AAAA,SAAQ,cAAc,qBAAoB;AAEnC,gBAAS,eAAe,QAAQ,GAAG,OAAe,cAAc;AACrE,MAAI,QAAkB;AACtB,MAAI,QAAQ,MAAM,QAAQ,IAAI;AAE9B,MAAI,UAAU,IAAI;AAChB,UAAM,IAAI,MAAM,4BAA4B,IAAI,EAAE;AAAA,EACpD;AAEA,SAAO,MAAM,IAAI,CAACA,UAAS;AACzB,QAAI,OAAO,KAAK,IAAI,MAAM,QAAQA,KAAI,IAAI,KAAK;AAC/C,QAAI,aAAa,QAAQ,OAAO,QAAQ;AAExC,WAAO,EAAC,MAAAA,OAAM,OAAO,WAAU;AAAA,EACjC,CAAC;AACH;",
6
+ "names": ["stop"]
7
+ }
@@ -0,0 +1,16 @@
1
+ import { type DEFAULT_STOPS } from './constants.js';
2
+ export type CreatePaletteOptions<N extends string> = {
3
+ name: N;
4
+ swatches: Array<{
5
+ hex: string;
6
+ stop: number;
7
+ }>;
8
+ hueShift: number;
9
+ saturationShift: number;
10
+ };
11
+ export type CreatePaletteReturn<N extends string> = {
12
+ [K in N]: {
13
+ [J in (typeof DEFAULT_STOPS)[number]]: string;
14
+ };
15
+ };
16
+ export declare function createPalette<const N extends string>({ name, swatches, hueShift, saturationShift, }: CreatePaletteOptions<N>): CreatePaletteReturn<N>;
@@ -0,0 +1,36 @@
1
+ "use strict";
2
+ import { DEFAULT_STOP } from "./constants.js";
3
+ import { createDisplayColor } from "./createDisplayColor.js";
4
+ import { createSwatches } from "./createSwatches.js";
5
+ export function createPalette({
6
+ name,
7
+ swatches,
8
+ hueShift,
9
+ saturationShift
10
+ }) {
11
+ let defaultSwatch = swatches.find((swatch) => swatch.stop === DEFAULT_STOP);
12
+ if (!defaultSwatch) {
13
+ throw new Error(`Swatches are missing color for stop "${DEFAULT_STOP}"!`);
14
+ }
15
+ let allSwatches = createSwatches({
16
+ value: defaultSwatch.hex,
17
+ valueStop: DEFAULT_STOP,
18
+ h: hueShift,
19
+ s: saturationShift
20
+ });
21
+ let palette = {};
22
+ allSwatches.filter((swatch) => ![0, 1e3].includes(swatch.stop)).forEach((newSwatch) => {
23
+ let existingSwatch = swatches.find((swatch) => swatch.stop === newSwatch.stop);
24
+ if (existingSwatch) {
25
+ Object.assign(palette, {
26
+ [existingSwatch.stop]: createDisplayColor(existingSwatch.hex, true)
27
+ });
28
+ } else {
29
+ Object.assign(palette, { [newSwatch.stop]: createDisplayColor(newSwatch.hex, true) });
30
+ }
31
+ });
32
+ return {
33
+ [name]: palette
34
+ };
35
+ }
36
+ //# sourceMappingURL=createPalette.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../source/development/internals/createPalette.ts"],
4
+ "sourcesContent": ["import {DEFAULT_STOP, type DEFAULT_STOPS} from './constants.js';\nimport {createDisplayColor} from './createDisplayColor.js';\nimport {createSwatches} from './createSwatches.js';\n\nexport type CreatePaletteOptions<N extends string> = {\n name: N;\n swatches: Array<{hex: string; stop: number}>;\n hueShift: number;\n saturationShift: number;\n};\n\nexport type CreatePaletteReturn<N extends string> = {\n [K in N]: {[J in (typeof DEFAULT_STOPS)[number]]: string};\n};\n\nexport function createPalette<const N extends string>({\n name,\n swatches,\n hueShift,\n saturationShift,\n}: CreatePaletteOptions<N>): CreatePaletteReturn<N> {\n let defaultSwatch = swatches.find((swatch) => swatch.stop === DEFAULT_STOP);\n\n if (!defaultSwatch) {\n throw new Error(`Swatches are missing color for stop \"${DEFAULT_STOP}\"!`);\n }\n\n let allSwatches = createSwatches({\n value: defaultSwatch.hex,\n valueStop: DEFAULT_STOP,\n h: hueShift,\n s: saturationShift,\n });\n let palette = {};\n\n allSwatches\n .filter((swatch) => ![0, 1000].includes(swatch.stop))\n .forEach((newSwatch) => {\n let existingSwatch = swatches.find((swatch) => swatch.stop === newSwatch.stop);\n\n if (existingSwatch) {\n Object.assign(palette, {\n [existingSwatch.stop]: createDisplayColor(existingSwatch.hex, true),\n });\n } else {\n Object.assign(palette, {[newSwatch.stop]: createDisplayColor(newSwatch.hex, true)});\n }\n });\n\n // eslint-disable-next-line @typescript-eslint/consistent-type-assertions -- false positive\n return {\n [name]: palette,\n } as CreatePaletteReturn<N>;\n}\n"],
5
+ "mappings": ";AAAA,SAAQ,oBAAuC;AAC/C,SAAQ,0BAAyB;AACjC,SAAQ,sBAAqB;AAatB,gBAAS,cAAsC;AAAA,EACpD;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,GAAoD;AAClD,MAAI,gBAAgB,SAAS,KAAK,CAAC,WAAW,OAAO,SAAS,YAAY;AAE1E,MAAI,CAAC,eAAe;AAClB,UAAM,IAAI,MAAM,wCAAwC,YAAY,IAAI;AAAA,EAC1E;AAEA,MAAI,cAAc,eAAe;AAAA,IAC/B,OAAO,cAAc;AAAA,IACrB,WAAW;AAAA,IACX,GAAG;AAAA,IACH,GAAG;AAAA,EACL,CAAC;AACD,MAAI,UAAU,CAAC;AAEf,cACG,OAAO,CAAC,WAAW,CAAC,CAAC,GAAG,GAAI,EAAE,SAAS,OAAO,IAAI,CAAC,EACnD,QAAQ,CAAC,cAAc;AACtB,QAAI,iBAAiB,SAAS,KAAK,CAAC,WAAW,OAAO,SAAS,UAAU,IAAI;AAE7E,QAAI,gBAAgB;AAClB,aAAO,OAAO,SAAS;AAAA,QACrB,CAAC,eAAe,IAAI,GAAG,mBAAmB,eAAe,KAAK,IAAI;AAAA,MACpE,CAAC;AAAA,IACH,OAAO;AACL,aAAO,OAAO,SAAS,EAAC,CAAC,UAAU,IAAI,GAAG,mBAAmB,UAAU,KAAK,IAAI,EAAC,CAAC;AAAA,IACpF;AAAA,EACF,CAAC;AAGH,SAAO;AAAA,IACL,CAAC,IAAI,GAAG;AAAA,EACV;AACF;",
6
+ "names": []
7
+ }
@@ -0,0 +1,4 @@
1
+ export declare function createSaturationScale(tweak?: number, stop?: number): {
2
+ stop: number;
3
+ tweak: number;
4
+ }[];
@@ -0,0 +1,18 @@
1
+ "use strict";
2
+ import { DEFAULT_STOP, DEFAULT_STOPS } from "./constants.js";
3
+ export function createSaturationScale(tweak = 0, stop = DEFAULT_STOP) {
4
+ let stops = DEFAULT_STOPS;
5
+ let index = stops.indexOf(stop);
6
+ if (index === -1) {
7
+ throw new Error(`Invalid key value: ${stop}`);
8
+ }
9
+ return stops.map((stop2) => {
10
+ let diff = Math.abs(stops.indexOf(stop2) - index);
11
+ let tweakValue = tweak ? Math.round((diff + 1) * tweak * (1 + diff / 10)) : 0;
12
+ if (tweakValue > 100) {
13
+ return { stop: stop2, tweak: 100 };
14
+ }
15
+ return { stop: stop2, tweak: tweakValue };
16
+ });
17
+ }
18
+ //# sourceMappingURL=createSaturationScale.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../source/development/internals/createSaturationScale.ts"],
4
+ "sourcesContent": ["import {DEFAULT_STOP, DEFAULT_STOPS} from './constants.js';\n\nexport function createSaturationScale(tweak = 0, stop: number = DEFAULT_STOP) {\n let stops: number[] = DEFAULT_STOPS as unknown as number[];\n let index = stops.indexOf(stop);\n\n if (index === -1) {\n throw new Error(`Invalid key value: ${stop}`);\n }\n\n return stops.map((stop) => {\n let diff = Math.abs(stops.indexOf(stop) - index);\n let tweakValue = tweak ? Math.round((diff + 1) * tweak * (1 + diff / 10)) : 0;\n\n if (tweakValue > 100) {\n return {stop, tweak: 100};\n }\n\n return {stop, tweak: tweakValue};\n });\n}\n"],
5
+ "mappings": ";AAAA,SAAQ,cAAc,qBAAoB;AAEnC,gBAAS,sBAAsB,QAAQ,GAAG,OAAe,cAAc;AAC5E,MAAI,QAAkB;AACtB,MAAI,QAAQ,MAAM,QAAQ,IAAI;AAE9B,MAAI,UAAU,IAAI;AAChB,UAAM,IAAI,MAAM,sBAAsB,IAAI,EAAE;AAAA,EAC9C;AAEA,SAAO,MAAM,IAAI,CAACA,UAAS;AACzB,QAAI,OAAO,KAAK,IAAI,MAAM,QAAQA,KAAI,IAAI,KAAK;AAC/C,QAAI,aAAa,QAAQ,KAAK,OAAO,OAAO,KAAK,SAAS,IAAI,OAAO,GAAG,IAAI;AAE5E,QAAI,aAAa,KAAK;AACpB,aAAO,EAAC,MAAAA,OAAM,OAAO,IAAG;AAAA,IAC1B;AAEA,WAAO,EAAC,MAAAA,OAAM,OAAO,WAAU;AAAA,EACjC,CAAC;AACH;",
6
+ "names": ["stop"]
7
+ }
@@ -0,0 +1,10 @@
1
+ import { type PaletteConfig } from './PaletteConfig.js';
2
+ export declare function createSwatches(palette: PaletteConfig): {
3
+ stop: number;
4
+ hex: string;
5
+ h: number;
6
+ hScale: number;
7
+ s: number;
8
+ sScale: number;
9
+ l: number;
10
+ }[];
@@ -0,0 +1,31 @@
1
+ "use strict";
2
+ import { clamp } from "./clamp.js";
3
+ import { createDistributionValues } from "./createDistributionValues.js";
4
+ import { createHueScale } from "./createHueScale.js";
5
+ import { createSaturationScale } from "./createSaturationScale.js";
6
+ import { hexToHsl } from "./hexToHsl.js";
7
+ import { hslToHex } from "./hslToHex.js";
8
+ import { unsignedModulo } from "./unsignedModulo.js";
9
+ export function createSwatches(palette) {
10
+ let hueScale = createHueScale(palette.h, palette.valueStop);
11
+ let saturationScale = createSaturationScale(palette.s, palette.valueStop);
12
+ let { h, s, l } = hexToHsl(palette.value);
13
+ let distributionScale = createDistributionValues(l, palette.valueStop);
14
+ let swatches = hueScale.map(({ stop }, stopIndex) => {
15
+ let newH = unsignedModulo(h + hueScale[stopIndex].tweak, 360);
16
+ let newS = clamp(s + saturationScale[stopIndex].tweak, 0, 100);
17
+ let newL = clamp(distributionScale[stopIndex].value, 0.1, 99.9);
18
+ let newHex = hslToHex(newH, newS, newL);
19
+ return {
20
+ stop,
21
+ hex: stop === palette.valueStop ? palette.value.toUpperCase() : newHex.toUpperCase(),
22
+ h: newH,
23
+ hScale: (unsignedModulo(hueScale[stopIndex].tweak + 180, 360) - 180) / 180 * 50,
24
+ s: newS,
25
+ sScale: newS - 50,
26
+ l: newL
27
+ };
28
+ });
29
+ return swatches;
30
+ }
31
+ //# sourceMappingURL=createSwatches.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../source/development/internals/createSwatches.ts"],
4
+ "sourcesContent": ["import {clamp} from './clamp.js';\nimport {createDistributionValues} from './createDistributionValues.js';\nimport {createHueScale} from './createHueScale.js';\nimport {createSaturationScale} from './createSaturationScale.js';\nimport {hexToHsl} from './hexToHsl.js';\nimport {hslToHex} from './hslToHex.js';\nimport {type PaletteConfig} from './PaletteConfig.js';\nimport {unsignedModulo} from './unsignedModulo.js';\n\nexport function createSwatches(palette: PaletteConfig) {\n let hueScale = createHueScale(palette.h, palette.valueStop);\n let saturationScale = createSaturationScale(palette.s, palette.valueStop);\n let {h, s, l} = hexToHsl(palette.value);\n let distributionScale = createDistributionValues(l, palette.valueStop);\n\n let swatches = hueScale.map(({stop}, stopIndex) => {\n let newH = unsignedModulo(h + hueScale[stopIndex]!.tweak, 360);\n let newS = clamp(s + saturationScale[stopIndex]!.tweak, 0, 100);\n let newL = clamp(distributionScale[stopIndex]!.value, 0.1, 99.9); // this is to make sure the first two or last two swatches (the first being total white and the last being total black) aren't the same lightness\n let newHex = hslToHex(newH, newS, newL);\n\n return {\n stop,\n hex: stop === palette.valueStop ? palette.value.toUpperCase() : newHex.toUpperCase(),\n h: newH,\n hScale: ((unsignedModulo(hueScale[stopIndex]!.tweak + 180, 360) - 180) / 180) * 50,\n s: newS,\n sScale: newS - 50,\n l: newL,\n };\n });\n\n return swatches;\n}\n"],
5
+ "mappings": ";AAAA,SAAQ,aAAY;AACpB,SAAQ,gCAA+B;AACvC,SAAQ,sBAAqB;AAC7B,SAAQ,6BAA4B;AACpC,SAAQ,gBAAe;AACvB,SAAQ,gBAAe;AAEvB,SAAQ,sBAAqB;AAEtB,gBAAS,eAAe,SAAwB;AACrD,MAAI,WAAW,eAAe,QAAQ,GAAG,QAAQ,SAAS;AAC1D,MAAI,kBAAkB,sBAAsB,QAAQ,GAAG,QAAQ,SAAS;AACxE,MAAI,EAAC,GAAG,GAAG,EAAC,IAAI,SAAS,QAAQ,KAAK;AACtC,MAAI,oBAAoB,yBAAyB,GAAG,QAAQ,SAAS;AAErE,MAAI,WAAW,SAAS,IAAI,CAAC,EAAC,KAAI,GAAG,cAAc;AACjD,QAAI,OAAO,eAAe,IAAI,SAAS,SAAS,EAAG,OAAO,GAAG;AAC7D,QAAI,OAAO,MAAM,IAAI,gBAAgB,SAAS,EAAG,OAAO,GAAG,GAAG;AAC9D,QAAI,OAAO,MAAM,kBAAkB,SAAS,EAAG,OAAO,KAAK,IAAI;AAC/D,QAAI,SAAS,SAAS,MAAM,MAAM,IAAI;AAEtC,WAAO;AAAA,MACL;AAAA,MACA,KAAK,SAAS,QAAQ,YAAY,QAAQ,MAAM,YAAY,IAAI,OAAO,YAAY;AAAA,MACnF,GAAG;AAAA,MACH,SAAU,eAAe,SAAS,SAAS,EAAG,QAAQ,KAAK,GAAG,IAAI,OAAO,MAAO;AAAA,MAChF,GAAG;AAAA,MACH,QAAQ,OAAO;AAAA,MACf,GAAG;AAAA,IACL;AAAA,EACF,CAAC;AAED,SAAO;AACT;",
6
+ "names": []
7
+ }
@@ -0,0 +1,5 @@
1
+ export declare function hexToHsl(rawHex: string): {
2
+ h: number;
3
+ s: number;
4
+ l: number;
5
+ };
@@ -0,0 +1,37 @@
1
+ "use strict";
2
+ import { hexToRgb } from "./hexToRgb.js";
3
+ export function hexToHsl(rawHex) {
4
+ let hex = rawHex;
5
+ if (hex.length === 6 && !hex.startsWith(`#`)) {
6
+ hex = `#${hex}`;
7
+ }
8
+ let { r, g, b } = hexToRgb(hex);
9
+ r /= 255;
10
+ g /= 255;
11
+ b /= 255;
12
+ let cmin = Math.min(r, g, b);
13
+ let cmax = Math.max(r, g, b);
14
+ let delta = cmax - cmin;
15
+ let h = 0;
16
+ let s = 0;
17
+ let l = 0;
18
+ if (delta === 0) {
19
+ h = 0;
20
+ } else if (cmax === r) {
21
+ h = (g - b) / delta % 6;
22
+ } else if (cmax === g) {
23
+ h = (b - r) / delta + 2;
24
+ } else {
25
+ h = (r - g) / delta + 4;
26
+ }
27
+ h = Math.round(h * 60);
28
+ if (h < 0) {
29
+ h += 360;
30
+ }
31
+ l = (cmax + cmin) / 2;
32
+ s = delta === 0 ? 0 : delta / (1 - Math.abs(2 * l - 1));
33
+ s = +(s * 100).toFixed(1);
34
+ l = +(l * 100).toFixed(1);
35
+ return { h, s, l };
36
+ }
37
+ //# sourceMappingURL=hexToHsl.js.map