siesa-ui-kit 1.0.3 → 1.0.5

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 (459) hide show
  1. package/README.md +28 -54
  2. package/claude/agents/siesa-ui-kit-specialist.md +2401 -0
  3. package/claude/prompts/component-template.md +121 -0
  4. package/claude/settings.local.json +61 -0
  5. package/docs/border-radius.md +1261 -0
  6. package/docs/colors.md +832 -0
  7. package/docs/dark-mode-guide.md +1426 -0
  8. package/docs/filters.md +1243 -0
  9. package/docs/icons.md +1283 -0
  10. package/docs/shadows.md +1377 -0
  11. package/docs/spacing.md +1684 -0
  12. package/docs/typography.md +1268 -0
  13. package/package.json +14 -34
  14. package/postcss.config.cjs +6 -0
  15. package/public/,Business Logo.png +0 -0
  16. package/public/.Siesa Logo.png +0 -0
  17. package/public/bg_siesa.png +0 -0
  18. package/public/siesa_logo_mobile.png +0 -0
  19. package/public/vite.svg +1 -0
  20. package/src/App.css +42 -0
  21. package/src/App.tsx +8 -0
  22. package/src/ButtonTest.tsx +147 -0
  23. package/src/assets/fonts/README.md +261 -0
  24. package/src/assets/fonts/SiesaBT/SiesaBT-Bold.otf +0 -0
  25. package/src/assets/fonts/SiesaBT/SiesaBT-Light.otf +0 -0
  26. package/src/assets/fonts/SiesaBT/SiesaBT-Regular.otf +0 -0
  27. package/src/assets/react.svg +1 -0
  28. package/src/components/Alert/Alert.stories.tsx +332 -0
  29. package/src/components/Alert/Alert.tsx +106 -0
  30. package/src/components/Alert/Alert.types.ts +54 -0
  31. package/src/components/Avatar/Avatar.stories.tsx +494 -0
  32. package/src/components/Avatar/Avatar.tsx +143 -0
  33. package/src/components/Avatar/Avatar.types.ts +53 -0
  34. package/src/components/Badge/Badge.stories.tsx +339 -0
  35. package/src/components/Badge/Badge.tsx +278 -0
  36. package/src/components/Badge/Badge.types.ts +58 -0
  37. package/src/components/Button/Button.stories.tsx +950 -0
  38. package/src/components/Button/Button.tsx +337 -0
  39. package/src/components/Button/Button.types.ts +180 -0
  40. package/src/components/Button/icons.tsx +87 -0
  41. package/{dist/components/Button/index.d.ts → src/components/Button/index.ts} +3 -4
  42. package/src/components/Checkbox/Checkbox.stories.tsx +453 -0
  43. package/src/components/Checkbox/Checkbox.tsx +208 -0
  44. package/src/components/Checkbox/Checkbox.types.ts +61 -0
  45. package/src/components/DescriptionList/DescriptionList.stories.tsx +250 -0
  46. package/src/components/DescriptionList/DescriptionList.tsx +96 -0
  47. package/src/components/DescriptionList/DescriptionList.types.ts +29 -0
  48. package/src/components/Divider/Divider.stories.tsx +263 -0
  49. package/src/components/Divider/Divider.tsx +80 -0
  50. package/src/components/Divider/Divider.types.ts +24 -0
  51. package/src/components/Dropdown/Dropdown.stories.tsx +552 -0
  52. package/src/components/Dropdown/Dropdown.tsx +422 -0
  53. package/src/components/Dropdown/Dropdown.types.ts +146 -0
  54. package/src/components/Dropdown/README.md +266 -0
  55. package/src/components/Dropdown/icons.tsx +72 -0
  56. package/{dist/components/Dropdown/index.d.ts → src/components/Dropdown/index.ts} +8 -4
  57. package/src/components/Input/Input.stories.tsx +583 -0
  58. package/src/components/Input/Input.tsx +204 -0
  59. package/src/components/Input/Input.types.ts +80 -0
  60. package/src/components/Input/icons.tsx +145 -0
  61. package/{dist/components/Input/index.d.ts → src/components/Input/index.ts} +2 -3
  62. package/src/components/LoginView/LoginView.stories.tsx +148 -0
  63. package/src/components/LoginView/LoginView.tsx +426 -0
  64. package/src/components/LoginView/LoginView.types.ts +52 -0
  65. package/src/components/LoginView/README.md +396 -0
  66. package/src/components/LoginView/icons.tsx +85 -0
  67. package/{dist/components/LoginView/index.d.ts → src/components/LoginView/index.ts} +3 -4
  68. package/src/components/Navbar/Navbar.stories.tsx +810 -0
  69. package/src/components/Navbar/Navbar.tsx +755 -0
  70. package/src/components/Navbar/Navbar.types.ts +219 -0
  71. package/src/components/Navbar/README.md +279 -0
  72. package/src/components/Navbar/icons.tsx +102 -0
  73. package/src/components/Navbar/index.ts +8 -0
  74. package/src/components/NavigationBar/NavigationBar.stories.tsx +406 -0
  75. package/src/components/NavigationBar/NavigationBar.tsx +246 -0
  76. package/src/components/NavigationBar/NavigationBar.types.ts +74 -0
  77. package/src/components/NavigationBar/README.md +469 -0
  78. package/{dist/components/NavigationBar/index.d.ts → src/components/NavigationBar/index.ts} +2 -3
  79. package/src/components/NavigationRail/NavigationRail.stories.tsx +417 -0
  80. package/src/components/NavigationRail/NavigationRail.tsx +418 -0
  81. package/src/components/NavigationRail/NavigationRail.types.ts +109 -0
  82. package/src/components/NavigationRail/README.md +224 -0
  83. package/{dist/components/NavigationRail/index.d.ts → src/components/NavigationRail/index.ts} +2 -3
  84. package/src/components/Notification/Notification.stories.tsx +513 -0
  85. package/src/components/Notification/Notification.tsx +145 -0
  86. package/src/components/Notification/Notification.types.ts +142 -0
  87. package/src/components/Notification/README.md +409 -0
  88. package/{dist/components/Notification/index.d.ts → src/components/Notification/index.ts} +3 -3
  89. package/src/components/POSConvention/POSConvention.stories.tsx +235 -0
  90. package/src/components/POSConvention/POSConvention.tsx +129 -0
  91. package/{dist/components/POSConvention/POSConvention.types.d.ts → src/components/POSConvention/POSConvention.types.ts} +38 -37
  92. package/src/components/POSConvention/README.md +123 -0
  93. package/src/components/POSConvention/icons.tsx +45 -0
  94. package/{dist/components/POSConvention/index.d.ts → src/components/POSConvention/index.ts} +3 -4
  95. package/src/components/POSLocationButton/POSLocationButton.stories.tsx +531 -0
  96. package/src/components/POSLocationButton/POSLocationButton.tsx +247 -0
  97. package/src/components/POSLocationButton/POSLocationButton.types.ts +87 -0
  98. package/src/components/POSLocationButton/README.md +253 -0
  99. package/src/components/POSLocationButton/icons.tsx +120 -0
  100. package/src/components/POSLocationButton/index.ts +14 -0
  101. package/src/components/POSNumberButton/POSNumberButton.stories.tsx +415 -0
  102. package/src/components/POSNumberButton/POSNumberButton.tsx +179 -0
  103. package/src/components/POSNumberButton/POSNumberButton.types.ts +51 -0
  104. package/src/components/POSNumberButton/README.md +321 -0
  105. package/{dist/components/POSNumberButton/index.d.ts → src/components/POSNumberButton/index.ts} +3 -3
  106. package/src/components/POSProductButton/POSProductButton.stories.tsx +318 -0
  107. package/src/components/POSProductButton/POSProductButton.tsx +152 -0
  108. package/src/components/POSProductButton/POSProductButton.types.ts +46 -0
  109. package/src/components/POSProductButton/README.md +269 -0
  110. package/{dist/components/POSProductButton/index.d.ts → src/components/POSProductButton/index.ts} +2 -3
  111. package/src/components/POSProductCard/POSProductCard.stories.tsx +642 -0
  112. package/src/components/POSProductCard/POSProductCard.tsx +208 -0
  113. package/src/components/POSProductCard/POSProductCard.types.ts +76 -0
  114. package/src/components/POSProductCard/README.md +179 -0
  115. package/src/components/POSProductCard/icons.tsx +26 -0
  116. package/{dist/components/POSProductCard/index.d.ts → src/components/POSProductCard/index.ts} +2 -3
  117. package/src/components/POSProductSidebarItems/POSProductSidebarItems.stories.tsx +753 -0
  118. package/src/components/POSProductSidebarItems/POSProductSidebarItems.tsx +332 -0
  119. package/src/components/POSProductSidebarItems/POSProductSidebarItems.types.ts +119 -0
  120. package/src/components/POSProductSidebarItems/README.md +198 -0
  121. package/src/components/POSProductSidebarItems/icons.tsx +21 -0
  122. package/{dist/components/POSProductSidebarItems/index.d.ts → src/components/POSProductSidebarItems/index.ts} +3 -4
  123. package/src/components/POSTable/POSTable.stories.tsx +737 -0
  124. package/src/components/POSTable/POSTable.tsx +401 -0
  125. package/src/components/POSTable/POSTable.types.ts +83 -0
  126. package/src/components/POSTable/README.md +286 -0
  127. package/src/components/POSTable/index.ts +7 -0
  128. package/src/components/Pagination/Pagination.stories.tsx +555 -0
  129. package/src/components/Pagination/Pagination.tsx +286 -0
  130. package/src/components/Pagination/Pagination.types.ts +93 -0
  131. package/src/components/Pagination/README.md +298 -0
  132. package/src/components/Pagination/icons.tsx +47 -0
  133. package/{dist/components/Pagination/index.d.ts → src/components/Pagination/index.ts} +3 -4
  134. package/src/components/Quantity/Quantity.stories.tsx +457 -0
  135. package/src/components/Quantity/Quantity.tsx +289 -0
  136. package/src/components/Quantity/Quantity.types.ts +70 -0
  137. package/src/components/Radio/Radio.stories.tsx +523 -0
  138. package/src/components/Radio/Radio.tsx +170 -0
  139. package/src/components/Radio/Radio.types.ts +122 -0
  140. package/src/components/Select/README.md +299 -0
  141. package/src/components/Select/Select.stories.tsx +673 -0
  142. package/src/components/Select/Select.tsx +454 -0
  143. package/src/components/Select/Select.types.ts +148 -0
  144. package/src/components/Select/icons.tsx +50 -0
  145. package/{dist/components/Select/index.d.ts → src/components/Select/index.ts} +3 -4
  146. package/src/components/SignUpView/SignUpView.stories.tsx +129 -0
  147. package/src/components/SignUpView/SignUpView.tsx +503 -0
  148. package/src/components/SignUpView/SignUpView.types.ts +58 -0
  149. package/src/components/SignUpView/icons.tsx +71 -0
  150. package/{dist/components/SignUpView/index.d.ts → src/components/SignUpView/index.ts} +3 -4
  151. package/src/components/Switch/README.md +112 -0
  152. package/src/components/Switch/Switch.stories.tsx +550 -0
  153. package/src/components/Switch/Switch.tsx +246 -0
  154. package/src/components/Switch/Switch.types.ts +67 -0
  155. package/src/components/Table/README.md +369 -0
  156. package/src/components/Table/Table.stories.tsx +805 -0
  157. package/src/components/Table/Table.tsx +688 -0
  158. package/src/components/Table/Table.types.ts +204 -0
  159. package/src/components/Table/index.ts +9 -0
  160. package/src/components/Tabs/README.md +201 -0
  161. package/src/components/Tabs/Tabs.stories.tsx +580 -0
  162. package/src/components/Tabs/Tabs.tsx +356 -0
  163. package/src/components/Tabs/Tabs.types.ts +127 -0
  164. package/src/components/Tabs/icons.tsx +129 -0
  165. package/src/components/Tabs/index.ts +11 -0
  166. package/src/components/Textarea/Textarea.stories.tsx +535 -0
  167. package/src/components/Textarea/Textarea.tsx +188 -0
  168. package/src/components/Textarea/Textarea.types.ts +54 -0
  169. package/src/context/ThemeContext.tsx +99 -0
  170. package/{dist/context/index.d.ts → src/context/index.ts} +1 -2
  171. package/src/index.css +29 -0
  172. package/src/index.ts +39 -0
  173. package/src/main.tsx +10 -0
  174. package/src/views/ProductsView/ProductsView.stories.tsx +344 -0
  175. package/src/views/ProductsView/ProductsView.tsx +480 -0
  176. package/src/views/ProductsView/ProductsView.types.ts +238 -0
  177. package/src/views/ProductsView/README.md +312 -0
  178. package/src/views/ProductsView/icons.tsx +38 -0
  179. package/src/views/ProductsView/index.ts +8 -0
  180. package/src/views/RecoverPasswordView/README.md +269 -0
  181. package/src/views/RecoverPasswordView/RecoverPasswordView.stories.tsx +131 -0
  182. package/src/views/RecoverPasswordView/RecoverPasswordView.tsx +376 -0
  183. package/src/views/RecoverPasswordView/RecoverPasswordView.types.ts +56 -0
  184. package/src/views/RecoverPasswordView/icons.tsx +17 -0
  185. package/{dist/views/RecoverPasswordView/index.d.ts → src/views/RecoverPasswordView/index.ts} +2 -3
  186. package/src/views/TableLayoutView/README.md +268 -0
  187. package/src/views/TableLayoutView/TableLayoutView.stories.tsx +235 -0
  188. package/src/views/TableLayoutView/TableLayoutView.tsx +461 -0
  189. package/src/views/TableLayoutView/TableLayoutView.types.ts +209 -0
  190. package/src/views/TableLayoutView/icons.tsx +113 -0
  191. package/src/views/TableLayoutView/index.ts +6 -0
  192. package/storybook/main.ts +20 -0
  193. package/storybook/preview.tsx +84 -0
  194. package/storybook/vitest.setup.ts +7 -0
  195. package/tailwind.config.js +128 -0
  196. package/dist/ButtonTest.d.ts +0 -6
  197. package/dist/ButtonTest.d.ts.map +0 -1
  198. package/dist/components/Alert/Alert.d.ts +0 -23
  199. package/dist/components/Alert/Alert.d.ts.map +0 -1
  200. package/dist/components/Alert/Alert.types.d.ts +0 -46
  201. package/dist/components/Alert/Alert.types.d.ts.map +0 -1
  202. package/dist/components/Avatar/Avatar.d.ts +0 -41
  203. package/dist/components/Avatar/Avatar.d.ts.map +0 -1
  204. package/dist/components/Avatar/Avatar.types.d.ts +0 -46
  205. package/dist/components/Avatar/Avatar.types.d.ts.map +0 -1
  206. package/dist/components/Badge/Badge.d.ts +0 -42
  207. package/dist/components/Badge/Badge.d.ts.map +0 -1
  208. package/dist/components/Badge/Badge.types.d.ts +0 -32
  209. package/dist/components/Badge/Badge.types.d.ts.map +0 -1
  210. package/dist/components/Button/Button.d.ts +0 -84
  211. package/dist/components/Button/Button.d.ts.map +0 -1
  212. package/dist/components/Button/Button.types.d.ts +0 -162
  213. package/dist/components/Button/Button.types.d.ts.map +0 -1
  214. package/dist/components/Button/icons.d.ts +0 -26
  215. package/dist/components/Button/icons.d.ts.map +0 -1
  216. package/dist/components/Button/index.d.ts.map +0 -1
  217. package/dist/components/Checkbox/Checkbox.d.ts +0 -31
  218. package/dist/components/Checkbox/Checkbox.d.ts.map +0 -1
  219. package/dist/components/Checkbox/Checkbox.types.d.ts +0 -53
  220. package/dist/components/Checkbox/Checkbox.types.d.ts.map +0 -1
  221. package/dist/components/DescriptionList/DescriptionList.d.ts +0 -38
  222. package/dist/components/DescriptionList/DescriptionList.d.ts.map +0 -1
  223. package/dist/components/DescriptionList/DescriptionList.types.d.ts +0 -27
  224. package/dist/components/DescriptionList/DescriptionList.types.d.ts.map +0 -1
  225. package/dist/components/Divider/Divider.d.ts +0 -33
  226. package/dist/components/Divider/Divider.d.ts.map +0 -1
  227. package/dist/components/Divider/Divider.types.d.ts +0 -22
  228. package/dist/components/Divider/Divider.types.d.ts.map +0 -1
  229. package/dist/components/Dropdown/Dropdown.d.ts +0 -66
  230. package/dist/components/Dropdown/Dropdown.d.ts.map +0 -1
  231. package/dist/components/Dropdown/Dropdown.types.d.ts +0 -124
  232. package/dist/components/Dropdown/Dropdown.types.d.ts.map +0 -1
  233. package/dist/components/Dropdown/icons.d.ts +0 -10
  234. package/dist/components/Dropdown/icons.d.ts.map +0 -1
  235. package/dist/components/Dropdown/index.d.ts.map +0 -1
  236. package/dist/components/DropdownItemCollapsible/DropdownItemCollapsible.d.ts +0 -101
  237. package/dist/components/DropdownItemCollapsible/DropdownItemCollapsible.d.ts.map +0 -1
  238. package/dist/components/DropdownItemCollapsible/DropdownItemCollapsible.types.d.ts +0 -95
  239. package/dist/components/DropdownItemCollapsible/DropdownItemCollapsible.types.d.ts.map +0 -1
  240. package/dist/components/DropdownItemCollapsible/icons.d.ts +0 -19
  241. package/dist/components/DropdownItemCollapsible/icons.d.ts.map +0 -1
  242. package/dist/components/DropdownItemCollapsible/index.d.ts +0 -9
  243. package/dist/components/DropdownItemCollapsible/index.d.ts.map +0 -1
  244. package/dist/components/DropdownItemHeading/DropdownItemHeading.d.ts +0 -75
  245. package/dist/components/DropdownItemHeading/DropdownItemHeading.d.ts.map +0 -1
  246. package/dist/components/DropdownItemHeading/DropdownItemHeading.types.d.ts +0 -85
  247. package/dist/components/DropdownItemHeading/DropdownItemHeading.types.d.ts.map +0 -1
  248. package/dist/components/DropdownItemHeading/icons.d.ts +0 -48
  249. package/dist/components/DropdownItemHeading/icons.d.ts.map +0 -1
  250. package/dist/components/DropdownItemHeading/index.d.ts +0 -4
  251. package/dist/components/DropdownItemHeading/index.d.ts.map +0 -1
  252. package/dist/components/Input/Input.d.ts +0 -40
  253. package/dist/components/Input/Input.d.ts.map +0 -1
  254. package/dist/components/Input/Input.types.d.ts +0 -71
  255. package/dist/components/Input/Input.types.d.ts.map +0 -1
  256. package/dist/components/Input/icons.d.ts +0 -15
  257. package/dist/components/Input/icons.d.ts.map +0 -1
  258. package/dist/components/Input/index.d.ts.map +0 -1
  259. package/dist/components/LoginView/LoginView.d.ts +0 -36
  260. package/dist/components/LoginView/LoginView.d.ts.map +0 -1
  261. package/dist/components/LoginView/LoginView.types.d.ts +0 -46
  262. package/dist/components/LoginView/LoginView.types.d.ts.map +0 -1
  263. package/dist/components/LoginView/icons.d.ts +0 -18
  264. package/dist/components/LoginView/icons.d.ts.map +0 -1
  265. package/dist/components/LoginView/index.d.ts.map +0 -1
  266. package/dist/components/Navbar/Navbar.d.ts +0 -63
  267. package/dist/components/Navbar/Navbar.d.ts.map +0 -1
  268. package/dist/components/Navbar/Navbar.types.d.ts +0 -194
  269. package/dist/components/Navbar/Navbar.types.d.ts.map +0 -1
  270. package/dist/components/Navbar/icons.d.ts +0 -12
  271. package/dist/components/Navbar/icons.d.ts.map +0 -1
  272. package/dist/components/Navbar/index.d.ts +0 -4
  273. package/dist/components/Navbar/index.d.ts.map +0 -1
  274. package/dist/components/NavigationBar/NavigationBar.d.ts +0 -75
  275. package/dist/components/NavigationBar/NavigationBar.d.ts.map +0 -1
  276. package/dist/components/NavigationBar/NavigationBar.types.d.ts +0 -63
  277. package/dist/components/NavigationBar/NavigationBar.types.d.ts.map +0 -1
  278. package/dist/components/NavigationBar/index.d.ts.map +0 -1
  279. package/dist/components/NavigationRail/NavigationRail.d.ts +0 -7
  280. package/dist/components/NavigationRail/NavigationRail.d.ts.map +0 -1
  281. package/dist/components/NavigationRail/NavigationRail.types.d.ts +0 -92
  282. package/dist/components/NavigationRail/NavigationRail.types.d.ts.map +0 -1
  283. package/dist/components/NavigationRail/index.d.ts.map +0 -1
  284. package/dist/components/NavigationRailItem/NavigationRailItem.d.ts +0 -90
  285. package/dist/components/NavigationRailItem/NavigationRailItem.d.ts.map +0 -1
  286. package/dist/components/NavigationRailItem/NavigationRailItem.types.d.ts +0 -155
  287. package/dist/components/NavigationRailItem/NavigationRailItem.types.d.ts.map +0 -1
  288. package/dist/components/NavigationRailItem/index.d.ts +0 -3
  289. package/dist/components/NavigationRailItem/index.d.ts.map +0 -1
  290. package/dist/components/NavigationRailPanel/NavigationRailPanel.d.ts +0 -124
  291. package/dist/components/NavigationRailPanel/NavigationRailPanel.d.ts.map +0 -1
  292. package/dist/components/NavigationRailPanel/NavigationRailPanel.types.d.ts +0 -154
  293. package/dist/components/NavigationRailPanel/NavigationRailPanel.types.d.ts.map +0 -1
  294. package/dist/components/NavigationRailPanel/index.d.ts +0 -3
  295. package/dist/components/NavigationRailPanel/index.d.ts.map +0 -1
  296. package/dist/components/NavigationRailTypes/NavigationRailTypes.d.ts +0 -99
  297. package/dist/components/NavigationRailTypes/NavigationRailTypes.d.ts.map +0 -1
  298. package/dist/components/NavigationRailTypes/NavigationRailTypes.types.d.ts +0 -111
  299. package/dist/components/NavigationRailTypes/NavigationRailTypes.types.d.ts.map +0 -1
  300. package/dist/components/NavigationRailTypes/icons.d.ts +0 -58
  301. package/dist/components/NavigationRailTypes/icons.d.ts.map +0 -1
  302. package/dist/components/NavigationRailTypes/index.d.ts +0 -4
  303. package/dist/components/NavigationRailTypes/index.d.ts.map +0 -1
  304. package/dist/components/Notification/Notification.d.ts +0 -52
  305. package/dist/components/Notification/Notification.d.ts.map +0 -1
  306. package/dist/components/Notification/Notification.types.d.ts +0 -138
  307. package/dist/components/Notification/Notification.types.d.ts.map +0 -1
  308. package/dist/components/Notification/index.d.ts.map +0 -1
  309. package/dist/components/POSConvention/POSConvention.d.ts +0 -55
  310. package/dist/components/POSConvention/POSConvention.d.ts.map +0 -1
  311. package/dist/components/POSConvention/POSConvention.types.d.ts.map +0 -1
  312. package/dist/components/POSConvention/icons.d.ts +0 -21
  313. package/dist/components/POSConvention/icons.d.ts.map +0 -1
  314. package/dist/components/POSConvention/index.d.ts.map +0 -1
  315. package/dist/components/POSLocationButton/POSLocationButton.d.ts +0 -73
  316. package/dist/components/POSLocationButton/POSLocationButton.d.ts.map +0 -1
  317. package/dist/components/POSLocationButton/POSLocationButton.types.d.ts +0 -75
  318. package/dist/components/POSLocationButton/POSLocationButton.types.d.ts.map +0 -1
  319. package/dist/components/POSLocationButton/icons.d.ts +0 -37
  320. package/dist/components/POSLocationButton/icons.d.ts.map +0 -1
  321. package/dist/components/POSLocationButton/index.d.ts +0 -4
  322. package/dist/components/POSLocationButton/index.d.ts.map +0 -1
  323. package/dist/components/POSNumberButton/POSNumberButton.d.ts +0 -61
  324. package/dist/components/POSNumberButton/POSNumberButton.d.ts.map +0 -1
  325. package/dist/components/POSNumberButton/POSNumberButton.types.d.ts +0 -43
  326. package/dist/components/POSNumberButton/POSNumberButton.types.d.ts.map +0 -1
  327. package/dist/components/POSNumberButton/index.d.ts.map +0 -1
  328. package/dist/components/POSProductButton/POSProductButton.d.ts +0 -59
  329. package/dist/components/POSProductButton/POSProductButton.d.ts.map +0 -1
  330. package/dist/components/POSProductButton/POSProductButton.types.d.ts +0 -40
  331. package/dist/components/POSProductButton/POSProductButton.types.d.ts.map +0 -1
  332. package/dist/components/POSProductButton/index.d.ts.map +0 -1
  333. package/dist/components/POSProductCard/POSProductCard.d.ts +0 -68
  334. package/dist/components/POSProductCard/POSProductCard.d.ts.map +0 -1
  335. package/dist/components/POSProductCard/POSProductCard.types.d.ts +0 -67
  336. package/dist/components/POSProductCard/POSProductCard.types.d.ts.map +0 -1
  337. package/dist/components/POSProductCard/icons.d.ts +0 -10
  338. package/dist/components/POSProductCard/icons.d.ts.map +0 -1
  339. package/dist/components/POSProductCard/index.d.ts.map +0 -1
  340. package/dist/components/POSProductSidebarItems/POSProductSidebarItems.d.ts +0 -57
  341. package/dist/components/POSProductSidebarItems/POSProductSidebarItems.d.ts.map +0 -1
  342. package/dist/components/POSProductSidebarItems/POSProductSidebarItems.types.d.ts +0 -85
  343. package/dist/components/POSProductSidebarItems/POSProductSidebarItems.types.d.ts.map +0 -1
  344. package/dist/components/POSProductSidebarItems/icons.d.ts +0 -9
  345. package/dist/components/POSProductSidebarItems/icons.d.ts.map +0 -1
  346. package/dist/components/POSProductSidebarItems/index.d.ts.map +0 -1
  347. package/dist/components/POSTable/POSTable.d.ts +0 -75
  348. package/dist/components/POSTable/POSTable.d.ts.map +0 -1
  349. package/dist/components/POSTable/POSTable.types.d.ts +0 -71
  350. package/dist/components/POSTable/POSTable.types.d.ts.map +0 -1
  351. package/dist/components/POSTable/index.d.ts +0 -3
  352. package/dist/components/POSTable/index.d.ts.map +0 -1
  353. package/dist/components/Pagination/Pagination.d.ts +0 -29
  354. package/dist/components/Pagination/Pagination.d.ts.map +0 -1
  355. package/dist/components/Pagination/Pagination.types.d.ts +0 -79
  356. package/dist/components/Pagination/Pagination.types.d.ts.map +0 -1
  357. package/dist/components/Pagination/icons.d.ts +0 -18
  358. package/dist/components/Pagination/icons.d.ts.map +0 -1
  359. package/dist/components/Pagination/index.d.ts.map +0 -1
  360. package/dist/components/Quantity/Quantity.d.ts +0 -38
  361. package/dist/components/Quantity/Quantity.d.ts.map +0 -1
  362. package/dist/components/Quantity/Quantity.types.d.ts +0 -59
  363. package/dist/components/Quantity/Quantity.types.d.ts.map +0 -1
  364. package/dist/components/Radio/Radio.d.ts +0 -45
  365. package/dist/components/Radio/Radio.d.ts.map +0 -1
  366. package/dist/components/Radio/Radio.types.d.ts +0 -115
  367. package/dist/components/Radio/Radio.types.d.ts.map +0 -1
  368. package/dist/components/Select/Select.d.ts +0 -37
  369. package/dist/components/Select/Select.d.ts.map +0 -1
  370. package/dist/components/Select/Select.types.d.ts +0 -124
  371. package/dist/components/Select/Select.types.d.ts.map +0 -1
  372. package/dist/components/Select/icons.d.ts +0 -16
  373. package/dist/components/Select/icons.d.ts.map +0 -1
  374. package/dist/components/Select/index.d.ts.map +0 -1
  375. package/dist/components/SignUpView/SignUpView.d.ts +0 -38
  376. package/dist/components/SignUpView/SignUpView.d.ts.map +0 -1
  377. package/dist/components/SignUpView/SignUpView.types.d.ts +0 -51
  378. package/dist/components/SignUpView/SignUpView.types.d.ts.map +0 -1
  379. package/dist/components/SignUpView/icons.d.ts +0 -18
  380. package/dist/components/SignUpView/icons.d.ts.map +0 -1
  381. package/dist/components/SignUpView/index.d.ts.map +0 -1
  382. package/dist/components/Switch/Switch.d.ts +0 -46
  383. package/dist/components/Switch/Switch.d.ts.map +0 -1
  384. package/dist/components/Switch/Switch.types.d.ts +0 -58
  385. package/dist/components/Switch/Switch.types.d.ts.map +0 -1
  386. package/dist/components/Table/Table.d.ts +0 -64
  387. package/dist/components/Table/Table.d.ts.map +0 -1
  388. package/dist/components/Table/Table.types.d.ts +0 -173
  389. package/dist/components/Table/Table.types.d.ts.map +0 -1
  390. package/dist/components/Table/index.d.ts +0 -3
  391. package/dist/components/Table/index.d.ts.map +0 -1
  392. package/dist/components/Tabs/Tabs.d.ts +0 -76
  393. package/dist/components/Tabs/Tabs.d.ts.map +0 -1
  394. package/dist/components/Tabs/Tabs.types.d.ts +0 -107
  395. package/dist/components/Tabs/Tabs.types.d.ts.map +0 -1
  396. package/dist/components/Tabs/icons.d.ts +0 -45
  397. package/dist/components/Tabs/icons.d.ts.map +0 -1
  398. package/dist/components/Tabs/index.d.ts +0 -4
  399. package/dist/components/Tabs/index.d.ts.map +0 -1
  400. package/dist/components/Textarea/Textarea.d.ts +0 -38
  401. package/dist/components/Textarea/Textarea.d.ts.map +0 -1
  402. package/dist/components/Textarea/Textarea.types.d.ts +0 -46
  403. package/dist/components/Textarea/Textarea.types.d.ts.map +0 -1
  404. package/dist/context/ThemeContext.d.ts +0 -46
  405. package/dist/context/ThemeContext.d.ts.map +0 -1
  406. package/dist/context/index.d.ts.map +0 -1
  407. package/dist/index.d.ts +0 -56
  408. package/dist/index.d.ts.map +0 -1
  409. package/dist/siesa-ui-kit.cjs +0 -1260
  410. package/dist/siesa-ui-kit.cjs.map +0 -1
  411. package/dist/siesa-ui-kit.mjs +0 -4496
  412. package/dist/siesa-ui-kit.mjs.map +0 -1
  413. package/dist/views/ListView/ListView.d.ts +0 -47
  414. package/dist/views/ListView/ListView.d.ts.map +0 -1
  415. package/dist/views/ListView/ListView.types.d.ts +0 -177
  416. package/dist/views/ListView/ListView.types.d.ts.map +0 -1
  417. package/dist/views/ListView/icons.d.ts +0 -60
  418. package/dist/views/ListView/icons.d.ts.map +0 -1
  419. package/dist/views/ListView/index.d.ts +0 -3
  420. package/dist/views/ListView/index.d.ts.map +0 -1
  421. package/dist/views/LoginView/LoginView.d.ts +0 -36
  422. package/dist/views/LoginView/LoginView.d.ts.map +0 -1
  423. package/dist/views/LoginView/LoginView.types.d.ts +0 -46
  424. package/dist/views/LoginView/LoginView.types.d.ts.map +0 -1
  425. package/dist/views/LoginView/icons.d.ts +0 -18
  426. package/dist/views/LoginView/icons.d.ts.map +0 -1
  427. package/dist/views/LoginView/index.d.ts +0 -4
  428. package/dist/views/LoginView/index.d.ts.map +0 -1
  429. package/dist/views/ProductsView/ProductsView.d.ts +0 -56
  430. package/dist/views/ProductsView/ProductsView.d.ts.map +0 -1
  431. package/dist/views/ProductsView/ProductsView.types.d.ts +0 -184
  432. package/dist/views/ProductsView/ProductsView.types.d.ts.map +0 -1
  433. package/dist/views/ProductsView/icons.d.ts +0 -12
  434. package/dist/views/ProductsView/icons.d.ts.map +0 -1
  435. package/dist/views/ProductsView/index.d.ts +0 -3
  436. package/dist/views/ProductsView/index.d.ts.map +0 -1
  437. package/dist/views/RecoverPasswordView/RecoverPasswordView.d.ts +0 -34
  438. package/dist/views/RecoverPasswordView/RecoverPasswordView.d.ts.map +0 -1
  439. package/dist/views/RecoverPasswordView/RecoverPasswordView.types.d.ts +0 -50
  440. package/dist/views/RecoverPasswordView/RecoverPasswordView.types.d.ts.map +0 -1
  441. package/dist/views/RecoverPasswordView/icons.d.ts +0 -9
  442. package/dist/views/RecoverPasswordView/icons.d.ts.map +0 -1
  443. package/dist/views/RecoverPasswordView/index.d.ts.map +0 -1
  444. package/dist/views/SignUpView/SignUpView.d.ts +0 -38
  445. package/dist/views/SignUpView/SignUpView.d.ts.map +0 -1
  446. package/dist/views/SignUpView/SignUpView.types.d.ts +0 -51
  447. package/dist/views/SignUpView/SignUpView.types.d.ts.map +0 -1
  448. package/dist/views/SignUpView/icons.d.ts +0 -18
  449. package/dist/views/SignUpView/icons.d.ts.map +0 -1
  450. package/dist/views/SignUpView/index.d.ts +0 -4
  451. package/dist/views/SignUpView/index.d.ts.map +0 -1
  452. package/dist/views/TableLayoutView/TableLayoutView.d.ts +0 -46
  453. package/dist/views/TableLayoutView/TableLayoutView.d.ts.map +0 -1
  454. package/dist/views/TableLayoutView/TableLayoutView.types.d.ts +0 -170
  455. package/dist/views/TableLayoutView/TableLayoutView.types.d.ts.map +0 -1
  456. package/dist/views/TableLayoutView/icons.d.ts +0 -27
  457. package/dist/views/TableLayoutView/icons.d.ts.map +0 -1
  458. package/dist/views/TableLayoutView/index.d.ts +0 -3
  459. package/dist/views/TableLayoutView/index.d.ts.map +0 -1
