react-restyle-components 0.4.47 → 0.4.49

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 (234) hide show
  1. package/lib/index.js +3 -1
  2. package/lib/src/core-components/index.js +1 -1
  3. package/lib/src/core-components/src/components/Accordion/AccordionSection/Accordion.js +15 -1
  4. package/lib/src/core-components/src/components/Accordion/AccordionSection/AccordionContext.js +6 -1
  5. package/lib/src/core-components/src/components/Accordion/AccordionSection/AccordionSection.js +39 -1
  6. package/lib/src/core-components/src/components/Accordion/AccordionSection/Header.js +39 -1
  7. package/lib/src/core-components/src/components/Accordion/AccordionSection/elements.js +94 -57
  8. package/lib/src/core-components/src/components/Accordion/AccordionSection/hooks/useCurrentAccordionIndex.js +13 -1
  9. package/lib/src/core-components/src/components/Accordion/AccordionSection/index.js +3 -1
  10. package/lib/src/core-components/src/components/Accordion/AccordionSection/types.js +9 -1
  11. package/lib/src/core-components/src/components/Accordion/Collapsible/Collapsible2.component.js +249 -1
  12. package/lib/src/core-components/src/components/Action/types.js +8 -1
  13. package/lib/src/core-components/src/components/AlertBanner/AlertBanner.js +45 -1
  14. package/lib/src/core-components/src/components/AlertBanner/elements.js +120 -45
  15. package/lib/src/core-components/src/components/AlertBanner/index.js +2 -1
  16. package/lib/src/core-components/src/components/AlertBanner/types.js +10 -1
  17. package/lib/src/core-components/src/components/AutoComplete/auto-complete-filter-group-by-multiple-select-multiple-fields-display/auto-complete-filter-group-by-multiple-select-multiple-fields-display.component.d.ts +3 -1
  18. package/lib/src/core-components/src/components/AutoComplete/auto-complete-filter-group-by-multiple-select-multiple-fields-display/auto-complete-filter-group-by-multiple-select-multiple-fields-display.component.js +466 -1
  19. package/lib/src/core-components/src/components/AutoComplete/auto-complete-filter-multi-select-multi-fields-display-drag-drop/auto-complete-filter-multi-select-multi-fields-display-drag-drop.component.js +229 -1
  20. package/lib/src/core-components/src/components/AutoComplete/auto-complete-filter-multi-select-selected-top-display/auto-complete-filter-multi-select-selected-top-display.component.js +174 -1
  21. package/lib/src/core-components/src/components/AutoComplete/auto-complete-filter-multiple-select-multiple-fields-display/auto-complete-filter-multiple-select-multiple-fields-display.component.js +129 -2
  22. package/lib/src/core-components/src/components/AutoComplete/auto-complete-filter-single-select/auto-complete-filter-single-select.component.js +55 -1
  23. package/lib/src/core-components/src/components/AutoComplete/auto-complete-filter-single-select-multiple-fields-display/auto-complete-filter-single-select-multiple-fields-display.component.js +308 -2
  24. package/lib/src/core-components/src/components/AutoComplete/auto-complete-group-by/auto-complete-group-by.component.js +115 -1
  25. package/lib/src/core-components/src/components/AutoComplete/autocomplete/autocomplete.js +442 -2
  26. package/lib/src/core-components/src/components/AutoComplete/index.js +8 -1
  27. package/lib/src/core-components/src/components/Avatar/Avatar.js +148 -14
  28. package/lib/src/core-components/src/components/Badge/Badge.js +25 -2
  29. package/lib/src/core-components/src/components/Badge/InnerBadge/Inline.js +25 -1
  30. package/lib/src/core-components/src/components/Badge/InnerBadge/InnerBadge.js +25 -1
  31. package/lib/src/core-components/src/components/Badge/InnerBadge/elements.js +78 -32
  32. package/lib/src/core-components/src/components/Badge/InnerBadge/index.js +1 -1
  33. package/lib/src/core-components/src/components/Badge/index.js +1 -1
  34. package/lib/src/core-components/src/components/Badge/types.js +5 -1
  35. package/lib/src/core-components/src/components/Breadcrumb/Breadcrumb.js +83 -1
  36. package/lib/src/core-components/src/components/Breadcrumb/elements.js +166 -94
  37. package/lib/src/core-components/src/components/Breadcrumb/index.js +3 -1
  38. package/lib/src/core-components/src/components/Breadcrumb/types.js +3 -1
  39. package/lib/src/core-components/src/components/Button/button.component.js +18 -1
  40. package/lib/src/core-components/src/components/Button/buttonGroup/buttonGroup.component.js +4 -1
  41. package/lib/src/core-components/src/components/Button/index.js +2 -1
  42. package/lib/src/core-components/src/components/Button/types.js +1 -1
  43. package/lib/src/core-components/src/components/Chip/Chip.js +64 -1
  44. package/lib/src/core-components/src/components/Chip/elements.js +148 -48
  45. package/lib/src/core-components/src/components/Chip/index.js +2 -1
  46. package/lib/src/core-components/src/components/Chip/types.js +4 -1
  47. package/lib/src/core-components/src/components/Divider/Divider.js +25 -1
  48. package/lib/src/core-components/src/components/Divider/elements.js +68 -31
  49. package/lib/src/core-components/src/components/Divider/index.js +2 -1
  50. package/lib/src/core-components/src/components/Divider/types.js +4 -1
  51. package/lib/src/core-components/src/components/DynamicGrid/DynamicGrid.js +147 -1
  52. package/lib/src/core-components/src/components/DynamicGrid/GridContainer.js +24 -17
  53. package/lib/src/core-components/src/components/DynamicGrid/elements.js +162 -100
  54. package/lib/src/core-components/src/components/DynamicGrid/index.js +3 -1
  55. package/lib/src/core-components/src/components/DynamicGrid/types.js +28 -1
  56. package/lib/src/core-components/src/components/DynamicGrid/utils.js +193 -1
  57. package/lib/src/core-components/src/components/FormField/FormField.js +103 -1
  58. package/lib/src/core-components/src/components/FormField/components/CheckboxGroupInput.js +37 -1
  59. package/lib/src/core-components/src/components/FormField/components/CheckboxInput.js +8 -1
  60. package/lib/src/core-components/src/components/FormField/components/CssMultilineInput.js +192 -1
  61. package/lib/src/core-components/src/components/FormField/components/DatePickerInput.js +99 -1
  62. package/lib/src/core-components/src/components/FormField/components/DropdownInput.js +70 -1
  63. package/lib/src/core-components/src/components/FormField/components/OtpInput.js +81 -1
  64. package/lib/src/core-components/src/components/FormField/components/PasswordInput.js +40 -1
  65. package/lib/src/core-components/src/components/FormField/components/PinInput.js +75 -1
  66. package/lib/src/core-components/src/components/FormField/components/RadioInput.js +54 -1
  67. package/lib/src/core-components/src/components/FormField/components/TextDropdownInput.js +94 -1
  68. package/lib/src/core-components/src/components/FormField/components/ToggleInput.js +36 -1
  69. package/lib/src/core-components/src/components/FormField/components/index.js +11 -1
  70. package/lib/src/core-components/src/components/FormField/css-properties.js +161 -1
  71. package/lib/src/core-components/src/components/FormField/index.js +2 -1
  72. package/lib/src/core-components/src/components/Icon/Icon.js +159 -1
  73. package/lib/src/core-components/src/components/Icon/index.js +2 -1
  74. package/lib/src/core-components/src/components/Icon/types.js +9 -1
  75. package/lib/src/core-components/src/components/Loader/loader.component.js +215 -2
  76. package/lib/src/core-components/src/components/Masonry/Masonry.js +73 -1
  77. package/lib/src/core-components/src/components/Masonry/elements.js +46 -29
  78. package/lib/src/core-components/src/components/Masonry/hooks.js +100 -1
  79. package/lib/src/core-components/src/components/Masonry/index.js +3 -1
  80. package/lib/src/core-components/src/components/Masonry/types.js +1 -1
  81. package/lib/src/core-components/src/components/Modal/BasicModal/modal.component.d.ts +3 -1
  82. package/lib/src/core-components/src/components/Modal/BasicModal/modal.component.js +123 -1
  83. package/lib/src/core-components/src/components/Modal/index.js +2 -1
  84. package/lib/src/core-components/src/components/Modal/modal-confirm/modal-confirm.component.js +147 -1
  85. package/lib/src/core-components/src/components/Picker/color-picker/color-picker.component.js +12 -1
  86. package/lib/src/core-components/src/components/Picker/color-picker-modal/color-picker-modal.component.js +40 -1
  87. package/lib/src/core-components/src/components/Picker/index.js +2 -1
  88. package/lib/src/core-components/src/components/Selection/index.js +4 -1
  89. package/lib/src/core-components/src/components/Selection/multi-select/multi-select.component.js +49 -1
  90. package/lib/src/core-components/src/components/Selection/multi-select-with-field/multi-select-with-field.component.js +58 -1
  91. package/lib/src/core-components/src/components/Selection/multi-selection-dropdown/multi-selection-dropdown.component.js +43 -1
  92. package/lib/src/core-components/src/components/Selection/single-select/single-select.component.js +87 -1
  93. package/lib/src/core-components/src/components/Skeleton/Skeleton.js +51 -1
  94. package/lib/src/core-components/src/components/Skeleton/elements.js +143 -54
  95. package/lib/src/core-components/src/components/Skeleton/index.js +2 -1
  96. package/lib/src/core-components/src/components/Skeleton/types.js +4 -1
  97. package/lib/src/core-components/src/components/SpeedDial/SpeedDial.js +128 -1
  98. package/lib/src/core-components/src/components/SpeedDial/elements.js +132 -62
  99. package/lib/src/core-components/src/components/SpeedDial/index.js +2 -1
  100. package/lib/src/core-components/src/components/SpeedDial/types.js +3 -1
  101. package/lib/src/core-components/src/components/Stepper2/stepper.component.js +139 -1
  102. package/lib/src/core-components/src/components/Switch/Switch.js +26 -1
  103. package/lib/src/core-components/src/components/Switch/elements.js +103 -34
  104. package/lib/src/core-components/src/components/Switch/index.js +2 -1
  105. package/lib/src/core-components/src/components/Switch/types.js +3 -1
  106. package/lib/src/core-components/src/components/Table/Table.js +1526 -1
  107. package/lib/src/core-components/src/components/Table/columnReorder.js +332 -36
  108. package/lib/src/core-components/src/components/Table/columnResize.js +284 -21
  109. package/lib/src/core-components/src/components/Table/elements.js +277 -173
  110. package/lib/src/core-components/src/components/Table/filters.js +555 -30
  111. package/lib/src/core-components/src/components/Table/hooks.js +536 -2
  112. package/lib/src/core-components/src/components/Table/index.js +6 -1
  113. package/lib/src/core-components/src/components/Table/types.js +1 -1
  114. package/lib/src/core-components/src/components/Tabs/tabs.component.js +22 -1
  115. package/lib/src/core-components/src/components/Tags1/Tags.component.js +118 -1
  116. package/lib/src/core-components/src/components/Tags1/types.js +20 -1
  117. package/lib/src/core-components/src/components/Timer1/timer.component.js +76 -1
  118. package/lib/src/core-components/src/components/Toast/Toast.js +50 -1
  119. package/lib/src/core-components/src/components/Toast/elements.js +122 -41
  120. package/lib/src/core-components/src/components/Toast/index.js +2 -1
  121. package/lib/src/core-components/src/components/Toast/types.js +9 -1
  122. package/lib/src/core-components/src/components/Tooltip/Tooltip.js +200 -1
  123. package/lib/src/core-components/src/components/Tooltip/elements.js +117 -55
  124. package/lib/src/core-components/src/components/Tooltip/index.js +2 -1
  125. package/lib/src/core-components/src/components/Tooltip/types.js +17 -1
  126. package/lib/src/core-components/src/components/Tooltip/utils.js +140 -1
  127. package/lib/src/core-components/src/components/TreeSelect/TreeSelect.js +303 -1
  128. package/lib/src/core-components/src/components/TreeSelect/elements.js +216 -117
  129. package/lib/src/core-components/src/components/TreeSelect/hooks.js +252 -1
  130. package/lib/src/core-components/src/components/TreeSelect/index.js +3 -1
  131. package/lib/src/core-components/src/components/TreeSelect/types.js +1 -1
  132. package/lib/src/core-components/src/components/ag-grid/AgGrid.js +1057 -1
  133. package/lib/src/core-components/src/components/ag-grid/elements.js +790 -396
  134. package/lib/src/core-components/src/components/ag-grid/hooks.js +1220 -4
  135. package/lib/src/core-components/src/components/ag-grid/index.js +15 -1
  136. package/lib/src/core-components/src/components/ag-grid/types.js +6 -1
  137. package/lib/src/core-components/src/components/index.js +31 -1
  138. package/lib/src/core-components/src/components/pdf/pdf-images.components.js +7 -1
  139. package/lib/src/core-components/src/components/pdf/pdf-table.components.js +48 -5
  140. package/lib/src/core-components/src/components/pdf/pdf-typography.components.js +70 -1
  141. package/lib/src/core-components/src/components/pdf/pdf-wrapped-view.components.js +50 -1
  142. package/lib/src/core-components/src/core-components/Avatar.js +33 -4
  143. package/lib/src/core-components/src/core-components/CoreButton/CoreButton.js +10 -1
  144. package/lib/src/core-components/src/core-components/CoreButton/elements.js +176 -67
  145. package/lib/src/core-components/src/core-components/CoreButton/index.js +3 -1
  146. package/lib/src/core-components/src/core-components/CoreButton/types.js +6 -1
  147. package/lib/src/core-components/src/core-components/CoreButton/utils.js +12 -1
  148. package/lib/src/core-components/src/core-components/Divider/Divider.js +19 -4
  149. package/lib/src/core-components/src/core-components/Divider/index.js +1 -1
  150. package/lib/src/core-components/src/core-components/SelectionCardStrip/index.js +1 -1
  151. package/lib/src/core-components/src/core-components/SelectionCardStrip/selectionCardStrip.js +33 -10
  152. package/lib/src/core-components/src/core-components/StateLayer.js +5 -3
  153. package/lib/src/core-components/src/core-components/ToggleCore/elements.js +50 -25
  154. package/lib/src/core-components/src/core-components/ToggleCore/index.js +2 -1
  155. package/lib/src/core-components/src/core-components/ToggleCore/toggleCore.js +14 -1
  156. package/lib/src/core-components/src/core-components/atoms/Input/Input.js +22 -1
  157. package/lib/src/core-components/src/core-components/atoms/Label/Label.js +21 -1
  158. package/lib/src/core-components/src/core-components/atoms/Textarea/Textarea.js +19 -1
  159. package/lib/src/core-components/src/core-components/index.js +3 -1
  160. package/lib/src/core-components/src/helpers/constants.js +11 -1
  161. package/lib/src/core-components/src/hooks/index.js +1 -1
  162. package/lib/src/core-components/src/hooks/outside.hook.js +28 -1
  163. package/lib/src/core-components/src/index.js +12 -1
  164. package/lib/src/core-components/src/tc.global.css +3 -0
  165. package/lib/src/core-components/src/tc.module.css +1 -1
  166. package/lib/src/core-components/src/utils/abstracts/breakpoints/index.js +28 -1
  167. package/lib/src/core-components/src/utils/abstracts/colors/index.js +49 -1
  168. package/lib/src/core-components/src/utils/abstracts/index.js +5 -1
  169. package/lib/src/core-components/src/utils/abstracts/space/index.js +26 -1
  170. package/lib/src/core-components/src/utils/abstracts/theme/ThemeBoundary.js +8 -1
  171. package/lib/src/core-components/src/utils/abstracts/theme/default-themes.js +30 -1
  172. package/lib/src/core-components/src/utils/abstracts/theme/index.js +3 -1
  173. package/lib/src/core-components/src/utils/abstracts/theme/theme.js +30 -1
  174. package/lib/src/core-components/src/utils/abstracts/theme/types.js +1 -1
  175. package/lib/src/core-components/src/utils/abstracts/theme/useTheme.js +17 -1
  176. package/lib/src/core-components/src/utils/abstracts/typography/index.js +25 -1
  177. package/lib/src/core-components/src/utils/context/DefaultsProvider.js +8 -1
  178. package/lib/src/core-components/src/utils/context/InternalProvider.js +24 -1
  179. package/lib/src/core-components/src/utils/context/index.js +2 -1
  180. package/lib/src/core-components/src/utils/designTokens.js +128 -1
  181. package/lib/src/core-components/src/utils/helpers/attachSubComponents.js +23 -1
  182. package/lib/src/core-components/src/utils/helpers/flattenChildren.js +11 -1
  183. package/lib/src/core-components/src/utils/helpers/getChildByType.js +3 -1
  184. package/lib/src/core-components/src/utils/helpers/index.js +5 -1
  185. package/lib/src/core-components/src/utils/helpers/isComponentType.js +16 -1
  186. package/lib/src/core-components/src/utils/helpers/separateChildrenByType.js +12 -1
  187. package/lib/src/core-components/src/utils/hooks/index.js +18 -1
  188. package/lib/src/core-components/src/utils/hooks/useClickOutside.js +18 -1
  189. package/lib/src/core-components/src/utils/hooks/useCombinedRefs.js +17 -1
  190. package/lib/src/core-components/src/utils/hooks/useDebouncedCallback.js +12 -1
  191. package/lib/src/core-components/src/utils/hooks/useDebouncedValue.js +20 -1
  192. package/lib/src/core-components/src/utils/hooks/useDeprecation.js +40 -1
  193. package/lib/src/core-components/src/utils/hooks/useDeviceDetect.js +10 -1
  194. package/lib/src/core-components/src/utils/hooks/useDeviceForm.js +24 -1
  195. package/lib/src/core-components/src/utils/hooks/useDisableBodyScroll.js +16 -1
  196. package/lib/src/core-components/src/utils/hooks/useHoverState.js +36 -1
  197. package/lib/src/core-components/src/utils/hooks/useId.js +7 -1
  198. package/lib/src/core-components/src/utils/hooks/useIsBrowser.js +11 -1
  199. package/lib/src/core-components/src/utils/hooks/useMediaQuery.js +16 -1
  200. package/lib/src/core-components/src/utils/hooks/useOverflow.js +22 -1
  201. package/lib/src/core-components/src/utils/hooks/useSafeLayoutEffect.js +5 -1
  202. package/lib/src/core-components/src/utils/hooks/useScrollingUp.js +18 -1
  203. package/lib/src/core-components/src/utils/hooks/useTrapFocus.js +30 -1
  204. package/lib/src/core-components/src/utils/hooks/useWindowDimensions.js +23 -1
  205. package/lib/src/core-components/src/utils/index.js +9 -1
  206. package/lib/src/core-components/src/utils/stories/Wrappers.js +23 -8
  207. package/lib/src/core-components/src/utils/stories/cleanProps.js +5 -1
  208. package/lib/src/core-components/src/utils/stories/index.js +4 -1
  209. package/lib/src/core-components/src/utils/stories/sleep.js +4 -1
  210. package/lib/src/core-components/src/utils/stories/view-ports.js +50 -1
  211. package/lib/src/core-components/src/utils/styling/calcWidthOfColumns.js +5 -1
  212. package/lib/src/core-components/src/utils/styling/createGridContainer.js +12 -6
  213. package/lib/src/core-components/src/utils/styling/createTransition.js +7 -2
  214. package/lib/src/core-components/src/utils/styling/forwardProps.js +10 -1
  215. package/lib/src/core-components/src/utils/styling/index.js +5 -1
  216. package/lib/src/core-components/src/utils/styling/pxToRem.js +6 -1
  217. package/lib/src/core-components/src/utils/testing/getComputedStyle.js +3 -1
  218. package/lib/src/core-components/src/utils/testing/index.js +1 -1
  219. package/lib/src/core-components/src/utils/utility.util.js +14 -1
  220. package/lib/src/core-components/tailwind.config.js +233 -1
  221. package/lib/src/core-hooks/index.js +3 -1
  222. package/lib/src/core-hooks/src/useClickOutside/useClickOutside.hook.js +46 -1
  223. package/lib/src/core-hooks/src/useDebounce/useDebounce.hook.js +30 -1
  224. package/lib/src/core-hooks/src/usePreventEKey/usePreventEKey.hook.js +8 -1
  225. package/lib/src/core-utils/index.js +7 -1
  226. package/lib/src/core-utils/src/calculation/calculation.util.js +89 -1
  227. package/lib/src/core-utils/src/colors/color.util.js +15 -1
  228. package/lib/src/core-utils/src/convert/numberToWords/numToWords.util.js +145 -1
  229. package/lib/src/core-utils/src/convert/typography/camelCaseToTitleCase.util.js +5 -1
  230. package/lib/src/core-utils/src/form-helper/form-helper.util.js +82 -1
  231. package/lib/src/core-utils/src/index.js +7 -1
  232. package/lib/src/core-utils/src/utility/utility.util.js +12 -1
  233. package/lib/src/core-utils/src/uuid/uuid.util.js +8 -1
  234. package/package.json +1 -1
