@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,3 @@
1
+ import { type ComponentThemeDefinition } from './ComponentThemeDefinition.js';
2
+ import { type UseComponentTheme } from './UseComponentTheme.js';
3
+ export declare function createComponentTheme<const N extends string, const D extends ComponentThemeDefinition | undefined = undefined>(themeName: N, themeDefinition?: NonNullable<D>): UseComponentTheme<N, D>;
@@ -0,0 +1,36 @@
1
+ "use strict";
2
+ import { useContext } from "react";
3
+ import { createUseComponentThemeReturn } from "./createUseComponentThemeReturn.js";
4
+ import { themeContext } from "./themeContext.js";
5
+ export function createComponentTheme(themeName, themeDefinition) {
6
+ let useComponentTheme = (themeProps) => {
7
+ let theme = useContext(themeContext);
8
+ if (!theme) {
9
+ throw new Error("No theme was found!");
10
+ }
11
+ let componentTheme = theme[themeName];
12
+ if (!componentTheme) {
13
+ throw new Error(`Theme for component "${themeName}" wasn't found!`);
14
+ }
15
+ let hasElements = Boolean(themeDefinition?.elements);
16
+ if (!hasElements) {
17
+ return createUseComponentThemeReturn(
18
+ componentTheme,
19
+ themeProps
20
+ );
21
+ }
22
+ let getClassNames = {};
23
+ for (let element of themeDefinition?.elements ?? []) {
24
+ getClassNames[element] = createUseComponentThemeReturn(
25
+ componentTheme,
26
+ themeProps,
27
+ element
28
+ );
29
+ }
30
+ return getClassNames;
31
+ };
32
+ useComponentTheme.themeDefinition = themeDefinition;
33
+ useComponentTheme.componentThemeName = themeName;
34
+ return useComponentTheme;
35
+ }
36
+ //# sourceMappingURL=createComponentTheme.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../source/theme/internals/createComponentTheme.ts"],
4
+ "sourcesContent": ["import {useContext} from 'react';\n\nimport {type Theme} from '../Theme.js';\nimport {type ClassName} from './ClassName.js';\nimport {type ComponentTheme} from './ComponentTheme.js';\nimport {type ComponentThemeDefinition} from './ComponentThemeDefinition.js';\nimport {type ComponentThemeDefinitionElements} from './ComponentThemeDefinitionElements.js';\nimport {type ComponentThemeDefinitionVariants} from './ComponentThemeDefinitionVariants.js';\nimport {type ComponentThemeProps} from './ComponentThemeProps.js';\nimport {createUseComponentThemeReturn} from './createUseComponentThemeReturn.js';\nimport {themeContext} from './themeContext.js';\nimport {type UseComponentTheme} from './UseComponentTheme.js';\n\nexport function createComponentTheme<\n const N extends string,\n const D extends ComponentThemeDefinition | undefined = undefined,\n>(themeName: N, themeDefinition?: NonNullable<D>): UseComponentTheme<N, D> {\n let useComponentTheme = (themeProps?: ComponentThemeProps<D>) => {\n let theme = useContext(themeContext);\n\n if (!theme) {\n throw new Error('No theme was found!');\n }\n\n let componentTheme = theme[themeName as keyof Theme] as unknown as\n | ComponentTheme<{\n variants: ComponentThemeDefinitionVariants;\n elements: ComponentThemeDefinitionElements;\n }>\n | ComponentTheme<{variants: ComponentThemeDefinitionVariants}>\n | undefined;\n\n if (!componentTheme) {\n throw new Error(`Theme for component \"${themeName}\" wasn't found!`);\n }\n\n let hasElements = Boolean(themeDefinition?.elements);\n\n if (!hasElements) {\n return createUseComponentThemeReturn(\n componentTheme as\n | ComponentTheme<{variants: ComponentThemeDefinitionVariants}>\n | ComponentTheme<undefined>,\n themeProps,\n );\n }\n\n let getClassNames: Record<string, (...args: ClassName[]) => string> = {};\n\n for (let element of themeDefinition?.elements ?? []) {\n getClassNames[element] = createUseComponentThemeReturn(\n componentTheme as\n | ComponentTheme<{variants: ComponentThemeDefinitionVariants}>\n | ComponentTheme<undefined>,\n themeProps,\n element,\n );\n }\n\n return getClassNames;\n };\n\n (useComponentTheme as UseComponentTheme<N, D>).themeDefinition = themeDefinition;\n (useComponentTheme as UseComponentTheme<N, D>).componentThemeName = themeName;\n\n return useComponentTheme as UseComponentTheme<N, D>;\n}\n"],
5
+ "mappings": ";AAAA,SAAQ,kBAAiB;AASzB,SAAQ,qCAAoC;AAC5C,SAAQ,oBAAmB;AAGpB,gBAAS,qBAGd,WAAc,iBAA2D;AACzE,MAAI,oBAAoB,CAAC,eAAwC;AAC/D,QAAI,QAAQ,WAAW,YAAY;AAEnC,QAAI,CAAC,OAAO;AACV,YAAM,IAAI,MAAM,qBAAqB;AAAA,IACvC;AAEA,QAAI,iBAAiB,MAAM,SAAwB;AAQnD,QAAI,CAAC,gBAAgB;AACnB,YAAM,IAAI,MAAM,wBAAwB,SAAS,iBAAiB;AAAA,IACpE;AAEA,QAAI,cAAc,QAAQ,iBAAiB,QAAQ;AAEnD,QAAI,CAAC,aAAa;AAChB,aAAO;AAAA,QACL;AAAA,QAGA;AAAA,MACF;AAAA,IACF;AAEA,QAAI,gBAAkE,CAAC;AAEvE,aAAS,WAAW,iBAAiB,YAAY,CAAC,GAAG;AACnD,oBAAc,OAAO,IAAI;AAAA,QACvB;AAAA,QAGA;AAAA,QACA;AAAA,MACF;AAAA,IACF;AAEA,WAAO;AAAA,EACT;AAEA,EAAC,kBAA8C,kBAAkB;AACjE,EAAC,kBAA8C,qBAAqB;AAEpE,SAAO;AACT;",
6
+ "names": []
7
+ }
@@ -0,0 +1,15 @@
1
+ import { type ClassName } from './ClassName.js';
2
+ import { type ComponentTheme } from './ComponentTheme.js';
3
+ import { type ComponentThemeDefinitionElements } from './ComponentThemeDefinitionElements.js';
4
+ import { type ComponentThemeDefinitionVariants } from './ComponentThemeDefinitionVariants.js';
5
+ import { type ComponentThemeProps } from './ComponentThemeProps.js';
6
+ export declare function createUseComponentThemeReturn(componentTheme: ComponentTheme<{
7
+ variants: ComponentThemeDefinitionVariants;
8
+ elements: ComponentThemeDefinitionElements;
9
+ }> | ComponentTheme<{
10
+ elements: ComponentThemeDefinitionElements;
11
+ }> | ComponentTheme<{
12
+ variants: ComponentThemeDefinitionVariants;
13
+ }> | ComponentTheme<undefined>, themeProps?: ComponentThemeProps<{
14
+ variants: ComponentThemeDefinitionVariants;
15
+ }> | ComponentThemeProps<undefined>, elementName?: string): (baseClassName: ClassName, overrideClassName: ClassName) => string;
@@ -0,0 +1,51 @@
1
+ "use strict";
2
+ import { booleanToString } from "./booleanToString.js";
3
+ import { cx } from "./cx.js";
4
+ import { pickPropertyIfExists } from "./pickPropertyIfExists.js";
5
+ export function createUseComponentThemeReturn(componentTheme, themeProps, elementName) {
6
+ if (!themeProps || !("variants" in componentTheme)) {
7
+ return (baseClassName, overrideClassName) => cx(
8
+ baseClassName,
9
+ "classNames" in componentTheme ? pickPropertyIfExists(componentTheme.classNames, elementName) : "className" in componentTheme ? componentTheme.className : void 0,
10
+ overrideClassName
11
+ );
12
+ }
13
+ let { variants, compoundVariants } = componentTheme;
14
+ let getVariantClassNames = Object.keys(variants).map((variant) => {
15
+ let variantProp = themeProps[variant];
16
+ let variantKey = booleanToString(variantProp);
17
+ return pickPropertyIfExists(variants[variant]?.[variantKey], elementName);
18
+ });
19
+ let getCompoundVariantClassNames = [];
20
+ if (compoundVariants) {
21
+ for (let compoundVariant of compoundVariants) {
22
+ let { className, classNames, ...rest } = compoundVariant;
23
+ let matchesAllSelectors = true;
24
+ for (let [cvKey, cvSelector] of Object.entries(rest)) {
25
+ let selector = themeProps[cvKey];
26
+ if (Array.isArray(cvSelector)) {
27
+ if (!cvSelector.includes(selector)) {
28
+ matchesAllSelectors = false;
29
+ break;
30
+ }
31
+ } else if (selector !== cvSelector) {
32
+ matchesAllSelectors = false;
33
+ break;
34
+ }
35
+ }
36
+ if (matchesAllSelectors) {
37
+ getCompoundVariantClassNames.push(
38
+ "classNames" in compoundVariant ? pickPropertyIfExists(classNames, elementName) : className
39
+ );
40
+ }
41
+ }
42
+ }
43
+ return (baseClassName, overrideClassName) => cx(
44
+ baseClassName,
45
+ "classNames" in componentTheme ? pickPropertyIfExists(componentTheme.classNames, elementName) : "className" in componentTheme ? componentTheme.className : void 0,
46
+ getVariantClassNames,
47
+ getCompoundVariantClassNames,
48
+ overrideClassName
49
+ );
50
+ }
51
+ //# sourceMappingURL=createUseComponentThemeReturn.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../source/theme/internals/createUseComponentThemeReturn.ts"],
4
+ "sourcesContent": ["/* eslint-disable unicorn/consistent-destructuring -- destructuring leads to messy code because of complicated types */\nimport {booleanToString} from './booleanToString.js';\nimport {type ClassName} from './ClassName.js';\nimport {type ComponentTheme} from './ComponentTheme.js';\nimport {type ComponentThemeDefinitionElements} from './ComponentThemeDefinitionElements.js';\nimport {type ComponentThemeDefinitionVariants} from './ComponentThemeDefinitionVariants.js';\nimport {type ComponentThemeProps} from './ComponentThemeProps.js';\nimport {cx} from './cx.js';\nimport {pickPropertyIfExists} from './pickPropertyIfExists.js';\n\nexport function createUseComponentThemeReturn(\n componentTheme:\n | ComponentTheme<{\n variants: ComponentThemeDefinitionVariants;\n elements: ComponentThemeDefinitionElements;\n }>\n | ComponentTheme<{elements: ComponentThemeDefinitionElements}>\n | ComponentTheme<{variants: ComponentThemeDefinitionVariants}>\n | ComponentTheme<undefined>,\n themeProps?:\n | ComponentThemeProps<{variants: ComponentThemeDefinitionVariants}>\n | ComponentThemeProps<undefined>,\n elementName?: string,\n) {\n if (!themeProps || !('variants' in componentTheme)) {\n return (baseClassName: ClassName, overrideClassName: ClassName) =>\n cx(\n baseClassName,\n 'classNames' in componentTheme ?\n pickPropertyIfExists(componentTheme.classNames, elementName)\n : 'className' in componentTheme ? componentTheme.className\n : undefined,\n overrideClassName,\n );\n }\n\n let {variants, compoundVariants} = componentTheme;\n let getVariantClassNames = Object.keys(variants).map((variant) => {\n let variantProp = themeProps[variant as keyof typeof themeProps] as boolean | string;\n let variantKey = booleanToString(variantProp);\n\n return pickPropertyIfExists(variants[variant]?.[variantKey as 'false' | 'true'], elementName);\n });\n let getCompoundVariantClassNames: ClassName[] = [];\n\n if (compoundVariants) {\n for (let compoundVariant of compoundVariants) {\n let {className, classNames, ...rest} = compoundVariant;\n let matchesAllSelectors = true;\n\n for (let [cvKey, cvSelector] of Object.entries(rest)) {\n let selector = themeProps[cvKey as keyof typeof themeProps];\n\n if (Array.isArray(cvSelector)) {\n if (!cvSelector.includes(selector as string)) {\n matchesAllSelectors = false;\n\n break;\n }\n } else if (selector !== cvSelector) {\n matchesAllSelectors = false;\n\n break;\n }\n }\n\n if (matchesAllSelectors) {\n getCompoundVariantClassNames.push(\n ('classNames' in compoundVariant ?\n pickPropertyIfExists(classNames as Record<string, ClassName>, elementName)\n : className) as ClassName,\n );\n }\n }\n }\n\n return (baseClassName: ClassName, overrideClassName: ClassName) =>\n cx(\n baseClassName,\n 'classNames' in componentTheme ? pickPropertyIfExists(componentTheme.classNames, elementName)\n : 'className' in componentTheme ? componentTheme.className\n : undefined,\n getVariantClassNames,\n getCompoundVariantClassNames,\n overrideClassName,\n );\n}\n"],
5
+ "mappings": ";AACA,SAAQ,uBAAsB;AAM9B,SAAQ,UAAS;AACjB,SAAQ,4BAA2B;AAE5B,gBAAS,8BACd,gBAQA,YAGA,aACA;AACA,MAAI,CAAC,cAAc,EAAE,cAAc,iBAAiB;AAClD,WAAO,CAAC,eAA0B,sBAChC;AAAA,MACE;AAAA,MACA,gBAAgB,iBACd,qBAAqB,eAAe,YAAY,WAAW,IAC3D,eAAe,iBAAiB,eAAe,YAC/C;AAAA,MACF;AAAA,IACF;AAAA,EACJ;AAEA,MAAI,EAAC,UAAU,iBAAgB,IAAI;AACnC,MAAI,uBAAuB,OAAO,KAAK,QAAQ,EAAE,IAAI,CAAC,YAAY;AAChE,QAAI,cAAc,WAAW,OAAkC;AAC/D,QAAI,aAAa,gBAAgB,WAAW;AAE5C,WAAO,qBAAqB,SAAS,OAAO,IAAI,UAA8B,GAAG,WAAW;AAAA,EAC9F,CAAC;AACD,MAAI,+BAA4C,CAAC;AAEjD,MAAI,kBAAkB;AACpB,aAAS,mBAAmB,kBAAkB;AAC5C,UAAI,EAAC,WAAW,YAAY,GAAG,KAAI,IAAI;AACvC,UAAI,sBAAsB;AAE1B,eAAS,CAAC,OAAO,UAAU,KAAK,OAAO,QAAQ,IAAI,GAAG;AACpD,YAAI,WAAW,WAAW,KAAgC;AAE1D,YAAI,MAAM,QAAQ,UAAU,GAAG;AAC7B,cAAI,CAAC,WAAW,SAAS,QAAkB,GAAG;AAC5C,kCAAsB;AAEtB;AAAA,UACF;AAAA,QACF,WAAW,aAAa,YAAY;AAClC,gCAAsB;AAEtB;AAAA,QACF;AAAA,MACF;AAEA,UAAI,qBAAqB;AACvB,qCAA6B;AAAA,UAC1B,gBAAgB,kBACf,qBAAqB,YAAyC,WAAW,IACzE;AAAA,QACJ;AAAA,MACF;AAAA,IACF;AAAA,EACF;AAEA,SAAO,CAAC,eAA0B,sBAChC;AAAA,IACE;AAAA,IACA,gBAAgB,iBAAiB,qBAAqB,eAAe,YAAY,WAAW,IAC1F,eAAe,iBAAiB,eAAe,YAC/C;AAAA,IACF;AAAA,IACA;AAAA,IACA;AAAA,EACF;AACJ;",
6
+ "names": []
7
+ }
@@ -0,0 +1,2 @@
1
+ import { type ClassName } from './ClassName.js';
2
+ export declare function cx(...inputs: ClassName[]): string;
@@ -0,0 +1,6 @@
1
+ "use strict";
2
+ import { twMerge } from "tailwind-merge";
3
+ export function cx(...inputs) {
4
+ return twMerge(...inputs);
5
+ }
6
+ //# sourceMappingURL=cx.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../source/theme/internals/cx.ts"],
4
+ "sourcesContent": ["// import {type ClassValue, clsx} from 'clsx';\nimport {twMerge} from 'tailwind-merge';\n\nimport {type ClassName} from './ClassName.js';\n\n// TODO: is the merging done correctly? write some tests\nexport function cx(...inputs: ClassName[] /*ClassValue[]*/) {\n // return twMerge(clsx(inputs));\n return twMerge(...inputs);\n}\n"],
5
+ "mappings": ";AACA,SAAQ,eAAc;AAKf,gBAAS,MAAM,QAAsC;AAE1D,SAAO,QAAQ,GAAG,MAAM;AAC1B;",
6
+ "names": []
7
+ }
@@ -0,0 +1,4 @@
1
+ import { type ClassName } from './ClassName.js';
2
+ type PickPropertyIfExistsReturn<T extends ClassName | Record<string, ClassName> | undefined, U extends string | undefined> = U extends undefined ? T : T extends Record<string, ClassName> ? null : ClassName;
3
+ export declare function pickPropertyIfExists<T extends ClassName | Record<string, ClassName> | undefined, U extends string | undefined>(object: T, property?: U): PickPropertyIfExistsReturn<T, U>;
4
+ export {};
@@ -0,0 +1,11 @@
1
+ "use strict";
2
+ export function pickPropertyIfExists(object, property) {
3
+ if (!property) {
4
+ return object;
5
+ }
6
+ if (Array.isArray(object) || !object || typeof object === "string") {
7
+ return null;
8
+ }
9
+ return object[property];
10
+ }
11
+ //# sourceMappingURL=pickPropertyIfExists.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../source/theme/internals/pickPropertyIfExists.ts"],
4
+ "sourcesContent": ["import {type ClassName} from './ClassName.js';\n\ntype PickPropertyIfExistsReturn<\n T extends ClassName | Record<string, ClassName> | undefined,\n U extends string | undefined,\n> =\n U extends undefined ? T\n : T extends Record<string, ClassName> ? null\n : ClassName;\n\nexport function pickPropertyIfExists<\n T extends ClassName | Record<string, ClassName> | undefined,\n U extends string | undefined,\n>(object: T, property?: U): PickPropertyIfExistsReturn<T, U> {\n if (!property) {\n return object as PickPropertyIfExistsReturn<T, U>;\n }\n\n if (Array.isArray(object) || !object || typeof object === 'string') {\n return null as PickPropertyIfExistsReturn<T, U>;\n }\n\n return object[property] as PickPropertyIfExistsReturn<T, U>;\n}\n"],
5
+ "mappings": ";AAUO,gBAAS,qBAGd,QAAW,UAAgD;AAC3D,MAAI,CAAC,UAAU;AACb,WAAO;AAAA,EACT;AAEA,MAAI,MAAM,QAAQ,MAAM,KAAK,CAAC,UAAU,OAAO,WAAW,UAAU;AAClE,WAAO;AAAA,EACT;AAEA,SAAO,OAAO,QAAQ;AACxB;",
6
+ "names": []
7
+ }
@@ -0,0 +1,217 @@
1
+ /// <reference types="react" resolution-mode="require"/>
2
+ export declare const themeContext: import("react").Context<import("@jakubmazanec/ts-utils").Simplify<{
3
+ Button: {
4
+ className?: import("./ClassName.js").ClassName;
5
+ variants: import("./ComponentThemeVariants.js").ComponentThemeVariants<{
6
+ readonly type: ["solid", "outline", "text", "icon"];
7
+ readonly size: ["small", "medium", "large"];
8
+ readonly disabled: [true, false];
9
+ }, undefined>;
10
+ compoundVariants?: import("./ComponentThemeCompoundVariants.js").ComponentThemeCompoundVariants<{
11
+ readonly type: ["solid", "outline", "text", "icon"];
12
+ readonly size: ["small", "medium", "large"];
13
+ readonly disabled: [true, false];
14
+ }, undefined>;
15
+ };
16
+ } & {
17
+ CheckboxField: {
18
+ className: import("./ClassName.js").ClassName;
19
+ };
20
+ } & {
21
+ Checkbox: {
22
+ classNames?: {
23
+ root: import("./ClassName.js").ClassName;
24
+ checked: import("./ClassName.js").ClassName;
25
+ unchecked: import("./ClassName.js").ClassName;
26
+ icon: import("./ClassName.js").ClassName;
27
+ };
28
+ variants: import("./ComponentThemeVariants.js").ComponentThemeVariants<{
29
+ readonly disabled: [true, false];
30
+ }, ["root", "checked", "unchecked", "icon"]>;
31
+ compoundVariants?: import("./ComponentThemeCompoundVariants.js").ComponentThemeCompoundVariants<{
32
+ readonly disabled: [true, false];
33
+ }, ["root", "checked", "unchecked", "icon"]>;
34
+ };
35
+ } & {
36
+ Combobox: {
37
+ classNames?: {
38
+ root: import("./ClassName.js").ClassName;
39
+ item: import("./ClassName.js").ClassName;
40
+ icon: import("./ClassName.js").ClassName;
41
+ input: import("./ClassName.js").ClassName;
42
+ label: import("./ClassName.js").ClassName;
43
+ panel: import("./ClassName.js").ClassName;
44
+ items: import("./ClassName.js").ClassName;
45
+ };
46
+ variants: import("./ComponentThemeVariants.js").ComponentThemeVariants<{
47
+ readonly disabled: [true, false];
48
+ }, ["root", "label", "icon", "panel", "items", "item", "input"]>;
49
+ compoundVariants?: import("./ComponentThemeCompoundVariants.js").ComponentThemeCompoundVariants<{
50
+ readonly disabled: [true, false];
51
+ }, ["root", "label", "icon", "panel", "items", "item", "input"]>;
52
+ };
53
+ } & {
54
+ ConfirmDialog: {
55
+ classNames: {
56
+ root: import("./ClassName.js").ClassName;
57
+ backdrop: import("./ClassName.js").ClassName;
58
+ };
59
+ };
60
+ } & {
61
+ DialogPanel: {
62
+ className: import("./ClassName.js").ClassName;
63
+ };
64
+ } & {
65
+ Dialog: {
66
+ classNames: {
67
+ root: import("./ClassName.js").ClassName;
68
+ backdrop: import("./ClassName.js").ClassName;
69
+ };
70
+ };
71
+ } & {
72
+ DialogTitle: {
73
+ className: import("./ClassName.js").ClassName;
74
+ };
75
+ } & {
76
+ Error: {
77
+ className: import("./ClassName.js").ClassName;
78
+ };
79
+ } & {
80
+ Field: {
81
+ className: import("./ClassName.js").ClassName;
82
+ };
83
+ } & {
84
+ Form: {
85
+ className: import("./ClassName.js").ClassName;
86
+ };
87
+ } & {
88
+ Input: {
89
+ classNames?: {
90
+ root: import("./ClassName.js").ClassName;
91
+ icon: import("./ClassName.js").ClassName;
92
+ input: import("./ClassName.js").ClassName;
93
+ clearButton: import("./ClassName.js").ClassName;
94
+ };
95
+ variants: import("./ComponentThemeVariants.js").ComponentThemeVariants<{
96
+ readonly disabled: [true, false];
97
+ }, ["root", "input", "icon", "clearButton"]>;
98
+ compoundVariants?: import("./ComponentThemeCompoundVariants.js").ComponentThemeCompoundVariants<{
99
+ readonly disabled: [true, false];
100
+ }, ["root", "input", "icon", "clearButton"]>;
101
+ };
102
+ } & {
103
+ Label: {
104
+ className: import("./ClassName.js").ClassName;
105
+ };
106
+ } & {
107
+ Listbox: {
108
+ classNames?: {
109
+ root: import("./ClassName.js").ClassName;
110
+ item: import("./ClassName.js").ClassName;
111
+ icon: import("./ClassName.js").ClassName;
112
+ label: import("./ClassName.js").ClassName;
113
+ panel: import("./ClassName.js").ClassName;
114
+ items: import("./ClassName.js").ClassName;
115
+ };
116
+ variants: import("./ComponentThemeVariants.js").ComponentThemeVariants<{
117
+ readonly disabled: [true, false];
118
+ }, ["root", "label", "icon", "panel", "items", "item"]>;
119
+ compoundVariants?: import("./ComponentThemeCompoundVariants.js").ComponentThemeCompoundVariants<{
120
+ readonly disabled: [true, false];
121
+ }, ["root", "label", "icon", "panel", "items", "item"]>;
122
+ };
123
+ } & {
124
+ MenuButton: {
125
+ className: import("./ClassName.js").ClassName;
126
+ };
127
+ } & {
128
+ MenuItems: {
129
+ className: import("./ClassName.js").ClassName;
130
+ };
131
+ } & {
132
+ MenuItem: {
133
+ className: import("./ClassName.js").ClassName;
134
+ };
135
+ } & {
136
+ Menu: {
137
+ className: import("./ClassName.js").ClassName;
138
+ };
139
+ } & {
140
+ PopoverButton: {
141
+ className: import("./ClassName.js").ClassName;
142
+ };
143
+ } & {
144
+ PopoverPanel: {
145
+ className: import("./ClassName.js").ClassName;
146
+ };
147
+ } & {
148
+ Popover: {
149
+ className: import("./ClassName.js").ClassName;
150
+ };
151
+ } & {
152
+ RadioField: {
153
+ className: import("./ClassName.js").ClassName;
154
+ };
155
+ } & {
156
+ RadioGroupField: {
157
+ className?: import("./ClassName.js").ClassName;
158
+ variants: import("./ComponentThemeVariants.js").ComponentThemeVariants<{
159
+ readonly disabled: [true, false];
160
+ }, undefined>;
161
+ compoundVariants?: import("./ComponentThemeCompoundVariants.js").ComponentThemeCompoundVariants<{
162
+ readonly disabled: [true, false];
163
+ }, undefined>;
164
+ };
165
+ } & {
166
+ Radio: {
167
+ classNames?: {
168
+ root: import("./ClassName.js").ClassName;
169
+ checked: import("./ClassName.js").ClassName;
170
+ unchecked: import("./ClassName.js").ClassName;
171
+ icon: import("./ClassName.js").ClassName;
172
+ };
173
+ variants: import("./ComponentThemeVariants.js").ComponentThemeVariants<{
174
+ readonly disabled: [true, false];
175
+ }, ["root", "checked", "unchecked", "icon"]>;
176
+ compoundVariants?: import("./ComponentThemeCompoundVariants.js").ComponentThemeCompoundVariants<{
177
+ readonly disabled: [true, false];
178
+ }, ["root", "checked", "unchecked", "icon"]>;
179
+ };
180
+ } & {
181
+ TableCell: {
182
+ className: import("./ClassName.js").ClassName;
183
+ };
184
+ } & {
185
+ TableHeaderCell: {
186
+ className: import("./ClassName.js").ClassName;
187
+ };
188
+ } & {
189
+ TableHeader: {
190
+ className: import("./ClassName.js").ClassName;
191
+ };
192
+ } & {
193
+ TableRow: {
194
+ className: import("./ClassName.js").ClassName;
195
+ };
196
+ } & {
197
+ Table: {
198
+ classNames: {
199
+ root: import("./ClassName.js").ClassName;
200
+ table: import("./ClassName.js").ClassName;
201
+ };
202
+ };
203
+ } & {
204
+ Textarea: {
205
+ classNames?: {
206
+ root: import("./ClassName.js").ClassName;
207
+ icon: import("./ClassName.js").ClassName;
208
+ input: import("./ClassName.js").ClassName;
209
+ };
210
+ variants: import("./ComponentThemeVariants.js").ComponentThemeVariants<{
211
+ readonly disabled: [true, false];
212
+ }, ["root", "input", "icon"]>;
213
+ compoundVariants?: import("./ComponentThemeCompoundVariants.js").ComponentThemeCompoundVariants<{
214
+ readonly disabled: [true, false];
215
+ }, ["root", "input", "icon"]>;
216
+ };
217
+ }> | undefined>;
@@ -0,0 +1,4 @@
1
+ "use strict";
2
+ import { createContext } from "react";
3
+ export const themeContext = createContext(void 0);
4
+ //# sourceMappingURL=themeContext.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../source/theme/internals/themeContext.ts"],
4
+ "sourcesContent": ["import {createContext} from 'react';\n\nimport {type Theme} from '../Theme.js';\n\nexport const themeContext = createContext<Theme | undefined>(undefined);\n"],
5
+ "mappings": ";AAAA,SAAQ,qBAAoB;AAIrB,aAAM,eAAe,cAAiC,MAAS;",
6
+ "names": []
7
+ }
@@ -0,0 +1,216 @@
1
+ export declare function useTheme(): import("@jakubmazanec/ts-utils").Simplify<{
2
+ Button: {
3
+ className?: import("./ClassName.js").ClassName;
4
+ variants: import("./ComponentThemeVariants.js").ComponentThemeVariants<{
5
+ readonly type: ["solid", "outline", "text", "icon"];
6
+ readonly size: ["small", "medium", "large"];
7
+ readonly disabled: [true, false];
8
+ }, undefined>;
9
+ compoundVariants?: import("./ComponentThemeCompoundVariants.js").ComponentThemeCompoundVariants<{
10
+ readonly type: ["solid", "outline", "text", "icon"];
11
+ readonly size: ["small", "medium", "large"];
12
+ readonly disabled: [true, false];
13
+ }, undefined>;
14
+ };
15
+ } & {
16
+ CheckboxField: {
17
+ className: import("./ClassName.js").ClassName;
18
+ };
19
+ } & {
20
+ Checkbox: {
21
+ classNames?: {
22
+ root: import("./ClassName.js").ClassName;
23
+ checked: import("./ClassName.js").ClassName;
24
+ unchecked: import("./ClassName.js").ClassName;
25
+ icon: import("./ClassName.js").ClassName;
26
+ };
27
+ variants: import("./ComponentThemeVariants.js").ComponentThemeVariants<{
28
+ readonly disabled: [true, false];
29
+ }, ["root", "checked", "unchecked", "icon"]>;
30
+ compoundVariants?: import("./ComponentThemeCompoundVariants.js").ComponentThemeCompoundVariants<{
31
+ readonly disabled: [true, false];
32
+ }, ["root", "checked", "unchecked", "icon"]>;
33
+ };
34
+ } & {
35
+ Combobox: {
36
+ classNames?: {
37
+ root: import("./ClassName.js").ClassName;
38
+ item: import("./ClassName.js").ClassName;
39
+ icon: import("./ClassName.js").ClassName;
40
+ input: import("./ClassName.js").ClassName;
41
+ label: import("./ClassName.js").ClassName;
42
+ panel: import("./ClassName.js").ClassName;
43
+ items: import("./ClassName.js").ClassName;
44
+ };
45
+ variants: import("./ComponentThemeVariants.js").ComponentThemeVariants<{
46
+ readonly disabled: [true, false];
47
+ }, ["root", "label", "icon", "panel", "items", "item", "input"]>;
48
+ compoundVariants?: import("./ComponentThemeCompoundVariants.js").ComponentThemeCompoundVariants<{
49
+ readonly disabled: [true, false];
50
+ }, ["root", "label", "icon", "panel", "items", "item", "input"]>;
51
+ };
52
+ } & {
53
+ ConfirmDialog: {
54
+ classNames: {
55
+ root: import("./ClassName.js").ClassName;
56
+ backdrop: import("./ClassName.js").ClassName;
57
+ };
58
+ };
59
+ } & {
60
+ DialogPanel: {
61
+ className: import("./ClassName.js").ClassName;
62
+ };
63
+ } & {
64
+ Dialog: {
65
+ classNames: {
66
+ root: import("./ClassName.js").ClassName;
67
+ backdrop: import("./ClassName.js").ClassName;
68
+ };
69
+ };
70
+ } & {
71
+ DialogTitle: {
72
+ className: import("./ClassName.js").ClassName;
73
+ };
74
+ } & {
75
+ Error: {
76
+ className: import("./ClassName.js").ClassName;
77
+ };
78
+ } & {
79
+ Field: {
80
+ className: import("./ClassName.js").ClassName;
81
+ };
82
+ } & {
83
+ Form: {
84
+ className: import("./ClassName.js").ClassName;
85
+ };
86
+ } & {
87
+ Input: {
88
+ classNames?: {
89
+ root: import("./ClassName.js").ClassName;
90
+ icon: import("./ClassName.js").ClassName;
91
+ input: import("./ClassName.js").ClassName;
92
+ clearButton: import("./ClassName.js").ClassName;
93
+ };
94
+ variants: import("./ComponentThemeVariants.js").ComponentThemeVariants<{
95
+ readonly disabled: [true, false];
96
+ }, ["root", "input", "icon", "clearButton"]>;
97
+ compoundVariants?: import("./ComponentThemeCompoundVariants.js").ComponentThemeCompoundVariants<{
98
+ readonly disabled: [true, false];
99
+ }, ["root", "input", "icon", "clearButton"]>;
100
+ };
101
+ } & {
102
+ Label: {
103
+ className: import("./ClassName.js").ClassName;
104
+ };
105
+ } & {
106
+ Listbox: {
107
+ classNames?: {
108
+ root: import("./ClassName.js").ClassName;
109
+ item: import("./ClassName.js").ClassName;
110
+ icon: import("./ClassName.js").ClassName;
111
+ label: import("./ClassName.js").ClassName;
112
+ panel: import("./ClassName.js").ClassName;
113
+ items: import("./ClassName.js").ClassName;
114
+ };
115
+ variants: import("./ComponentThemeVariants.js").ComponentThemeVariants<{
116
+ readonly disabled: [true, false];
117
+ }, ["root", "label", "icon", "panel", "items", "item"]>;
118
+ compoundVariants?: import("./ComponentThemeCompoundVariants.js").ComponentThemeCompoundVariants<{
119
+ readonly disabled: [true, false];
120
+ }, ["root", "label", "icon", "panel", "items", "item"]>;
121
+ };
122
+ } & {
123
+ MenuButton: {
124
+ className: import("./ClassName.js").ClassName;
125
+ };
126
+ } & {
127
+ MenuItems: {
128
+ className: import("./ClassName.js").ClassName;
129
+ };
130
+ } & {
131
+ MenuItem: {
132
+ className: import("./ClassName.js").ClassName;
133
+ };
134
+ } & {
135
+ Menu: {
136
+ className: import("./ClassName.js").ClassName;
137
+ };
138
+ } & {
139
+ PopoverButton: {
140
+ className: import("./ClassName.js").ClassName;
141
+ };
142
+ } & {
143
+ PopoverPanel: {
144
+ className: import("./ClassName.js").ClassName;
145
+ };
146
+ } & {
147
+ Popover: {
148
+ className: import("./ClassName.js").ClassName;
149
+ };
150
+ } & {
151
+ RadioField: {
152
+ className: import("./ClassName.js").ClassName;
153
+ };
154
+ } & {
155
+ RadioGroupField: {
156
+ className?: import("./ClassName.js").ClassName;
157
+ variants: import("./ComponentThemeVariants.js").ComponentThemeVariants<{
158
+ readonly disabled: [true, false];
159
+ }, undefined>;
160
+ compoundVariants?: import("./ComponentThemeCompoundVariants.js").ComponentThemeCompoundVariants<{
161
+ readonly disabled: [true, false];
162
+ }, undefined>;
163
+ };
164
+ } & {
165
+ Radio: {
166
+ classNames?: {
167
+ root: import("./ClassName.js").ClassName;
168
+ checked: import("./ClassName.js").ClassName;
169
+ unchecked: import("./ClassName.js").ClassName;
170
+ icon: import("./ClassName.js").ClassName;
171
+ };
172
+ variants: import("./ComponentThemeVariants.js").ComponentThemeVariants<{
173
+ readonly disabled: [true, false];
174
+ }, ["root", "checked", "unchecked", "icon"]>;
175
+ compoundVariants?: import("./ComponentThemeCompoundVariants.js").ComponentThemeCompoundVariants<{
176
+ readonly disabled: [true, false];
177
+ }, ["root", "checked", "unchecked", "icon"]>;
178
+ };
179
+ } & {
180
+ TableCell: {
181
+ className: import("./ClassName.js").ClassName;
182
+ };
183
+ } & {
184
+ TableHeaderCell: {
185
+ className: import("./ClassName.js").ClassName;
186
+ };
187
+ } & {
188
+ TableHeader: {
189
+ className: import("./ClassName.js").ClassName;
190
+ };
191
+ } & {
192
+ TableRow: {
193
+ className: import("./ClassName.js").ClassName;
194
+ };
195
+ } & {
196
+ Table: {
197
+ classNames: {
198
+ root: import("./ClassName.js").ClassName;
199
+ table: import("./ClassName.js").ClassName;
200
+ };
201
+ };
202
+ } & {
203
+ Textarea: {
204
+ classNames?: {
205
+ root: import("./ClassName.js").ClassName;
206
+ icon: import("./ClassName.js").ClassName;
207
+ input: import("./ClassName.js").ClassName;
208
+ };
209
+ variants: import("./ComponentThemeVariants.js").ComponentThemeVariants<{
210
+ readonly disabled: [true, false];
211
+ }, ["root", "input", "icon"]>;
212
+ compoundVariants?: import("./ComponentThemeCompoundVariants.js").ComponentThemeCompoundVariants<{
213
+ readonly disabled: [true, false];
214
+ }, ["root", "input", "icon"]>;
215
+ };
216
+ }> | undefined;
@@ -0,0 +1,7 @@
1
+ "use strict";
2
+ import { useContext } from "react";
3
+ import { themeContext } from "./themeContext.js";
4
+ export function useTheme() {
5
+ return useContext(themeContext);
6
+ }
7
+ //# sourceMappingURL=useTheme.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../source/theme/internals/useTheme.ts"],
4
+ "sourcesContent": ["import {useContext} from 'react';\n\nimport {themeContext} from './themeContext.js';\n\nexport function useTheme() {\n return useContext(themeContext);\n}\n"],
5
+ "mappings": ";AAAA,SAAQ,kBAAiB;AAEzB,SAAQ,oBAAmB;AAEpB,gBAAS,WAAW;AACzB,SAAO,WAAW,YAAY;AAChC;",
6
+ "names": []
7
+ }