siesa-ui-kit 1.0.2 → 1.0.4

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 (189) hide show
  1. package/README.md +115 -115
  2. package/bin/install.cjs +502 -502
  3. package/bin/prepare-publish.cjs +28 -28
  4. package/bin/restore-folders.cjs +28 -28
  5. package/claude/agents/siesa-ui-kit-specialist.md +2445 -0
  6. package/claude/prompts/component-template.md +121 -0
  7. package/claude/prompts/siesa-ui-kit.md +28 -0
  8. package/claude/settings.local.json +67 -2
  9. package/dist/components/Button/icons.d.ts +6 -5
  10. package/dist/components/Button/icons.d.ts.map +1 -1
  11. package/dist/components/DropdownItemCollapsible/DropdownItemCollapsible.d.ts.map +1 -1
  12. package/dist/components/DropdownItemCollapsible/DropdownItemCollapsible.types.d.ts +21 -0
  13. package/dist/components/DropdownItemCollapsible/DropdownItemCollapsible.types.d.ts.map +1 -1
  14. package/dist/components/NavigationRailCommercial/NavigationRailCommercial.d.ts +122 -0
  15. package/dist/components/NavigationRailCommercial/NavigationRailCommercial.d.ts.map +1 -0
  16. package/dist/components/NavigationRailCommercial/NavigationRailCommercial.types.d.ts +139 -0
  17. package/dist/components/NavigationRailCommercial/NavigationRailCommercial.types.d.ts.map +1 -0
  18. package/dist/components/NavigationRailCommercial/icons.d.ts +33 -0
  19. package/dist/components/NavigationRailCommercial/icons.d.ts.map +1 -0
  20. package/dist/components/NavigationRailCommercial/index.d.ts +4 -0
  21. package/dist/components/NavigationRailCommercial/index.d.ts.map +1 -0
  22. package/dist/components/NavigationRailItem/NavigationRailItem.d.ts.map +1 -1
  23. package/dist/components/NavigationRailItem/NavigationRailItem.types.d.ts +7 -0
  24. package/dist/components/NavigationRailItem/NavigationRailItem.types.d.ts.map +1 -1
  25. package/dist/components/NavigationRailTypes/NavigationRailTypes.d.ts.map +1 -1
  26. package/dist/components/NavigationRailTypes/NavigationRailTypes.types.d.ts +41 -0
  27. package/dist/components/NavigationRailTypes/NavigationRailTypes.types.d.ts.map +1 -1
  28. package/dist/components/NavigationRailTypes/icons.d.ts +15 -29
  29. package/dist/components/NavigationRailTypes/icons.d.ts.map +1 -1
  30. package/dist/components/Select/Select.d.ts.map +1 -1
  31. package/dist/components/Select/icons.d.ts +6 -2
  32. package/dist/components/Select/icons.d.ts.map +1 -1
  33. package/dist/index.d.ts +32 -0
  34. package/dist/index.d.ts.map +1 -1
  35. package/dist/siesa-ui-kit.cjs +404 -190
  36. package/dist/siesa-ui-kit.cjs.map +1 -1
  37. package/dist/siesa-ui-kit.mjs +6590 -1506
  38. package/dist/siesa-ui-kit.mjs.map +1 -1
  39. package/dist/views/LayoutCommercial/LayoutCommercial.d.ts +48 -0
  40. package/dist/views/LayoutCommercial/LayoutCommercial.d.ts.map +1 -0
  41. package/dist/views/LayoutCommercial/LayoutCommercial.types.d.ts +49 -0
  42. package/dist/views/LayoutCommercial/LayoutCommercial.types.d.ts.map +1 -0
  43. package/dist/views/LayoutCommercial/index.d.ts +3 -0
  44. package/dist/views/LayoutCommercial/index.d.ts.map +1 -0
  45. package/docs/icons.md +12 -31
  46. package/package.json +111 -110
  47. package/src/components/Avatar/Avatar.stories.tsx +494 -494
  48. package/src/components/Button/Button.stories.tsx +950 -950
  49. package/src/components/Button/Button.tsx +337 -337
  50. package/src/components/Button/Button.types.ts +180 -180
  51. package/src/components/Button/icons.tsx +23 -62
  52. package/src/components/DescriptionList/DescriptionList.stories.tsx +250 -250
  53. package/src/components/Divider/Divider.stories.tsx +263 -263
  54. package/src/components/DropdownItemCollapsible/DropdownItemCollapsible.stories.tsx +317 -317
  55. package/src/components/DropdownItemCollapsible/DropdownItemCollapsible.tsx +307 -287
  56. package/src/components/DropdownItemCollapsible/DropdownItemCollapsible.types.ts +136 -111
  57. package/src/components/DropdownItemCollapsible/README.md +264 -264
  58. package/src/components/DropdownItemCollapsible/icons.tsx +57 -57
  59. package/src/components/DropdownItemCollapsible/index.ts +12 -12
  60. package/src/components/DropdownItemHeading/DropdownItemHeading.stories.tsx +386 -386
  61. package/src/components/DropdownItemHeading/DropdownItemHeading.tsx +216 -216
  62. package/src/components/DropdownItemHeading/DropdownItemHeading.types.ts +93 -93
  63. package/src/components/DropdownItemHeading/README.md +573 -573
  64. package/src/components/DropdownItemHeading/icons.tsx +125 -125
  65. package/src/components/DropdownItemHeading/index.ts +3 -3
  66. package/src/components/Input/Input.stories.tsx +583 -583
  67. package/src/components/LoginView/LoginView.stories.tsx +148 -148
  68. package/src/components/LoginView/LoginView.tsx +426 -426
  69. package/src/components/LoginView/LoginView.types.ts +52 -52
  70. package/src/components/LoginView/README.md +396 -396
  71. package/src/components/LoginView/icons.tsx +85 -85
  72. package/src/components/LoginView/index.ts +3 -3
  73. package/src/components/Navbar/Navbar.stories.tsx +810 -810
  74. package/src/components/Navbar/Navbar.tsx +755 -755
  75. package/src/components/Navbar/Navbar.types.ts +219 -219
  76. package/src/components/Navbar/README.md +279 -279
  77. package/src/components/Navbar/index.ts +8 -8
  78. package/src/components/NavigationRailCommercial/NavigationRailCommercial.stories.tsx +464 -0
  79. package/src/components/NavigationRailCommercial/NavigationRailCommercial.tsx +301 -0
  80. package/src/components/NavigationRailCommercial/NavigationRailCommercial.types.ts +162 -0
  81. package/src/components/NavigationRailCommercial/README.md +251 -0
  82. package/src/components/NavigationRailCommercial/icons.tsx +54 -0
  83. package/src/components/NavigationRailCommercial/index.ts +6 -0
  84. package/src/components/NavigationRailItem/NavigationRailItem.stories.tsx +667 -667
  85. package/src/components/NavigationRailItem/NavigationRailItem.tsx +314 -313
  86. package/src/components/NavigationRailItem/NavigationRailItem.types.ts +175 -167
  87. package/src/components/NavigationRailItem/README.md +476 -476
  88. package/src/components/NavigationRailItem/index.ts +2 -2
  89. package/src/components/NavigationRailPanel/NavigationRailPanel.stories.tsx +462 -462
  90. package/src/components/NavigationRailPanel/NavigationRailPanel.tsx +332 -332
  91. package/src/components/NavigationRailPanel/NavigationRailPanel.types.ts +178 -178
  92. package/src/components/NavigationRailPanel/README.md +461 -461
  93. package/src/components/NavigationRailPanel/index.ts +6 -6
  94. package/src/components/NavigationRailTypes/NavigationRailTypes.stories.tsx +682 -528
  95. package/src/components/NavigationRailTypes/NavigationRailTypes.tsx +363 -378
  96. package/src/components/NavigationRailTypes/NavigationRailTypes.types.ts +178 -130
  97. package/src/components/NavigationRailTypes/README.md +573 -573
  98. package/src/components/NavigationRailTypes/icons.tsx +76 -141
  99. package/src/components/NavigationRailTypes/index.ts +7 -7
  100. package/src/components/Notification/Notification.stories.tsx +513 -513
  101. package/src/components/Notification/Notification.tsx +145 -145
  102. package/src/components/Notification/Notification.types.ts +142 -142
  103. package/src/components/Notification/README.md +409 -409
  104. package/src/components/POSConvention/POSConvention.stories.tsx +235 -235
  105. package/src/components/POSConvention/POSConvention.tsx +129 -129
  106. package/src/components/POSConvention/POSConvention.types.ts +38 -38
  107. package/src/components/POSConvention/README.md +123 -123
  108. package/src/components/POSConvention/icons.tsx +45 -45
  109. package/src/components/POSConvention/index.ts +3 -3
  110. package/src/components/POSLocationButton/POSLocationButton.stories.tsx +531 -531
  111. package/src/components/POSLocationButton/POSLocationButton.tsx +247 -247
  112. package/src/components/POSLocationButton/POSLocationButton.types.ts +87 -87
  113. package/src/components/POSLocationButton/README.md +253 -253
  114. package/src/components/POSLocationButton/icons.tsx +120 -120
  115. package/src/components/POSLocationButton/index.ts +14 -14
  116. package/src/components/POSNumberButton/POSNumberButton.stories.tsx +415 -415
  117. package/src/components/POSNumberButton/POSNumberButton.tsx +179 -179
  118. package/src/components/POSNumberButton/POSNumberButton.types.ts +51 -51
  119. package/src/components/POSNumberButton/README.md +321 -321
  120. package/src/components/POSNumberButton/index.ts +3 -3
  121. package/src/components/POSProductButton/POSProductButton.stories.tsx +318 -318
  122. package/src/components/POSProductCard/POSProductCard.stories.tsx +642 -642
  123. package/src/components/POSProductCard/POSProductCard.tsx +208 -208
  124. package/src/components/POSProductCard/POSProductCard.types.ts +76 -76
  125. package/src/components/POSProductCard/README.md +179 -179
  126. package/src/components/POSProductCard/icons.tsx +26 -26
  127. package/src/components/POSProductCard/index.ts +2 -2
  128. package/src/components/POSProductSidebarItems/POSProductSidebarItems.stories.tsx +753 -753
  129. package/src/components/POSProductSidebarItems/POSProductSidebarItems.tsx +332 -332
  130. package/src/components/POSProductSidebarItems/POSProductSidebarItems.types.ts +119 -119
  131. package/src/components/POSProductSidebarItems/README.md +198 -198
  132. package/src/components/POSProductSidebarItems/icons.tsx +21 -21
  133. package/src/components/POSProductSidebarItems/index.ts +3 -3
  134. package/src/components/POSTable/POSTable.stories.tsx +737 -737
  135. package/src/components/POSTable/POSTable.tsx +401 -401
  136. package/src/components/POSTable/README.md +286 -286
  137. package/src/components/Quantity/Quantity.stories.tsx +457 -457
  138. package/src/components/Radio/Radio.stories.tsx +523 -523
  139. package/src/components/Radio/Radio.tsx +1 -1
  140. package/src/components/Select/Select.stories.tsx +32 -0
  141. package/src/components/Select/Select.tsx +457 -454
  142. package/src/components/Select/icons.tsx +16 -41
  143. package/src/components/SignUpView/SignUpView.stories.tsx +129 -129
  144. package/src/components/SignUpView/SignUpView.tsx +503 -503
  145. package/src/components/SignUpView/SignUpView.types.ts +58 -58
  146. package/src/components/SignUpView/icons.tsx +71 -71
  147. package/src/components/SignUpView/index.ts +3 -3
  148. package/src/components/Switch/README.md +112 -112
  149. package/src/components/Switch/Switch.stories.tsx +550 -550
  150. package/src/components/Switch/Switch.tsx +246 -246
  151. package/src/components/Switch/Switch.types.ts +67 -67
  152. package/src/components/Table/Table.stories.tsx +805 -805
  153. package/src/components/Tabs/README.md +201 -201
  154. package/src/components/Tabs/Tabs.stories.tsx +580 -580
  155. package/src/components/Tabs/Tabs.tsx +356 -356
  156. package/src/components/Tabs/Tabs.types.ts +127 -127
  157. package/src/components/Tabs/icons.tsx +129 -129
  158. package/src/components/Tabs/index.ts +11 -11
  159. package/src/components/Textarea/Textarea.stories.tsx +535 -535
  160. package/src/index.ts +133 -102
  161. package/src/views/LayoutCommercial/LayoutCommercial.stories.tsx +374 -0
  162. package/src/views/LayoutCommercial/LayoutCommercial.tsx +125 -0
  163. package/src/views/LayoutCommercial/LayoutCommercial.types.ts +54 -0
  164. package/src/views/LayoutCommercial/README.md +286 -0
  165. package/src/views/LayoutCommercial/index.ts +2 -0
  166. package/src/views/ListView/ListView.stories.tsx +329 -329
  167. package/src/views/ListView/ListView.tsx +570 -570
  168. package/src/views/ListView/ListView.types.ts +211 -211
  169. package/src/views/ListView/icons.tsx +282 -282
  170. package/src/views/ListView/index.ts +11 -11
  171. package/src/views/LoginView/LoginView.tsx +426 -426
  172. package/src/views/ProductsView/ProductsView.stories.tsx +344 -344
  173. package/src/views/ProductsView/ProductsView.tsx +480 -480
  174. package/src/views/ProductsView/ProductsView.types.ts +238 -238
  175. package/src/views/ProductsView/README.md +312 -312
  176. package/src/views/ProductsView/icons.tsx +38 -38
  177. package/src/views/ProductsView/index.ts +8 -8
  178. package/src/views/RecoverPasswordView/RecoverPasswordView.tsx +376 -376
  179. package/src/views/SignUpView/SignUpView.tsx +503 -503
  180. package/src/views/TableLayoutView/README.md +268 -268
  181. package/src/views/TableLayoutView/TableLayoutView.stories.tsx +235 -235
  182. package/src/views/TableLayoutView/TableLayoutView.tsx +461 -461
  183. package/src/views/TableLayoutView/TableLayoutView.types.ts +209 -209
  184. package/src/views/TableLayoutView/icons.tsx +113 -113
  185. package/src/views/TableLayoutView/index.ts +6 -6
  186. package/storybook/main.ts +19 -19
  187. package/storybook/preview.tsx +84 -84
  188. package/storybook/vitest.setup.ts +6 -6
  189. package/tailwind.config.js +128 -128