@@ -1 +1,73 @@
1
- "use strict";"use client";import{jsx as t,jsxs as u,Fragment as j}from"react/jsx-runtime";import{forwardRef as E,useCallback as w,useState as z,useEffect as B}from"react";import{MasonryContainer as G,MasonryColumn as V,MasonryItemWrapper as A,MasonryImage as D,ImagePlaceholder as v,EmptyState as J,MasonryCard as K,MasonryCardContent as O}from"./elements";import{useResponsiveValue as F,useColumnDistribution as Q,useImageLoading as U}from"./hooks";const X=()=>u("svg",{viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"1.5",children:[t("rect",{x:"3",y:"3",width:"7",height:"7",rx:"1"}),t("rect",{x:"14",y:"3",width:"7",height:"7",rx:"1"}),t("rect",{x:"3",y:"14",width:"7",height:"7",rx:"1"}),t("rect",{x:"14",y:"14",width:"7",height:"7",rx:"1"})]});export const Masonry=E(function(m,g){const{items:r,columns:h=3,gutter:y=16,renderItem:f,sequential:p=!1,animationDuration:i=300,animated:x=!0,staggerDelay:a=50,classNames:o={},styles:n={},className:$,style:I,onImageLoad:s,onLayoutComplete:L,minItemHeight:k,loadingPlaceholder:Y,emptyState:H}=m,M=F(h,3),N=F(y,16),T=Q(r,M,p),{setLoading:d,isLoading:b}=U();let W=0;B(()=>{if(r.length>0){const e=setTimeout(()=>{L?.()},i+a*r.length);return()=>clearTimeout(e)}},[r,i,a,L]);const R=w((e,c)=>{const l=c.currentTarget;d(e.id,!1),s?.(e,l.naturalWidth,l.naturalHeight)},[d,s]),_=w((e,c,l)=>e.src?u(K,{$borderRadius:8,children:[b(e.id)&&t(v,{$height:e.height,$borderRadius:8}),t(D,{src:e.src,alt:e.alt||"",$objectFit:"cover",$borderRadius:0,$isLoading:b(e.id),onLoad:C=>R(e,C),onError:()=>d(e.id,!1)}),e.content&&t(O,{children:e.content})]}):e.content?e.content:null,[b,R,d]),P=f||_;return r.length===0?t(J,{className:o.root,style:n.root,children:H||u(j,{children:[t(X,{}),t("span",{children:"No items to display"})]})}):t(G,{ref:g,$gutter:N,className:$||o.root,style:{...n.root,...I},role:"grid","aria-label":"Masonry layout",children:T.map((e,c)=>t(V,{$gutter:N,$columnCount:M,className:o.column,style:n.column,role:"gridcell",children:e.map((l,C)=>{const q=W++;return t(A,{$animated:x,$animationDuration:i,$staggerIndex:q,$staggerDelay:a,$minHeight:k,className:o.item,style:n.item,children:P(l,C,c)},l.id)})},c))})});Masonry.displayName="Masonry";export const MasonryImageComponent=E(function(m,g){const{src:r,alt:h="",className:y,style:f,onLoad:p,onError:i,objectFit:x="cover",borderRadius:a=8}=m,[o,n]=z(!0),$=s=>{n(!1),p?.(s)},I=s=>{n(!1),i?.(s)};return u(j,{children:[o&&t(v,{$borderRadius:a}),t(D,{ref:g,src:r,alt:h,className:y,style:f,$objectFit:x,$borderRadius:a,$isLoading:o,onLoad:$,onError:I})]})});MasonryImageComponent.displayName="MasonryImage";
1
+ 'use client';
2
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
3
+ import { forwardRef, useCallback, useState, useEffect } from 'react';
4
+ import { MasonryContainer, MasonryColumn, MasonryItemWrapper, MasonryImage, ImagePlaceholder, EmptyState, MasonryCard, MasonryCardContent, } from './elements';
5
+ import { useResponsiveValue, useColumnDistribution, useImageLoading } from './hooks';
6
+ // Default empty icon
7
+ const EmptyIcon = () => (_jsxs("svg", { viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "1.5", children: [_jsx("rect", { x: "3", y: "3", width: "7", height: "7", rx: "1" }), _jsx("rect", { x: "14", y: "3", width: "7", height: "7", rx: "1" }), _jsx("rect", { x: "3", y: "14", width: "7", height: "7", rx: "1" }), _jsx("rect", { x: "14", y: "14", width: "7", height: "7", rx: "1" })] }));
8
+ export const Masonry = forwardRef(function MasonryComponent(props, ref) {
9
+ const { items, columns = 3, gutter = 16, renderItem, sequential = false, animationDuration = 300, animated = true, staggerDelay = 50, classNames = {}, styles = {}, className, style, onImageLoad, onLayoutComplete, minItemHeight, loadingPlaceholder, emptyState, } = props;
10
+ // Get responsive values
11
+ const columnCount = useResponsiveValue(columns, 3);
12
+ const gutterSize = useResponsiveValue(gutter, 16);
13
+ // Distribute items into columns
14
+ const columnData = useColumnDistribution(items, columnCount, sequential);
15
+ // Image loading state
16
+ const { setLoading, isLoading } = useImageLoading();
17
+ // Track global item index for stagger animation
18
+ let globalIndex = 0;
19
+ // Layout complete callback
20
+ useEffect(() => {
21
+ if (items.length > 0) {
22
+ const timeout = setTimeout(() => {
23
+ onLayoutComplete?.();
24
+ }, animationDuration + staggerDelay * items.length);
25
+ return () => clearTimeout(timeout);
26
+ }
27
+ }, [items, animationDuration, staggerDelay, onLayoutComplete]);
28
+ // Handle image load
29
+ const handleImageLoad = useCallback((item, e) => {
30
+ const img = e.currentTarget;
31
+ setLoading(item.id, false);
32
+ onImageLoad?.(item, img.naturalWidth, img.naturalHeight);
33
+ }, [setLoading, onImageLoad]);
34
+ // Default render function
35
+ const defaultRenderItem = useCallback((item, index, columnIndex) => {
36
+ if (item.src) {
37
+ // Image item
38
+ return (_jsxs(MasonryCard, { "$borderRadius": 8, children: [isLoading(item.id) && (_jsx(ImagePlaceholder, { "$height": item.height, "$borderRadius": 8 })), _jsx(MasonryImage, { src: item.src, alt: item.alt || '', "$objectFit": "cover", "$borderRadius": 0, "$isLoading": isLoading(item.id), onLoad: (e) => handleImageLoad(item, e), onError: () => setLoading(item.id, false) }), item.content && (_jsx(MasonryCardContent, { children: item.content }))] }));
39
+ }
40
+ // Content item
41
+ if (item.content) {
42
+ return item.content;
43
+ }
44
+ return null;
45
+ }, [isLoading, handleImageLoad, setLoading]);
46
+ // Use custom render or default
47
+ const render = renderItem || defaultRenderItem;
48
+ // Empty state
49
+ if (items.length === 0) {
50
+ return (_jsx(EmptyState, { className: classNames.root, style: styles.root, children: emptyState || (_jsxs(_Fragment, { children: [_jsx(EmptyIcon, {}), _jsx("span", { children: "No items to display" })] })) }));
51
+ }
52
+ return (_jsx(MasonryContainer, { ref: ref, "$gutter": gutterSize, className: className || classNames.root, style: { ...styles.root, ...style }, role: "grid", "aria-label": "Masonry layout", children: columnData.map((columnItems, columnIndex) => (_jsx(MasonryColumn, { "$gutter": gutterSize, "$columnCount": columnCount, className: classNames.column, style: styles.column, role: "gridcell", children: columnItems.map((item, itemIndex) => {
53
+ const currentGlobalIndex = globalIndex++;
54
+ return (_jsx(MasonryItemWrapper, { "$animated": animated, "$animationDuration": animationDuration, "$staggerIndex": currentGlobalIndex, "$staggerDelay": staggerDelay, "$minHeight": minItemHeight, className: classNames.item, style: styles.item, children: render(item, itemIndex, columnIndex) }, item.id));
55
+ }) }, columnIndex))) }));
56
+ });
57
+ // Display name
58
+ Masonry.displayName = 'Masonry';
59
+ // MasonryImage component for standalone use
60
+ export const MasonryImageComponent = forwardRef(function MasonryImageComponent(props, ref) {
61
+ const { src, alt = '', className, style, onLoad, onError, objectFit = 'cover', borderRadius = 8, } = props;
62
+ const [isLoading, setIsLoading] = useState(true);
63
+ const handleLoad = (e) => {
64
+ setIsLoading(false);
65
+ onLoad?.(e);
66
+ };
67
+ const handleError = (e) => {
68
+ setIsLoading(false);
69
+ onError?.(e);
70
+ };
71
+ return (_jsxs(_Fragment, { children: [isLoading && _jsx(ImagePlaceholder, { "$borderRadius": borderRadius }), _jsx(MasonryImage, { ref: ref, src: src, alt: alt, className: className, style: style, "$objectFit": objectFit, "$borderRadius": borderRadius, "$isLoading": isLoading, onLoad: handleLoad, onError: handleError })] }));
72
+ });
73
+ MasonryImageComponent.displayName = 'MasonryImage';
@@ -1,4 +1,7 @@
1
- "use strict";import{styled as t,css as n,keyframes as a}from"styled-components";import{tokens as e}from"../../utils/designTokens";const s=a`
1
+ import { styled, css, keyframes } from 'styled-components';
2
+ import { tokens } from '../../utils/designTokens';
3
+ // Animations
4
+ const fadeIn = keyframes `
2
5
  from {
3
6
  opacity: 0;
4
7
  transform: translateY(10px);
@@ -7,38 +10,44 @@
7
10
  opacity: 1;
8
11
  transform: translateY(0);
9
12
  }
