@imj_media/ui 1.2.33 → 1.2.35

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 (31) hide show
  1. package/CHANGELOG.md +70 -0
  2. package/dist/index.css +1 -1
  3. package/dist/index.esm.js +4868 -4767
  4. package/dist/index.esm.js.map +1 -1
  5. package/dist/index.js +9 -9
  6. package/dist/index.js.map +1 -1
  7. package/dist/modules/Badge/index.d.ts +1 -1
  8. package/dist/modules/Badge/index.d.ts.map +1 -1
  9. package/dist/modules/CardsWithAside/components/organisms/CardsWithAside.d.ts +1 -1
  10. package/dist/modules/CardsWithAside/components/organisms/CardsWithAside.d.ts.map +1 -1
  11. package/dist/modules/CardsWithAside/stories/CardsWithAside.stories.d.ts +4 -0
  12. package/dist/modules/CardsWithAside/stories/CardsWithAside.stories.d.ts.map +1 -1
  13. package/dist/modules/CardsWithAside/types/index.d.ts +7 -0
  14. package/dist/modules/CardsWithAside/types/index.d.ts.map +1 -1
  15. package/dist/modules/Drawer/index.d.ts +6 -2
  16. package/dist/modules/Drawer/index.d.ts.map +1 -1
  17. package/dist/modules/Drawer/stories/Drawer.stories.d.ts +2 -0
  18. package/dist/modules/Drawer/stories/Drawer.stories.d.ts.map +1 -1
  19. package/dist/modules/InnerButton/index.d.ts +1 -1
  20. package/dist/modules/InnerButton/index.d.ts.map +1 -1
  21. package/dist/modules/InnerButton/stories/InnerButton.stories.d.ts +7 -0
  22. package/dist/modules/InnerButton/stories/InnerButton.stories.d.ts.map +1 -1
  23. package/dist/shared/types/badge.d.ts +2 -0
  24. package/dist/shared/types/badge.d.ts.map +1 -1
  25. package/dist/shared/types/button.d.ts +4 -0
  26. package/dist/shared/types/button.d.ts.map +1 -1
  27. package/dist/shared/types/drawer.d.ts +4 -0
  28. package/dist/shared/types/drawer.d.ts.map +1 -1
  29. package/dist/shared/types/tooltip.d.ts +1 -0
  30. package/dist/shared/types/tooltip.d.ts.map +1 -1
  31. package/package.json +1 -1
