siesa-ui-kit 1.0.6 → 1.0.8

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 (297) hide show
  1. package/README.md +115 -89
  2. package/dist/ButtonTest.d.ts +6 -0
  3. package/dist/ButtonTest.d.ts.map +1 -0
  4. package/dist/components/Alert/Alert.d.ts +23 -0
  5. package/dist/components/Alert/Alert.d.ts.map +1 -0
  6. package/dist/components/Alert/Alert.types.d.ts +46 -0
  7. package/dist/components/Alert/Alert.types.d.ts.map +1 -0
  8. package/dist/components/Avatar/Avatar.d.ts +41 -0
  9. package/dist/components/Avatar/Avatar.d.ts.map +1 -0
  10. package/dist/components/Avatar/Avatar.types.d.ts +46 -0
  11. package/dist/components/Avatar/Avatar.types.d.ts.map +1 -0
  12. package/dist/components/Badge/Badge.d.ts +42 -0
  13. package/dist/components/Badge/Badge.d.ts.map +1 -0
  14. package/dist/components/Badge/Badge.types.d.ts +32 -0
  15. package/dist/components/Badge/Badge.types.d.ts.map +1 -0
  16. package/dist/components/Button/Button.d.ts +84 -0
  17. package/dist/components/Button/Button.d.ts.map +1 -0
  18. package/dist/components/Button/Button.types.d.ts +162 -0
  19. package/dist/components/Button/Button.types.d.ts.map +1 -0
  20. package/dist/components/Button/icons.d.ts +26 -0
  21. package/dist/components/Button/icons.d.ts.map +1 -0
  22. package/dist/components/Button/index.d.ts +4 -0
  23. package/dist/components/Button/index.d.ts.map +1 -0
  24. package/dist/components/Checkbox/Checkbox.d.ts +31 -0
  25. package/dist/components/Checkbox/Checkbox.d.ts.map +1 -0
  26. package/dist/components/Checkbox/Checkbox.types.d.ts +53 -0
  27. package/dist/components/Checkbox/Checkbox.types.d.ts.map +1 -0
  28. package/dist/components/DescriptionList/DescriptionList.d.ts +38 -0
  29. package/dist/components/DescriptionList/DescriptionList.d.ts.map +1 -0
  30. package/dist/components/DescriptionList/DescriptionList.types.d.ts +27 -0
  31. package/dist/components/DescriptionList/DescriptionList.types.d.ts.map +1 -0
  32. package/dist/components/Divider/Divider.d.ts +33 -0
  33. package/dist/components/Divider/Divider.d.ts.map +1 -0
  34. package/dist/components/Divider/Divider.types.d.ts +22 -0
  35. package/dist/components/Divider/Divider.types.d.ts.map +1 -0
  36. package/dist/components/Dropdown/Dropdown.d.ts +66 -0
  37. package/dist/components/Dropdown/Dropdown.d.ts.map +1 -0
  38. package/dist/components/Dropdown/Dropdown.types.d.ts +124 -0
  39. package/dist/components/Dropdown/Dropdown.types.d.ts.map +1 -0
  40. package/dist/components/Dropdown/icons.d.ts +10 -0
  41. package/dist/components/Dropdown/icons.d.ts.map +1 -0
  42. package/dist/components/Dropdown/index.d.ts +4 -0
  43. package/dist/components/Dropdown/index.d.ts.map +1 -0
  44. package/dist/components/DropdownItemCollapsible/DropdownItemCollapsible.d.ts +101 -0
  45. package/dist/components/DropdownItemCollapsible/DropdownItemCollapsible.d.ts.map +1 -0
  46. package/dist/components/DropdownItemCollapsible/DropdownItemCollapsible.types.d.ts +95 -0
  47. package/dist/components/DropdownItemCollapsible/DropdownItemCollapsible.types.d.ts.map +1 -0
  48. package/dist/components/DropdownItemCollapsible/icons.d.ts +19 -0
  49. package/dist/components/DropdownItemCollapsible/icons.d.ts.map +1 -0
  50. package/dist/components/DropdownItemCollapsible/index.d.ts +9 -0
  51. package/dist/components/DropdownItemCollapsible/index.d.ts.map +1 -0
  52. package/dist/components/DropdownItemHeading/DropdownItemHeading.d.ts +75 -0
  53. package/dist/components/DropdownItemHeading/DropdownItemHeading.d.ts.map +1 -0
  54. package/dist/components/DropdownItemHeading/DropdownItemHeading.types.d.ts +85 -0
  55. package/dist/components/DropdownItemHeading/DropdownItemHeading.types.d.ts.map +1 -0
  56. package/dist/components/DropdownItemHeading/icons.d.ts +48 -0
  57. package/dist/components/DropdownItemHeading/icons.d.ts.map +1 -0
  58. package/dist/components/DropdownItemHeading/index.d.ts +4 -0
  59. package/dist/components/DropdownItemHeading/index.d.ts.map +1 -0
  60. package/dist/components/Input/Input.d.ts +40 -0
  61. package/dist/components/Input/Input.d.ts.map +1 -0
  62. package/dist/components/Input/Input.types.d.ts +71 -0
  63. package/dist/components/Input/Input.types.d.ts.map +1 -0
  64. package/dist/components/Input/icons.d.ts +15 -0
  65. package/dist/components/Input/icons.d.ts.map +1 -0
  66. package/dist/components/Input/index.d.ts +3 -0
  67. package/dist/components/Input/index.d.ts.map +1 -0
  68. package/dist/components/LoginView/LoginView.d.ts +36 -0
  69. package/dist/components/LoginView/LoginView.d.ts.map +1 -0
  70. package/dist/components/LoginView/LoginView.types.d.ts +46 -0
  71. package/dist/components/LoginView/LoginView.types.d.ts.map +1 -0
  72. package/dist/components/LoginView/icons.d.ts +18 -0
  73. package/dist/components/LoginView/icons.d.ts.map +1 -0
  74. package/dist/components/LoginView/index.d.ts +4 -0
  75. package/dist/components/LoginView/index.d.ts.map +1 -0
  76. package/dist/components/Navbar/Navbar.d.ts +63 -0
  77. package/dist/components/Navbar/Navbar.d.ts.map +1 -0
  78. package/dist/components/Navbar/Navbar.types.d.ts +194 -0
  79. package/dist/components/Navbar/Navbar.types.d.ts.map +1 -0
  80. package/dist/components/Navbar/icons.d.ts +12 -0
  81. package/dist/components/Navbar/icons.d.ts.map +1 -0
  82. package/dist/components/Navbar/index.d.ts +4 -0
  83. package/dist/components/Navbar/index.d.ts.map +1 -0
  84. package/dist/components/NavigationBar/NavigationBar.d.ts +75 -0
  85. package/dist/components/NavigationBar/NavigationBar.d.ts.map +1 -0
  86. package/dist/components/NavigationBar/NavigationBar.types.d.ts +63 -0
  87. package/dist/components/NavigationBar/NavigationBar.types.d.ts.map +1 -0
  88. package/dist/components/NavigationBar/index.d.ts +3 -0
  89. package/dist/components/NavigationBar/index.d.ts.map +1 -0
  90. package/dist/components/NavigationRail/NavigationRail.d.ts +7 -0
  91. package/dist/components/NavigationRail/NavigationRail.d.ts.map +1 -0
  92. package/dist/components/NavigationRail/NavigationRail.types.d.ts +92 -0
  93. package/dist/components/NavigationRail/NavigationRail.types.d.ts.map +1 -0
  94. package/dist/components/NavigationRail/index.d.ts +3 -0
  95. package/dist/components/NavigationRail/index.d.ts.map +1 -0
  96. package/dist/components/NavigationRailItem/NavigationRailItem.d.ts +90 -0
  97. package/dist/components/NavigationRailItem/NavigationRailItem.d.ts.map +1 -0
  98. package/dist/components/NavigationRailItem/NavigationRailItem.types.d.ts +155 -0
  99. package/dist/components/NavigationRailItem/NavigationRailItem.types.d.ts.map +1 -0
  100. package/dist/components/NavigationRailItem/index.d.ts +3 -0
  101. package/dist/components/NavigationRailItem/index.d.ts.map +1 -0
  102. package/dist/components/NavigationRailPanel/NavigationRailPanel.d.ts +124 -0
  103. package/dist/components/NavigationRailPanel/NavigationRailPanel.d.ts.map +1 -0
  104. package/dist/components/NavigationRailPanel/NavigationRailPanel.types.d.ts +154 -0
  105. package/dist/components/NavigationRailPanel/NavigationRailPanel.types.d.ts.map +1 -0
  106. package/dist/components/NavigationRailPanel/index.d.ts +3 -0
  107. package/dist/components/NavigationRailPanel/index.d.ts.map +1 -0
  108. package/dist/components/NavigationRailTypes/NavigationRailTypes.d.ts +99 -0
  109. package/dist/components/NavigationRailTypes/NavigationRailTypes.d.ts.map +1 -0
  110. package/dist/components/NavigationRailTypes/NavigationRailTypes.types.d.ts +111 -0
  111. package/dist/components/NavigationRailTypes/NavigationRailTypes.types.d.ts.map +1 -0
  112. package/dist/components/NavigationRailTypes/icons.d.ts +58 -0
  113. package/dist/components/NavigationRailTypes/icons.d.ts.map +1 -0
  114. package/dist/components/NavigationRailTypes/index.d.ts +4 -0
  115. package/dist/components/NavigationRailTypes/index.d.ts.map +1 -0
  116. package/dist/components/Notification/Notification.d.ts +52 -0
  117. package/dist/components/Notification/Notification.d.ts.map +1 -0
  118. package/dist/components/Notification/Notification.types.d.ts +138 -0
  119. package/dist/components/Notification/Notification.types.d.ts.map +1 -0
  120. package/dist/components/Notification/index.d.ts +3 -0
  121. package/dist/components/Notification/index.d.ts.map +1 -0
  122. package/dist/components/POSConvention/POSConvention.d.ts +55 -0
  123. package/dist/components/POSConvention/POSConvention.d.ts.map +1 -0
  124. package/dist/components/POSConvention/POSConvention.types.d.ts +37 -0
  125. package/dist/components/POSConvention/POSConvention.types.d.ts.map +1 -0
  126. package/dist/components/POSConvention/icons.d.ts +21 -0
  127. package/dist/components/POSConvention/icons.d.ts.map +1 -0
  128. package/dist/components/POSConvention/index.d.ts +4 -0
  129. package/dist/components/POSConvention/index.d.ts.map +1 -0
  130. package/dist/components/POSLocationButton/POSLocationButton.d.ts +73 -0
  131. package/dist/components/POSLocationButton/POSLocationButton.d.ts.map +1 -0
  132. package/dist/components/POSLocationButton/POSLocationButton.types.d.ts +75 -0
  133. package/dist/components/POSLocationButton/POSLocationButton.types.d.ts.map +1 -0
  134. package/dist/components/POSLocationButton/icons.d.ts +37 -0
  135. package/dist/components/POSLocationButton/icons.d.ts.map +1 -0
  136. package/dist/components/POSLocationButton/index.d.ts +4 -0
  137. package/dist/components/POSLocationButton/index.d.ts.map +1 -0
  138. package/dist/components/POSNumberButton/POSNumberButton.d.ts +61 -0
  139. package/dist/components/POSNumberButton/POSNumberButton.d.ts.map +1 -0
  140. package/dist/components/POSNumberButton/POSNumberButton.types.d.ts +43 -0
  141. package/dist/components/POSNumberButton/POSNumberButton.types.d.ts.map +1 -0
  142. package/dist/components/POSNumberButton/index.d.ts +3 -0
  143. package/dist/components/POSNumberButton/index.d.ts.map +1 -0
  144. package/dist/components/POSProductButton/POSProductButton.d.ts +59 -0
  145. package/dist/components/POSProductButton/POSProductButton.d.ts.map +1 -0
  146. package/dist/components/POSProductButton/POSProductButton.types.d.ts +40 -0
  147. package/dist/components/POSProductButton/POSProductButton.types.d.ts.map +1 -0
  148. package/dist/components/POSProductButton/index.d.ts +3 -0
  149. package/dist/components/POSProductButton/index.d.ts.map +1 -0
  150. package/dist/components/POSProductCard/POSProductCard.d.ts +68 -0
  151. package/dist/components/POSProductCard/POSProductCard.d.ts.map +1 -0
  152. package/dist/components/POSProductCard/POSProductCard.types.d.ts +67 -0
  153. package/dist/components/POSProductCard/POSProductCard.types.d.ts.map +1 -0
  154. package/dist/components/POSProductCard/icons.d.ts +10 -0
  155. package/dist/components/POSProductCard/icons.d.ts.map +1 -0
  156. package/dist/components/POSProductCard/index.d.ts +3 -0
  157. package/dist/components/POSProductCard/index.d.ts.map +1 -0
  158. package/dist/components/POSProductSidebarItems/POSProductSidebarItems.d.ts +57 -0
  159. package/dist/components/POSProductSidebarItems/POSProductSidebarItems.d.ts.map +1 -0
  160. package/dist/components/POSProductSidebarItems/POSProductSidebarItems.types.d.ts +85 -0
  161. package/dist/components/POSProductSidebarItems/POSProductSidebarItems.types.d.ts.map +1 -0
  162. package/dist/components/POSProductSidebarItems/icons.d.ts +9 -0
  163. package/dist/components/POSProductSidebarItems/icons.d.ts.map +1 -0
  164. package/dist/components/POSProductSidebarItems/index.d.ts +4 -0
  165. package/dist/components/POSProductSidebarItems/index.d.ts.map +1 -0
  166. package/dist/components/POSTable/POSTable.d.ts +75 -0
  167. package/dist/components/POSTable/POSTable.d.ts.map +1 -0
  168. package/dist/components/POSTable/POSTable.types.d.ts +71 -0
  169. package/dist/components/POSTable/POSTable.types.d.ts.map +1 -0
  170. package/dist/components/POSTable/index.d.ts +3 -0
  171. package/dist/components/POSTable/index.d.ts.map +1 -0
  172. package/dist/components/Pagination/Pagination.d.ts +29 -0
  173. package/dist/components/Pagination/Pagination.d.ts.map +1 -0
  174. package/dist/components/Pagination/Pagination.types.d.ts +79 -0
  175. package/dist/components/Pagination/Pagination.types.d.ts.map +1 -0
  176. package/dist/components/Pagination/icons.d.ts +18 -0
  177. package/dist/components/Pagination/icons.d.ts.map +1 -0
  178. package/dist/components/Pagination/index.d.ts +4 -0
  179. package/dist/components/Pagination/index.d.ts.map +1 -0
  180. package/dist/components/Quantity/Quantity.d.ts +38 -0
  181. package/dist/components/Quantity/Quantity.d.ts.map +1 -0
  182. package/dist/components/Quantity/Quantity.types.d.ts +59 -0
  183. package/dist/components/Quantity/Quantity.types.d.ts.map +1 -0
  184. package/dist/components/Radio/Radio.d.ts +45 -0
  185. package/dist/components/Radio/Radio.d.ts.map +1 -0
  186. package/dist/components/Radio/Radio.types.d.ts +115 -0
  187. package/dist/components/Radio/Radio.types.d.ts.map +1 -0
  188. package/dist/components/Select/Select.d.ts +37 -0
  189. package/dist/components/Select/Select.d.ts.map +1 -0
  190. package/dist/components/Select/Select.types.d.ts +124 -0
  191. package/dist/components/Select/Select.types.d.ts.map +1 -0
  192. package/dist/components/Select/icons.d.ts +16 -0
  193. package/dist/components/Select/icons.d.ts.map +1 -0
  194. package/dist/components/Select/index.d.ts +4 -0
  195. package/dist/components/Select/index.d.ts.map +1 -0
  196. package/dist/components/SignUpView/SignUpView.d.ts +38 -0
  197. package/dist/components/SignUpView/SignUpView.d.ts.map +1 -0
  198. package/dist/components/SignUpView/SignUpView.types.d.ts +51 -0
  199. package/dist/components/SignUpView/SignUpView.types.d.ts.map +1 -0
  200. package/dist/components/SignUpView/icons.d.ts +18 -0
  201. package/dist/components/SignUpView/icons.d.ts.map +1 -0
  202. package/dist/components/SignUpView/index.d.ts +4 -0
  203. package/dist/components/SignUpView/index.d.ts.map +1 -0
  204. package/dist/components/Switch/Switch.d.ts +46 -0
  205. package/dist/components/Switch/Switch.d.ts.map +1 -0
  206. package/dist/components/Switch/Switch.types.d.ts +58 -0
  207. package/dist/components/Switch/Switch.types.d.ts.map +1 -0
  208. package/dist/components/Table/Table.d.ts +64 -0
  209. package/dist/components/Table/Table.d.ts.map +1 -0
  210. package/dist/components/Table/Table.types.d.ts +173 -0
  211. package/dist/components/Table/Table.types.d.ts.map +1 -0
  212. package/dist/components/Table/index.d.ts +3 -0
  213. package/dist/components/Table/index.d.ts.map +1 -0
  214. package/dist/components/Tabs/Tabs.d.ts +76 -0
  215. package/dist/components/Tabs/Tabs.d.ts.map +1 -0
  216. package/dist/components/Tabs/Tabs.types.d.ts +107 -0
  217. package/dist/components/Tabs/Tabs.types.d.ts.map +1 -0
  218. package/dist/components/Tabs/icons.d.ts +45 -0
  219. package/dist/components/Tabs/icons.d.ts.map +1 -0
  220. package/dist/components/Tabs/index.d.ts +4 -0
  221. package/dist/components/Tabs/index.d.ts.map +1 -0
  222. package/dist/components/Textarea/Textarea.d.ts +38 -0
  223. package/dist/components/Textarea/Textarea.d.ts.map +1 -0
  224. package/dist/components/Textarea/Textarea.types.d.ts +46 -0
  225. package/dist/components/Textarea/Textarea.types.d.ts.map +1 -0
  226. package/dist/context/ThemeContext.d.ts +46 -0
  227. package/dist/context/ThemeContext.d.ts.map +1 -0
  228. package/dist/context/index.d.ts +2 -0
  229. package/dist/context/index.d.ts.map +1 -0
  230. package/dist/index.d.ts +57 -0
  231. package/dist/index.d.ts.map +1 -0
  232. package/dist/siesa-ui-kit.cjs +1273 -0
  233. package/dist/siesa-ui-kit.cjs.map +1 -0
  234. package/dist/siesa-ui-kit.mjs +4510 -0
  235. package/dist/siesa-ui-kit.mjs.map +1 -0
  236. package/dist/style.css +1 -0
  237. package/dist/views/ListView/ListView.d.ts +47 -0
  238. package/dist/views/ListView/ListView.d.ts.map +1 -0
  239. package/dist/views/ListView/ListView.types.d.ts +177 -0
  240. package/dist/views/ListView/ListView.types.d.ts.map +1 -0
  241. package/dist/views/ListView/icons.d.ts +60 -0
  242. package/dist/views/ListView/icons.d.ts.map +1 -0
  243. package/dist/views/ListView/index.d.ts +3 -0
  244. package/dist/views/ListView/index.d.ts.map +1 -0
  245. package/dist/views/LoginView/LoginView.d.ts +36 -0
  246. package/dist/views/LoginView/LoginView.d.ts.map +1 -0
  247. package/dist/views/LoginView/LoginView.types.d.ts +46 -0
  248. package/dist/views/LoginView/LoginView.types.d.ts.map +1 -0
  249. package/dist/views/LoginView/icons.d.ts +18 -0
  250. package/dist/views/LoginView/icons.d.ts.map +1 -0
  251. package/dist/views/LoginView/index.d.ts +4 -0
  252. package/dist/views/LoginView/index.d.ts.map +1 -0
  253. package/dist/views/ProductsView/ProductsView.d.ts +56 -0
  254. package/dist/views/ProductsView/ProductsView.d.ts.map +1 -0
  255. package/dist/views/ProductsView/ProductsView.types.d.ts +184 -0
  256. package/dist/views/ProductsView/ProductsView.types.d.ts.map +1 -0
  257. package/dist/views/ProductsView/icons.d.ts +12 -0
  258. package/dist/views/ProductsView/icons.d.ts.map +1 -0
  259. package/dist/views/ProductsView/index.d.ts +3 -0
  260. package/dist/views/ProductsView/index.d.ts.map +1 -0
  261. package/dist/views/RecoverPasswordView/RecoverPasswordView.d.ts +34 -0
  262. package/dist/views/RecoverPasswordView/RecoverPasswordView.d.ts.map +1 -0
  263. package/dist/views/RecoverPasswordView/RecoverPasswordView.types.d.ts +50 -0
  264. package/dist/views/RecoverPasswordView/RecoverPasswordView.types.d.ts.map +1 -0
  265. package/dist/views/RecoverPasswordView/icons.d.ts +9 -0
  266. package/dist/views/RecoverPasswordView/icons.d.ts.map +1 -0
  267. package/dist/views/RecoverPasswordView/index.d.ts +3 -0
  268. package/dist/views/RecoverPasswordView/index.d.ts.map +1 -0
  269. package/dist/views/SignUpView/SignUpView.d.ts +38 -0
  270. package/dist/views/SignUpView/SignUpView.d.ts.map +1 -0
  271. package/dist/views/SignUpView/SignUpView.types.d.ts +51 -0
  272. package/dist/views/SignUpView/SignUpView.types.d.ts.map +1 -0
  273. package/dist/views/SignUpView/icons.d.ts +18 -0
  274. package/dist/views/SignUpView/icons.d.ts.map +1 -0
  275. package/dist/views/SignUpView/index.d.ts +4 -0
  276. package/dist/views/SignUpView/index.d.ts.map +1 -0
  277. package/dist/views/TableLayoutView/TableLayoutView.d.ts +46 -0
  278. package/dist/views/TableLayoutView/TableLayoutView.d.ts.map +1 -0
  279. package/dist/views/TableLayoutView/TableLayoutView.types.d.ts +170 -0
  280. package/dist/views/TableLayoutView/TableLayoutView.types.d.ts.map +1 -0
  281. package/dist/views/TableLayoutView/icons.d.ts +27 -0
  282. package/dist/views/TableLayoutView/icons.d.ts.map +1 -0
  283. package/dist/views/TableLayoutView/index.d.ts +3 -0
  284. package/dist/views/TableLayoutView/index.d.ts.map +1 -0
  285. package/package.json +93 -92
  286. package/bin/install.cjs +0 -502
  287. package/bin/prepare-publish.cjs +0 -28
  288. package/bin/restore-folders.cjs +0 -28
  289. package/dist/,Business Logo.png +0 -0
  290. package/dist/.Siesa Logo.png +0 -0
  291. package/dist/bg_siesa.png +0 -0
  292. package/dist/index.cjs +0 -1479
  293. package/dist/index.cjs.map +0 -1
  294. package/dist/index.js +0 -1479
  295. package/dist/index.js.map +0 -1
  296. package/dist/siesa_logo_mobile.png +0 -0
  297. package/dist/vite.svg +0 -1