10
- `,x=a`
13
+ `;
14
+ const shimmer = keyframes `
11
15
  0% {
12
16
  background-position: -200% 0;
13
17
  }
14
18
  100% {
15
19
  background-position: 200% 0;
16
20
  }
17
- `;export const MasonryContainer=t.div`
21
+ `;
22
+ export const MasonryContainer = styled.div `
18
23
  display: flex;
19
24
  width: 100%;
20
25
  box-sizing: border-box;
21
- gap: ${({$gutter:o})=>o}px;
22
- `,MasonryColumn=t.div`
26
+ gap: ${({ $gutter }) => $gutter}px;
27
+ `;
28
+ export const MasonryColumn = styled.div `
23
29
  display: flex;
24
30
  flex-direction: column;
25
31
  flex: 1;
26
32
  min-width: 0;
27
- gap: ${({$gutter:o})=>o}px;
28
- `,MasonryItemWrapper=t.div`
33
+ gap: ${({ $gutter }) => $gutter}px;
34
+ `;
35
+ export const MasonryItemWrapper = styled.div `
29
36
  width: 100%;
30
37
  box-sizing: border-box;
31
38
  overflow: hidden;
32
39
 
33
- ${({$minHeight:o})=>o&&n`
34
- min-height: ${o}px;
40
+ ${({ $minHeight }) => $minHeight &&
41
+ css `
42
+ min-height: ${$minHeight}px;
35
43
  `}
36
44
 
37
45
  /* Animation */
38
- ${({$animated:o,$animationDuration:i,$staggerIndex:r,$staggerDelay:p})=>o&&n`
46
+ ${({ $animated, $animationDuration, $staggerIndex, $staggerDelay }) => $animated &&
47
+ css `
39
48
  opacity: 0;
40
- animation: ${s} ${i}ms ease-out forwards;
41
- animation-delay: ${r*p}ms;
49
+ animation: ${fadeIn} ${$animationDuration}ms ease-out forwards;
50
+ animation-delay: ${$staggerIndex * $staggerDelay}ms;
42
51
  `}
43
52
 
44
53
  /* Reduce motion */
@@ -46,37 +55,41 @@
46
55
  animation: none;
47
56
  opacity: 1;
48
57
  }