package/src/index.ts CHANGED
@@ -1,102 +1,133 @@
1
- // Componentes
2
- export { Button } from './components/Button/Button';
3
- export type { ButtonProps, ButtonType, ButtonSize, ButtonState } from './components/Button/Button.types';
4
-
5
- export { Input } from './components/Input/Input';
6
- export type { InputProps, InputState } from './components/Input/Input.types';
7
-
8
- export { Textarea } from './components/Textarea/Textarea';
9
- export type { TextareaProps, TextareaState } from './components/Textarea/Textarea.types';
10
-
11
- export { Checkbox } from './components/Checkbox/Checkbox';
12
- export type { CheckboxProps, CheckboxState } from './components/Checkbox/Checkbox.types';
13
-
14
- export { Radio } from './components/Radio/Radio';
15
- export type { RadioProps, RadioState } from './components/Radio/Radio.types';
16
-
17
- export { Switch } from './components/Switch/Switch';
18
- export type { SwitchProps, SwitchState } from './components/Switch/Switch.types';
19
-
20
- export { Avatar } from './components/Avatar/Avatar';
21
- export type { AvatarProps, AvatarSize, AvatarType } from './components/Avatar/Avatar.types';
22
-
23
- export { Divider } from './components/Divider/Divider';
24
- export type { DividerProps, DividerType } from './components/Divider/Divider.types';
25
-
26
- export { DescriptionList } from './components/DescriptionList/DescriptionList';
27
- export type { DescriptionListProps } from './components/DescriptionList/DescriptionList.types';
28
-
29
- export { Alert } from './components/Alert/Alert';
30
- export type { AlertProps } from './components/Alert/Alert.types';
31
-
32
- export { Badge } from './components/Badge/Badge';
33
- export type { BadgeProps, BadgeColor } from './components/Badge/Badge.types';
34
-
35
- export { Quantity } from './components/Quantity/Quantity';
36
- export type { QuantityProps } from './components/Quantity/Quantity.types';
37
-
38
- // export { NavigationRailItem } from './components/NavigationRailItem/NavigationRailItem';
39
- // export type { NavigationRailItemProps, NavigationRailItemState } from './components/NavigationRailItem/NavigationRailItem.types';
40
-
41
- export { Dropdown } from './components/Dropdown/Dropdown';
42
- export type { DropdownProps, DropdownItemProps } from './components/Dropdown/Dropdown.types';
43
-
44
- // export { DropdownItemCollapsible } from './components/DropdownItemCollapsible/DropdownItemCollapsible';
45
- // export type { DropdownItemCollapsibleProps, DropdownItemCollapsibleChildProps } from './components/DropdownItemCollapsible/DropdownItemCollapsible.types';
46
-
47
- // export { DropdownItemHeading } from './components/DropdownItemHeading/DropdownItemHeading';
48
- // export type { DropdownItemHeadingProps } from './components/DropdownItemHeading/DropdownItemHeading.types';
49
-
50
- export { Notification } from './components/Notification/Notification';
51
- export type { NotificationProps } from './components/Notification/Notification.types';
52
-
53
- export { Pagination } from './components/Pagination/Pagination';
54
- export type { PaginationProps } from './components/Pagination/Pagination.types';
55
-
56
- export { Select } from './components/Select/Select';
57
- export type { SelectProps, SelectOption } from './components/Select/Select.types';
58
-
59
- // export { NavigationRail } from './components/NavigationRail/NavigationRail';
60
- // export type { NavigationRailItemProps as NavigationRailProps } from './components/NavigationRail/NavigationRail.types';
61
-
62
- // export { NavigationRailPanel } from './components/NavigationRailPanel/NavigationRailPanel';
63
- // export type { NavigationRailPanelProps, NavigationRailPanelSectionProps, NavigationRailPanelItemProps } from './components/NavigationRailPanel/NavigationRailPanel.types';
64
-
65
- // export { NavigationRailTypes } from './components/NavigationRailTypes/NavigationRailTypes';
66
- // export type { NavigationRailTypesProps, NavigationRailItem as NavigationRailTypeItem } from './components/NavigationRailTypes/NavigationRailTypes.types';
67
-
68
- export { Table } from './components/Table/Table';
69
- export type { TableProps, TableColumn, SortDirection } from './components/Table/Table.types';
70
-
71
- export { Tabs } from './components/Tabs/Tabs';
72
- export type { TabsProps, TabItem } from './components/Tabs/Tabs.types';
73
-
74
- export { Navbar } from './components/Navbar/Navbar';
75
- export type { NavbarProps, NavbarVariant, UserDropdownProps } from './components/Navbar/Navbar.types';
76
-
77
- export { NavigationBar } from './components/NavigationBar/NavigationBar';
78
- export type { NavigationBarProps, NavigationBarItem } from './components/NavigationBar/NavigationBar.types';
79
-
80
- export { POSConvention } from './components/POSConvention/POSConvention';
81
- export type { POSConventionProps, ConventionStatus } from './components/POSConvention/POSConvention.types';
82
-
83
- export { POSLocationButton } from './components/POSLocationButton/POSLocationButton';
84
- export type { POSLocationButtonProps, POSLocationStatus, POSLocationState, POSLocationCapacity } from './components/POSLocationButton/POSLocationButton.types';
85
-
86
- export { POSNumberButton } from './components/POSNumberButton/POSNumberButton';
87
- export type { POSNumberButtonProps } from './components/POSNumberButton/POSNumberButton.types';
88
-
89
- export { POSProductButton } from './components/POSProductButton/POSProductButton';
90
- export type { POSProductButtonProps } from './components/POSProductButton/POSProductButton.types';
91
-
92
- export { POSProductCard } from './components/POSProductCard/POSProductCard';
93
- export type { POSProductCardProps } from './components/POSProductCard/POSProductCard.types';
94
-
95
- export { POSProductSidebarItems } from './components/POSProductSidebarItems/POSProductSidebarItems';
96
- export type { POSProductSidebarItemsProps, DescriptionItem } from './components/POSProductSidebarItems/POSProductSidebarItems.types';
97
-
98
- export { POSTable } from './components/POSTable/POSTable';
99
- export type { POSTableProps, TableStatus, TableShape, ChairCount } from './components/POSTable/POSTable.types';
100
-
101
- // Context y Hooks
102
- export { ThemeProvider, useTheme, type Theme } from './context';
1
+ // Componentes
2
+ export { Button } from './components/Button/Button';
3
+ export type { ButtonProps, ButtonType, ButtonSize, ButtonState } from './components/Button/Button.types';
4
+
5
+ export { Input } from './components/Input/Input';
6
+ export type { InputProps, InputState } from './components/Input/Input.types';
7
+
8
+ export { Textarea } from './components/Textarea/Textarea';
9
+ export type { TextareaProps, TextareaState } from './components/Textarea/Textarea.types';
10
+
11
+ export { Checkbox } from './components/Checkbox/Checkbox';
12
+ export type { CheckboxProps, CheckboxState } from './components/Checkbox/Checkbox.types';
13
+
14
+ export { Radio } from './components/Radio/Radio';
15
+ export type { RadioProps, RadioState } from './components/Radio/Radio.types';
16
+
17
+ export { Switch } from './components/Switch/Switch';
18
+ export type { SwitchProps, SwitchState } from './components/Switch/Switch.types';
19
+
20
+ export { Avatar } from './components/Avatar/Avatar';
21
+ export type { AvatarProps, AvatarSize, AvatarType } from './components/Avatar/Avatar.types';
22
+
23
+ export { Divider } from './components/Divider/Divider';
24
+ export type { DividerProps, DividerType } from './components/Divider/Divider.types';
25
+
26
+ export { DescriptionList } from './components/DescriptionList/DescriptionList';
27
+ export type { DescriptionListProps } from './components/DescriptionList/DescriptionList.types';
28
+
29
+ export { Alert } from './components/Alert/Alert';
30
+ export type { AlertProps } from './components/Alert/Alert.types';
31
+
32
+ export { Badge } from './components/Badge/Badge';
33
+ export type { BadgeProps, BadgeColor } from './components/Badge/Badge.types';
34
+
35
+ export { Quantity } from './components/Quantity/Quantity';
36
+ export type { QuantityProps } from './components/Quantity/Quantity.types';
37
+
38
+ export { NavigationRailItem } from './components/NavigationRailItem/NavigationRailItem';
39
+ export type { NavigationRailItemProps, NavigationRailItemState } from './components/NavigationRailItem/NavigationRailItem.types';
40
+
41
+ export { Dropdown } from './components/Dropdown/Dropdown';
42
+ export type { DropdownProps, DropdownItemProps } from './components/Dropdown/Dropdown.types';
43
+
44
+ export { DropdownItemCollapsible } from './components/DropdownItemCollapsible/DropdownItemCollapsible';
45
+ export type { DropdownItemCollapsibleProps, DropdownItemCollapsibleChildProps } from './components/DropdownItemCollapsible/DropdownItemCollapsible.types';
46
+
47
+ export { DropdownItemHeading } from './components/DropdownItemHeading/DropdownItemHeading';
48
+ export type { DropdownItemHeadingProps } from './components/DropdownItemHeading/DropdownItemHeading.types';
49
+
50
+ export { Notification } from './components/Notification/Notification';
51
+ export type { NotificationProps } from './components/Notification/Notification.types';
52
+
53
+ export { Pagination } from './components/Pagination/Pagination';
54
+ export type { PaginationProps } from './components/Pagination/Pagination.types';
55
+
56
+ export { Select } from './components/Select/Select';
57
+ export type { SelectProps, SelectOption } from './components/Select/Select.types';
58
+
59
+ export { NavigationRail } from './components/NavigationRail/NavigationRail';
60
+ export type { NavigationRailItemProps as NavigationRailProps } from './components/NavigationRail/NavigationRail.types';
61
+
62
+ export { NavigationRailPanel } from './components/NavigationRailPanel/NavigationRailPanel';
63
+ export type { NavigationRailPanelProps, NavigationRailPanelSectionProps, NavigationRailPanelItemProps } from './components/NavigationRailPanel/NavigationRailPanel.types';
64
+
65
+ export { NavigationRailTypes } from './components/NavigationRailTypes/NavigationRailTypes';
66
+ export type { NavigationRailTypesProps, NavigationRailItem as NavigationRailTypeItem } from './components/NavigationRailTypes/NavigationRailTypes.types';
67
+
68
+ export { NavigationRailCommercial } from './components/NavigationRailCommercial/NavigationRailCommercial';
69
+ export type { NavigationRailCommercialProps, NavigationRailCommercialMenuItem } from './components/NavigationRailCommercial/NavigationRailCommercial.types';
70
+
71
+ export { Table } from './components/Table/Table';
72
+ export type { TableProps, TableColumn, SortDirection } from './components/Table/Table.types';
73
+
74
+ export { Tabs } from './components/Tabs/Tabs';
75
+ export type { TabsProps, TabItem } from './components/Tabs/Tabs.types';
76
+
77
+ export { Navbar } from './components/Navbar/Navbar';
78
+ export type { NavbarProps, NavbarVariant, UserDropdownProps } from './components/Navbar/Navbar.types';
79
+
80
+ export { NavigationBar } from './components/NavigationBar/NavigationBar';
81
+ export type { NavigationBarProps, NavigationBarItem } from './components/NavigationBar/NavigationBar.types';
82
+
83
+ export { POSConvention } from './components/POSConvention/POSConvention';
84
+ export type { POSConventionProps, ConventionStatus } from './components/POSConvention/POSConvention.types';
85
+
86
+ export { POSLocationButton } from './components/POSLocationButton/POSLocationButton';
87
+ export type { POSLocationButtonProps, POSLocationStatus, POSLocationState, POSLocationCapacity } from './components/POSLocationButton/POSLocationButton.types';
88
+
89
+ export { POSNumberButton } from './components/POSNumberButton/POSNumberButton';
90
+ export type { POSNumberButtonProps } from './components/POSNumberButton/POSNumberButton.types';
91
+
92
+ export { POSProductButton } from './components/POSProductButton/POSProductButton';
93
+ export type { POSProductButtonProps } from './components/POSProductButton/POSProductButton.types';
94
+
95
+ export { POSProductCard } from './components/POSProductCard/POSProductCard';
96
+ export type { POSProductCardProps } from './components/POSProductCard/POSProductCard.types';
97
+
98
+ export { POSProductSidebarItems } from './components/POSProductSidebarItems/POSProductSidebarItems';
99
+ export type { POSProductSidebarItemsProps, DescriptionItem } from './components/POSProductSidebarItems/POSProductSidebarItems.types';
100
+
101
+ export { POSTable } from './components/POSTable/POSTable';
102
+ export type { POSTableProps, TableStatus, TableShape, ChairCount } from './components/POSTable/POSTable.types';
103
+
104
+ export { LoginView } from './components/LoginView/LoginView';
105
+ export type { LoginViewProps } from './components/LoginView/LoginView.types';
106
+
107
+ export { SignUpView } from './components/SignUpView/SignUpView';
108
+ export type { SignUpViewProps } from './components/SignUpView/SignUpView.types';
109
+
110
+ // Views
111
+ export { LayoutCommercial } from './views/LayoutCommercial/LayoutCommercial';
112
+ export type { LayoutCommercialProps } from './views/LayoutCommercial/LayoutCommercial.types';
113
+
114
+ export { ListView } from './views/ListView/ListView';
115
+ export type { ListViewProps } from './views/ListView/ListView.types';
116
+
117
+ export { LoginView as LoginViewPage } from './views/LoginView/LoginView';
118
+ export type { LoginViewProps as LoginViewPageProps } from './views/LoginView/LoginView.types';
119
+
120
+ export { ProductsView } from './views/ProductsView/ProductsView';
121
+ export type { ProductsViewProps } from './views/ProductsView/ProductsView.types';
122
+
123
+ export { RecoverPasswordView } from './views/RecoverPasswordView/RecoverPasswordView';
124
+ export type { RecoverPasswordViewProps } from './views/RecoverPasswordView/RecoverPasswordView.types';
125
+
126
+ export { SignUpView as SignUpViewPage } from './views/SignUpView/SignUpView';
127
+ export type { SignUpViewProps as SignUpViewPageProps } from './views/SignUpView/SignUpView.types';
128
+
129
+ export { TableLayoutView } from './views/TableLayoutView/TableLayoutView';
130
+ export type { TableLayoutViewProps } from './views/TableLayoutView/TableLayoutView.types';
131
+
132
+ // Context y Hooks
133
+ export { ThemeProvider, useTheme, type Theme } from './context';
@@ -0,0 +1,374 @@
1
+ import type { Meta, StoryObj } from '@storybook/react';
2
+ import { useState } from 'react';
3
+ import { LayoutCommercial } from './LayoutCommercial';
4
+ import {
5
+ Cog6ToothIcon,
6
+ ShoppingCartIcon,
7
+ CubeIcon,
8
+ DocumentIcon,
9
+ } from '../../components/NavigationRailCommercial/icons';
10
+
11
+ const meta = {
12
+ title: 'Siesa UI Kit/Views/LayoutCommercial',
13
+ component: LayoutCommercial,
14
+ parameters: {
15
+ layout: 'fullscreen',
16
+ docs: {
17
+ description: {
18
+ component:
19
+ 'Vista de layout comercial completa con NavigationRail lateral, Navbar superior y formulario de configuración de ítems.',
20
+ },
21
+ },
22
+ },
23
+ tags: ['autodocs'],
24
+ argTypes: {
25
+ productName: {
26
+ control: 'text',
27
+ description: 'Nombre del producto en el Navbar',
28
+ table: {
29
+ type: { summary: 'string' },
30
+ category: 'Apariencia',
31
+ },
32
+ },
33
+ userDropdown: {
34
+ control: 'object',
35
+ description: 'Configuración del dropdown de usuario',
36
+ table: {
37
+ type: { summary: 'UserDropdownProps' },
38
+ category: 'Contenido',
39
+ },
40
+ },
41
+ navigationItems: {
42
+ control: 'object',
43
+ description: 'Items del NavigationRail',
44
+ table: {
45
+ type: { summary: 'NavigationRailCommercialMenuItem[]' },
46
+ category: 'Contenido',
47
+ },
48
+ },
49
+ formData: {
50
+ control: 'object',
51
+ description: 'Datos del formulario',
52
+ table: {
53
+ type: { summary: 'FormData' },
54
+ category: 'Estado',
55
+ },
56
+ },
57
+ },
58
+ } satisfies Meta<typeof LayoutCommercial>;
59
+
60
+ export default meta;
61
+ type Story = StoryObj<typeof meta>;
62
+
63
+ // ============================================
64
+ // DATOS DE PRUEBA
65
+ // ============================================
66
+
67
+ const avatarUrl = 'https://avatar.iran.liara.run/public/boy?username=carlos';
68
+
69
+ const defaultUserDropdown = {
70
+ avatar: avatarUrl,
71
+ name: 'Carlos',
72
+ email: 'carlos@siesa.com',
73
+ };
74
+
75
+ const defaultNavigationItems = [
76
+ {
77
+ id: 'config',
78
+ label: 'Configuración',
79
+ icon: <Cog6ToothIcon />,
80
+ active: true,
81
+ isCollapsible: true,
82
+ children: [
83
+ {
84
+ id: 'general',
85
+ label: 'General',
86
+ icon: <Cog6ToothIcon />,
87
+ },
88
+ {
89
+ id: 'users',
90
+ label: 'Usuarios',
91
+ icon: <Cog6ToothIcon />,
92
+ },
93
+ {
94
+ id: 'permissions',
95
+ label: 'Permisos',
96
+ icon: <Cog6ToothIcon />,
97
+ },
98
+ ],
99
+ },
100
+ {
101
+ id: 'cart',
102
+ label: 'Carrito',
103
+ icon: <ShoppingCartIcon />,
104
+ isCollapsible: true,
105
+ children: [
106
+ {
107
+ id: 'active-carts',
108
+ label: 'Carritos activos',
109
+ icon: <ShoppingCartIcon />,
110
+ },
111
+ {
112
+ id: 'pending',
113
+ label: 'Pendientes',
114
+ icon: <ShoppingCartIcon />,
115
+ },
116
+ ],
117
+ },
118
+ {
119
+ id: 'products',
120
+ label: 'Productos',
121
+ icon: <CubeIcon />,
122
+ isCollapsible: true,
123
+ children: [
124
+ {
125
+ id: 'catalog',
126
+ label: 'Catálogo',
127
+ icon: <CubeIcon />,
128
+ },
129
+ {
130
+ id: 'inventory',
131
+ label: 'Inventario',
132
+ icon: <CubeIcon />,
133
+ },
134
+ {
135
+ id: 'categories',
136
+ label: 'Categorías',
137
+ icon: <CubeIcon />,
138
+ },
139
+ ],
140
+ },
141
+ {
142
+ id: 'documents',
143
+ label: 'Documentos',
144
+ icon: <DocumentIcon />,
145
+ isCollapsible: true,
146
+ children: [
147
+ {
148
+ id: 'invoices',
149
+ label: 'Facturas',
150
+ icon: <DocumentIcon />,
151
+ },
152
+ {
153
+ id: 'orders',
154
+ label: 'Pedidos',
155
+ icon: <DocumentIcon />,
156
+ },
157
+ {
158
+ id: 'reports',
159
+ label: 'Reportes',
160
+ icon: <DocumentIcon />,
161
+ },
162
+ ],
163
+ },
164
+ ];
165
+
166
+ const defaultFormData = {
167
+ codigoItem: '',
168
+ nombre: '',
169
+ tipoItem: 'inventario' as const,
170
+ extension1: '',
171
+ extension2: '',
172
+ modeloCosto: '',
173
+ configuracionSerial: '',
174
+ manejaLotes: '',
175
+ manejaSeriales: false,
176
+ procesoManufactura: false,
177
+ puedeComprarse: false,
178
+ puedeVenderse: false,
179
+ permitirExtension1: false,
180
+ permitirExtension2: false,
181
+ permitirModeloCosto: false,
182
+ permitirManejaLotes: false,
183
+ permitirManejaSeriales: false,
184
+ permitirConfiguracionSerial: false,
185
+ permitirProcesoManufactura: false,
186
+ permitirCompras: false,
187
+ permitirVentas: false,
188
+ };
189
+
190
+ // ============================================
191
+ // 1. PLAYGROUND INTERACTIVO
192
+ // ============================================
193
+ export const Playground: Story = {
194
+ args: {
195
+ productName: 'SB Comercial',
196
+ userDropdown: defaultUserDropdown,
197
+ navigationItems: defaultNavigationItems,
198
+ formData: defaultFormData,
199
+ },
200
+ render: (args) => {
201
+ const [formData, setFormData] = useState(args.formData);
202
+
203
+ return (
204
+ <LayoutCommercial
205
+ {...args}
206
+ formData={formData}
207
+ onFormChange={setFormData}
208
+ />
209
+ );
210
+ },
211
+ };
212
+
213
+ // ============================================
214
+ // 2. ESTADO: FORMULARIO VACÍO
215
+ // ============================================
216
+ export const FormularioVacio: Story = {
217
+ render: () => {
218
+ const [formData, setFormData] = useState(defaultFormData);
219
+
220
+ return (
221
+ <LayoutCommercial
222
+ productName="SB Comercial"
223
+ userDropdown={defaultUserDropdown}
224
+ navigationItems={defaultNavigationItems}
225
+ formData={formData}
226
+ onFormChange={setFormData}
227
+ />
228
+ );
229
+ },
230
+ };
231
+
232
+ // ============================================
233
+ // 3. ESTADO: FORMULARIO CON DATOS
234
+ // ============================================
235
+ export const FormularioConDatos: Story = {
236
+ render: () => {
237
+ const [formData, setFormData] = useState({
238
+ codigoItem: 'ITEM-001',
239
+ nombre: 'Producto de Ejemplo',
240
+ tipoItem: 'inventario' as const,
241
+ extension1: 'azul',
242
+ extension2: 'm',
243
+ modeloCosto: 'fifo',
244
+ configuracionSerial: '1234567890123456789O',
245
+ manejaLotes: 'si',
246
+ manejaSeriales: true,
247
+ procesoManufactura: true,
248
+ puedeComprarse: true,
249
+ puedeVenderse: true,
250
+ permitirExtension1: true,
251
+ permitirExtension2: true,
252
+ permitirModeloCosto: false,
253
+ permitirManejaLotes: true,
254
+ permitirManejaSeriales: true,
255
+ permitirConfiguracionSerial: false,
256
+ permitirProcesoManufactura: true,
257
+ permitirCompras: true,
258
+ permitirVentas: true,
259
+ });
260
+
261
+ return (
262
+ <LayoutCommercial
263
+ productName="SB Comercial"
264
+ userDropdown={defaultUserDropdown}
265
+ navigationItems={defaultNavigationItems}
266
+ formData={formData}
267
+ onFormChange={setFormData}
268
+ />
269
+ );
270
+ },
271
+ };
272
+
273
+ // ============================================
274
+ // 4. ESTADO: TIPO SERVICIO
275
+ // ============================================
276
+ export const TipoServicio: Story = {
277
+ render: () => {
278
+ const [formData, setFormData] = useState({
279
+ ...defaultFormData,
280
+ codigoItem: 'SERV-001',
281
+ nombre: 'Servicio de Consultoría',
282
+ tipoItem: 'servicio' as const,
283
+ puedeComprarse: false,
284
+ puedeVenderse: true,
285
+ });
286
+
287
+ return (
288
+ <LayoutCommercial
289
+ productName="SB Comercial"
290
+ userDropdown={defaultUserDropdown}
291
+ navigationItems={defaultNavigationItems}
292
+ formData={formData}
293
+ onFormChange={setFormData}
294
+ />
295
+ );
296
+ },
297
+ };
298
+
299
+ // ============================================
300
+ // 5. ESTADO: SIN USUARIO
301
+ // ============================================
302
+ export const SinUsuario: Story = {
303
+ render: () => {
304
+ const [formData, setFormData] = useState(defaultFormData);
305
+
306
+ return (
307
+ <LayoutCommercial
308
+ productName="SB Comercial"
309
+ navigationItems={defaultNavigationItems}
310
+ formData={formData}
311
+ onFormChange={setFormData}
312
+ />
313
+ );
314
+ },
315
+ };
316
+
317
+ // ============================================
318
+ // 6. ESTADO: SIN NAVEGACIÓN
319
+ // ============================================
320
+ export const SinNavegacion: Story = {
321
+ render: () => {
322
+ const [formData, setFormData] = useState(defaultFormData);
323
+
324
+ return (
325
+ <LayoutCommercial
326
+ productName="SB Comercial"
327
+ userDropdown={defaultUserDropdown}
328
+ formData={formData}
329
+ onFormChange={setFormData}
330
+ />
331
+ );
332
+ },
333
+ };
334
+
335
+ // ============================================
336
+ // 7. ESTADO: CREACIÓN ÍTEM (BASADO EN FIGMA)
337
+ // ============================================
338
+ export const CreacionItem: Story = {
339
+ render: () => {
340
+ const [formData, setFormData] = useState({
341
+ codigoItem: '',
342
+ nombre: '',
343
+ tipoItem: 'inventario' as const,
344
+ extension1: '',
345
+ extension2: '',
346
+ modeloCosto: '',
347
+ configuracionSerial: '',
348
+ manejaLotes: '',
349
+ manejaSeriales: false,
350
+ procesoManufactura: false,
351
+ puedeComprarse: true,
352
+ puedeVenderse: true,
353
+ permitirExtension1: false,
354
+ permitirExtension2: false,
355
+ permitirModeloCosto: false,
356
+ permitirManejaLotes: false,
357
+ permitirManejaSeriales: false,
358
+ permitirConfiguracionSerial: false,
359
+ permitirProcesoManufactura: false,
360
+ permitirCompras: true,
361
+ permitirVentas: true,
362
+ });
363
+
364
+ return (
365
+ <LayoutCommercial
366
+ productName="SB Comercial"
367
+ userDropdown={defaultUserDropdown}
368
+ navigationItems={defaultNavigationItems}
369
+ formData={formData}
370
+ onFormChange={setFormData}
371
+ />
372
+ );
373
+ },
374
+ };