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.
- package/README.md +115 -115
- package/bin/install.cjs +502 -502
- package/bin/prepare-publish.cjs +28 -28
- package/bin/restore-folders.cjs +28 -28
- package/claude/agents/siesa-ui-kit-specialist.md +2445 -0
- package/claude/prompts/component-template.md +121 -0
- package/claude/prompts/siesa-ui-kit.md +28 -0
- package/claude/settings.local.json +67 -2
- package/dist/components/Button/icons.d.ts +6 -5
- package/dist/components/Button/icons.d.ts.map +1 -1
- package/dist/components/DropdownItemCollapsible/DropdownItemCollapsible.d.ts.map +1 -1
- package/dist/components/DropdownItemCollapsible/DropdownItemCollapsible.types.d.ts +21 -0
- package/dist/components/DropdownItemCollapsible/DropdownItemCollapsible.types.d.ts.map +1 -1
- package/dist/components/NavigationRailCommercial/NavigationRailCommercial.d.ts +122 -0
- package/dist/components/NavigationRailCommercial/NavigationRailCommercial.d.ts.map +1 -0
- package/dist/components/NavigationRailCommercial/NavigationRailCommercial.types.d.ts +139 -0
- package/dist/components/NavigationRailCommercial/NavigationRailCommercial.types.d.ts.map +1 -0
- package/dist/components/NavigationRailCommercial/icons.d.ts +33 -0
- package/dist/components/NavigationRailCommercial/icons.d.ts.map +1 -0
- package/dist/components/NavigationRailCommercial/index.d.ts +4 -0
- package/dist/components/NavigationRailCommercial/index.d.ts.map +1 -0
- package/dist/components/NavigationRailItem/NavigationRailItem.d.ts.map +1 -1
- package/dist/components/NavigationRailItem/NavigationRailItem.types.d.ts +7 -0
- package/dist/components/NavigationRailItem/NavigationRailItem.types.d.ts.map +1 -1
- package/dist/components/NavigationRailTypes/NavigationRailTypes.d.ts.map +1 -1
- package/dist/components/NavigationRailTypes/NavigationRailTypes.types.d.ts +41 -0
- package/dist/components/NavigationRailTypes/NavigationRailTypes.types.d.ts.map +1 -1
- package/dist/components/NavigationRailTypes/icons.d.ts +15 -29
- package/dist/components/NavigationRailTypes/icons.d.ts.map +1 -1
- package/dist/components/Select/Select.d.ts.map +1 -1
- package/dist/components/Select/icons.d.ts +6 -2
- package/dist/components/Select/icons.d.ts.map +1 -1
- package/dist/index.d.ts +32 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/siesa-ui-kit.cjs +404 -190
- package/dist/siesa-ui-kit.cjs.map +1 -1
- package/dist/siesa-ui-kit.mjs +6590 -1506
- package/dist/siesa-ui-kit.mjs.map +1 -1
- package/dist/views/LayoutCommercial/LayoutCommercial.d.ts +48 -0
- package/dist/views/LayoutCommercial/LayoutCommercial.d.ts.map +1 -0
- package/dist/views/LayoutCommercial/LayoutCommercial.types.d.ts +49 -0
- package/dist/views/LayoutCommercial/LayoutCommercial.types.d.ts.map +1 -0
- package/dist/views/LayoutCommercial/index.d.ts +3 -0
- package/dist/views/LayoutCommercial/index.d.ts.map +1 -0
- package/docs/icons.md +12 -31
- package/package.json +111 -110
- package/src/components/Avatar/Avatar.stories.tsx +494 -494
- package/src/components/Button/Button.stories.tsx +950 -950
- package/src/components/Button/Button.tsx +337 -337
- package/src/components/Button/Button.types.ts +180 -180
- package/src/components/Button/icons.tsx +23 -62
- package/src/components/DescriptionList/DescriptionList.stories.tsx +250 -250
- package/src/components/Divider/Divider.stories.tsx +263 -263
- package/src/components/DropdownItemCollapsible/DropdownItemCollapsible.stories.tsx +317 -317
- package/src/components/DropdownItemCollapsible/DropdownItemCollapsible.tsx +307 -287
- package/src/components/DropdownItemCollapsible/DropdownItemCollapsible.types.ts +136 -111
- package/src/components/DropdownItemCollapsible/README.md +264 -264
- package/src/components/DropdownItemCollapsible/icons.tsx +57 -57
- package/src/components/DropdownItemCollapsible/index.ts +12 -12
- package/src/components/DropdownItemHeading/DropdownItemHeading.stories.tsx +386 -386
- package/src/components/DropdownItemHeading/DropdownItemHeading.tsx +216 -216
- package/src/components/DropdownItemHeading/DropdownItemHeading.types.ts +93 -93
- package/src/components/DropdownItemHeading/README.md +573 -573
- package/src/components/DropdownItemHeading/icons.tsx +125 -125
- package/src/components/DropdownItemHeading/index.ts +3 -3
- package/src/components/Input/Input.stories.tsx +583 -583
- package/src/components/LoginView/LoginView.stories.tsx +148 -148
- package/src/components/LoginView/LoginView.tsx +426 -426
- package/src/components/LoginView/LoginView.types.ts +52 -52
- package/src/components/LoginView/README.md +396 -396
- package/src/components/LoginView/icons.tsx +85 -85
- package/src/components/LoginView/index.ts +3 -3
- package/src/components/Navbar/Navbar.stories.tsx +810 -810
- package/src/components/Navbar/Navbar.tsx +755 -755
- package/src/components/Navbar/Navbar.types.ts +219 -219
- package/src/components/Navbar/README.md +279 -279
- package/src/components/Navbar/index.ts +8 -8
- package/src/components/NavigationRailCommercial/NavigationRailCommercial.stories.tsx +464 -0
- package/src/components/NavigationRailCommercial/NavigationRailCommercial.tsx +301 -0
- package/src/components/NavigationRailCommercial/NavigationRailCommercial.types.ts +162 -0
- package/src/components/NavigationRailCommercial/README.md +251 -0
- package/src/components/NavigationRailCommercial/icons.tsx +54 -0
- package/src/components/NavigationRailCommercial/index.ts +6 -0
- package/src/components/NavigationRailItem/NavigationRailItem.stories.tsx +667 -667
- package/src/components/NavigationRailItem/NavigationRailItem.tsx +314 -313
- package/src/components/NavigationRailItem/NavigationRailItem.types.ts +175 -167
- package/src/components/NavigationRailItem/README.md +476 -476
- package/src/components/NavigationRailItem/index.ts +2 -2
- package/src/components/NavigationRailPanel/NavigationRailPanel.stories.tsx +462 -462
- package/src/components/NavigationRailPanel/NavigationRailPanel.tsx +332 -332
- package/src/components/NavigationRailPanel/NavigationRailPanel.types.ts +178 -178
- package/src/components/NavigationRailPanel/README.md +461 -461
- package/src/components/NavigationRailPanel/index.ts +6 -6
- package/src/components/NavigationRailTypes/NavigationRailTypes.stories.tsx +682 -528
- package/src/components/NavigationRailTypes/NavigationRailTypes.tsx +363 -378
- package/src/components/NavigationRailTypes/NavigationRailTypes.types.ts +178 -130
- package/src/components/NavigationRailTypes/README.md +573 -573
- package/src/components/NavigationRailTypes/icons.tsx +76 -141
- package/src/components/NavigationRailTypes/index.ts +7 -7
- package/src/components/Notification/Notification.stories.tsx +513 -513
- package/src/components/Notification/Notification.tsx +145 -145
- package/src/components/Notification/Notification.types.ts +142 -142
- package/src/components/Notification/README.md +409 -409
- package/src/components/POSConvention/POSConvention.stories.tsx +235 -235
- package/src/components/POSConvention/POSConvention.tsx +129 -129
- package/src/components/POSConvention/POSConvention.types.ts +38 -38
- package/src/components/POSConvention/README.md +123 -123
- package/src/components/POSConvention/icons.tsx +45 -45
- package/src/components/POSConvention/index.ts +3 -3
- package/src/components/POSLocationButton/POSLocationButton.stories.tsx +531 -531
- package/src/components/POSLocationButton/POSLocationButton.tsx +247 -247
- package/src/components/POSLocationButton/POSLocationButton.types.ts +87 -87
- package/src/components/POSLocationButton/README.md +253 -253
- package/src/components/POSLocationButton/icons.tsx +120 -120
- package/src/components/POSLocationButton/index.ts +14 -14
- package/src/components/POSNumberButton/POSNumberButton.stories.tsx +415 -415
- package/src/components/POSNumberButton/POSNumberButton.tsx +179 -179
- package/src/components/POSNumberButton/POSNumberButton.types.ts +51 -51
- package/src/components/POSNumberButton/README.md +321 -321
- package/src/components/POSNumberButton/index.ts +3 -3
- package/src/components/POSProductButton/POSProductButton.stories.tsx +318 -318
- package/src/components/POSProductCard/POSProductCard.stories.tsx +642 -642
- package/src/components/POSProductCard/POSProductCard.tsx +208 -208
- package/src/components/POSProductCard/POSProductCard.types.ts +76 -76
- package/src/components/POSProductCard/README.md +179 -179
- package/src/components/POSProductCard/icons.tsx +26 -26
- package/src/components/POSProductCard/index.ts +2 -2
- package/src/components/POSProductSidebarItems/POSProductSidebarItems.stories.tsx +753 -753
- package/src/components/POSProductSidebarItems/POSProductSidebarItems.tsx +332 -332
- package/src/components/POSProductSidebarItems/POSProductSidebarItems.types.ts +119 -119
- package/src/components/POSProductSidebarItems/README.md +198 -198
- package/src/components/POSProductSidebarItems/icons.tsx +21 -21
- package/src/components/POSProductSidebarItems/index.ts +3 -3
- package/src/components/POSTable/POSTable.stories.tsx +737 -737
- package/src/components/POSTable/POSTable.tsx +401 -401
- package/src/components/POSTable/README.md +286 -286
- package/src/components/Quantity/Quantity.stories.tsx +457 -457
- package/src/components/Radio/Radio.stories.tsx +523 -523
- package/src/components/Radio/Radio.tsx +1 -1
- package/src/components/Select/Select.stories.tsx +32 -0
- package/src/components/Select/Select.tsx +457 -454
- package/src/components/Select/icons.tsx +16 -41
- package/src/components/SignUpView/SignUpView.stories.tsx +129 -129
- package/src/components/SignUpView/SignUpView.tsx +503 -503
- package/src/components/SignUpView/SignUpView.types.ts +58 -58
- package/src/components/SignUpView/icons.tsx +71 -71
- package/src/components/SignUpView/index.ts +3 -3
- package/src/components/Switch/README.md +112 -112
- package/src/components/Switch/Switch.stories.tsx +550 -550
- package/src/components/Switch/Switch.tsx +246 -246
- package/src/components/Switch/Switch.types.ts +67 -67
- package/src/components/Table/Table.stories.tsx +805 -805
- package/src/components/Tabs/README.md +201 -201
- package/src/components/Tabs/Tabs.stories.tsx +580 -580
- package/src/components/Tabs/Tabs.tsx +356 -356
- package/src/components/Tabs/Tabs.types.ts +127 -127
- package/src/components/Tabs/icons.tsx +129 -129
- package/src/components/Tabs/index.ts +11 -11
- package/src/components/Textarea/Textarea.stories.tsx +535 -535
- package/src/index.ts +133 -102
- package/src/views/LayoutCommercial/LayoutCommercial.stories.tsx +374 -0
- package/src/views/LayoutCommercial/LayoutCommercial.tsx +125 -0
- package/src/views/LayoutCommercial/LayoutCommercial.types.ts +54 -0
- package/src/views/LayoutCommercial/README.md +286 -0
- package/src/views/LayoutCommercial/index.ts +2 -0
- package/src/views/ListView/ListView.stories.tsx +329 -329
- package/src/views/ListView/ListView.tsx +570 -570
- package/src/views/ListView/ListView.types.ts +211 -211
- package/src/views/ListView/icons.tsx +282 -282
- package/src/views/ListView/index.ts +11 -11
- package/src/views/LoginView/LoginView.tsx +426 -426
- package/src/views/ProductsView/ProductsView.stories.tsx +344 -344
- package/src/views/ProductsView/ProductsView.tsx +480 -480
- package/src/views/ProductsView/ProductsView.types.ts +238 -238
- package/src/views/ProductsView/README.md +312 -312
- package/src/views/ProductsView/icons.tsx +38 -38
- package/src/views/ProductsView/index.ts +8 -8
- package/src/views/RecoverPasswordView/RecoverPasswordView.tsx +376 -376
- package/src/views/SignUpView/SignUpView.tsx +503 -503
- package/src/views/TableLayoutView/README.md +268 -268
- package/src/views/TableLayoutView/TableLayoutView.stories.tsx +235 -235
- package/src/views/TableLayoutView/TableLayoutView.tsx +461 -461
- package/src/views/TableLayoutView/TableLayoutView.types.ts +209 -209
- package/src/views/TableLayoutView/icons.tsx +113 -113
- package/src/views/TableLayoutView/index.ts +6 -6
- package/storybook/main.ts +19 -19
- package/storybook/preview.tsx +84 -84
- package/storybook/vitest.setup.ts +6 -6
- package/tailwind.config.js +128 -128
|
@@ -1,127 +1,127 @@
|
|
|
1
|
-
import type { ReactNode } from 'react';
|
|
2
|
-
|
|
3
|
-
/**
|
|
4
|
-
* Configuración de un item de Tab individual
|
|
5
|
-
*/
|
|
6
|
-
export interface TabItem {
|
|
7
|
-
/**
|
|
8
|
-
* Identificador único del tab
|
|
9
|
-
*/
|
|
10
|
-
id: string;
|
|
11
|
-
|
|
12
|
-
/**
|
|
13
|
-
* Texto a mostrar en el tab
|
|
14
|
-
*/
|
|
15
|
-
label: string;
|
|
16
|
-
|
|
17
|
-
/**
|
|
18
|
-
* Icono a mostrar a la izquierda del texto (opcional)
|
|
19
|
-
*/
|
|
20
|
-
icon?: ReactNode;
|
|
21
|
-
|
|
22
|
-
/**
|
|
23
|
-
* Número de notificaciones a mostrar en el badge (opcional)
|
|
24
|
-
*/
|
|
25
|
-
badge?: number;
|
|
26
|
-
|
|
27
|
-
/**
|
|
28
|
-
* Si el tab está deshabilitado
|
|
29
|
-
* @default false
|
|
30
|
-
*/
|
|
31
|
-
disabled?: boolean;
|
|
32
|
-
}
|
|
33
|
-
|
|
34
|
-
/**
|
|
35
|
-
* Props del componente Tab individual (interno)
|
|
36
|
-
*/
|
|
37
|
-
export interface TabProps {
|
|
38
|
-
/**
|
|
39
|
-
* Texto a mostrar en el tab
|
|
40
|
-
*/
|
|
41
|
-
label: string;
|
|
42
|
-
|
|
43
|
-
/**
|
|
44
|
-
* Si el tab está activo/seleccionado
|
|
45
|
-
* @default false
|
|
46
|
-
*/
|
|
47
|
-
active?: boolean;
|
|
48
|
-
|
|
49
|
-
/**
|
|
50
|
-
* Icono a mostrar a la izquierda del texto (opcional)
|
|
51
|
-
*/
|
|
52
|
-
icon?: ReactNode;
|
|
53
|
-
|
|
54
|
-
/**
|
|
55
|
-
* Número de notificaciones a mostrar en el badge (opcional)
|
|
56
|
-
*/
|
|
57
|
-
badge?: number;
|
|
58
|
-
|
|
59
|
-
/**
|
|
60
|
-
* Si el tab está deshabilitado
|
|
61
|
-
* @default false
|
|
62
|
-
*/
|
|
63
|
-
disabled?: boolean;
|
|
64
|
-
|
|
65
|
-
/**
|
|
66
|
-
* Función callback ejecutada al hacer click
|
|
67
|
-
*/
|
|
68
|
-
onClick?: () => void;
|
|
69
|
-
|
|
70
|
-
/**
|
|
71
|
-
* Clases CSS adicionales
|
|
72
|
-
*/
|
|
73
|
-
className?: string;
|
|
74
|
-
|
|
75
|
-
/**
|
|
76
|
-
* Etiqueta accesible para lectores de pantalla
|
|
77
|
-
*/
|
|
78
|
-
ariaLabel?: string;
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
/**
|
|
82
|
-
* Props del componente Tabs (contenedor)
|
|
83
|
-
*/
|
|
84
|
-
export interface TabsProps {
|
|
85
|
-
/**
|
|
86
|
-
* Lista de tabs a mostrar
|
|
87
|
-
*/
|
|
88
|
-
items: TabItem[];
|
|
89
|
-
|
|
90
|
-
/**
|
|
91
|
-
* ID del tab actualmente seleccionado
|
|
92
|
-
*/
|
|
93
|
-
activeId?: string;
|
|
94
|
-
|
|
95
|
-
/**
|
|
96
|
-
* ID del tab seleccionado por defecto (para componente no controlado)
|
|
97
|
-
*/
|
|
98
|
-
defaultActiveId?: string;
|
|
99
|
-
|
|
100
|
-
/**
|
|
101
|
-
* Callback ejecutado cuando cambia el tab seleccionado
|
|
102
|
-
*/
|
|
103
|
-
onChange?: (id: string) => void;
|
|
104
|
-
|
|
105
|
-
/**
|
|
106
|
-
* Clases CSS adicionales para el contenedor
|
|
107
|
-
*/
|
|
108
|
-
className?: string;
|
|
109
|
-
|
|
110
|
-
/**
|
|
111
|
-
* Si los tabs deben ocupar todo el ancho disponible
|
|
112
|
-
* @default false
|
|
113
|
-
*/
|
|
114
|
-
fullWidth?: boolean;
|
|
115
|
-
|
|
116
|
-
/**
|
|
117
|
-
* Tamaño de los tabs
|
|
118
|
-
* @default 'base'
|
|
119
|
-
*/
|
|
120
|
-
size?: 'sm' | 'base' | 'lg';
|
|
121
|
-
|
|
122
|
-
/**
|
|
123
|
-
* Si se muestra la línea inferior del contenedor de tabs
|
|
124
|
-
* @default true
|
|
125
|
-
*/
|
|
126
|
-
showBorder?: boolean;
|
|
127
|
-
}
|
|
1
|
+
import type { ReactNode } from 'react';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* Configuración de un item de Tab individual
|
|
5
|
+
*/
|
|
6
|
+
export interface TabItem {
|
|
7
|
+
/**
|
|
8
|
+
* Identificador único del tab
|
|
9
|
+
*/
|
|
10
|
+
id: string;
|
|
11
|
+
|
|
12
|
+
/**
|
|
13
|
+
* Texto a mostrar en el tab
|
|
14
|
+
*/
|
|
15
|
+
label: string;
|
|
16
|
+
|
|
17
|
+
/**
|
|
18
|
+
* Icono a mostrar a la izquierda del texto (opcional)
|
|
19
|
+
*/
|
|
20
|
+
icon?: ReactNode;
|
|
21
|
+
|
|
22
|
+
/**
|
|
23
|
+
* Número de notificaciones a mostrar en el badge (opcional)
|
|
24
|
+
*/
|
|
25
|
+
badge?: number;
|
|
26
|
+
|
|
27
|
+
/**
|
|
28
|
+
* Si el tab está deshabilitado
|
|
29
|
+
* @default false
|
|
30
|
+
*/
|
|
31
|
+
disabled?: boolean;
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
/**
|
|
35
|
+
* Props del componente Tab individual (interno)
|
|
36
|
+
*/
|
|
37
|
+
export interface TabProps {
|
|
38
|
+
/**
|
|
39
|
+
* Texto a mostrar en el tab
|
|
40
|
+
*/
|
|
41
|
+
label: string;
|
|
42
|
+
|
|
43
|
+
/**
|
|
44
|
+
* Si el tab está activo/seleccionado
|
|
45
|
+
* @default false
|
|
46
|
+
*/
|
|
47
|
+
active?: boolean;
|
|
48
|
+
|
|
49
|
+
/**
|
|
50
|
+
* Icono a mostrar a la izquierda del texto (opcional)
|
|
51
|
+
*/
|
|
52
|
+
icon?: ReactNode;
|
|
53
|
+
|
|
54
|
+
/**
|
|
55
|
+
* Número de notificaciones a mostrar en el badge (opcional)
|
|
56
|
+
*/
|
|
57
|
+
badge?: number;
|
|
58
|
+
|
|
59
|
+
/**
|
|
60
|
+
* Si el tab está deshabilitado
|
|
61
|
+
* @default false
|
|
62
|
+
*/
|
|
63
|
+
disabled?: boolean;
|
|
64
|
+
|
|
65
|
+
/**
|
|
66
|
+
* Función callback ejecutada al hacer click
|
|
67
|
+
*/
|
|
68
|
+
onClick?: () => void;
|
|
69
|
+
|
|
70
|
+
/**
|
|
71
|
+
* Clases CSS adicionales
|
|
72
|
+
*/
|
|
73
|
+
className?: string;
|
|
74
|
+
|
|
75
|
+
/**
|
|
76
|
+
* Etiqueta accesible para lectores de pantalla
|
|
77
|
+
*/
|
|
78
|
+
ariaLabel?: string;
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
/**
|
|
82
|
+
* Props del componente Tabs (contenedor)
|
|
83
|
+
*/
|
|
84
|
+
export interface TabsProps {
|
|
85
|
+
/**
|
|
86
|
+
* Lista de tabs a mostrar
|
|
87
|
+
*/
|
|
88
|
+
items: TabItem[];
|
|
89
|
+
|
|
90
|
+
/**
|
|
91
|
+
* ID del tab actualmente seleccionado
|
|
92
|
+
*/
|
|
93
|
+
activeId?: string;
|
|
94
|
+
|
|
95
|
+
/**
|
|
96
|
+
* ID del tab seleccionado por defecto (para componente no controlado)
|
|
97
|
+
*/
|
|
98
|
+
defaultActiveId?: string;
|
|
99
|
+
|
|
100
|
+
/**
|
|
101
|
+
* Callback ejecutado cuando cambia el tab seleccionado
|
|
102
|
+
*/
|
|
103
|
+
onChange?: (id: string) => void;
|
|
104
|
+
|
|
105
|
+
/**
|
|
106
|
+
* Clases CSS adicionales para el contenedor
|
|
107
|
+
*/
|
|
108
|
+
className?: string;
|
|
109
|
+
|
|
110
|
+
/**
|
|
111
|
+
* Si los tabs deben ocupar todo el ancho disponible
|
|
112
|
+
* @default false
|
|
113
|
+
*/
|
|
114
|
+
fullWidth?: boolean;
|
|
115
|
+
|
|
116
|
+
/**
|
|
117
|
+
* Tamaño de los tabs
|
|
118
|
+
* @default 'base'
|
|
119
|
+
*/
|
|
120
|
+
size?: 'sm' | 'base' | 'lg';
|
|
121
|
+
|
|
122
|
+
/**
|
|
123
|
+
* Si se muestra la línea inferior del contenedor de tabs
|
|
124
|
+
* @default true
|
|
125
|
+
*/
|
|
126
|
+
showBorder?: boolean;
|
|
127
|
+
}
|
|
@@ -1,129 +1,129 @@
|
|
|
1
|
-
import React from 'react';
|
|
2
|
-
|
|
3
|
-
/**
|
|
4
|
-
* Icono de check (Heroicons Micro 16x16)
|
|
5
|
-
* Usado como icono de ejemplo en los tabs
|
|
6
|
-
*/
|
|
7
|
-
export const CheckIcon: React.FC<{ className?: string }> = ({ className = '' }) => (
|
|
8
|
-
<svg
|
|
9
|
-
className={className}
|
|
10
|
-
xmlns="http://www.w3.org/2000/svg"
|
|
11
|
-
viewBox="0 0 16 16"
|
|
12
|
-
fill="currentColor"
|
|
13
|
-
aria-hidden="true"
|
|
14
|
-
>
|
|
15
|
-
<path
|
|
16
|
-
fillRule="evenodd"
|
|
17
|
-
d="M12.416 3.376a.75.75 0 0 1 .208 1.04l-5 7.5a.75.75 0 0 1-1.154.114l-3-3a.75.75 0 0 1 1.06-1.06l2.353 2.353 4.493-6.74a.75.75 0 0 1 1.04-.207Z"
|
|
18
|
-
clipRule="evenodd"
|
|
19
|
-
/>
|
|
20
|
-
</svg>
|
|
21
|
-
);
|
|
22
|
-
|
|
23
|
-
/**
|
|
24
|
-
* Icono de inicio/home (Heroicons Micro 16x16)
|
|
25
|
-
*/
|
|
26
|
-
export const HomeIcon: React.FC<{ className?: string }> = ({ className = '' }) => (
|
|
27
|
-
<svg
|
|
28
|
-
className={className}
|
|
29
|
-
xmlns="http://www.w3.org/2000/svg"
|
|
30
|
-
viewBox="0 0 16 16"
|
|
31
|
-
fill="currentColor"
|
|
32
|
-
aria-hidden="true"
|
|
33
|
-
>
|
|
34
|
-
<path
|
|
35
|
-
d="M8.543 2.232a.75.75 0 0 0-1.085 0l-5.25 5.5A.75.75 0 0 0 2.75 9H4v4a1 1 0 0 0 1 1h1a1 1 0 0 0 1-1v-1a1 1 0 1 1 2 0v1a1 1 0 0 0 1 1h1a1 1 0 0 0 1-1V9h1.25a.75.75 0 0 0 .543-1.268l-5.25-5.5Z"
|
|
36
|
-
/>
|
|
37
|
-
</svg>
|
|
38
|
-
);
|
|
39
|
-
|
|
40
|
-
/**
|
|
41
|
-
* Icono de usuario (Heroicons Micro 16x16)
|
|
42
|
-
*/
|
|
43
|
-
export const UserIcon: React.FC<{ className?: string }> = ({ className = '' }) => (
|
|
44
|
-
<svg
|
|
45
|
-
className={className}
|
|
46
|
-
xmlns="http://www.w3.org/2000/svg"
|
|
47
|
-
viewBox="0 0 16 16"
|
|
48
|
-
fill="currentColor"
|
|
49
|
-
aria-hidden="true"
|
|
50
|
-
>
|
|
51
|
-
<path
|
|
52
|
-
d="M8 8a3 3 0 1 0 0-6 3 3 0 0 0 0 6ZM12.735 14c.618 0 1.093-.561.872-1.139a6.002 6.002 0 0 0-11.215 0c-.22.578.254 1.139.872 1.139h9.47Z"
|
|
53
|
-
/>
|
|
54
|
-
</svg>
|
|
55
|
-
);
|
|
56
|
-
|
|
57
|
-
/**
|
|
58
|
-
* Icono de configuración/engranaje (Heroicons Micro 16x16)
|
|
59
|
-
*/
|
|
60
|
-
export const CogIcon: React.FC<{ className?: string }> = ({ className = '' }) => (
|
|
61
|
-
<svg
|
|
62
|
-
className={className}
|
|
63
|
-
xmlns="http://www.w3.org/2000/svg"
|
|
64
|
-
viewBox="0 0 16 16"
|
|
65
|
-
fill="currentColor"
|
|
66
|
-
aria-hidden="true"
|
|
67
|
-
>
|
|
68
|
-
<path
|
|
69
|
-
fillRule="evenodd"
|
|
70
|
-
d="M6.455 1.45A.5.5 0 0 1 6.952 1h2.096a.5.5 0 0 1 .497.45l.186 1.858a4.996 4.996 0 0 1 1.466.848l1.703-.769a.5.5 0 0 1 .639.206l1.047 1.814a.5.5 0 0 1-.14.656l-1.517 1.09a5.026 5.026 0 0 1 0 1.694l1.516 1.09a.5.5 0 0 1 .141.656l-1.047 1.814a.5.5 0 0 1-.639.206l-1.703-.768c-.433.36-.928.649-1.466.847l-.186 1.858a.5.5 0 0 1-.497.45H6.952a.5.5 0 0 1-.497-.45l-.186-1.858a4.993 4.993 0 0 1-1.466-.848l-1.703.769a.5.5 0 0 1-.639-.206l-1.047-1.814a.5.5 0 0 1 .14-.656l1.517-1.09a5.033 5.033 0 0 1 0-1.694l-1.516-1.09a.5.5 0 0 1-.141-.656L2.46 3.593a.5.5 0 0 1 .639-.206l1.703.769c.433-.36.928-.65 1.466-.848l.186-1.858ZM8 10.5a2.5 2.5 0 1 0 0-5 2.5 2.5 0 0 0 0 5Z"
|
|
71
|
-
clipRule="evenodd"
|
|
72
|
-
/>
|
|
73
|
-
</svg>
|
|
74
|
-
);
|
|
75
|
-
|
|
76
|
-
/**
|
|
77
|
-
* Icono de campana/notificaciones (Heroicons Micro 16x16)
|
|
78
|
-
*/
|
|
79
|
-
export const BellIcon: React.FC<{ className?: string }> = ({ className = '' }) => (
|
|
80
|
-
<svg
|
|
81
|
-
className={className}
|
|
82
|
-
xmlns="http://www.w3.org/2000/svg"
|
|
83
|
-
viewBox="0 0 16 16"
|
|
84
|
-
fill="currentColor"
|
|
85
|
-
aria-hidden="true"
|
|
86
|
-
>
|
|
87
|
-
<path
|
|
88
|
-
fillRule="evenodd"
|
|
89
|
-
d="M12 5a4 4 0 0 0-8 0v2.379a1.5 1.5 0 0 1-.44 1.06L2.294 9.707a1 1 0 0 0-.294.707V11a1 1 0 0 0 1 1h2a3 3 0 1 0 6 0h2a1 1 0 0 0 1-1v-.586a1 1 0 0 0-.293-.707L12.44 8.44A1.5 1.5 0 0 1 12 7.38V5Zm-4 9a1 1 0 0 1-1-1h2a1 1 0 0 1-1 1Z"
|
|
90
|
-
clipRule="evenodd"
|
|
91
|
-
/>
|
|
92
|
-
</svg>
|
|
93
|
-
);
|
|
94
|
-
|
|
95
|
-
/**
|
|
96
|
-
* Icono de documento (Heroicons Micro 16x16)
|
|
97
|
-
*/
|
|
98
|
-
export const DocumentIcon: React.FC<{ className?: string }> = ({ className = '' }) => (
|
|
99
|
-
<svg
|
|
100
|
-
className={className}
|
|
101
|
-
xmlns="http://www.w3.org/2000/svg"
|
|
102
|
-
viewBox="0 0 16 16"
|
|
103
|
-
fill="currentColor"
|
|
104
|
-
aria-hidden="true"
|
|
105
|
-
>
|
|
106
|
-
<path
|
|
107
|
-
fillRule="evenodd"
|
|
108
|
-
d="M4 2a1.5 1.5 0 0 0-1.5 1.5v9A1.5 1.5 0 0 0 4 14h8a1.5 1.5 0 0 0 1.5-1.5V6.621a1.5 1.5 0 0 0-.44-1.06L9.94 2.439A1.5 1.5 0 0 0 8.878 2H4Zm1 5.75A.75.75 0 0 1 5.75 7h4.5a.75.75 0 0 1 0 1.5h-4.5A.75.75 0 0 1 5 7.75Zm0 3a.75.75 0 0 1 .75-.75h4.5a.75.75 0 0 1 0 1.5h-4.5a.75.75 0 0 1-.75-.75Z"
|
|
109
|
-
clipRule="evenodd"
|
|
110
|
-
/>
|
|
111
|
-
</svg>
|
|
112
|
-
);
|
|
113
|
-
|
|
114
|
-
/**
|
|
115
|
-
* Icono de gráfico/estadísticas (Heroicons Micro 16x16)
|
|
116
|
-
*/
|
|
117
|
-
export const ChartIcon: React.FC<{ className?: string }> = ({ className = '' }) => (
|
|
118
|
-
<svg
|
|
119
|
-
className={className}
|
|
120
|
-
xmlns="http://www.w3.org/2000/svg"
|
|
121
|
-
viewBox="0 0 16 16"
|
|
122
|
-
fill="currentColor"
|
|
123
|
-
aria-hidden="true"
|
|
124
|
-
>
|
|
125
|
-
<path
|
|
126
|
-
d="M13 6.5a.5.5 0 0 1 .5.5v5a.5.5 0 0 1-1 0V7a.5.5 0 0 1 .5-.5ZM10 4a.5.5 0 0 1 .5.5v7.5a.5.5 0 0 1-1 0V4.5A.5.5 0 0 1 10 4ZM7 8a.5.5 0 0 1 .5.5V12a.5.5 0 0 1-1 0V8.5A.5.5 0 0 1 7 8ZM4 10.5a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-1 0v-1a.5.5 0 0 1 .5-.5Z"
|
|
127
|
-
/>
|
|
128
|
-
</svg>
|
|
129
|
-
);
|
|
1
|
+
import React from 'react';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* Icono de check (Heroicons Micro 16x16)
|
|
5
|
+
* Usado como icono de ejemplo en los tabs
|
|
6
|
+
*/
|
|
7
|
+
export const CheckIcon: React.FC<{ className?: string }> = ({ className = '' }) => (
|
|
8
|
+
<svg
|
|
9
|
+
className={className}
|
|
10
|
+
xmlns="http://www.w3.org/2000/svg"
|
|
11
|
+
viewBox="0 0 16 16"
|
|
12
|
+
fill="currentColor"
|
|
13
|
+
aria-hidden="true"
|
|
14
|
+
>
|
|
15
|
+
<path
|
|
16
|
+
fillRule="evenodd"
|
|
17
|
+
d="M12.416 3.376a.75.75 0 0 1 .208 1.04l-5 7.5a.75.75 0 0 1-1.154.114l-3-3a.75.75 0 0 1 1.06-1.06l2.353 2.353 4.493-6.74a.75.75 0 0 1 1.04-.207Z"
|
|
18
|
+
clipRule="evenodd"
|
|
19
|
+
/>
|
|
20
|
+
</svg>
|
|
21
|
+
);
|
|
22
|
+
|
|
23
|
+
/**
|
|
24
|
+
* Icono de inicio/home (Heroicons Micro 16x16)
|
|
25
|
+
*/
|
|
26
|
+
export const HomeIcon: React.FC<{ className?: string }> = ({ className = '' }) => (
|
|
27
|
+
<svg
|
|
28
|
+
className={className}
|
|
29
|
+
xmlns="http://www.w3.org/2000/svg"
|
|
30
|
+
viewBox="0 0 16 16"
|
|
31
|
+
fill="currentColor"
|
|
32
|
+
aria-hidden="true"
|
|
33
|
+
>
|
|
34
|
+
<path
|
|
35
|
+
d="M8.543 2.232a.75.75 0 0 0-1.085 0l-5.25 5.5A.75.75 0 0 0 2.75 9H4v4a1 1 0 0 0 1 1h1a1 1 0 0 0 1-1v-1a1 1 0 1 1 2 0v1a1 1 0 0 0 1 1h1a1 1 0 0 0 1-1V9h1.25a.75.75 0 0 0 .543-1.268l-5.25-5.5Z"
|
|
36
|
+
/>
|
|
37
|
+
</svg>
|
|
38
|
+
);
|
|
39
|
+
|
|
40
|
+
/**
|
|
41
|
+
* Icono de usuario (Heroicons Micro 16x16)
|
|
42
|
+
*/
|
|
43
|
+
export const UserIcon: React.FC<{ className?: string }> = ({ className = '' }) => (
|
|
44
|
+
<svg
|
|
45
|
+
className={className}
|
|
46
|
+
xmlns="http://www.w3.org/2000/svg"
|
|
47
|
+
viewBox="0 0 16 16"
|
|
48
|
+
fill="currentColor"
|
|
49
|
+
aria-hidden="true"
|
|
50
|
+
>
|
|
51
|
+
<path
|
|
52
|
+
d="M8 8a3 3 0 1 0 0-6 3 3 0 0 0 0 6ZM12.735 14c.618 0 1.093-.561.872-1.139a6.002 6.002 0 0 0-11.215 0c-.22.578.254 1.139.872 1.139h9.47Z"
|
|
53
|
+
/>
|
|
54
|
+
</svg>
|
|
55
|
+
);
|
|
56
|
+
|
|
57
|
+
/**
|
|
58
|
+
* Icono de configuración/engranaje (Heroicons Micro 16x16)
|
|
59
|
+
*/
|
|
60
|
+
export const CogIcon: React.FC<{ className?: string }> = ({ className = '' }) => (
|
|
61
|
+
<svg
|
|
62
|
+
className={className}
|
|
63
|
+
xmlns="http://www.w3.org/2000/svg"
|
|
64
|
+
viewBox="0 0 16 16"
|
|
65
|
+
fill="currentColor"
|
|
66
|
+
aria-hidden="true"
|
|
67
|
+
>
|
|
68
|
+
<path
|
|
69
|
+
fillRule="evenodd"
|
|
70
|
+
d="M6.455 1.45A.5.5 0 0 1 6.952 1h2.096a.5.5 0 0 1 .497.45l.186 1.858a4.996 4.996 0 0 1 1.466.848l1.703-.769a.5.5 0 0 1 .639.206l1.047 1.814a.5.5 0 0 1-.14.656l-1.517 1.09a5.026 5.026 0 0 1 0 1.694l1.516 1.09a.5.5 0 0 1 .141.656l-1.047 1.814a.5.5 0 0 1-.639.206l-1.703-.768c-.433.36-.928.649-1.466.847l-.186 1.858a.5.5 0 0 1-.497.45H6.952a.5.5 0 0 1-.497-.45l-.186-1.858a4.993 4.993 0 0 1-1.466-.848l-1.703.769a.5.5 0 0 1-.639-.206l-1.047-1.814a.5.5 0 0 1 .14-.656l1.517-1.09a5.033 5.033 0 0 1 0-1.694l-1.516-1.09a.5.5 0 0 1-.141-.656L2.46 3.593a.5.5 0 0 1 .639-.206l1.703.769c.433-.36.928-.65 1.466-.848l.186-1.858ZM8 10.5a2.5 2.5 0 1 0 0-5 2.5 2.5 0 0 0 0 5Z"
|
|
71
|
+
clipRule="evenodd"
|
|
72
|
+
/>
|
|
73
|
+
</svg>
|
|
74
|
+
);
|
|
75
|
+
|
|
76
|
+
/**
|
|
77
|
+
* Icono de campana/notificaciones (Heroicons Micro 16x16)
|
|
78
|
+
*/
|
|
79
|
+
export const BellIcon: React.FC<{ className?: string }> = ({ className = '' }) => (
|
|
80
|
+
<svg
|
|
81
|
+
className={className}
|
|
82
|
+
xmlns="http://www.w3.org/2000/svg"
|
|
83
|
+
viewBox="0 0 16 16"
|
|
84
|
+
fill="currentColor"
|
|
85
|
+
aria-hidden="true"
|
|
86
|
+
>
|
|
87
|
+
<path
|
|
88
|
+
fillRule="evenodd"
|
|
89
|
+
d="M12 5a4 4 0 0 0-8 0v2.379a1.5 1.5 0 0 1-.44 1.06L2.294 9.707a1 1 0 0 0-.294.707V11a1 1 0 0 0 1 1h2a3 3 0 1 0 6 0h2a1 1 0 0 0 1-1v-.586a1 1 0 0 0-.293-.707L12.44 8.44A1.5 1.5 0 0 1 12 7.38V5Zm-4 9a1 1 0 0 1-1-1h2a1 1 0 0 1-1 1Z"
|
|
90
|
+
clipRule="evenodd"
|
|
91
|
+
/>
|
|
92
|
+
</svg>
|
|
93
|
+
);
|
|
94
|
+
|
|
95
|
+
/**
|
|
96
|
+
* Icono de documento (Heroicons Micro 16x16)
|
|
97
|
+
*/
|
|
98
|
+
export const DocumentIcon: React.FC<{ className?: string }> = ({ className = '' }) => (
|
|
99
|
+
<svg
|
|
100
|
+
className={className}
|
|
101
|
+
xmlns="http://www.w3.org/2000/svg"
|
|
102
|
+
viewBox="0 0 16 16"
|
|
103
|
+
fill="currentColor"
|
|
104
|
+
aria-hidden="true"
|
|
105
|
+
>
|
|
106
|
+
<path
|
|
107
|
+
fillRule="evenodd"
|
|
108
|
+
d="M4 2a1.5 1.5 0 0 0-1.5 1.5v9A1.5 1.5 0 0 0 4 14h8a1.5 1.5 0 0 0 1.5-1.5V6.621a1.5 1.5 0 0 0-.44-1.06L9.94 2.439A1.5 1.5 0 0 0 8.878 2H4Zm1 5.75A.75.75 0 0 1 5.75 7h4.5a.75.75 0 0 1 0 1.5h-4.5A.75.75 0 0 1 5 7.75Zm0 3a.75.75 0 0 1 .75-.75h4.5a.75.75 0 0 1 0 1.5h-4.5a.75.75 0 0 1-.75-.75Z"
|
|
109
|
+
clipRule="evenodd"
|
|
110
|
+
/>
|
|
111
|
+
</svg>
|
|
112
|
+
);
|
|
113
|
+
|
|
114
|
+
/**
|
|
115
|
+
* Icono de gráfico/estadísticas (Heroicons Micro 16x16)
|
|
116
|
+
*/
|
|
117
|
+
export const ChartIcon: React.FC<{ className?: string }> = ({ className = '' }) => (
|
|
118
|
+
<svg
|
|
119
|
+
className={className}
|
|
120
|
+
xmlns="http://www.w3.org/2000/svg"
|
|
121
|
+
viewBox="0 0 16 16"
|
|
122
|
+
fill="currentColor"
|
|
123
|
+
aria-hidden="true"
|
|
124
|
+
>
|
|
125
|
+
<path
|
|
126
|
+
d="M13 6.5a.5.5 0 0 1 .5.5v5a.5.5 0 0 1-1 0V7a.5.5 0 0 1 .5-.5ZM10 4a.5.5 0 0 1 .5.5v7.5a.5.5 0 0 1-1 0V4.5A.5.5 0 0 1 10 4ZM7 8a.5.5 0 0 1 .5.5V12a.5.5 0 0 1-1 0V8.5A.5.5 0 0 1 7 8ZM4 10.5a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-1 0v-1a.5.5 0 0 1 .5-.5Z"
|
|
127
|
+
/>
|
|
128
|
+
</svg>
|
|
129
|
+
);
|
|
@@ -1,11 +1,11 @@
|
|
|
1
|
-
export { Tabs, Tab } from './Tabs';
|
|
2
|
-
export type { TabsProps, TabProps, TabItem } from './Tabs.types';
|
|
3
|
-
export {
|
|
4
|
-
CheckIcon,
|
|
5
|
-
HomeIcon,
|
|
6
|
-
UserIcon,
|
|
7
|
-
CogIcon,
|
|
8
|
-
BellIcon,
|
|
9
|
-
DocumentIcon,
|
|
10
|
-
ChartIcon,
|
|
11
|
-
} from './icons';
|
|
1
|
+
export { Tabs, Tab } from './Tabs';
|
|
2
|
+
export type { TabsProps, TabProps, TabItem } from './Tabs.types';
|
|
3
|
+
export {
|
|
4
|
+
CheckIcon,
|
|
5
|
+
HomeIcon,
|
|
6
|
+
UserIcon,
|
|
7
|
+
CogIcon,
|
|
8
|
+
BellIcon,
|
|
9
|
+
DocumentIcon,
|
|
10
|
+
ChartIcon,
|
|
11
|
+
} from './icons';
|