49
- `,MasonryImage=t.img`
58
+ `;
59
+ export const MasonryImage = styled.img `
50
60
  width: 100%;
51
61
  height: auto;
52
62
  display: block;
53
- object-fit: ${({$objectFit:o})=>o};
54
- border-radius: ${({$borderRadius:o})=>typeof o=="number"?`${o}px`:o};
63
+ object-fit: ${({ $objectFit }) => $objectFit};
64
+ border-radius: ${({ $borderRadius }) => typeof $borderRadius === 'number' ? `${$borderRadius}px` : $borderRadius};
55
65
  transition: opacity 0.3s ease;
56
66
 
57
- ${({$isLoading:o})=>o&&n`
67
+ ${({ $isLoading }) => $isLoading &&
68
+ css `
58
69
  opacity: 0;
59
70
  `}
60
- `,ImagePlaceholder=t.div`
71
+ `;
72
+ export const ImagePlaceholder = styled.div `
61
73
  width: 100%;
62
- height: ${({$height:o})=>o?typeof o=="number"?`${o}px`:o:"200px"};
74
+ height: ${({ $height }) => $height ? (typeof $height === 'number' ? `${$height}px` : $height) : '200px'};
63
75
  background: linear-gradient(
64
76
  90deg,
65
- ${e.surface||"#f0f0f0"} 25%,
66
- ${e.outlineSoft||"#e5e5e5"} 50%,
67
- ${e.surface||"#f0f0f0"} 75%
77
+ ${tokens.surface || '#f0f0f0'} 25%,
78
+ ${tokens.outlineSoft || '#e5e5e5'} 50%,
79
+ ${tokens.surface || '#f0f0f0'} 75%
68
80
  );
69
81
  background-size: 400% 100%;
70
- animation: ${x} 1.5s ease-in-out infinite;
71
- border-radius: ${({$borderRadius:o})=>typeof o=="number"?`${o}px`:o};
72
- `,EmptyState=t.div`
82
+ animation: ${shimmer} 1.5s ease-in-out infinite;
83
+ border-radius: ${({ $borderRadius }) => typeof $borderRadius === 'number' ? `${$borderRadius}px` : $borderRadius};
84
+ `;
85
+ export const EmptyState = styled.div `
73
86
  display: flex;
74
87
  flex-direction: column;
75
88
  align-items: center;
76
89
  justify-content: center;
77
90
  padding: 48px 24px;
78
91
  text-align: center;
79
- color: ${e.onSurface?`${e.onSurface}80`:"#6b7280"};
92
+ color: ${tokens.onSurface ? `${tokens.onSurface}80` : '#6b7280'};
80
93
  font-size: 14px;
81
94
 
82
95
  svg {
@@ -85,9 +98,11 @@
85
98
  margin-bottom: 16px;
86
99
  opacity: 0.5;
87
100
  }
88
- `,MasonryCard=t.div`
101
+ `;
102
+ // Card style for default item rendering
103
+ export const MasonryCard = styled.div `
89
104
  background: white;
90
- border-radius: ${({$borderRadius:o})=>typeof o=="number"?`${o}px`:o};
105
+ border-radius: ${({ $borderRadius }) => typeof $borderRadius === 'number' ? `${$borderRadius}px` : $borderRadius};
91
106
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08), 0 1px 2px rgba(0, 0, 0, 0.06);
92
107
  overflow: hidden;
93
108
  transition: transform 0.2s ease, box-shadow 0.2s ease;
@@ -96,10 +111,12 @@
96
111
  transform: translateY(-2px);
97
112
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1), 0 2px 4px rgba(0, 0, 0, 0.06);
98
113
  }
99
- `,MasonryCardImage=t.img`
114
+ `;
115
+ export const MasonryCardImage = styled.img `
100
116
  width: 100%;
101
117
  height: auto;
102
118
  display: block;
103
- `,MasonryCardContent=t.div`
119
+ `;
120
+ export const MasonryCardContent = styled.div `
104
121
  padding: 12px 16px;
105
122
  `;
@@ -1 +1,100 @@
1
- "use strict";import{useState as c,useEffect as m,useCallback as f,useMemo as w}from"react";const g={xs:0,sm:640,md:768,lg:1024,xl:1280,"2xl":1536};export function useResponsiveValue(n,t){const[s,o]=c(()=>typeof n=="number"?n:h(n,t,typeof window<"u"?window.innerWidth:1024));return m(()=>{if(typeof n=="number"){o(n);return}const e=()=>{const r=window.innerWidth;o(h(n,t,r))};return e(),window.addEventListener("resize",e),()=>window.removeEventListener("resize",e)},[n,t]),s}function h(n,t,s){const o=Object.entries(g).sort(([,e],[,r])=>r-e);for(const[e,r]of o)if(s>=r&&n[e]!==void 0)return n[e];return t}export function useColumnDistribution(n,t,s=!1){return w(()=>{const o=Array.from({length:t},()=>[]);if(s)n.forEach((e,r)=>{const i=e.column!==void 0?Math.min(e.column,t-1):r%t;o[i].push(e)});else{const e=Array(t).fill(0);n.forEach(r=>{let i;r.column!==void 0?i=Math.min(r.column,t-1):i=e.indexOf(Math.min(...e)),o[i].push(r),e[i]++})}return o},[n,t,s])}export function useImageLoading(){const[n,t]=c({}),[s,o]=c(new Set),e=f((d,a)=>{t(u=>({...u,[d]:a})),a||o(u=>new Set(u).add(d))},[]),r=f(d=>n[d]??!0,[n]),i=f(d=>s.has(d),[s]);return{setLoading:e,isLoading:r,isLoaded:i}}
1
+ import { useState, useEffect, useCallback, useMemo } from 'react';
2
+ // Breakpoint values in pixels
3
+ const BREAKPOINT_VALUES = {
4
+ xs: 0,
5
+ sm: 640,
6
+ md: 768,
7
+ lg: 1024,
8
+ xl: 1280,
9
+ '2xl': 1536,
10
+ };
11
+ /**
12
+ * Hook to get responsive value based on current viewport width
13
+ */
14
+ export function useResponsiveValue(value, defaultValue) {
15
+ const [currentValue, setCurrentValue] = useState(() => {
16
+ if (typeof value === 'number')
17
+ return value;
18
+ return getResponsiveValue(value, defaultValue, typeof window !== 'undefined' ? window.innerWidth : 1024);
19
+ });
20
+ useEffect(() => {
21
+ if (typeof value === 'number') {
22
+ setCurrentValue(value);
23
+ return;
24
+ }
25
+ const handleResize = () => {
26
+ const width = window.innerWidth;
27
+ setCurrentValue(getResponsiveValue(value, defaultValue, width));
28
+ };
29
+ handleResize();
30
+ window.addEventListener('resize', handleResize);
31
+ return () => window.removeEventListener('resize', handleResize);
32
+ }, [value, defaultValue]);
33
+ return currentValue;
34
+ }
35
+ function getResponsiveValue(breakpoints, defaultValue, width) {
36
+ const sortedBreakpoints = Object.entries(BREAKPOINT_VALUES)
37
+ .sort(([, a], [, b]) => b - a);
38
+ for (const [key, breakpointWidth] of sortedBreakpoints) {
39
+ if (width >= breakpointWidth && breakpoints[key] !== undefined) {
40
+ return breakpoints[key];
41
+ }
42
+ }
43
+ return defaultValue;
44
+ }
45
+ /**
46
+ * Hook to distribute items into columns
47
+ */
48
+ export function useColumnDistribution(items, columnCount, sequential = false) {
49
+ return useMemo(() => {
50
+ const columns = Array.from({ length: columnCount }, () => []);
51
+ if (sequential) {
52
+ // Sequential: place items in order, filling columns one by one
53
+ items.forEach((item, index) => {
54
+ const columnIndex = item.column !== undefined
55
+ ? Math.min(item.column, columnCount - 1)
56
+ : index % columnCount;
57
+ columns[columnIndex].push(item);
58
+ });
59
+ }
60
+ else {
61
+ // Balanced: distribute items to shortest column
62
+ const columnHeights = Array(columnCount).fill(0);
63
+ items.forEach((item) => {
64
+ let targetColumn;
65
+ if (item.column !== undefined) {
66
+ // Respect specified column
67
+ targetColumn = Math.min(item.column, columnCount - 1);
68
+ }
69
+ else {
70
+ // Find shortest column
71
+ targetColumn = columnHeights.indexOf(Math.min(...columnHeights));
72
+ }
73
+ columns[targetColumn].push(item);
74
+ // Increment height (use 1 as placeholder, actual heights vary)
75
+ columnHeights[targetColumn]++;
76
+ });
77
+ }
78
+ return columns;
79
+ }, [items, columnCount, sequential]);
80
+ }
81
+ /**
82
+ * Hook to track image loading states
83
+ */
84
+ export function useImageLoading() {
85
+ const [loadingStates, setLoadingStates] = useState({});
86
+ const [loadedImages, setLoadedImages] = useState(new Set());
87
+ const setLoading = useCallback((id, isLoading) => {
88
+ setLoadingStates(prev => ({ ...prev, [id]: isLoading }));
89
+ if (!isLoading) {
90
+ setLoadedImages(prev => new Set(prev).add(id));
91
+ }
92
+ }, []);
93
+ const isLoading = useCallback((id) => {
94
+ return loadingStates[id] ?? true;
95
+ }, [loadingStates]);
96
+ const isLoaded = useCallback((id) => {
97
+ return loadedImages.has(id);
98
+ }, [loadedImages]);
99
+ return { setLoading, isLoading, isLoaded };
100
+ }
@@ -1 +1,3 @@
1
- "use strict";export{Masonry,MasonryImageComponent as MasonryImage}from"./Masonry";export*from"./types";export{useResponsiveValue,useColumnDistribution,useImageLoading}from"./hooks";
1
+ export { Masonry, MasonryImageComponent as MasonryImage } from './Masonry';
2
+ export * from './types';
3
+ export { useResponsiveValue, useColumnDistribution, useImageLoading } from './hooks';
@@ -1 +1 @@
1
- "use strict";export{};
1
+ export {};
@@ -70,6 +70,8 @@ export interface ModalProps {
70
70
  overlayOpacity?: number;
71
71
  /** Overlay background color */
72
72
  overlayColor?: string;
73
+ /** Base z-index for overlay/content stack */
74
+ zIndex?: number;
73
75
  /** Click overlay to close */
74
76
  closeOnOverlayClick?: boolean;
75
77
  /** Close on Escape key */
@@ -97,4 +99,4 @@ export interface ModalProps {
97
99
  /** Modal content */
98
100
  children: React.ReactNode;
99
101
  }
100
- export declare const Modal: ({ visible, title, className, contentClassName, headerClassName, style, contentStyle, onClose, isAutoClose, autoCloseDelay, size, position, showCloseButton, closeButton, overlayOpacity, overlayColor, closeOnOverlayClick, closeOnEscape, showHeader, headerBgColor, headerTextColor, borderRadius, maxWidth, contentPadding, headerPadding, animationDuration, classNames, styles, children, }: ModalProps) => React.JSX.Element | null;
102
+ export declare const Modal: ({ visible, title, className, contentClassName, headerClassName, style, contentStyle, onClose, isAutoClose, autoCloseDelay, size, position, showCloseButton, closeButton, overlayOpacity, overlayColor, zIndex, closeOnOverlayClick, closeOnEscape, showHeader, headerBgColor, headerTextColor, borderRadius, maxWidth, contentPadding, headerPadding, animationDuration, classNames, styles, children, }: ModalProps) => React.JSX.Element | null;
@@ -1 +1,123 @@
1
- "use strict";import{jsx as a,jsxs as y,Fragment as Q}from"react/jsx-runtime";import{useEffect as x,useState as M}from"react";import e from"../../../tc.module.css";import{cn as r}from"../../../utils";export const Modal=({visible:h,title:d="",className:E="",contentClassName:Y="",headerClassName:$="",style:R={},contentStyle:W={},onClose:t,isAutoClose:s=!1,autoCloseDelay:b=1e3,size:f="md",position:c="center",showCloseButton:v=!0,closeButton:_,overlayOpacity:B=.5,overlayColor:F,closeOnOverlayClick:I=!0,closeOnEscape:w=!0,showHeader:N=!0,headerBgColor:S,headerTextColor:k,borderRadius:p="0.5rem",maxWidth:H,contentPadding:P="1rem",headerPadding:q="1rem",animationDuration:i=300,classNames:n={},styles:o={},children:z})=>{const[m,j]=M(h),[u,T]=M(!1);x(()=>{h?(j(!0),setTimeout(()=>T(!0),10)):(T(!1),setTimeout(()=>j(!1),i))},[h,i]),x(()=>{if(m&&s){const g=setTimeout(()=>{t&&t()},typeof s=="number"?s:b);return()=>clearTimeout(g)}},[m,s,b,t]),x(()=>{if(!w||!m)return;const l=g=>{g.key==="Escape"&&t&&t()};return document.addEventListener("keydown",l),()=>document.removeEventListener("keydown",l)},[m,w,t]);const L=l=>{I&&l.target===l.currentTarget&&t&&t()},G=()=>{t&&t()},J={sm:"28rem",md:"32rem",lg:"42rem",xl:"56rem",full:"95%"},K={center:e["items-center"],top:e["items-start"],bottom:e["items-end"]},O=H||(f!=="full"?J[f]:"95%");return m?y(Q,{children:[a("div",{className:r(e.fixed,e["inset-0"],e["z-40"],e["bg-black"],n.overlay),style:{opacity:u?B:0,transition:`opacity ${i}ms ease-in-out`,backgroundColor:F||void 0,...o.overlay},onClick:L}),a("div",{className:r(e.flex,e["justify-center"],K[c],e["overflow-x-hidden"],e["overflow-y-auto"],e.fixed,e["inset-0"],e["z-50"],e["outline-none"],e["focus:outline-none"],E,n.container),style:{...R,transition:`opacity ${i}ms ease-in-out`,opacity:u?1:0,...o.container},onClick:L,children:a("div",{className:r(e.relative,e["w-full"],e["my-5"],e["mx-auto"],n.wrapper),style:{maxWidth:O,marginLeft:f==="full"?"1rem":void 0,marginRight:f==="full"?"1rem":void 0,transform:u?c==="center"?"scale(1)":"translateY(0)":c==="center"?"scale(0.95)":c==="top"?"translateY(-20px)":"translateY(20px)",transition:`transform ${i}ms ease-out, opacity ${i}ms ease-out`,opacity:u?1:0,...o.wrapper},onClick:l=>l.stopPropagation(),children:y("div",{className:r(e["border-0"],e["shadow-xl"],e.relative,e.flex,e["flex-col"],e["bg-white"],e["outline-none"],e["focus:outline-none"],Y,n.content),style:{borderRadius:p,...W,...o.content},children:[N&&y("div",{className:r(e.flex,e["items-center"],e["justify-between"],e["border-b"],e["border-solid"],e["border-gray-200"],$,n.header),style:{padding:q,backgroundColor:S,borderTopLeftRadius:p,borderTopRightRadius:p,borderBottom:d||v?void 0:"none",...o.header},children:[d&&a("h3",{className:r(e["text-xl"],e["font-semibold"],e["m-0"],e["flex-1"],n.title),style:{color:k,...o.title},children:d}),v&&a("button",{type:"button",className:r(e["p-1"],e["ml-4"],e["border-0"],e["bg-transparent"],e["cursor-pointer"],e["outline-none"],e["focus:outline-none"],e["transition-colors"],e["hover:bg-gray-100"],e.rounded,n.closeButton),onClick:G,"aria-label":"Close modal",style:{marginLeft:d?"1rem":0,marginRight:d?0:"auto",...o.closeButton},children:_||a("span",{className:r(e.block,e["text-2xl"],e["leading-none"],e["font-light"]),style:{color:k||"#1f2937",height:"1.5rem",width:"1.5rem",display:"flex",alignItems:"center",justifyContent:"center",lineHeight:1},children:"\xD7"})})]}),a("div",{className:r(e.flex,e["flex-col"],e["w-full"],e["h-auto"],e["overflow-y-auto"],n.body),style:{padding:P,...o.body},children:z})]})})})]}):null};
1
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
2
+ import { useEffect, useState } from 'react';
3
+ import s from '../../../tc.module.css';
4
+ import { cn } from '../../../utils';
5
+ export const Modal = ({ visible, title = '', className = '', contentClassName = '', headerClassName = '', style = {}, contentStyle = {}, onClose, isAutoClose = false, autoCloseDelay = 1000, size = 'md', position = 'center', showCloseButton = true, closeButton, overlayOpacity = 0.5, overlayColor, zIndex = 11000, closeOnOverlayClick = true, closeOnEscape = true, showHeader = true, headerBgColor, headerTextColor, borderRadius = '0.5rem', maxWidth, contentPadding = '1rem', headerPadding = '1rem', animationDuration = 300, classNames = {}, styles = {}, children, }) => {
6
+ const [showModal, setShowModal] = useState(visible);
7
+ const [isAnimating, setIsAnimating] = useState(false);
8
+ useEffect(() => {
9
+ if (visible) {
10
+ setShowModal(true);
11
+ setTimeout(() => setIsAnimating(true), 10);
12
+ }
13
+ else {
14
+ setIsAnimating(false);
15
+ setTimeout(() => setShowModal(false), animationDuration);
16
+ }
17
+ }, [visible, animationDuration]);
18
+ useEffect(() => {
19
+ if (showModal && isAutoClose) {
20
+ const delay = typeof isAutoClose === 'number' ? isAutoClose : autoCloseDelay;
21
+ const timer = setTimeout(() => {
22
+ onClose && onClose();
23
+ }, delay);
24
+ return () => clearTimeout(timer);
25
+ }
26
+ }, [showModal, isAutoClose, autoCloseDelay, onClose]);
27
+ useEffect(() => {
28
+ if (!closeOnEscape || !showModal)
29
+ return;
30
+ const handleEscape = (e) => {
31
+ if (e.key === 'Escape') {
32
+ onClose && onClose();
33
+ }
34
+ };
35
+ document.addEventListener('keydown', handleEscape);
36
+ return () => document.removeEventListener('keydown', handleEscape);
37
+ }, [showModal, closeOnEscape, onClose]);
38
+ const handleOverlayClick = (e) => {
39
+ if (closeOnOverlayClick && e.target === e.currentTarget) {
40
+ onClose && onClose();
41
+ }
42
+ };
43
+ const handleClose = () => {
44
+ onClose && onClose();
45
+ };
46
+ const sizeMaxWidths = {
47
+ sm: '28rem',
48
+ md: '32rem',
49
+ lg: '42rem',
50
+ xl: '56rem',
51
+ full: '95%',
52
+ };
53
+ const positionClasses = {
54
+ center: s['items-center'],
55
+ top: s['items-start'],
56
+ bottom: s['items-end'],
57
+ };
58
+ const modalMaxWidth = maxWidth || (size !== 'full' ? sizeMaxWidths[size] : '95%');
59
+ const baseZIndex = zIndex ?? 11000;
60
+ const overlayZIndex = styles.overlay?.zIndex ?? baseZIndex;
61
+ const containerZIndex = styles.container?.zIndex ??
62
+ (typeof style.zIndex === 'number' ? style.zIndex : undefined) ??
63
+ baseZIndex + 1;
64
+ if (!showModal)
65
+ return null;
66
+ return (_jsxs(_Fragment, { children: [_jsx("div", { className: cn(s['fixed'], s['inset-0'], s['z-40'], s['bg-black'], classNames.overlay), style: {
67
+ opacity: isAnimating ? overlayOpacity : 0,
68
+ transition: `opacity ${animationDuration}ms ease-in-out`,
69
+ backgroundColor: overlayColor || undefined,
70
+ zIndex: overlayZIndex,
71
+ ...styles.overlay,
72
+ }, onClick: handleOverlayClick }), _jsx("div", { className: cn(s['flex'], s['justify-center'], positionClasses[position], s['overflow-x-hidden'], s['overflow-y-auto'], s['fixed'], s['inset-0'], s['z-50'], s['outline-none'], s['focus:outline-none'], className, classNames.container), style: {
73
+ ...style,
74
+ transition: `opacity ${animationDuration}ms ease-in-out`,
75
+ opacity: isAnimating ? 1 : 0,
76
+ zIndex: containerZIndex,
77
+ ...styles.container,
78
+ }, onClick: handleOverlayClick, children: _jsx("div", { className: cn(s['relative'], s['w-full'], s['my-5'], s['mx-auto'], classNames.wrapper), style: {
79
+ maxWidth: modalMaxWidth,
80
+ marginLeft: size === 'full' ? '1rem' : undefined,
81
+ marginRight: size === 'full' ? '1rem' : undefined,
82
+ transform: isAnimating
83
+ ? position === 'center'
84
+ ? 'scale(1)'
85
+ : position === 'top'
86
+ ? 'translateY(0)'
87
+ : 'translateY(0)'
88
+ : position === 'center'
89
+ ? 'scale(0.95)'
90
+ : position === 'top'
91
+ ? 'translateY(-20px)'
92
+ : 'translateY(20px)',
93
+ transition: `transform ${animationDuration}ms ease-out, opacity ${animationDuration}ms ease-out`,
94
+ opacity: isAnimating ? 1 : 0,
95
+ ...styles.wrapper,
96
+ }, onClick: (e) => e.stopPropagation(), children: _jsxs("div", { className: cn(s['border-0'], s['shadow-xl'], s['relative'], s['flex'], s['flex-col'], s['bg-white'], s['outline-none'], s['focus:outline-none'], contentClassName, classNames.content), style: {
97
+ borderRadius,
98
+ ...contentStyle,
99
+ ...styles.content,
100
+ }, children: [showHeader && (_jsxs("div", { className: cn(s['flex'], s['items-center'], s['justify-between'], s['border-b'], s['border-solid'], s['border-gray-200'], headerClassName, classNames.header), style: {
101
+ padding: headerPadding,
102
+ backgroundColor: headerBgColor,
103
+ borderTopLeftRadius: borderRadius,
104
+ borderTopRightRadius: borderRadius,
105
+ borderBottom: title || showCloseButton ? undefined : 'none',
106
+ ...styles.header,
107
+ }, children: [title && (_jsx("h3", { className: cn(s['text-xl'], s['font-semibold'], s['m-0'], s['flex-1'], classNames.title), style: { color: headerTextColor, ...styles.title }, children: title })), showCloseButton && (_jsx("button", { type: "button", className: cn(s['p-1'], s['ml-4'], s['border-0'], s['bg-transparent'], s['cursor-pointer'], s['outline-none'], s['focus:outline-none'], s['transition-colors'], s['hover:bg-gray-100'], s['rounded'], classNames.closeButton), onClick: handleClose, "aria-label": "Close modal", style: {
108
+ marginLeft: title ? '1rem' : 0,
109
+ marginRight: title ? 0 : 'auto',
110
+ ...styles.closeButton,
111
+ }, children: closeButton || (_jsx("span", { className: cn(s['block'], s['text-2xl'], s['leading-none'], s['font-light']), style: {
112
+ color: headerTextColor || '#1f2937',
113
+ height: '1.5rem',
114
+ width: '1.5rem',
115
+ display: 'flex',
116
+ alignItems: 'center',
117
+ justifyContent: 'center',
118
+ lineHeight: 1,
119
+ }, children: "\u00D7" })) }))] })), _jsx("div", { className: cn(s['flex'], s['flex-col'], s['w-full'], s['h-auto'], s['overflow-y-auto'], classNames.body), style: {
120
+ padding: contentPadding,
121
+ ...styles.body,
122
+ }, children: children })] }) }) })] }));
123
+ };
@@ -1 +1,2 @@
1
- "use strict";export*from"./BasicModal/modal.component";export*from"./modal-confirm/modal-confirm.component";
1
+ export * from './BasicModal/modal.component';
2
+ export * from './modal-confirm/modal-confirm.component';