package/dist/index.js DELETED
@@ -1,1479 +0,0 @@
1
- import { jsxs, Fragment, jsx } from "react/jsx-runtime";
2
- import { forwardRef, cloneElement, useRef, useEffect, useState, createContext, useContext } from "react";
3
- const Button = ({
4
- type = "default",
5
- size = "base",
6
- iconOnly = false,
7
- leftIcon,
8
- rightIcon,
9
- children,
10
- disabled = false,
11
- className = "",
12
- onClick,
13
- htmlType = "button",
14
- fullWidth = false,
15
- ariaLabel,
16
- badge = false,
17
- badgeCount,
18
- badgeColor = "red",
19
- ...rest
20
- }) => {
21
- const sizeClasses = {
22
- xs: iconOnly ? "h-6 w-6 p-1" : "h-6 py-1 px-2 gap-2",
23
- sm: iconOnly ? "h-7 w-7 p-1.5" : "h-7 py-1 px-2 gap-2",
24
- base: iconOnly ? "h-8 w-8 p-2" : "h-8 py-1.5 px-2.5 gap-2",
25
- l: iconOnly ? "h-9 w-9 p-2.5" : "h-9 py-2 px-3 gap-3",
26
- xl: iconOnly ? "h-10 w-10 p-3" : "h-10 py-2 px-4 gap-3"
27
- };
28
- const iconSizeClasses = {
29
- xs: "w-4 h-4",
30
- sm: "w-4 h-4",
31
- base: "w-4 h-4",
32
- l: "w-4 h-4",
33
- xl: "w-4 h-4"
34
- };
35
- const textSizeClasses = {
36
- xs: "text-xs",
37
- // Label Tiny - 12px
38
- sm: "text-sm",
39
- // Label Small - 14px
40
- base: "text-sm",
41
- // Label Small - 14px (default para base)
42
- l: "text-sm",
43
- // Label Small - 14px (corregido según Figma)
44
- xl: "text-sm"
45
- // Label Small - 14px (corregido según Figma)
46
- };
47
- const typeClasses = {
48
- default: `
49
- bg-primary-custom-600
50
- text-primary-inverse-content
51
- border
52
- border-primary-inverse-border
53
- shadow-button-inset
54
- hover:bg-primary-custom-500
55
- active:scale-95
56
- transition-all
57
- duration-150
58
- dark:bg-dark-bg-inverse
59
- dark:text-dark-content-inverse
60
- dark:border-dark-border-inverse
61
- dark:hover:bg-dark-bg-inverse/90
62
- `,
63
- outline: `
64
- bg-transparent
65
- text-primary-custom-600
66
- border
67
- border-primary-custom-300
68
- shadow-sm
69
- hover:bg-primary-custom-100
70
- active:scale-95
71
- transition-all
72
- duration-150
73
- dark:text-dark-content-custom
74
- dark:border-dark-border-custom
75
- dark:hover:bg-dark-bg-custom/20
76
- `,
77
- plain: `
78
- bg-transparent
79
- text-primary-custom-600
80
- border
81
- border-transparent
82
- hover:bg-hover-overlay
83
- active:scale-95
84
- transition-all
85
- duration-150
86
- dark:text-dark-content-custom
87
- dark:hover:bg-hover-overlay-dark
88
- `
89
- };
90
- const baseClasses = `
91
- inline-flex
92
- items-center
93
- justify-center
94
- rounded-md
95
- font-bold
96
- whitespace-nowrap
97
- focus:outline-none
98
- focus:ring-4
99
- focus:ring-primary-custom-400
100
- focus:ring-offset-2
101
- focus:ring-offset-primary-custom-100
102
- dark:focus:ring-dark-border-custom
103
- dark:focus:ring-offset-dark-bg-primary
104
- disabled:opacity-50
105
- disabled:cursor-not-allowed
106
- disabled:pointer-events-none
107
- `;
108
- const widthClass = fullWidth ? "w-full" : "";
109
- const buttonClasses = [
110
- baseClasses,
111
- sizeClasses[size],
112
- typeClasses[type],
113
- widthClass,
114
- className
115
- ].join(" ").replace(/\s+/g, " ").trim();
116
- const renderIcon = (icon) => {
117
- if (!icon) return null;
118
- return /* @__PURE__ */ jsx("span", { className: `inline-flex items-center justify-center ${iconSizeClasses[size]}`, children: icon });
119
- };
120
- const renderContent = () => {
121
- if (iconOnly) {
122
- return renderIcon(leftIcon);
123
- }
124
- return /* @__PURE__ */ jsxs(Fragment, { children: [
125
- leftIcon && renderIcon(leftIcon),
126
- children && /* @__PURE__ */ jsx("span", { className: textSizeClasses[size], children }),
127
- rightIcon && renderIcon(rightIcon)
128
- ] });
129
- };
130
- const badgeColorClasses = {
131
- zinc: { bg: "bg-zinc-600", text: "text-white" },
132
- red: { bg: "bg-red-700", text: "text-white" },
133
- orange: { bg: "bg-orange-700", text: "text-white" },
134
- amber: { bg: "bg-amber-700", text: "text-white" },
135
- yellow: { bg: "bg-yellow-700", text: "text-white" },
136
- lime: { bg: "bg-lime-700", text: "text-white" },
137
- green: { bg: "bg-green-700", text: "text-white" },
138
- emerald: { bg: "bg-emerald-700", text: "text-white" },
139
- teal: { bg: "bg-teal-700", text: "text-white" },
140
- cyan: { bg: "bg-cyan-700", text: "text-white" },
141
- sky: { bg: "bg-sky-700", text: "text-white" },
142
- blue: { bg: "bg-blue-700", text: "text-white" },
143
- indigo: { bg: "bg-indigo-700", text: "text-white" },
144
- violet: { bg: "bg-violet-700", text: "text-white" },
145
- purple: { bg: "bg-purple-700", text: "text-white" },
146
- fuchsia: { bg: "bg-fuchsia-700", text: "text-white" },
147
- pink: { bg: "bg-pink-700", text: "text-white" },
148
- rose: { bg: "bg-rose-700", text: "text-white" },
149
- primary: { bg: "bg-primary-custom-600", text: "text-white" },
150
- secondary: { bg: "bg-zinc-600", text: "text-white" },
151
- tertiary: { bg: "bg-zinc-600", text: "text-white" }
152
- };
153
- const badgeColors = badgeColorClasses[badgeColor] || badgeColorClasses.red;
154
- const renderBadge = () => {
155
- if (!badge && badgeCount === void 0) return null;
156
- if (badgeCount !== void 0) {
157
- return /* @__PURE__ */ jsx(
158
- "span",
159
- {
160
- className: `
161
- absolute
162
- -top-1
163
- -right-1
164
- flex
165
- items-center
166
- justify-center
167
- min-w-[16px]
168
- h-4
169
- px-1
170
- rounded-full
171
- text-[10px]
172
- font-bold
173
- leading-none
174
- ${badgeColors.bg}
175
- ${badgeColors.text}
176
- pointer-events-none
177
- `.trim().replace(/\s+/g, " "),
178
- "aria-label": `${badgeCount} notificaciones`,
179
- children: badgeCount > 99 ? "99+" : badgeCount
180
- }
181
- );
182
- }
183
- return /* @__PURE__ */ jsx(
184
- "span",
185
- {
186
- className: `
187
- absolute
188
- -top-1
189
- -right-1
190
- w-2
191
- h-2
192
- rounded-full
193
- ${badgeColors.bg}
194
- pointer-events-none
195
- `.trim().replace(/\s+/g, " "),
196
- "aria-label": "Notificación"
197
- }
198
- );
199
- };
200
- return /* @__PURE__ */ jsxs(
201
- "button",
202
- {
203
- type: htmlType,
204
- className: `${buttonClasses} ${badge || badgeCount !== void 0 ? "relative" : ""}`,
205
- disabled,
206
- onClick,
207
- "aria-label": ariaLabel,
208
- ...rest,
209
- children: [
210
- renderContent(),
211
- renderBadge()
212
- ]
213
- }
214
- );
215
- };
216
- const Input = forwardRef(
217
- ({
218
- label,
219
- labelSecondary,
220
- helperText,
221
- error = false,
222
- errorMessage,
223
- leftIcon,
224
- rightIcon,
225
- fullWidth = false,
226
- className = "",
227
- disabled = false,
228
- id,
229
- ...props
230
- }, ref) => {
231
- const inputId = id || `input-${Math.random().toString(36).substr(2, 9)}`;
232
- const baseInputClasses = `
233
- w-full
234
- px-3
235
- py-1.5
236
- text-sm
237
- leading-6
238
- font-normal
239
- text-content-primary
240
- bg-bg-primary
241
- border
242
- border-border-primary
243
- rounded-md
244
- outline-none
245
- transition-all
246
- duration-150
247
- placeholder:text-content-tertiary
248
- dark:bg-dark-bg-primary
249
- dark:border-dark-border-primary
250
- dark:text-dark-content-primary
251
- dark:placeholder:text-dark-content-tertiary
252
- `;
253
- const interactiveClasses = !disabled ? `
254
- hover:border-primary-custom-600
255
- focus:border-primary-custom-600
256
- focus:ring-2
257
- focus:ring-primary-custom-400
258
- focus:ring-offset-2
259
- dark:hover:border-dark-border-custom
260
- dark:focus:border-dark-border-custom
261
- dark:focus:ring-dark-border-custom
262
- dark:focus:ring-offset-dark-bg-primary
263
- ` : `
264
- opacity-50
265
- cursor-not-allowed
266
- bg-bg-secondary
267
- dark:bg-dark-bg-secondary
268
- `;
269
- const errorClasses = error ? `
270
- !border-error-border
271
- focus:!ring-error-border/30
272
- focus:!ring-offset-2
273
- dark:!border-error-border
274
- dark:focus:!ring-error-border/30
275
- dark:focus:!ring-offset-dark-bg-primary
276
- ` : "";
277
- const containerClasses = fullWidth ? "w-full" : "w-[265px]";
278
- const renderIcon = (icon) => {
279
- if (!icon) return null;
280
- const existingClassName = icon.props.className || "";
281
- return cloneElement(icon, {
282
- className: `w-4 h-4 text-content-tertiary dark:text-dark-content-tertiary ${existingClassName}`
283
- });
284
- };
285
- return /* @__PURE__ */ jsxs("div", { className: `flex flex-col gap-2 ${containerClasses} ${className}`, children: [
286
- label && /* @__PURE__ */ jsxs(
287
- "label",
288
- {
289
- htmlFor: inputId,
290
- className: "flex items-center w-full font-bold text-sm leading-5 text-content-primary dark:text-dark-content-primary",
291
- children: [
292
- /* @__PURE__ */ jsx("span", { className: "flex-1", children: label }),
293
- labelSecondary && /* @__PURE__ */ jsx("span", { className: "text-xs leading-4 text-primary-custom-600 dark:text-primary-custom-600", children: labelSecondary })
294
- ]
295
- }
296
- ),
297
- /* @__PURE__ */ jsxs("div", { className: "relative flex items-center", children: [
298
- leftIcon && /* @__PURE__ */ jsx("div", { className: "absolute left-3 pointer-events-none", children: renderIcon(leftIcon) }),
299
- /* @__PURE__ */ jsx(
300
- "input",
301
- {
302
- ref,
303
- id: inputId,
304
- disabled,
305
- className: `
306
- ${baseInputClasses}
307
- ${interactiveClasses}
308
- ${errorClasses}
309
- ${leftIcon ? "pl-9" : ""}
310
- ${rightIcon ? "pr-9" : ""}
311
- `.trim().replace(/\s+/g, " "),
312
- ...props
313
- }
314
- ),
315
- rightIcon && /* @__PURE__ */ jsx("div", { className: "absolute right-3 pointer-events-none", children: renderIcon(rightIcon) })
316
- ] }),
317
- (helperText || errorMessage) && /* @__PURE__ */ jsx(
318
- "p",
319
- {
320
- className: `
321
- text-xs
322
- leading-5
323
- ${error ? "text-error-content dark:text-error-content" : "text-content-tertiary dark:text-dark-content-tertiary"}
324
- `.trim().replace(/\s+/g, " "),
325
- children: error && errorMessage ? errorMessage : helperText
326
- }
327
- )
328
- ] });
329
- }
330
- );
331
- Input.displayName = "Input";
332
- const Textarea = forwardRef(
333
- ({
334
- label,
335
- description,
336
- helperText,
337
- error = false,
338
- errorMessage,
339
- fullWidth = false,
340
- resize = "vertical",
341
- className = "",
342
- disabled = false,
343
- id,
344
- rows = 4,
345
- ...props
346
- }, ref) => {
347
- const textareaId = id || `textarea-${Math.random().toString(36).substr(2, 9)}`;
348
- const baseTextareaClasses = `
349
- w-full
350
- px-3
351
- pr-1.5
352
- py-1.5
353
- text-base
354
- leading-6
355
- font-normal
356
- bg-bg-primary
357
- border
358
- border-border-primary
359
- rounded-lg
360
- outline-none
361
- transition-all
362
- duration-150
363
- placeholder:text-content-tertiary
364
- dark:bg-dark-bg-primary
365
- dark:border-dark-border-primary
366
- dark:text-dark-content-primary
367
- dark:placeholder:text-dark-content-tertiary
368
- `;
369
- const interactiveClasses = !disabled ? `
370
- hover:border-zinc-400
371
- focus:border-2
372
- focus:border-primary-custom-600
373
- dark:hover:border-zinc-500
374
- dark:focus:border-2
375
- dark:focus:border-dark-border-custom
376
- ` : `
377
- opacity-50
378
- cursor-not-allowed
379
- bg-bg-secondary
380
- dark:bg-dark-bg-secondary
381
- `;
382
- const errorClasses = error ? `
383
- !border-error-border
384
- focus:!border-2
385
- focus:!border-error-border
386
- dark:!border-error-border
387
- dark:focus:!border-2
388
- dark:focus:!border-error-border
389
- ` : "";
390
- const resizeClasses = resize === "none" ? "resize-none" : resize === "vertical" ? "resize-y" : resize === "horizontal" ? "resize-x" : "resize";
391
- const containerClasses = fullWidth ? "w-full" : "w-[312px]";
392
- return /* @__PURE__ */ jsxs("div", { className: `flex flex-col gap-2 ${containerClasses} ${className}`, children: [
393
- (label || description) && /* @__PURE__ */ jsxs("div", { className: "flex flex-col gap-1 w-full", children: [
394
- label && /* @__PURE__ */ jsx(
395
- "label",
396
- {
397
- htmlFor: textareaId,
398
- className: "font-bold text-sm leading-5 text-content-primary dark:text-dark-content-primary",
399
- children: label
400
- }
401
- ),
402
- description && /* @__PURE__ */ jsx("p", { className: "text-sm leading-5 text-content-secondary dark:text-dark-content-secondary", children: description })
403
- ] }),
404
- /* @__PURE__ */ jsx(
405
- "textarea",
406
- {
407
- ref,
408
- id: textareaId,
409
- disabled,
410
- rows,
411
- className: `
412
- ${baseTextareaClasses}
413
- ${interactiveClasses}
414
- ${errorClasses}
415
- ${resizeClasses}
416
- `.trim().replace(/\s+/g, " "),
417
- ...props
418
- }
419
- ),
420
- (helperText || errorMessage) && /* @__PURE__ */ jsx(
421
- "p",
422
- {
423
- className: `
424
- text-sm
425
- leading-5
426
- text-content-tertiary
427
- dark:text-dark-content-tertiary
428
- `.trim().replace(/\s+/g, " "),
429
- children: error && errorMessage ? errorMessage : helperText
430
- }
431
- )
432
- ] });
433
- }
434
- );
435
- Textarea.displayName = "Textarea";
436
- const Checkbox = forwardRef(
437
- ({
438
- label,
439
- description,
440
- checked = false,
441
- indeterminate = false,
442
- disabled = false,
443
- className = "",
444
- id,
445
- onChange,
446
- ...props
447
- }, ref) => {
448
- const inputRef = useRef(null);
449
- const combinedRef = ref || inputRef;
450
- const checkboxId = id || `checkbox-${Math.random().toString(36).substr(2, 9)}`;
451
- useEffect(() => {
452
- if (combinedRef.current) {
453
- combinedRef.current.indeterminate = indeterminate;
454
- }
455
- }, [indeterminate, combinedRef]);
456
- const baseCheckboxClasses = `
457
- w-4
458
- h-4
459
- rounded
460
- border
461
- border-border-primary
462
- bg-bg-primary
463
- transition-all
464
- duration-150
465
- flex
466
- items-center
467
- justify-center
468
- dark:bg-dark-bg-primary
469
- dark:border-dark-border-primary
470
- `;
471
- const interactiveClasses = !disabled ? checked || indeterminate ? `
472
- peer-hover:border-[#50a5f7]
473
- peer-focus:ring-2
474
- peer-focus:ring-primary-custom-400/20
475
- peer-focus:border-primary-custom-600
476
- dark:peer-hover:border-[#50a5f7]
477
- dark:peer-focus:border-dark-border-custom
478
- dark:peer-focus:ring-dark-border-custom/20
479
- ` : `
480
- peer-hover:border-[#b6b6b9]
481
- peer-focus:ring-2
482
- peer-focus:ring-primary-custom-400/20
483
- peer-focus:border-primary-custom-600
484
- dark:peer-hover:border-[#b6b6b9]
485
- dark:peer-focus:border-dark-border-custom
486
- dark:peer-focus:ring-dark-border-custom/20
487
- ` : `
488
- opacity-50
489
- cursor-not-allowed
490
- `;
491
- const checkedClasses = checked || indeterminate ? `
492
- !bg-primary-custom-600
493
- !border-primary-custom-500
494
- shadow-button-inset
495
- dark:!bg-dark-bg-inverse
496
- dark:!border-dark-bg-inverse
497
- ` : "";
498
- const checkboxClasses = [
499
- baseCheckboxClasses,
500
- interactiveClasses,
501
- checkedClasses,
502
- disabled ? "cursor-not-allowed" : "cursor-pointer"
503
- ].join(" ").replace(/\s+/g, " ").trim();
504
- return /* @__PURE__ */ jsxs("div", { className: `inline-flex gap-3 items-start ${className}`, children: [
505
- /* @__PURE__ */ jsxs("div", { className: "flex items-center justify-center h-5 w-4 shrink-0", children: [
506
- /* @__PURE__ */ jsx(
507
- "input",
508
- {
509
- ref: combinedRef,
510
- type: "checkbox",
511
- id: checkboxId,
512
- checked,
513
- disabled,
514
- onChange,
515
- className: "peer sr-only",
516
- ...props
517
- }
518
- ),
519
- /* @__PURE__ */ jsxs("label", { htmlFor: checkboxId, className: checkboxClasses, children: [
520
- checked && !indeterminate && /* @__PURE__ */ jsx(
521
- "svg",
522
- {
523
- className: "w-3 h-3 text-primary-inverse-content pointer-events-none",
524
- viewBox: "0 0 12 12",
525
- fill: "none",
526
- xmlns: "http://www.w3.org/2000/svg",
527
- children: /* @__PURE__ */ jsx(
528
- "path",
529
- {
530
- d: "M10 3L4.5 8.5L2 6",
531
- stroke: "currentColor",
532
- strokeWidth: "2",
533
- strokeLinecap: "round",
534
- strokeLinejoin: "round"
535
- }
536
- )
537
- }
538
- ),
539
- indeterminate && /* @__PURE__ */ jsx(
540
- "svg",
541
- {
542
- className: "w-3 h-3 text-primary-inverse-content pointer-events-none",
543
- viewBox: "0 0 12 12",
544
- fill: "none",
545
- xmlns: "http://www.w3.org/2000/svg",
546
- children: /* @__PURE__ */ jsx(
547
- "path",
548
- {
549
- d: "M2 6H10",
550
- stroke: "currentColor",
551
- strokeWidth: "2",
552
- strokeLinecap: "round"
553
- }
554
- )
555
- }
556
- )
557
- ] })
558
- ] }),
559
- (label || description) && /* @__PURE__ */ jsxs(
560
- "label",
561
- {
562
- htmlFor: checkboxId,
563
- className: `flex-1 flex flex-col gap-1 text-sm leading-5 ${disabled ? "cursor-not-allowed opacity-50" : "cursor-pointer"}`,
564
- children: [
565
- label && /* @__PURE__ */ jsx("span", { className: "font-bold text-content-primary dark:text-dark-content-primary", children: label }),
566
- description && /* @__PURE__ */ jsx("span", { className: "font-normal text-content-secondary dark:text-content-secondary", children: description })
567
- ]
568
- }
569
- )
570
- ] });
571
- }
572
- );
573
- Checkbox.displayName = "Checkbox";
574
- const Radio = forwardRef(
575
- ({
576
- label,
577
- description,
578
- checked = false,
579
- disabled = false,
580
- className = "",
581
- id,
582
- onChange,
583
- value,
584
- name,
585
- ...props
586
- }, ref) => {
587
- const radioId = id || `radio-${Math.random().toString(36).substr(2, 9)}`;
588
- const baseRadioClasses = `
589
- w-4
590
- h-4
591
- rounded-full
592
- border
593
- border-border-primary
594
- bg-bg-primary
595
- transition-all
596
- duration-150
597
- flex
598
- items-center
599
- justify-center
600
- dark:bg-dark-bg-primary
601
- dark:border-dark-border-primary
602
- `;
603
- const interactiveClasses = !disabled ? `
604
- peer-hover:border-primary-custom-600
605
- peer-focus:ring-2
606
- peer-focus:ring-primary-custom-400
607
- peer-focus:border-primary-custom-600
608
- dark:peer-hover:border-dark-border-custom
609
- dark:peer-focus:ring-dark-border-custom
610
- dark:peer-focus:border-dark-border-custom
611
- ` : `
612
- opacity-50
613
- cursor-not-allowed
614
- `;
615
- const checkedClasses = checked ? `
616
- !bg-primary-custom-600
617
- !border-primary-inverse-border
618
- shadow-[0px_2px_0px_0px_inset_rgba(255,255,255,0.15)]
619
- dark:!bg-dark-bg-inverse
620
- dark:!border-dark-bg-inverse
621
- ` : "";
622
- return /* @__PURE__ */ jsxs("div", { className: `flex gap-3 items-start ${className}`, children: [
623
- /* @__PURE__ */ jsxs("div", { className: "flex items-center justify-center h-5 w-4 shrink-0", children: [
624
- /* @__PURE__ */ jsx(
625
- "input",
626
- {
627
- ref,
628
- type: "radio",
629
- id: radioId,
630
- checked,
631
- disabled,
632
- onChange,
633
- value,
634
- name,
635
- className: "peer sr-only",
636
- ...props
637
- }
638
- ),
639
- /* @__PURE__ */ jsx(
640
- "label",
641
- {
642
- htmlFor: radioId,
643
- className: `
644
- ${baseRadioClasses}
645
- ${interactiveClasses}
646
- ${checkedClasses}
647
- ${disabled ? "cursor-not-allowed" : "cursor-pointer"}
648
- `.trim().replace(/\s+/g, " "),
649
- children: checked && /* @__PURE__ */ jsx("div", { className: "w-1.5 h-1.5 bg-white rounded-full dark:bg-dark-content-inverse" })
650
- }
651
- )
652
- ] }),
653
- (label || description) && /* @__PURE__ */ jsxs(
654
- "label",
655
- {
656
- htmlFor: radioId,
657
- className: `flex-1 flex flex-col gap-1 text-sm leading-5 ${disabled ? "cursor-not-allowed opacity-50" : "cursor-pointer"}`,
658
- children: [
659
- label && /* @__PURE__ */ jsx("span", { className: "font-bold text-content-primary dark:text-dark-content-primary", children: label }),
660
- description && /* @__PURE__ */ jsx("span", { className: "font-normal text-content-secondary dark:text-content-secondary", children: description })
661
- ]
662
- }
663
- )
664
- ] });
665
- }
666
- );
667
- Radio.displayName = "Radio";
668
- const Switch = forwardRef(
669
- ({
670
- label,
671
- description,
672
- labelPosition = "leading",
673
- checked = false,
674
- disabled = false,
675
- className = "",
676
- id,
677
- onChange,
678
- ariaLabel,
679
- ...props
680
- }, ref) => {
681
- const switchId = id || `switch-${Math.random().toString(36).substr(2, 9)}`;
682
- const baseTrackClasses = `
683
- w-8
684
- h-5
685
- rounded-xl
686
- border
687
- overflow-hidden
688
- relative
689
- transition-all
690
- duration-200
691
- `;
692
- const getTrackStateClasses = () => {
693
- if (disabled) {
694
- return checked ? `
695
- bg-primary-custom-600
696
- border-primary-inverse-border
697
- opacity-50
698
- cursor-not-allowed
699
- dark:bg-primary-custom-600
700
- dark:border-primary-inverse-border
701
- ` : `
702
- bg-[#fafafa]
703
- border-border-primary
704
- opacity-50
705
- cursor-not-allowed
706
- dark:bg-dark-bg-primary
707
- dark:border-dark-border-primary
708
- `;
709
- }
710
- return checked ? `
711
- bg-primary-custom-600
712
- border-primary-inverse-border
713
- cursor-pointer
714
- peer-hover:border-[#307cc5]
715
- peer-focus:shadow-[0px_0px_0px_2px_#dbeefe,0px_1px_2px_0px_rgba(0,0,0,0.05),0px_0px_0px_4px_#60b6fa]
716
- dark:bg-primary-custom-600
717
- dark:border-primary-inverse-border
718
- dark:peer-hover:border-[#307cc5]
719
- dark:peer-focus:shadow-[0px_0px_0px_2px_#dbeefe,0px_1px_2px_0px_rgba(0,0,0,0.05),0px_0px_0px_4px_#60b6fa]
720
- ` : `
721
- bg-[#fafafa]
722
- border-border-primary
723
- cursor-pointer
724
- peer-hover:border-[#b6b6b9]
725
- peer-focus:shadow-[0px_0px_0px_2px_#dbeefe,0px_1px_2px_0px_rgba(0,0,0,0.05),0px_0px_0px_4px_#60b6fa]
726
- dark:bg-dark-bg-primary
727
- dark:border-dark-border-primary
728
- dark:peer-hover:border-[#b6b6b9]
729
- dark:peer-focus:shadow-[0px_0px_0px_2px_#dbeefe,0px_1px_2px_0px_rgba(0,0,0,0.05),0px_0px_0px_4px_#60b6fa]
730
- `;
731
- };
732
- const getButtonClasses = () => {
733
- const baseButtonClasses = `
734
- absolute
735
- w-4
736
- h-4
737
- bg-white
738
- rounded-[10px]
739
- border
740
- top-1/2
741
- -translate-y-1/2
742
- transition-all
743
- duration-200
744
- `;
745
- const positionClass = checked ? "left-[13px]" : "left-px";
746
- if (disabled) {
747
- const borderClass2 = checked ? "border-primary-inverse-border dark:border-primary-inverse-border" : "border-border-primary dark:border-dark-border-primary";
748
- return `${baseButtonClasses} ${positionClass} ${borderClass2}`;
749
- }
750
- const borderClass = checked ? `
751
- border-primary-inverse-border
752
- peer-hover:border-[#307cc5]
753
- dark:border-primary-inverse-border
754
- dark:peer-hover:border-[#307cc5]
755
- ` : `
756
- border-border-primary
757
- peer-hover:border-[#b6b6b9]
758
- dark:border-dark-border-primary
759
- dark:peer-hover:border-[#b6b6b9]
760
- `;
761
- return `${baseButtonClasses} ${positionClass} ${borderClass}`;
762
- };
763
- const trackClasses = [
764
- baseTrackClasses,
765
- getTrackStateClasses()
766
- ].join(" ").replace(/\s+/g, " ").trim();
767
- const buttonClasses = getButtonClasses().replace(/\s+/g, " ").trim();
768
- const LabelContent = label || description ? /* @__PURE__ */ jsxs(
769
- "label",
770
- {
771
- htmlFor: switchId,
772
- className: `flex-1 flex flex-col gap-1 text-sm leading-5 ${disabled ? "cursor-not-allowed opacity-50" : "cursor-pointer"}`,
773
- children: [
774
- label && /* @__PURE__ */ jsx("span", { className: "font-bold text-content-primary dark:text-dark-content-primary", children: label }),
775
- description && /* @__PURE__ */ jsx("span", { className: "font-normal text-content-secondary dark:text-content-secondary", children: description })
776
- ]
777
- }
778
- ) : null;
779
- const SwitchInput = /* @__PURE__ */ jsxs("div", { className: "flex items-center justify-center shrink-0", children: [
780
- /* @__PURE__ */ jsx(
781
- "input",
782
- {
783
- ref,
784
- type: "checkbox",
785
- id: switchId,
786
- checked,
787
- disabled,
788
- onChange,
789
- className: "peer sr-only",
790
- "aria-label": ariaLabel || label,
791
- ...props
792
- }
793
- ),
794
- /* @__PURE__ */ jsx(
795
- "label",
796
- {
797
- htmlFor: switchId,
798
- className: trackClasses,
799
- "aria-hidden": "true",
800
- children: /* @__PURE__ */ jsx("div", { className: buttonClasses })
801
- }
802
- )
803
- ] });
804
- return /* @__PURE__ */ jsx("div", { className: `flex gap-2 items-center w-[344px] ${className}`, children: labelPosition === "leading" ? /* @__PURE__ */ jsxs(Fragment, { children: [
805
- LabelContent,
806
- SwitchInput
807
- ] }) : /* @__PURE__ */ jsxs(Fragment, { children: [
808
- SwitchInput,
809
- LabelContent
810
- ] }) });
811
- }
812
- );
813
- Switch.displayName = "Switch";
814
- const Avatar = forwardRef(
815
- ({
816
- size = "10",
817
- type = "circular",
818
- src,
819
- alt = "",
820
- initials,
821
- className = "",
822
- ...props
823
- }, ref) => {
824
- const containerSizeClasses = {
825
- "4": "w-5 h-5",
826
- "6": "w-6 h-6",
827
- "8": "w-8 h-8",
828
- "10": "w-10 h-10"
829
- };
830
- const textSizeClasses = {
831
- "4": "text-xs",
832
- // 12px - Paragraph Tiny
833
- "6": "text-xs",
834
- // 12px - Paragraph Tiny
835
- "8": "text-sm",
836
- // 14px - Paragraph Small
837
- "10": "text-base"
838
- // 16px - Paragraph Base
839
- };
840
- const typeClasses = {
841
- circular: "rounded-full",
842
- rounded: "rounded-md"
843
- };
844
- const baseClasses = `
845
- relative
846
- inline-flex
847
- items-center
848
- justify-center
849
- overflow-hidden
850
- ${containerSizeClasses[size]}
851
- ${typeClasses[type]}
852
- `;
853
- if (src) {
854
- return /* @__PURE__ */ jsx(
855
- "div",
856
- {
857
- ref,
858
- className: `${baseClasses} ${className}`.trim().replace(/\s+/g, " "),
859
- children: /* @__PURE__ */ jsx(
860
- "img",
861
- {
862
- src,
863
- alt,
864
- className: "w-full h-full object-cover",
865
- ...props
866
- }
867
- )
868
- }
869
- );
870
- }
871
- if (initials) {
872
- return /* @__PURE__ */ jsx(
873
- "div",
874
- {
875
- ref,
876
- className: `
877
- ${baseClasses}
878
- ${textSizeClasses[size]}
879
- bg-content-primary
880
- text-white
881
- font-normal
882
- dark:bg-dark-bg-inverse
883
- dark:text-dark-content-inverse
884
- ${className}
885
- `.trim().replace(/\s+/g, " "),
886
- children: /* @__PURE__ */ jsx("span", { className: "leading-none", children: initials })
887
- }
888
- );
889
- }
890
- return /* @__PURE__ */ jsx(
891
- "div",
892
- {
893
- ref,
894
- className: `
895
- ${baseClasses}
896
- bg-background-secondary
897
- dark:bg-dark-bg-primary
898
- ${className}
899
- `.trim().replace(/\s+/g, " ")
900
- }
901
- );
902
- }
903
- );
904
- Avatar.displayName = "Avatar";
905
- const Divider = forwardRef(
906
- ({
907
- type = "default",
908
- className = "",
909
- ...props
910
- }, ref) => {
911
- const typeClasses = {
912
- // Default: Línea más visible para separaciones claras
913
- // Light: border-primary (#e4e4e7)
914
- // Dark: dark-border-primary (#71717a)
915
- default: "bg-border-primary dark:bg-dark-border-primary",
916
- // Soft: Línea más sutil para separaciones suaves
917
- // Light: border-secondary (#f4f4f5 - muy claro)
918
- // Dark: gray-700 (#374151 - gris medio-oscuro, más sutil que dark-border-primary)
919
- soft: "bg-border-secondary dark:bg-gray-700"
920
- };
921
- const baseClasses = "w-full h-px border-0";
922
- const finalClasses = [
923
- baseClasses,
924
- typeClasses[type],
925
- className
926
- ].join(" ").replace(/\s+/g, " ").trim();
927
- return /* @__PURE__ */ jsx(
928
- "hr",
929
- {
930
- ref,
931
- className: finalClasses,
932
- ...props
933
- }
934
- );
935
- }
936
- );
937
- Divider.displayName = "Divider";
938
- const DescriptionList = forwardRef(
939
- ({
940
- term,
941
- details,
942
- className = "",
943
- ...props
944
- }, ref) => {
945
- const baseClasses = `
946
- flex
947
- flex-wrap
948
- gap-1
949
- items-start
950
- py-2.5
951
- border-b
952
- border-border-secondary
953
- dark:border-gray-700
954
- `;
955
- const columnClasses = "flex-1 min-w-[180px]";
956
- const finalClasses = [baseClasses, className].join(" ").replace(/\s+/g, " ").trim();
957
- return /* @__PURE__ */ jsxs("div", { ref, className: finalClasses, ...props, children: [
958
- /* @__PURE__ */ jsx("div", { className: columnClasses, children: /* @__PURE__ */ jsx("p", { className: "text-sm leading-5 text-content-secondary dark:text-gray-400 font-normal", children: term }) }),
959
- /* @__PURE__ */ jsx("div", { className: columnClasses, children: /* @__PURE__ */ jsx("p", { className: "text-sm leading-5 text-content-primary dark:text-dark-content-primary font-normal", children: details }) })
960
- ] });
961
- }
962
- );
963
- DescriptionList.displayName = "DescriptionList";
964
- const Alert = forwardRef(
965
- ({
966
- title,
967
- description,
968
- children,
969
- actions,
970
- onCancel,
971
- onConfirm,
972
- cancelText = "Cancelar",
973
- confirmText = "Confirmar",
974
- className = "",
975
- ...props
976
- }, ref) => {
977
- const actionButtons = actions || /* @__PURE__ */ jsxs(Fragment, { children: [
978
- onCancel && /* @__PURE__ */ jsx(Button, { type: "plain", size: "base", onClick: onCancel, children: cancelText }),
979
- onConfirm && /* @__PURE__ */ jsx(Button, { type: "default", size: "base", onClick: onConfirm, children: confirmText })
980
- ] });
981
- return /* @__PURE__ */ jsx(
982
- "div",
983
- {
984
- ref,
985
- className: `
986
- w-[512px]
987
- bg-white
988
- dark:bg-dark-bg-primary
989
- border
990
- border-border-primary
991
- dark:border-dark-border-primary
992
- rounded-xl
993
- ${className}
994
- `.trim().replace(/\s+/g, " "),
995
- ...props,
996
- children: /* @__PURE__ */ jsxs("div", { className: "p-6 flex flex-col gap-4", children: [
997
- /* @__PURE__ */ jsxs("div", { className: "flex flex-col gap-3", children: [
998
- /* @__PURE__ */ jsx("p", { className: "text-sm leading-5 font-bold text-content-primary dark:text-dark-content-primary", children: title }),
999
- description && /* @__PURE__ */ jsx("p", { className: "text-sm leading-5 font-normal text-content-tertiary dark:text-content-tertiary", children: description })
1000
- ] }),
1001
- children && /* @__PURE__ */ jsx("div", { className: "flex flex-col gap-3", children }),
1002
- /* @__PURE__ */ jsx("div", { className: "flex flex-wrap gap-3 items-center justify-end", children: actionButtons })
1003
- ] })
1004
- }
1005
- );
1006
- }
1007
- );
1008
- Alert.displayName = "Alert";
1009
- const Badge = forwardRef(
1010
- ({
1011
- color = "zinc",
1012
- leftIcon,
1013
- label,
1014
- count,
1015
- className = "",
1016
- ...props
1017
- }, ref) => {
1018
- const colorClasses = {
1019
- zinc: {
1020
- bg: "bg-zinc-100",
1021
- text: "text-zinc-600",
1022
- hover: "hover:bg-zinc-200",
1023
- notificationBg: "bg-zinc-600",
1024
- notificationText: "text-zinc-100"
1025
- },
1026
- red: {
1027
- bg: "bg-red-100",
1028
- text: "text-red-700",
1029
- hover: "hover:bg-red-200",
1030
- notificationBg: "bg-red-700",
1031
- notificationText: "text-red-100"
1032
- },
1033
- orange: {
1034
- bg: "bg-orange-100",
1035
- text: "text-orange-700",
1036
- hover: "hover:bg-orange-200",
1037
- notificationBg: "bg-orange-700",
1038
- notificationText: "text-orange-100"
1039
- },
1040
- amber: {
1041
- bg: "bg-amber-100",
1042
- text: "text-amber-700",
1043
- hover: "hover:bg-amber-200",
1044
- notificationBg: "bg-amber-700",
1045
- notificationText: "text-amber-100"
1046
- },
1047
- yellow: {
1048
- bg: "bg-yellow-100",
1049
- text: "text-yellow-700",
1050
- hover: "hover:bg-yellow-200",
1051
- notificationBg: "bg-yellow-700",
1052
- notificationText: "text-yellow-100"
1053
- },
1054
- lime: {
1055
- bg: "bg-lime-100",
1056
- text: "text-lime-700",
1057
- hover: "hover:bg-lime-200",
1058
- notificationBg: "bg-lime-700",
1059
- notificationText: "text-lime-100"
1060
- },
1061
- green: {
1062
- bg: "bg-green-100",
1063
- text: "text-green-700",
1064
- hover: "hover:bg-green-200",
1065
- notificationBg: "bg-green-700",
1066
- notificationText: "text-green-100"
1067
- },
1068
- emerald: {
1069
- bg: "bg-emerald-100",
1070
- text: "text-emerald-700",
1071
- hover: "hover:bg-emerald-200",
1072
- notificationBg: "bg-emerald-700",
1073
- notificationText: "text-emerald-100"
1074
- },
1075
- teal: {
1076
- bg: "bg-teal-100",
1077
- text: "text-teal-700",
1078
- hover: "hover:bg-teal-200",
1079
- notificationBg: "bg-teal-700",
1080
- notificationText: "text-teal-100"
1081
- },
1082
- cyan: {
1083
- bg: "bg-cyan-100",
1084
- text: "text-cyan-700",
1085
- hover: "hover:bg-cyan-200",
1086
- notificationBg: "bg-cyan-700",
1087
- notificationText: "text-cyan-100"
1088
- },
1089
- sky: {
1090
- bg: "bg-sky-100",
1091
- text: "text-sky-700",
1092
- hover: "hover:bg-sky-200",
1093
- notificationBg: "bg-sky-700",
1094
- notificationText: "text-sky-100"
1095
- },
1096
- blue: {
1097
- bg: "bg-blue-100",
1098
- text: "text-blue-700",
1099
- hover: "hover:bg-blue-200",
1100
- notificationBg: "bg-blue-700",
1101
- notificationText: "text-blue-100"
1102
- },
1103
- indigo: {
1104
- bg: "bg-indigo-100",
1105
- text: "text-indigo-700",
1106
- hover: "hover:bg-indigo-200",
1107
- notificationBg: "bg-indigo-700",
1108
- notificationText: "text-indigo-100"
1109
- },
1110
- violet: {
1111
- bg: "bg-violet-100",
1112
- text: "text-violet-700",
1113
- hover: "hover:bg-violet-200",
1114
- notificationBg: "bg-violet-700",
1115
- notificationText: "text-violet-100"
1116
- },
1117
- purple: {
1118
- bg: "bg-purple-100",
1119
- text: "text-purple-700",
1120
- hover: "hover:bg-purple-200",
1121
- notificationBg: "bg-purple-700",
1122
- notificationText: "text-purple-100"
1123
- },
1124
- fuchsia: {
1125
- bg: "bg-fuchsia-100",
1126
- text: "text-fuchsia-700",
1127
- hover: "hover:bg-fuchsia-200",
1128
- notificationBg: "bg-fuchsia-700",
1129
- notificationText: "text-fuchsia-100"
1130
- },
1131
- pink: {
1132
- bg: "bg-pink-100",
1133
- text: "text-pink-700",
1134
- hover: "hover:bg-pink-200",
1135
- notificationBg: "bg-pink-700",
1136
- notificationText: "text-pink-100"
1137
- },
1138
- rose: {
1139
- bg: "bg-rose-100",
1140
- text: "text-rose-700",
1141
- hover: "hover:bg-rose-200",
1142
- notificationBg: "bg-rose-700",
1143
- notificationText: "text-rose-100"
1144
- },
1145
- primary: {
1146
- bg: "bg-primary-custom-100",
1147
- text: "text-primary-custom-600",
1148
- hover: "hover:bg-primary-custom-200",
1149
- notificationBg: "bg-primary-custom-600",
1150
- notificationText: "text-primary-custom-100"
1151
- },
1152
- secondary: {
1153
- bg: "bg-zinc-100",
1154
- text: "text-zinc-600",
1155
- hover: "hover:bg-zinc-200",
1156
- notificationBg: "bg-zinc-600",
1157
- notificationText: "text-zinc-100"
1158
- },
1159
- tertiary: {
1160
- bg: "bg-zinc-100",
1161
- text: "text-zinc-600",
1162
- hover: "hover:bg-zinc-200",
1163
- notificationBg: "bg-zinc-600",
1164
- notificationText: "text-zinc-100"
1165
- }
1166
- };
1167
- const colors = colorClasses[color];
1168
- const renderIcon = (icon) => {
1169
- const existingClassName = icon.props.className || "";
1170
- return cloneElement(icon, {
1171
- className: `w-3 h-3 ${existingClassName}`.trim()
1172
- });
1173
- };
1174
- const finalClasses = [
1175
- "inline-flex",
1176
- "items-center",
1177
- "gap-1",
1178
- "px-1.5",
1179
- "py-1",
1180
- "rounded-md",
1181
- "font-sans",
1182
- colors.bg,
1183
- colors.hover,
1184
- "transition-colors",
1185
- "duration-200",
1186
- className
1187
- ].filter(Boolean).join(" ").replace(/\s+/g, " ").trim();
1188
- return /* @__PURE__ */ jsxs(
1189
- "div",
1190
- {
1191
- ref,
1192
- className: finalClasses,
1193
- ...props,
1194
- children: [
1195
- leftIcon && /* @__PURE__ */ jsx("div", { className: `flex items-center justify-center ${colors.text}`, children: renderIcon(leftIcon) }),
1196
- /* @__PURE__ */ jsx("span", { className: `font-sans text-xs leading-4 ${colors.text}`, children: label }),
1197
- count !== void 0 && /* @__PURE__ */ jsx(
1198
- "div",
1199
- {
1200
- className: `
1201
- h-3
1202
- flex
1203
- items-center
1204
- justify-center
1205
- px-0.5
1206
- rounded-sm
1207
- min-w-[12px]
1208
- ${colors.notificationBg}
1209
- `.trim().replace(/\s+/g, " "),
1210
- children: /* @__PURE__ */ jsx("span", { className: `font-sans text-xs leading-4 ${colors.notificationText}`, children: count })
1211
- }
1212
- )
1213
- ]
1214
- }
1215
- );
1216
- }
1217
- );
1218
- Badge.displayName = "Badge";
1219
- const Quantity = forwardRef(
1220
- ({
1221
- value: controlledValue,
1222
- defaultValue = 0,
1223
- onChange,
1224
- min = 0,
1225
- max,
1226
- label,
1227
- linkText,
1228
- onLinkClick,
1229
- helperText,
1230
- error = false,
1231
- disabled = false,
1232
- className = "",
1233
- ...props
1234
- }, ref) => {
1235
- const [internalValue, setInternalValue] = useState(defaultValue);
1236
- const isControlled = controlledValue !== void 0;
1237
- const currentValue = isControlled ? controlledValue : internalValue;
1238
- useEffect(() => {
1239
- if (!isControlled) {
1240
- setInternalValue(defaultValue);
1241
- }
1242
- }, [defaultValue, isControlled]);
1243
- const handleValueChange = (newValue) => {
1244
- let clampedValue = newValue;
1245
- if (min !== void 0 && clampedValue < min) {
1246
- clampedValue = min;
1247
- }
1248
- if (max !== void 0 && clampedValue > max) {
1249
- clampedValue = max;
1250
- }
1251
- if (!isControlled) {
1252
- setInternalValue(clampedValue);
1253
- }
1254
- onChange?.(clampedValue);
1255
- };
1256
- const handleDecrement = () => {
1257
- if (disabled) return;
1258
- handleValueChange(currentValue - 1);
1259
- };
1260
- const handleIncrement = () => {
1261
- if (disabled) return;
1262
- handleValueChange(currentValue + 1);
1263
- };
1264
- const isDecrementDisabled = disabled || min !== void 0 && currentValue <= min;
1265
- const isIncrementDisabled = disabled || max !== void 0 && currentValue >= max;
1266
- const MinusIcon = () => /* @__PURE__ */ jsx(
1267
- "svg",
1268
- {
1269
- width: "16",
1270
- height: "16",
1271
- viewBox: "0 0 16 16",
1272
- fill: "none",
1273
- xmlns: "http://www.w3.org/2000/svg",
1274
- children: /* @__PURE__ */ jsx(
1275
- "path",
1276
- {
1277
- d: "M3 8H13",
1278
- stroke: "currentColor",
1279
- strokeWidth: "1.5",
1280
- strokeLinecap: "round",
1281
- strokeLinejoin: "round"
1282
- }
1283
- )
1284
- }
1285
- );
1286
- const PlusIcon = () => /* @__PURE__ */ jsx(
1287
- "svg",
1288
- {
1289
- width: "16",
1290
- height: "16",
1291
- viewBox: "0 0 16 16",
1292
- fill: "none",
1293
- xmlns: "http://www.w3.org/2000/svg",
1294
- children: /* @__PURE__ */ jsx(
1295
- "path",
1296
- {
1297
- d: "M8 3V13M3 8H13",
1298
- stroke: "currentColor",
1299
- strokeWidth: "1.5",
1300
- strokeLinecap: "round",
1301
- strokeLinejoin: "round"
1302
- }
1303
- )
1304
- }
1305
- );
1306
- const borderClass = error ? "border-error-border dark:border-error-border" : "border-border-primary dark:border-dark-border-primary";
1307
- const hoverClass = !disabled && !error ? "hover:border-[#f9f9f9] dark:hover:border-[#f9f9f9]" : "";
1308
- const focusClass = !disabled && !error ? "focus-within:border-2 focus-within:border-[#329cff] dark:focus-within:border-[#329cff]" : "";
1309
- return /* @__PURE__ */ jsxs(
1310
- "div",
1311
- {
1312
- ref,
1313
- className: `flex flex-col gap-2 ${className}`.trim(),
1314
- ...props,
1315
- children: [
1316
- label && /* @__PURE__ */ jsxs("div", { className: "flex items-center justify-between", children: [
1317
- /* @__PURE__ */ jsx("label", { className: "text-sm leading-5 font-bold text-content-primary dark:text-dark-content-primary", children: label }),
1318
- linkText && /* @__PURE__ */ jsx(
1319
- "button",
1320
- {
1321
- type: "button",
1322
- onClick: onLinkClick,
1323
- disabled,
1324
- className: `
1325
- text-xs leading-4
1326
- text-primary-custom-600
1327
- hover:underline
1328
- dark:text-primary-custom-600
1329
- ${disabled ? "opacity-50 cursor-not-allowed" : "cursor-pointer"}
1330
- transition-colors
1331
- duration-200
1332
- `.trim().replace(/\s+/g, " "),
1333
- children: linkText
1334
- }
1335
- )
1336
- ] }),
1337
- /* @__PURE__ */ jsxs(
1338
- "div",
1339
- {
1340
- className: `
1341
- flex
1342
- items-center
1343
- gap-2
1344
- px-3
1345
- py-1.5
1346
- bg-white
1347
- dark:bg-dark-bg-primary
1348
- border
1349
- ${borderClass}
1350
- ${hoverClass}
1351
- ${focusClass}
1352
- rounded-lg
1353
- transition-colors
1354
- duration-200
1355
- ${disabled ? "opacity-50 cursor-not-allowed" : ""}
1356
- `.trim().replace(/\s+/g, " "),
1357
- children: [
1358
- /* @__PURE__ */ jsx(
1359
- "button",
1360
- {
1361
- type: "button",
1362
- onClick: handleDecrement,
1363
- disabled: isDecrementDisabled,
1364
- className: `
1365
- flex
1366
- items-center
1367
- justify-center
1368
- w-4
1369
- h-4
1370
- ${isDecrementDisabled ? "text-content-tertiary dark:text-content-tertiary cursor-not-allowed" : "text-content-primary dark:text-dark-content-primary hover:text-content-secondary dark:hover:text-content-secondary cursor-pointer"}
1371
- transition-colors
1372
- duration-200
1373
- `.trim().replace(/\s+/g, " "),
1374
- "aria-label": "Decrementar",
1375
- children: /* @__PURE__ */ jsx(MinusIcon, {})
1376
- }
1377
- ),
1378
- /* @__PURE__ */ jsx("div", { className: "flex-1 text-center", children: /* @__PURE__ */ jsx(
1379
- "span",
1380
- {
1381
- className: `
1382
- text-base leading-6
1383
- ${currentValue === 0 ? "text-content-tertiary dark:text-content-tertiary" : "text-content-primary dark:text-dark-content-primary"}
1384
- `.trim().replace(/\s+/g, " "),
1385
- children: currentValue
1386
- }
1387
- ) }),
1388
- /* @__PURE__ */ jsx(
1389
- "button",
1390
- {
1391
- type: "button",
1392
- onClick: handleIncrement,
1393
- disabled: isIncrementDisabled,
1394
- className: `
1395
- flex
1396
- items-center
1397
- justify-center
1398
- w-4
1399
- h-4
1400
- ${isIncrementDisabled ? "text-content-tertiary dark:text-content-tertiary cursor-not-allowed" : "text-content-primary dark:text-dark-content-primary hover:text-content-secondary dark:hover:text-content-secondary cursor-pointer"}
1401
- transition-colors
1402
- duration-200
1403
- `.trim().replace(/\s+/g, " "),
1404
- "aria-label": "Incrementar",
1405
- children: /* @__PURE__ */ jsx(PlusIcon, {})
1406
- }
1407
- )
1408
- ]
1409
- }
1410
- ),
1411
- helperText && /* @__PURE__ */ jsx(
1412
- "p",
1413
- {
1414
- className: `
1415
- text-sm leading-5
1416
- ${error ? "text-error-content dark:text-error-content" : "text-content-tertiary dark:text-content-tertiary"}
1417
- `.trim().replace(/\s+/g, " "),
1418
- children: helperText
1419
- }
1420
- )
1421
- ]
1422
- }
1423
- );
1424
- }
1425
- );
1426
- Quantity.displayName = "Quantity";
1427
- const ThemeContext = createContext(void 0);
1428
- const ThemeProvider = ({
1429
- children,
1430
- defaultTheme = "light"
1431
- }) => {
1432
- const [theme, setThemeState] = useState(() => {
1433
- if (typeof window !== "undefined") {
1434
- const savedTheme = localStorage.getItem("siesa-ui-theme");
1435
- return savedTheme || defaultTheme;
1436
- }
1437
- return defaultTheme;
1438
- });
1439
- useEffect(() => {
1440
- const root = window.document.documentElement;
1441
- if (theme === "dark") {
1442
- root.classList.add("dark");
1443
- } else {
1444
- root.classList.remove("dark");
1445
- }
1446
- localStorage.setItem("siesa-ui-theme", theme);
1447
- }, [theme]);
1448
- const toggleTheme = () => {
1449
- setThemeState((prev) => prev === "light" ? "dark" : "light");
1450
- };
1451
- const setTheme = (newTheme) => {
1452
- setThemeState(newTheme);
1453
- };
1454
- return /* @__PURE__ */ jsx(ThemeContext.Provider, { value: { theme, toggleTheme, setTheme }, children });
1455
- };
1456
- const useTheme = () => {
1457
- const context = useContext(ThemeContext);
1458
- if (context === void 0) {
1459
- throw new Error("useTheme debe ser usado dentro de un ThemeProvider");
1460
- }
1461
- return context;
1462
- };
1463
- export {
1464
- Alert,
1465
- Avatar,
1466
- Badge,
1467
- Button,
1468
- Checkbox,
1469
- DescriptionList,
1470
- Divider,
1471
- Input,
1472
- Quantity,
1473
- Radio,
1474
- Switch,
1475
- Textarea,
1476
- ThemeProvider,
1477
- useTheme
1478
- };
1479
- //# sourceMappingURL=index.js.map