package/CHANGELOG.md CHANGED
@@ -5,6 +5,76 @@ Todos los cambios notables de este proyecto serán documentados en este archivo.
5
5
  El formato está basado en [Keep a Changelog](https://keepachangelog.com/es-ES/1.0.0/),
6
6
  y este proyecto adhiere a [Semantic Versioning](https://semver.org/lang/es/).
7
7
 
8
+ ## [1.2.35] - 2026-02-04
9
+
10
+ ### Added
11
+ - **InnerButton - HoverText con Gestión Inteligente de Ancho**: Nueva funcionalidad para cambiar el texto al hacer hover con gestión automática del ancho
12
+ - Nueva prop `hoverText` que permite mostrar un texto diferente al hacer hover sobre el botón
13
+ - Solo funciona cuando el badge termina de cargar (`badgeLoading` cambia de `true` a `false`)
14
+ - El componente mantiene un estado interno que rastrea el tamaño máximo de los textos (children y hoverText)
15
+ - El ancho del botón se ajusta automáticamente al texto más largo y nunca se reduce una vez establecido
16
+ - Si el texto inicial tiene 5 caracteres y el hoverText tiene 7, el botón se ajusta a 7 caracteres
17
+ - Si el texto inicial tiene 7 caracteres y el hoverText tiene 5, el botón mantiene 7 caracteres
18
+ - El cambio de texto ocurre al hacer hover sobre el botón
19
+ - Optimizado con memoización para evitar re-renders innecesarios
20
+ - El recálculo del ancho solo ocurre cuando: `children` cambia, `hoverText` cambia, o `badgeLoading` se activa
21
+ - Funciona con todos los tamaños de botón (xs, sm, md, lg) y con iconos
22
+ - Nuevas stories en Storybook:
23
+ - `HoverTextShortInitial`: Texto inicial corto → hoverText largo
24
+ - `HoverTextLongInitial`: Texto inicial largo → hoverText corto
25
+ - `HoverTextDifferentSizes`: Diferentes tamaños de botón
26
+ - `HoverTextWithoutLoading`: Demuestra que no funciona sin badgeLoading
27
+ - `HoverTextMultipleScenarios`: Múltiples escenarios en una sola historia
28
+ - `HoverTextWithIcons`: Funcionalidad con diferentes tipos de iconos (string, Font Awesome, duotone, slots)
29
+
30
+ ### Changed
31
+ - **InnerButton - Optimizaciones de Rendimiento**: Mejoras en el rendimiento del componente
32
+ - Funciones `handleMouseEnter` y `handleMouseLeave` memoizadas con `useCallback`
33
+ - Valores calculados memoizados con `useMemo` (`displayText`, `childrenText`, `hoverTextValue`, `textStyle`)
34
+ - Optimización del `useEffect` de medición para evitar loops infinitos
35
+ - Uso de función de actualización en `setMaxTextWidth` para evitar dependencias innecesarias
36
+ - Reducción significativa de re-renders innecesarios
37
+
38
+ ## [1.2.34] - 2026-02-04
39
+
40
+ ### Added
41
+ - **Drawer - Compound Components para Footer**: El componente Drawer ahora soporta footer personalizado usando compound components
42
+ - Nuevo subcomponente `Drawer.Footer` que puede ser pasado como hijo del componente
43
+ - Función `extractFooterFromChildren` que detecta automáticamente el footer personalizado dentro de los children
44
+ - Si no se proporciona `Drawer.Footer`, se mantiene el comportamiento por defecto con botones Cancelar/Guardar
45
+ - Nueva story `CustomFooter` que demuestra el uso de compound components para footer personalizado
46
+ - **CardsWithAside - Tooltips Configurables**: Sistema completo de tooltips para las opciones de tabs
47
+ - Nueva prop `showTooltips` (por defecto: `true`) para habilitar/deshabilitar tooltips globalmente
48
+ - Nueva prop `tooltipPosition` (por defecto: `'right'`) para establecer la posición global de los tooltips
49
+ - Cada tab individual puede sobrescribir la posición del tooltip con su propia prop `tooltipPosition`
50
+ - Tooltips aplicados tanto a los botones de tabs como al botón de "más opciones"
51
+ - Nuevas stories: `WithTooltips`, `TooltipPositionGlobal`, `TooltipPositionIndividual`, `ShowHideTooltips`
52
+ - **Badge - Spinner de Carga**: Nuevo sistema de spinner de carga dentro del badge
53
+ - Nueva prop `loading` en el componente Badge para mostrar un spinner de carga
54
+ - Spinner adaptativo que se ajusta proporcionalmente a todos los tamaños de badge (`dot`, `sm`, `md`, `lg`)
55
+ - Tamaños del spinner: 32px para `dot`, 40px para `sm` y `md`, 48px para `lg`
56
+ - Badges `sm`, `md` y `lg` tienen tamaño fijo y circular cuando están en modo loading
57
+ - Spinner con borde delgado (`ui-border`) para mejor apariencia visual
58
+ - Nueva prop `badgeLoading` en `InnerButton` para pasar el estado de carga al badge
59
+ - Nueva story `BadgeWithLoading` en InnerButton que demuestra el spinner en diferentes configuraciones
60
+
61
+ ### Changed
62
+ - **Drawer - API de Footer**: Cambio de prop `footer` a compound component `Drawer.Footer`
63
+ - La prop `footer` ha sido removida en favor de usar `Drawer.Footer` como hijo
64
+ - Mejora la flexibilidad y expresividad de la API del componente
65
+ - Mantiene compatibilidad con el comportamiento por defecto cuando no se usa footer personalizado
66
+
67
+ ### Fixed
68
+ - **CardsWithAside - Icono "More Options"**: Corrección del icono que no aparecía en el componente Popup
69
+ - Cambio de `label || ''` a `label || null` en el componente Popup para que el icono se muestre correctamente
70
+ - El componente `InnerButton` solo renderiza el icono cuando `children` es `null` o `false`
71
+ - **Tooltip - Z-index CSS**: Corrección del valor de z-index en variables CSS
72
+ - Cambio de `--ui-z-max: 99999px` a `--ui-z-max: 99999` (z-index no debe tener unidades)
73
+ - Resuelve problema de tooltips no visibles debido a z-index incorrecto
74
+ - **Tooltip - Exportación de Tipos**: Agregada exportación de tipos `TooltipPosition` y `TooltipAlignment`
75
+ - Los tipos ahora están disponibles para importación desde `@/shared/types/tooltip`
76
+ - Resuelve error de TypeScript: "Module declares 'TooltipPosition' locally, but it is not exported"
77
+
8
78
  ## [1.2.33] - 2026-02-04
9
79
 
10
80
  ### Added