@@ -0,0 +1,406 @@
1
+ import type { Meta, StoryObj } from '@storybook/react';
2
+ import { useState } from 'react';
3
+ import { NavigationBar } from './NavigationBar';
4
+ import type { NavigationBarItem } from './NavigationBar.types';
5
+
6
+ // ===== ICONOS DE EJEMPLO =====
7
+ // Iconos simples de heroicons-micro (16x16px)
8
+ const HomeIcon = () => (
9
+ <svg width="16" height="16" viewBox="0 0 16 16" fill="none" xmlns="http://www.w3.org/2000/svg">
10
+ <path
11
+ d="M6.5 14.5v-3.505c0-.245.25-.495.5-.495h2c.25 0 .5.25.5.495V14.5m-7-3c0-2.485 0-3.729.586-4.664.586-.936 1.586-1.479 3.586-2.564l.328-.179C7.712 3.348 8.26 3 8.76 3c.5 0 1.048.348 2.26 1.093l.328.179c2 1.085 3 1.628 3.586 2.564.586.935.586 2.179.586 4.664v1c0 2.8 0 4.2-.545 5.27a5 5 0 0 1-2.185 2.185C11.7 20.5 10.3 20.5 7.5 20.5h1c-2.8 0-4.2 0-5.27-.545a5 5 0 0 1-2.185-2.185C.5 16.7.5 15.3.5 12.5v-1Z"
12
+ stroke="currentColor"
13
+ strokeWidth="1.5"
14
+ strokeLinecap="round"
15
+ strokeLinejoin="round"
16
+ />
17
+ </svg>
18
+ );
19
+
20
+ const SearchIcon = () => (
21
+ <svg width="16" height="16" viewBox="0 0 16 16" fill="none" xmlns="http://www.w3.org/2000/svg">
22
+ <path
23
+ d="M14 14l-2.9-2.9M12.667 7.333A5.333 5.333 0 1 1 2 7.333a5.333 5.333 0 0 1 10.667 0Z"
24
+ stroke="currentColor"
25
+ strokeWidth="1.5"
26
+ strokeLinecap="round"
27
+ strokeLinejoin="round"
28
+ />
29
+ </svg>
30
+ );
31
+
32
+ const HeartIcon = () => (
33
+ <svg width="16" height="16" viewBox="0 0 16 16" fill="none" xmlns="http://www.w3.org/2000/svg">
34
+ <path
35
+ d="M13.732 3.268A4 4 0 0 0 8.4 2.4L8 2.8l-.4-.4a4 4 0 0 0-5.332.932 4 4 0 0 0 .532 5.732l5.2 5.2 5.2-5.2a4 4 0 0 0 .532-5.796Z"
36
+ stroke="currentColor"
37
+ strokeWidth="1.5"
38
+ strokeLinecap="round"
39
+ strokeLinejoin="round"
40
+ />
41
+ </svg>
42
+ );
43
+
44
+ const BellIcon = () => (
45
+ <svg width="16" height="16" viewBox="0 0 16 16" fill="none" xmlns="http://www.w3.org/2000/svg">
46
+ <path
47
+ d="M6 13.333a2 2 0 1 0 4 0M11.333 5.333a3.333 3.333 0 1 0-6.666 0c0 3.773-1.334 5.334-1.334 5.334h9.334s-1.334-1.56-1.334-5.334Z"
48
+ stroke="currentColor"
49
+ strokeWidth="1.5"
50
+ strokeLinecap="round"
51
+ strokeLinejoin="round"
52
+ />
53
+ </svg>
54
+ );
55
+
56
+ const UserIcon = () => (
57
+ <svg width="16" height="16" viewBox="0 0 16 16" fill="none" xmlns="http://www.w3.org/2000/svg">
58
+ <path
59
+ d="M13.333 14v-1.333A2.667 2.667 0 0 0 10.667 10H5.333a2.667 2.667 0 0 0-2.666 2.667V14M8 7.333A2.667 2.667 0 1 0 8 2a2.667 2.667 0 0 0 0 5.333Z"
60
+ stroke="currentColor"
61
+ strokeWidth="1.5"
62
+ strokeLinecap="round"
63
+ strokeLinejoin="round"
64
+ />
65
+ </svg>
66
+ );
67
+
68
+ const meta = {
69
+ title: 'Siesa UI Kit/NavigationBar',
70
+ component: NavigationBar,
71
+ parameters: {
72
+ layout: 'fullscreen',
73
+ docs: {
74
+ description: {
75
+ component:
76
+ 'Barra de navegación inferior (Bottom Navigation Bar) para aplicaciones móviles. Permite al usuario navegar entre 3-5 vistas principales de la aplicación.',
77
+ },
78
+ },
79
+ },
80
+ tags: ['autodocs'],
81
+ argTypes: {
82
+ items: {
83
+ control: 'object',
84
+ description: 'Lista de ítems del navigation bar (máximo 5 recomendado)',
85
+ table: {
86
+ type: { summary: 'NavigationBarItem[]' },
87
+ category: 'Contenido',
88
+ },
89
+ },
90
+ activeItemId: {
91
+ control: 'text',
92
+ description: 'ID del ítem actualmente activo',
93
+ table: {
94
+ type: { summary: 'string' },
95
+ category: 'Estado',
96
+ },
97
+ },
98
+ onItemClick: {
99
+ action: 'itemClicked',
100
+ description: 'Función que se ejecuta cuando se hace click en un ítem',
101
+ table: {
102
+ type: { summary: '(id: string) => void' },
103
+ category: 'Comportamiento',
104
+ },
105
+ },
106
+ className: {
107
+ control: 'text',
108
+ description: 'Clases CSS adicionales',
109
+ table: {
110
+ type: { summary: 'string' },
111
+ category: 'Apariencia',
112
+ },
113
+ },
114
+ ariaLabel: {
115
+ control: 'text',
116
+ description: 'Etiqueta accesible para el navigation bar',
117
+ table: {
118
+ type: { summary: 'string' },
119
+ category: 'Accesibilidad',
120
+ },
121
+ },
122
+ },
123
+ } satisfies Meta<typeof NavigationBar>;
124
+
125
+ export default meta;
126
+ type Story = StoryObj<typeof meta>;
127
+
128
+ // ===== DATOS DE EJEMPLO =====
129
+ const sampleItems: NavigationBarItem[] = [
130
+ { id: 'home', icon: <HomeIcon />, label: 'Inicio', active: true },
131
+ { id: 'search', icon: <SearchIcon />, label: 'Buscar' },
132
+ { id: 'favorites', icon: <HeartIcon />, label: 'Favoritos' },
133
+ { id: 'notifications', icon: <BellIcon />, label: 'Alertas' },
134
+ { id: 'profile', icon: <UserIcon />, label: 'Perfil' },
135
+ ];
136
+
137
+ // ============================================
138
+ // 1. PLAYGROUND INTERACTIVO
139
+ // ============================================
140
+ export const Playground: Story = {
141
+ args: {
142
+ items: sampleItems,
143
+ activeItemId: 'home',
144
+ ariaLabel: 'Navegación Principal',
145
+ },
146
+ render: (args) => {
147
+ const [activeId, setActiveId] = useState(args.activeItemId || 'home');
148
+
149
+ return (
150
+ <div className="w-full flex items-end bg-background-secondary dark:bg-dark-bg-primary">
151
+ <NavigationBar
152
+ {...args}
153
+ activeItemId={activeId}
154
+ onItemClick={(id) => {
155
+ setActiveId(id);
156
+ args.onItemClick?.(id);
157
+ }}
158
+ />
159
+ </div>
160
+ );
161
+ },
162
+ };
163
+
164
+ // ============================================
165
+ // 2. VARIANTES DE CANTIDAD DE ÍTEMS
166
+ // ============================================
167
+ export const VariantesDeItems: Story = {
168
+ args: {
169
+ items: [],
170
+ },
171
+ render: () => (
172
+ <div className="space-y-8 p-6 bg-background-secondary dark:bg-dark-bg-primary">
173
+ {/* 3 Items */}
174
+ <div>
175
+ <h3 className="text-sm font-bold mb-4 text-content-primary dark:text-dark-content-primary">
176
+ 3 Ítems (Mínimo Recomendado)
177
+ </h3>
178
+ <div className="bg-bg-primary dark:bg-dark-bg-primary rounded-2xl overflow-hidden">
179
+ <NavigationBar
180
+ items={[
181
+ { id: 'home', icon: <HomeIcon />, label: 'Inicio', active: true },
182
+ { id: 'search', icon: <SearchIcon />, label: 'Buscar' },
183
+ { id: 'profile', icon: <UserIcon />, label: 'Perfil' },
184
+ ]}
185
+ activeItemId="home"
186
+ />
187
+ </div>
188
+ <p className="text-xs text-content-secondary dark:text-content-secondary mt-2">
189
+ Ideal para aplicaciones simples con pocas secciones principales
190
+ </p>
191
+ </div>
192
+
193
+ {/* 4 Items */}
194
+ <div>
195
+ <h3 className="text-sm font-bold mb-4 text-content-primary dark:text-dark-content-primary">
196
+ 4 Ítems (Óptimo)
197
+ </h3>
198
+ <div className="bg-bg-primary dark:bg-dark-bg-primary rounded-2xl overflow-hidden">
199
+ <NavigationBar
200
+ items={[
201
+ { id: 'home', icon: <HomeIcon />, label: 'Inicio', active: true },
202
+ { id: 'search', icon: <SearchIcon />, label: 'Buscar' },
203
+ { id: 'favorites', icon: <HeartIcon />, label: 'Favoritos' },
204
+ { id: 'profile', icon: <UserIcon />, label: 'Perfil' },
205
+ ]}
206
+ activeItemId="home"
207
+ />
208
+ </div>
209
+ <p className="text-xs text-content-secondary dark:text-content-secondary mt-2">
210
+ Balance perfecto entre funcionalidad y usabilidad
211
+ </p>
212
+ </div>
213
+
214
+ {/* 5 Items */}
215
+ <div>
216
+ <h3 className="text-sm font-bold mb-4 text-content-primary dark:text-dark-content-primary">
217
+ 5 Ítems (Máximo Recomendado)
218
+ </h3>
219
+ <div className="bg-bg-primary dark:bg-dark-bg-primary rounded-2xl overflow-hidden">
220
+ <NavigationBar items={sampleItems} activeItemId="home" />
221
+ </div>
222
+ <p className="text-xs text-content-secondary dark:text-content-secondary mt-2">
223
+ Máximo de ítems para mantener buena experiencia de usuario
224
+ </p>
225
+ </div>
226
+
227
+ {/* Tips */}
228
+ <div className="mt-6 p-4 bg-blue-50 dark:bg-blue-900/20 border border-blue-200 dark:border-blue-800 rounded-lg">
229
+ <p className="text-xs text-content-primary dark:text-dark-content-primary">
230
+ <strong>💡 Consejos:</strong>
231
+ <br />• Usa entre 3 y 5 ítems para mejor usabilidad
232
+ <br />• El primer ítem suele ser "Inicio" o la vista principal
233
+ <br />• Evita labels muy largos (máximo 10 caracteres)
234
+ <br />• Los iconos deben ser simples y reconocibles
235
+ </p>
236
+ </div>
237
+ </div>
238
+ ),
239
+ };
240
+
241
+ // ============================================
242
+ // 3. ESTADOS
243
+ // ============================================
244
+ export const Estados: Story = {
245
+ args: {
246
+ items: [],
247
+ },
248
+ render: () => (
249
+ <div className="space-y-8 p-6 bg-background-secondary dark:bg-dark-bg-primary">
250
+ {/* Estado Normal - Primer ítem activo */}
251
+ <div>
252
+ <h3 className="text-sm font-bold mb-4 text-content-primary dark:text-dark-content-primary">
253
+ Estado Normal (Primer Ítem Activo)
254
+ </h3>
255
+ <div className="bg-bg-primary dark:bg-dark-bg-primary rounded-2xl overflow-hidden">
256
+ <NavigationBar
257
+ items={[
258
+ { id: 'home', icon: <HomeIcon />, label: 'Inicio', active: true },
259
+ { id: 'search', icon: <SearchIcon />, label: 'Buscar' },
260
+ { id: 'favorites', icon: <HeartIcon />, label: 'Favoritos' },
261
+ { id: 'profile', icon: <UserIcon />, label: 'Perfil' },
262
+ ]}
263
+ activeItemId="home"
264
+ />
265
+ </div>
266
+ </div>
267
+
268
+ {/* Estado con ítem central activo */}
269
+ <div>
270
+ <h3 className="text-sm font-bold mb-4 text-content-primary dark:text-dark-content-primary">
271
+ Ítem Central Activo
272
+ </h3>
273
+ <div className="bg-bg-primary dark:bg-dark-bg-primary rounded-2xl overflow-hidden">
274
+ <NavigationBar
275
+ items={[
276
+ { id: 'home', icon: <HomeIcon />, label: 'Inicio' },
277
+ { id: 'search', icon: <SearchIcon />, label: 'Buscar' },
278
+ { id: 'favorites', icon: <HeartIcon />, label: 'Favoritos', active: true },
279
+ { id: 'profile', icon: <UserIcon />, label: 'Perfil' },
280
+ ]}
281
+ activeItemId="favorites"
282
+ />
283
+ </div>
284
+ <p className="text-xs text-content-secondary dark:text-content-secondary mt-2">
285
+ El ítem activo tiene fondo azul claro (light mode) o azul oscuro transparente (dark
286
+ mode)
287
+ </p>
288
+ </div>
289
+
290
+ {/* Estado con ítem deshabilitado */}
291
+ <div>
292
+ <h3 className="text-sm font-bold mb-4 text-content-primary dark:text-dark-content-primary">
293
+ Con Ítem Deshabilitado
294
+ </h3>
295
+ <div className="bg-bg-primary dark:bg-dark-bg-primary rounded-2xl overflow-hidden">
296
+ <NavigationBar
297
+ items={[
298
+ { id: 'home', icon: <HomeIcon />, label: 'Inicio', active: true },
299
+ { id: 'search', icon: <SearchIcon />, label: 'Buscar' },
300
+ {
301
+ id: 'favorites',
302
+ icon: <HeartIcon />,
303
+ label: 'Favoritos',
304
+ disabled: true,
305
+ },
306
+ { id: 'profile', icon: <UserIcon />, label: 'Perfil' },
307
+ ]}
308
+ activeItemId="home"
309
+ />
310
+ </div>
311
+ <p className="text-xs text-content-secondary dark:text-content-secondary mt-2">
312
+ Los ítems deshabilitados tienen opacidad reducida y no responden a clicks
313
+ </p>
314
+ </div>
315
+
316
+ {/* Estado hover */}
317
+ <div>
318
+ <h3 className="text-sm font-bold mb-4 text-content-primary dark:text-dark-content-primary">
319
+ Estado Hover
320
+ </h3>
321
+ <p className="text-xs text-content-secondary dark:text-content-secondary mb-2">
322
+ Pasa el mouse sobre los ítems inactivos para ver el efecto de hover
323
+ </p>
324
+ <div className="bg-bg-primary dark:bg-dark-bg-primary rounded-2xl overflow-hidden">
325
+ <NavigationBar
326
+ items={[
327
+ { id: 'home', icon: <HomeIcon />, label: 'Inicio', active: true },
328
+ { id: 'search', icon: <SearchIcon />, label: 'Buscar' },
329
+ { id: 'favorites', icon: <HeartIcon />, label: 'Favoritos' },
330
+ { id: 'profile', icon: <UserIcon />, label: 'Perfil' },
331
+ ]}
332
+ activeItemId="home"
333
+ />
334
+ </div>
335
+ </div>
336
+ </div>
337
+ ),
338
+ };
339
+
340
+ // ============================================
341
+ // 4. EJEMPLOS DE USO
342
+ // ============================================
343
+ export const EjemplosDeUso: Story = {
344
+ args: {
345
+ items: [],
346
+ },
347
+ render: () => {
348
+ const [activeTab1, setActiveTab1] = useState('home');
349
+ const [activeTab2, setActiveTab2] = useState('home');
350
+
351
+ return (
352
+ <div className="space-y-8 p-6 bg-background-secondary dark:bg-dark-bg-primary">
353
+ {/* Ejemplo 1: E-commerce */}
354
+ <div>
355
+ <h3 className="text-sm font-bold mb-4 text-content-primary dark:text-dark-content-primary">
356
+ App de E-commerce
357
+ </h3>
358
+ <div className="bg-bg-primary dark:bg-dark-bg-primary rounded-2xl overflow-hidden">
359
+ <NavigationBar
360
+ items={[
361
+ { id: 'home', icon: <HomeIcon />, label: 'Inicio' },
362
+ { id: 'search', icon: <SearchIcon />, label: 'Buscar' },
363
+ { id: 'favorites', icon: <HeartIcon />, label: 'Favoritos' },
364
+ { id: 'profile', icon: <UserIcon />, label: 'Cuenta' },
365
+ ]}
366
+ activeItemId={activeTab1}
367
+ onItemClick={setActiveTab1}
368
+ />
369
+ </div>
370
+ </div>
371
+
372
+ {/* Ejemplo 2: Red Social */}
373
+ <div>
374
+ <h3 className="text-sm font-bold mb-4 text-content-primary dark:text-dark-content-primary">
375
+ Red Social
376
+ </h3>
377
+ <div className="bg-bg-primary dark:bg-dark-bg-primary rounded-2xl overflow-hidden">
378
+ <NavigationBar
379
+ items={[
380
+ { id: 'home', icon: <HomeIcon />, label: 'Inicio' },
381
+ { id: 'search', icon: <SearchIcon />, label: 'Explorar' },
382
+ { id: 'notifications', icon: <BellIcon />, label: 'Alertas' },
383
+ { id: 'favorites', icon: <HeartIcon />, label: 'Guardados' },
384
+ { id: 'profile', icon: <UserIcon />, label: 'Perfil' },
385
+ ]}
386
+ activeItemId={activeTab2}
387
+ onItemClick={setActiveTab2}
388
+ />
389
+ </div>
390
+ </div>
391
+
392
+ {/* Tips */}
393
+ <div className="mt-6 p-4 bg-blue-50 dark:bg-blue-900/20 border border-blue-200 dark:border-blue-800 rounded-lg">
394
+ <p className="text-xs text-content-primary dark:text-dark-content-primary">
395
+ <strong>💡 Cuándo usar NavigationBar:</strong>
396
+ <br />• Aplicaciones móviles con 3-5 secciones principales
397
+ <br />• Navegación persistente entre vistas de igual jerarquía
398
+ <br />• Apps donde el usuario necesita cambiar frecuentemente entre secciones
399
+ <br />• NO usar en web desktop (considera tabs o sidebar en su lugar)
400
+ </p>
401
+ </div>
402
+ </div>
403
+ );
404
+ },
405
+ };
406
+
@@ -0,0 +1,246 @@
1
+ import React from 'react';
2
+ import type { NavigationBarProps, NavigationBarItem } from './NavigationBar.types';
3
+
4
+ /**
5
+ * NavigationBar del sistema de diseño Siesa
6
+ *
7
+ * **Componente de navegación inferior (Bottom Navigation Bar) para móvil.**
8
+ * Permite al usuario navegar entre vistas principales de la aplicación.
9
+ * Diseñado para contener 3-5 ítems de navegación.
10
+ *
11
+ * **🔄 Navegación Responsive:**
12
+ * El NavigationRail (navegación lateral vertical) se convierte en NavigationBar
13
+ * (navegación inferior horizontal) cuando la pantalla es móvil. Esta es una
14
+ * práctica recomendada de UX para aprovechar mejor el espacio en diferentes
15
+ * dispositivos:
16
+ * - **Desktop/Tablet**: Usar NavigationRail (lateral)
17
+ * - **Mobile**: Usar NavigationBar (inferior)
18
+ *
19
+ * **Características:**
20
+ * - Soporta hasta 5 ítems de navegación (recomendado: 3-5)
21
+ * - Cada ítem tiene icono + label
22
+ * - Indicador visual de ítem activo (fondo azul claro)
23
+ * - Estados: active, hover, disabled
24
+ * - Dark mode completo
25
+ * - Accesibilidad con ARIA labels
26
+ *
27
+ * **Mejores prácticas implementadas:**
28
+ * - Orden de modificadores: {responsive}:{dark}:{state}:{utility}
29
+ * - Dark mode con estrategia 'class' (darkMode: 'class')
30
+ * - Tokens de color consistentes con la documentación
31
+ * - Type safety con TypeScript estricto
32
+ * - Tipografía Label XXSmall (10px Bold) según sistema de diseño
33
+ * - Iconos de 16x16px según especificaciones de Figma
34
+ *
35
+ * @see docs/colors.md - Sistema de colores
36
+ * @see docs/typography.md - Sistema tipográfico (Label XXSmall)
37
+ * @see docs/spacing.md - Sistema de espaciado
38
+ * @see NavigationRail - Componente de navegación lateral para desktop
39
+ *
40
+ * @example
41
+ * ```tsx
42
+ * const items = [
43
+ * { id: 'home', icon: <HomeIcon />, label: 'Inicio', active: true },
44
+ * { id: 'search', icon: <SearchIcon />, label: 'Buscar' },
45
+ * { id: 'profile', icon: <ProfileIcon />, label: 'Perfil' },
46
+ * ];
47
+ *
48
+ * <NavigationBar
49
+ * items={items}
50
+ * activeItemId="home"
51
+ * onItemClick={(id) => console.log('Clicked:', id)}
52
+ * />
53
+ * ```
54
+ *
55
+ * @example
56
+ * // Patrón responsive: NavigationRail en desktop, NavigationBar en mobile
57
+ * ```tsx
58
+ * function ResponsiveNav() {
59
+ * return (
60
+ * <>
61
+ * // NavigationRail para desktop/tablet
62
+ * <div className="hidden md:block">
63
+ * <NavigationRail items={items} />
64
+ * </div>
65
+ *
66
+ * // NavigationBar para móvil
67
+ * <div className="md:hidden fixed bottom-0 left-0 right-0 z-50">
68
+ * <NavigationBar items={items} />
69
+ * </div>
70
+ * </>
71
+ * );
72
+ * }
73
+ * ```
74
+ */
75
+ export const NavigationBar: React.FC<NavigationBarProps> = ({
76
+ items,
77
+ activeItemId,
78
+ onItemClick,
79
+ className = '',
80
+ ariaLabel = 'Navegación Principal',
81
+ }) => {
82
+ // ===== VALIDACIÓN: Máximo 5 ítems =====
83
+ if (items.length > 5) {
84
+ console.warn('NavigationBar: Se recomienda un máximo de 5 ítems para mejor UX');
85
+ }
86
+
87
+ // ===== HANDLER DE CLICK =====
88
+ const handleItemClick = (item: NavigationBarItem) => {
89
+ if (item.disabled) return;
90
+
91
+ // Llamar onClick del ítem individual si existe
92
+ if (item.onClick) {
93
+ item.onClick(item.id);
94
+ }
95
+
96
+ // Llamar onItemClick global si existe
97
+ if (onItemClick) {
98
+ onItemClick(item.id);
99
+ }
100
+ };
101
+
102
+ // ===== RENDERIZAR ÍTEM =====
103
+ const renderItem = (item: NavigationBarItem) => {
104
+ const isActive = item.active || item.id === activeItemId;
105
+
106
+ // ===== CLASES DEL CONTENEDOR DEL ÍTEM =====
107
+ const itemContainerClasses = `
108
+ flex-1
109
+ flex
110
+ flex-col
111
+ items-center
112
+ gap-1
113
+ px-0.5
114
+ py-0
115
+ min-w-0
116
+ cursor-pointer
117
+ transition-all
118
+ duration-150
119
+ ${item.disabled ? 'opacity-50 cursor-not-allowed pointer-events-none' : ''}
120
+ `
121
+ .replace(/\s+/g, ' ')
122
+ .trim();
123
+
124
+ // ===== CLASES DEL ICON CONTAINER =====
125
+ // Fondo azul claro cuando está activo (rgb(219, 238, 254) = #dbeefe = primary-custom-100)
126
+ // En dark mode usa el mismo color opaco según Figma
127
+ const iconContainerClasses = `
128
+ flex
129
+ items-center
130
+ justify-center
131
+ px-4
132
+ py-1
133
+ rounded-full
134
+ overflow-hidden
135
+ transition-all
136
+ duration-150
137
+ ${
138
+ isActive
139
+ ? 'bg-primary-custom-100 dark:bg-primary-custom-100'
140
+ : 'bg-transparent hover:bg-hover-overlay dark:hover:bg-hover-overlay-dark'
141
+ }
142
+ `
143
+ .replace(/\s+/g, ' ')
144
+ .trim();
145
+
146
+ // ===== CLASES DEL LABEL =====
147
+ // Label XXSmall: 10px Bold, line-height 12px (según typography.md y Figma)
148
+ const labelClasses = `
149
+ font-['SiesaBT:Bold',sans-serif]
150
+ text-[10px]
151
+ leading-[12px]
152
+ font-bold
153
+ text-center
154
+ w-full
155
+ min-w-0
156
+ text-content-primary
157
+ dark:text-dark-content-primary
158
+ transition-colors
159
+ duration-150
160
+ `
161
+ .replace(/\s+/g, ' ')
162
+ .trim();
163
+
164
+ // ===== CLASES DEL ICONO =====
165
+ // Iconos de 16x16px según Figma
166
+ const iconClasses = `
167
+ w-4
168
+ h-4
169
+ shrink-0
170
+ text-content-primary
171
+ dark:text-dark-content-primary
172
+ transition-colors
173
+ duration-150
174
+ `
175
+ .replace(/\s+/g, ' ')
176
+ .trim();
177
+
178
+ return (
179
+ <button
180
+ key={item.id}
181
+ type="button"
182
+ className={itemContainerClasses}
183
+ onClick={() => handleItemClick(item)}
184
+ disabled={item.disabled}
185
+ aria-label={item.ariaLabel || item.label}
186
+ aria-current={isActive ? 'page' : undefined}
187
+ >
188
+ {/* Icon Container */}
189
+ <div className={iconContainerClasses}>
190
+ <span className={iconClasses}>{item.icon}</span>
191
+ </div>
192
+
193
+ {/* Label */}
194
+ <span className={labelClasses}>{item.label}</span>
195
+ </button>
196
+ );
197
+ };
198
+
199
+ // ===== CLASES DEL CONTENEDOR PRINCIPAL =====
200
+ const containerClasses = `
201
+ bg-bg-primary
202
+ dark:bg-dark-bg-primary
203
+ p-4
204
+ w-full
205
+ transition-colors
206
+ duration-150
207
+ `
208
+ .replace(/\s+/g, ' ')
209
+ .trim();
210
+
211
+ // ===== CLASES DEL MENU (Contenedor de ítems) =====
212
+ const menuClasses = `
213
+ flex
214
+ items-start
215
+ justify-center
216
+ w-full
217
+ `
218
+ .replace(/\s+/g, ' ')
219
+ .trim();
220
+
221
+ // ===== CLASES DEL DESTINATIONS (Contenedor con gap) =====
222
+ const destinationsClasses = `
223
+ flex-1
224
+ flex
225
+ items-start
226
+ gap-2
227
+ min-h-0
228
+ min-w-0
229
+ `
230
+ .replace(/\s+/g, ' ')
231
+ .trim();
232
+
233
+ return (
234
+ <nav
235
+ className={`${containerClasses} ${className}`.trim()}
236
+ role="navigation"
237
+ aria-label={ariaLabel}
238
+ >
239
+ <div className={menuClasses}>
240
+ <div className={destinationsClasses}>
241
+ {items.map((item) => renderItem(item))}
242
+ </div>
243
+ </div>
244
+ </nav>
245
+ );
246
+ };