@solostylist/ui-kit 1.0.203 → 1.0.205

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 (365) hide show
  1. package/dist/ArrowUpward-CDLbIMHR.js +6 -0
  2. package/dist/Box-CCxGQYgC.js +46 -0
  3. package/dist/ButtonBase-BpUvp8ep.js +801 -0
  4. package/dist/ChevronLeft-C7DUyLoc.js +6 -0
  5. package/dist/ChevronRight-VFk57Tte.js +6 -0
  6. package/dist/Close-OtVsJy75.js +6 -0
  7. package/dist/ContentCopy-DHDP4d6g.js +6 -0
  8. package/dist/DefaultPropsProvider-DpRXvTbj.js +157 -0
  9. package/dist/Download-Bbx6BZUJ.js +6 -0
  10. package/dist/ExpandMore-BTC1yHzp.js +6 -0
  11. package/dist/Favorite-mcH9KX-m.js +6 -0
  12. package/dist/Menu-Dhh4e9H1.js +1662 -0
  13. package/dist/MenuItem-aaIy8lan.js +213 -0
  14. package/dist/Paper--8Q3qCqb.js +329 -0
  15. package/dist/Select-B5RvkbDO.js +2545 -0
  16. package/dist/Stack-D-aoKnaS.js +158 -0
  17. package/dist/Typography-CswuXQLF.js +187 -0
  18. package/dist/assets/s-carousel.css +1 -1
  19. package/dist/assets/s-overlay-scrollbar.css +10 -1
  20. package/dist/assets/stripe-input.css +1 -1
  21. package/dist/avatar-BVV8tT0K.js +10 -0
  22. package/dist/buttonBaseClasses-CzfJbQi5.js +13 -0
  23. package/dist/checkbox-Dd2nIREk.js +57 -0
  24. package/dist/chunk-efA98nb6.js +13 -0
  25. package/dist/createSimplePaletteValueFilter-dAWZ3p3z.js +14 -0
  26. package/dist/createSvgIcon-KjKEsKNV.js +153 -0
  27. package/dist/createTheme-DuS5_nJb.js +2430 -0
  28. package/dist/defaultTheme-DBynruYK.js +5 -0
  29. package/dist/entries/carousel.js +3 -4
  30. package/dist/entries/chat.js +3 -4
  31. package/dist/entries/code.js +3 -4
  32. package/dist/entries/core.js +56 -122
  33. package/dist/entries/dates.js +7 -12
  34. package/dist/entries/dropzone.js +3 -4
  35. package/dist/entries/editor.js +2 -4
  36. package/dist/entries/gallery.js +7 -13
  37. package/dist/entries/i18n.js +3 -7
  38. package/dist/entries/motion.js +14 -27
  39. package/dist/entries/scrollbar.js +2 -4
  40. package/dist/entries/stripe.js +6 -10
  41. package/dist/extendSxProp-YPyfzlEb.js +29 -0
  42. package/dist/generateUtilityClass-DdqZpZoW.js +34 -0
  43. package/dist/generateUtilityClasses-BMwEKe3O.js +10 -0
  44. package/dist/hooks/index.js +5 -11
  45. package/dist/hooks/use-count-down.js +85 -76
  46. package/dist/hooks/use-dialog.js +21 -18
  47. package/dist/hooks/use-is-passed-position.js +20 -20
  48. package/dist/hooks/use-popover.js +18 -18
  49. package/dist/hooks/use-scroll-animation.js +74 -56
  50. package/dist/iconButtonClasses-ApDUTw5e.js +27 -0
  51. package/dist/identifier-_S1f0Pg2.js +190 -0
  52. package/dist/main.js +103 -196
  53. package/dist/mergeSlotProps-BG-pTgpj.js +48 -0
  54. package/dist/objectWithoutPropertiesLoose-BdL2_POW.js +23 -0
  55. package/dist/outlinedInputClasses-bgmdcolQ.js +43 -0
  56. package/dist/resolveProps-CcZ6Bxlf.js +30 -0
  57. package/dist/s-accordion/index.js +3 -4
  58. package/dist/s-accordion/s-accordion.js +3 -949
  59. package/dist/s-accordion-Da1IZflX.js +712 -0
  60. package/dist/s-action-overlay/index.js +2 -4
  61. package/dist/s-action-overlay/s-action-overlay.js +108 -109
  62. package/dist/s-autocomplete/index.js +2 -4
  63. package/dist/s-autocomplete/s-autocomplete.js +25 -31
  64. package/dist/s-avatar/index.js +2 -4
  65. package/dist/s-avatar/s-avatar.js +32 -22
  66. package/dist/s-blur-text/index.js +2 -4
  67. package/dist/s-blur-text/s-blur-text.js +67 -81
  68. package/dist/s-breadcrumbs/index.js +2 -3
  69. package/dist/s-breadcrumbs/s-breadcrumbs.js +49 -44
  70. package/dist/s-button/index.js +2 -4
  71. package/dist/s-button/s-button.js +11 -9
  72. package/dist/s-carousel/index.js +3 -4
  73. package/dist/s-carousel/s-carousel.js +3 -2480
  74. package/dist/s-carousel-BoDg9pKU.js +125 -0
  75. package/dist/s-category-card/index.js +1 -3
  76. package/dist/s-category-card/s-category-card.js +70 -105
  77. package/dist/s-chat-input/index.js +3 -4
  78. package/dist/s-chat-input/s-chat-input.js +3 -319
  79. package/dist/s-chat-input-v_XIZVGk.js +283 -0
  80. package/dist/s-chat-message/index.js +3 -4
  81. package/dist/s-chat-message/s-chat-message.js +3 -283
  82. package/dist/s-chat-message-CWtxsicj.js +281 -0
  83. package/dist/s-checkbox/index.js +2 -4
  84. package/dist/s-checkbox/s-checkbox.js +27 -17
  85. package/dist/s-chip/index.js +2 -4
  86. package/dist/s-chip/s-chip.js +11 -9
  87. package/dist/s-chips/index.js +2 -4
  88. package/dist/s-chips/s-chips.js +91 -86
  89. package/dist/s-code-block/index.js +3 -4
  90. package/dist/s-code-block/s-code-block.js +3 -1052
  91. package/dist/s-code-block-BqYdR0Em.js +608 -0
  92. package/dist/s-comment-message/index.js +3 -4
  93. package/dist/s-comment-message/s-comment-message.js +3 -123
  94. package/dist/s-comment-message-DDAHdQqY.js +195 -0
  95. package/dist/s-copyable-text/index.js +3 -4
  96. package/dist/s-copyable-text/s-copyable-text.js +50 -54
  97. package/dist/s-countdown/index.js +3 -5
  98. package/dist/s-countdown/s-count-box.js +102 -106
  99. package/dist/s-countdown/s-count-down.js +101 -109
  100. package/dist/s-data-table/index.js +3 -4
  101. package/dist/s-data-table/s-data-table.js +3 -1291
  102. package/dist/s-data-table-BjqqIsFX.js +893 -0
  103. package/dist/s-date-picker/index.js +3 -4
  104. package/dist/s-date-picker/s-date-picker.js +3 -1521
  105. package/dist/s-date-picker-BYqxsjPU.js +581 -0
  106. package/dist/s-datetime-picker/index.js +3 -4
  107. package/dist/s-datetime-picker/s-datetime-picker.js +3 -5180
  108. package/dist/s-datetime-picker-BtwGoxL3.js +3808 -0
  109. package/dist/s-dialog/index.js +2 -3
  110. package/dist/s-dialog/s-dialog.js +44 -36
  111. package/dist/s-dialog-confirm/index.js +3 -6
  112. package/dist/s-dialog-confirm/s-dialog-confirm.js +85 -74
  113. package/dist/s-dialog-message/index.js +3 -6
  114. package/dist/s-dialog-message/s-dialog-message.js +75 -66
  115. package/dist/s-empty/index.js +1 -3
  116. package/dist/s-empty/s-empty.js +13 -8
  117. package/dist/s-error/index.js +2 -4
  118. package/dist/s-error/s-error.js +31 -20
  119. package/dist/s-error-layout/index.js +2 -4
  120. package/dist/s-error-layout/s-error-layout.js +78 -56
  121. package/dist/s-file-dropzone/index.js +3 -4
  122. package/dist/s-file-dropzone/s-file-dropzone.js +3 -124
  123. package/dist/s-file-dropzone-BJBNFC_b.js +134 -0
  124. package/dist/s-file-icon/index.js +3 -4
  125. package/dist/s-file-icon/s-file-icon.js +327 -272
  126. package/dist/s-flex-box/index.js +3 -4
  127. package/dist/s-flex-box/s-flex-box.js +12 -8
  128. package/dist/s-form/index.js +2 -4
  129. package/dist/s-form/s-form.js +23 -15
  130. package/dist/s-gallery/index.js +3 -5
  131. package/dist/s-gallery/s-gallery.js +310 -346
  132. package/dist/s-glow-button/index.js +3 -4
  133. package/dist/s-glow-button/s-glow-button.js +29 -42
  134. package/dist/s-gradient-icon/index.js +2 -4
  135. package/dist/s-gradient-icon/s-gradient-icon.js +124 -79
  136. package/dist/s-i18n-provider/index.js +2 -4
  137. package/dist/s-i18n-provider/s-i18n-provider.js +23 -27
  138. package/dist/s-icon-button/index.js +2 -4
  139. package/dist/s-icon-button/s-icon-button.js +11 -8
  140. package/dist/s-image-comparison/index.js +3 -4
  141. package/dist/s-image-comparison/s-image-comparison.js +169 -207
  142. package/dist/s-image-modal/index.js +3 -5
  143. package/dist/s-image-modal/s-image-modal.js +396 -387
  144. package/dist/s-item-not-found/index.js +1 -3
  145. package/dist/s-item-not-found/s-item-not-found.js +240 -262
  146. package/dist/s-label/index.js +3 -4
  147. package/dist/s-label/s-label.js +3 -17
  148. package/dist/s-label-Bt4vQGGN.js +30 -0
  149. package/dist/s-language-switcher/index.js +3 -6
  150. package/dist/s-language-switcher/s-language-switcher.js +3 -252
  151. package/dist/s-language-switcher-BJP1r1la.js +198 -0
  152. package/dist/s-lazy-image/index.js +2 -4
  153. package/dist/s-lazy-image/s-lazy-image.js +41 -56
  154. package/dist/s-link/index.js +2 -4
  155. package/dist/s-link/s-link.js +30 -37
  156. package/dist/s-localization-provider/index.js +3 -4
  157. package/dist/s-localization-provider/s-localization-provider.js +3 -562
  158. package/dist/s-localization-provider-CeOR72Ti.js +537 -0
  159. package/dist/s-moving-border/index.js +1 -3
  160. package/dist/s-moving-border/s-moving-border.js +117 -131
  161. package/dist/s-multi-select/index.js +3 -4
  162. package/dist/s-multi-select/s-multi-select.js +3 -82
  163. package/dist/s-multi-select-xKP4heeG.js +64 -0
  164. package/dist/s-no-ssr/index.js +2 -4
  165. package/dist/s-no-ssr/s-no-ssr.js +13 -14
  166. package/dist/s-overlay-scrollbar/index.js +2 -4
  167. package/dist/s-overlay-scrollbar/s-overlay-scrollbar.js +34 -37
  168. package/dist/s-pagination/index.js +2 -4
  169. package/dist/s-pagination/s-pagination.js +32 -15
  170. package/dist/s-pixel-reveal/index.js +3 -4
  171. package/dist/s-pixel-reveal/s-pixel-reveal.js +138 -156
  172. package/dist/s-radial-pulse-animate/index.js +3 -4
  173. package/dist/s-radial-pulse-animate/s-radial-pulse-animate.js +80 -122
  174. package/dist/s-rating/index.js +1 -3
  175. package/dist/s-rating/s-rating.js +11 -9
  176. package/dist/s-review/index.js +3 -4
  177. package/dist/s-review/s-review.js +3 -160
  178. package/dist/s-review-DOBlCEU2.js +241 -0
  179. package/dist/s-scroll-reveal/index.js +2 -4
  180. package/dist/s-scroll-reveal/s-scroll-reveal.js +68 -64
  181. package/dist/s-scroll-to-top/index.js +3 -4
  182. package/dist/s-scroll-to-top/s-scroll-to-top.js +45 -44
  183. package/dist/s-scroll-velocity/index.js +4 -8
  184. package/dist/s-scroll-velocity/s-scroll-velocity.js +14 -8
  185. package/dist/s-scroll-velocity/scroll-velocity-container.js +25 -30
  186. package/dist/s-scroll-velocity/scroll-velocity-row.js +97 -118
  187. package/dist/s-select/index.js +3 -4
  188. package/dist/s-select/s-select.js +3 -112
  189. package/dist/s-select-DXbeZ0CG.js +110 -0
  190. package/dist/s-select-list/index.js +2 -4
  191. package/dist/s-select-list/s-select-list.js +44 -49
  192. package/dist/s-skeleton/index.js +2 -4
  193. package/dist/s-skeleton/s-skeleton.js +69 -35
  194. package/dist/s-snackbar-message/index.js +2 -6
  195. package/dist/s-snackbar-message/s-snackbar-message.js +48 -61
  196. package/dist/s-spotlight-cursor/index.js +2 -4
  197. package/dist/s-spotlight-cursor/s-spotlight-cursor.js +58 -61
  198. package/dist/s-stripe/index.js +6 -10
  199. package/dist/s-stripe/s-stripe-cvc.js +14 -10
  200. package/dist/s-stripe/s-stripe-expiry.js +14 -10
  201. package/dist/s-stripe/s-stripe-number.js +14 -10
  202. package/dist/s-stripe/s-stripe.js +31 -37
  203. package/dist/s-stripe/stripe-input.js +57 -81
  204. package/dist/s-switch/index.js +1 -3
  205. package/dist/s-switch/s-switch.js +27 -17
  206. package/dist/s-tabs/index.js +4 -8
  207. package/dist/s-tabs/s-tab-panel.js +23 -29
  208. package/dist/s-tabs/s-tab.js +11 -8
  209. package/dist/s-tabs/s-tabs.js +39 -35
  210. package/dist/s-text-editor/index.js +3 -5
  211. package/dist/s-text-editor/s-text-editor-toolbar.js +3 -207
  212. package/dist/s-text-editor/s-text-editor.js +75 -81
  213. package/dist/s-text-editor-toolbar-BDDttdIt.js +177 -0
  214. package/dist/s-text-field/index.js +3 -4
  215. package/dist/s-text-field/s-text-field.js +3 -49
  216. package/dist/s-text-field-ni42E-1x.js +41 -0
  217. package/dist/s-text-shimmer/index.js +3 -4
  218. package/dist/s-text-shimmer/s-text-shimmer.js +31 -32
  219. package/dist/s-text-truncation/index.js +1 -3
  220. package/dist/s-text-truncation/s-text-truncation.js +79 -81
  221. package/dist/s-theme-demo/index.js +3 -4
  222. package/dist/s-theme-demo/s-theme-demo.js +3 -380
  223. package/dist/s-theme-demo-B4pz6fse.js +828 -0
  224. package/dist/s-theme-provider/index.js +3 -4
  225. package/dist/s-theme-provider/s-theme-provider.js +35 -50
  226. package/dist/s-theme-switch/index.js +3 -4
  227. package/dist/s-theme-switch/s-theme-switch.js +3 -41
  228. package/dist/s-theme-switch-CCEdponC.js +37 -0
  229. package/dist/s-tip/index.js +3 -4
  230. package/dist/s-tip/s-tip.js +3 -34
  231. package/dist/s-tip-CG51Q6oR.js +34 -0
  232. package/dist/s-tool-bar/index.js +3 -4
  233. package/dist/s-tool-bar/s-tool-bar.js +3 -478
  234. package/dist/s-tool-bar-C2lZhhJm.js +404 -0
  235. package/dist/s-two-pane-layout/index.js +2 -3
  236. package/dist/s-two-pane-layout/s-two-pane-layout.js +102 -101
  237. package/dist/s-typewriter-text/index.js +2 -4
  238. package/dist/s-typewriter-text/s-typewriter-text.js +39 -45
  239. package/dist/s-zoom-image/index.js +1 -3
  240. package/dist/s-zoom-image/s-zoom-image.js +62 -88
  241. package/dist/select-D9KH9LAz.js +11 -0
  242. package/dist/styled-Dz7rwAje.js +168 -0
  243. package/dist/svgIconClasses-CygVMw0E.js +20 -0
  244. package/dist/tabClasses-CIRFQ-PB.js +21 -0
  245. package/dist/theme/components/accordion-details.js +7 -8
  246. package/dist/theme/components/accordion-summary.js +12 -17
  247. package/dist/theme/components/accordion.js +24 -32
  248. package/dist/theme/components/alert.js +45 -72
  249. package/dist/theme/components/app-bar.js +12 -18
  250. package/dist/theme/components/autocomplete.js +19 -30
  251. package/dist/theme/components/avatar.js +3 -13
  252. package/dist/theme/components/backdrop.js +13 -12
  253. package/dist/theme/components/button-base.js +12 -14
  254. package/dist/theme/components/button.js +92 -138
  255. package/dist/theme/components/card-actions.js +4 -10
  256. package/dist/theme/components/card-content.js +4 -11
  257. package/dist/theme/components/card-header.js +4 -10
  258. package/dist/theme/components/card.js +23 -35
  259. package/dist/theme/components/checkbox.js +3 -65
  260. package/dist/theme/components/chip.js +67 -106
  261. package/dist/theme/components/components.js +112 -111
  262. package/dist/theme/components/container.js +4 -6
  263. package/dist/theme/components/dialog-actions.js +4 -10
  264. package/dist/theme/components/dialog.js +11 -17
  265. package/dist/theme/components/drawer.js +4 -10
  266. package/dist/theme/components/form-control.js +4 -10
  267. package/dist/theme/components/form-label.js +7 -11
  268. package/dist/theme/components/icon-button.js +82 -132
  269. package/dist/theme/components/icon.js +9 -21
  270. package/dist/theme/components/input-adornment.js +7 -13
  271. package/dist/theme/components/input-base.js +10 -16
  272. package/dist/theme/components/linear-progress.js +11 -16
  273. package/dist/theme/components/link.js +31 -37
  274. package/dist/theme/components/list-item-button.js +27 -44
  275. package/dist/theme/components/list-item-icon.js +4 -10
  276. package/dist/theme/components/list-item-text.js +14 -16
  277. package/dist/theme/components/list-item.js +12 -20
  278. package/dist/theme/components/list-subheader.js +10 -14
  279. package/dist/theme/components/list.js +9 -13
  280. package/dist/theme/components/menu-item.js +7 -8
  281. package/dist/theme/components/menu.js +20 -22
  282. package/dist/theme/components/outlined-input.js +41 -64
  283. package/dist/theme/components/pagination-item.js +8 -18
  284. package/dist/theme/components/paper.js +4 -8
  285. package/dist/theme/components/popover.js +11 -13
  286. package/dist/theme/components/rating.js +4 -8
  287. package/dist/theme/components/select.js +3 -13
  288. package/dist/theme/components/skeleton.js +4 -10
  289. package/dist/theme/components/slider.js +4 -8
  290. package/dist/theme/components/step-connector.js +9 -13
  291. package/dist/theme/components/step-icon.js +39 -46
  292. package/dist/theme/components/step-label.js +7 -13
  293. package/dist/theme/components/svg-icon.js +20 -37
  294. package/dist/theme/components/tab.js +20 -34
  295. package/dist/theme/components/table-cell.js +4 -10
  296. package/dist/theme/components/table-pagination.js +14 -18
  297. package/dist/theme/components/tabs.js +20 -24
  298. package/dist/theme/components/toggle-button-group.js +3 -23
  299. package/dist/theme/components/toggle-button.js +3 -21
  300. package/dist/theme/components/tooltip.js +23 -23
  301. package/dist/theme/theme-primitives.js +3 -410
  302. package/dist/theme-primitives-BG66N-x4.js +398 -0
  303. package/dist/toggle-button-BI6z89CX.js +26 -0
  304. package/dist/toggle-button-group-Dzzh9mXv.js +28 -0
  305. package/dist/typographyClasses-C0nDz5e6.js +32 -0
  306. package/dist/useControlled-CvWtMQJF.js +32 -0
  307. package/dist/useEnhancedEffect-NLLl34XR.js +5 -0
  308. package/dist/useFormControl-ngLNi8dL.js +11 -0
  309. package/dist/useMobilePicker-DdH0AzNe.js +10635 -0
  310. package/dist/useTheme-BES_k_99.js +34 -0
  311. package/dist/useThemeProps-CJRFdjVv.js +19 -0
  312. package/dist/utils/dayjs.js +161 -113
  313. package/dist/utils/index.js +3 -11
  314. package/dist/utils/logger.js +45 -46
  315. package/dist/utils-Cu16ybRR.js +72 -0
  316. package/dist/warning-D7iWhOZI.js +110 -0
  317. package/package.json +29 -29
  318. package/dist/ArrowUpward-D8eqD-si.js +0 -8
  319. package/dist/Box-BkXoTbe8.js +0 -62
  320. package/dist/ButtonBase-D73M0QY5.js +0 -1099
  321. package/dist/ChevronLeft-BmgmPHp9.js +0 -8
  322. package/dist/ChevronRight-DbWSr8yz.js +0 -8
  323. package/dist/Close-lHCUMitI.js +0 -8
  324. package/dist/ContentCopy-D4SuJd86.js +0 -11
  325. package/dist/DefaultPropsProvider-DPuuPIbS.js +0 -64
  326. package/dist/Download-BoRQUwCf.js +0 -8
  327. package/dist/ExpandMore-C7yRQv1-.js +0 -8
  328. package/dist/Favorite-Bz_HcMgN.js +0 -8
  329. package/dist/Menu-GVFDMHCN.js +0 -2441
  330. package/dist/MenuItem-2wG8I2HO.js +0 -269
  331. package/dist/Paper-CR019bki.js +0 -553
  332. package/dist/Select-D2l9rDWL.js +0 -3966
  333. package/dist/Stack-Dfjnuorw.js +0 -174
  334. package/dist/Typography-PcmlIqm1.js +0 -253
  335. package/dist/_commonjsHelpers-ByX85dGu.js +0 -33
  336. package/dist/buttonBaseClasses-jtnoTmPn.js +0 -10
  337. package/dist/clsx-OuTLNxxd.js +0 -16
  338. package/dist/createSimplePaletteValueFilter-B7--0ryQ.js +0 -17
  339. package/dist/createSvgIcon-BkbeLOhM.js +0 -242
  340. package/dist/createTheme-DgoJyWM-.js +0 -2929
  341. package/dist/defaultTheme-CulFxfLR.js +0 -5
  342. package/dist/extendSxProp-BJEIxcAx.js +0 -36
  343. package/dist/generateUtilityClass-BhfUaMgk.js +0 -35
  344. package/dist/generateUtilityClasses-E9gROIFd.js +0 -10
  345. package/dist/iconButtonClasses-BMfIhNTh.js +0 -10
  346. package/dist/identifier-BKLqN993.js +0 -4
  347. package/dist/index-D3G5Rwl-.js +0 -211
  348. package/dist/index-DtGYsHSv.js +0 -94
  349. package/dist/jsx-runtime-tc70JA_2.js +0 -264
  350. package/dist/mergeSlotProps-CuzBQdlp.js +0 -62
  351. package/dist/objectWithoutPropertiesLoose-DiWPeE4c.js +0 -22
  352. package/dist/outlinedInputClasses-DnwW3ujt.js +0 -19
  353. package/dist/resolveProps-BDH0VJjn.js +0 -39
  354. package/dist/styled-8Y5KoVix.js +0 -203
  355. package/dist/svgIconClasses-C6auqaBA.js +0 -10
  356. package/dist/tabClasses-DFvXsFrN.js +0 -10
  357. package/dist/typographyClasses-jmoWZuXc.js +0 -10
  358. package/dist/useControlled-D1L5tREc.js +0 -31
  359. package/dist/useEnhancedEffect-CJGo-L3B.js +0 -5
  360. package/dist/useFormControl-CatNKXAi.js +0 -10
  361. package/dist/useMobilePicker-B-bNHHXB.js +0 -13498
  362. package/dist/useTheme-CWPkv7g3.js +0 -18
  363. package/dist/useThemeProps-XYgXGzjS.js +0 -27
  364. package/dist/utils-D1UMIV0b.js +0 -40
  365. package/dist/warning-Ba-7BBAN.js +0 -135
@@ -1,347 +1,311 @@
1
- import { j as r } from "../jsx-runtime-tc70JA_2.js";
2
- import { useState as g, useId as $, useEffect as b, useRef as D } from "react";
3
- import { Box as p, Paper as w, Skeleton as V, Typography as j } from "@mui/material";
4
- import { AnimatePresence as E, motion as I } from "framer-motion";
5
- import { SImageModal as M } from "../s-image-modal/s-image-modal.js";
6
- import F from "../s-lazy-image/s-lazy-image.js";
7
- const A = ({ item: s, sx: o, onClick: i }) => {
8
- const e = D(null), [l, c] = g(!1), [u, f] = g(!0);
9
- return b(() => {
10
- const d = {
11
- root: null,
12
- rootMargin: "50px",
13
- // Start loading 50px before entering viewport
14
- threshold: 0.1
15
- // Trigger when 10% of video is visible
16
- }, h = new IntersectionObserver((t) => {
17
- t.forEach((a) => c(a.isIntersecting));
18
- }, d), n = e.current;
19
- return n && h.observe(n), () => {
20
- n && h.unobserve(n);
21
- };
22
- }, []), b(() => {
23
- let d = !0;
24
- const h = async () => {
25
- if (!(!e.current || !l || !d))
26
- try {
27
- e.current.readyState >= 3 ? (f(!1), await e.current.play()) : (f(!0), await new Promise((t) => {
28
- e.current && (e.current.oncanplay = () => t());
29
- }), d && (f(!1), await e.current.play()));
30
- } catch (t) {
31
- console.warn("Video playback failed:", t);
32
- }
33
- }, n = e.current;
34
- return l ? h() : n && n.pause(), () => {
35
- d = !1, n && (n.pause(), n.removeAttribute("src"), n.load());
36
- };
37
- }, [l]), s.type === "video" ? /* @__PURE__ */ r.jsxs(
38
- p,
39
- {
40
- sx: {
41
- position: "relative",
42
- overflow: "hidden",
43
- width: "100%",
44
- height: "100%",
45
- ...o
46
- },
47
- children: [
48
- /* @__PURE__ */ r.jsx(
49
- p,
50
- {
51
- component: "video",
52
- ref: e,
53
- onClick: i,
54
- playsInline: !0,
55
- muted: !0,
56
- loop: !0,
57
- preload: "auto",
58
- sx: {
59
- width: "100%",
60
- height: "100%",
61
- objectFit: "cover",
62
- opacity: u ? 0.8 : 1,
63
- transition: "opacity 0.2s",
64
- transform: "translateZ(0)",
65
- willChange: "transform",
66
- display: "block"
67
- },
68
- children: /* @__PURE__ */ r.jsx("source", { src: s.url, type: "video/mp4" })
69
- }
70
- ),
71
- u && /* @__PURE__ */ r.jsx(
72
- p,
73
- {
74
- sx: {
75
- position: "absolute",
76
- inset: 0,
77
- display: "flex",
78
- alignItems: "center",
79
- justifyContent: "center",
80
- bgcolor: "action.disabled"
81
- },
82
- children: /* @__PURE__ */ r.jsx(
83
- p,
84
- {
85
- sx: {
86
- width: 24,
87
- height: 24,
88
- borderRadius: "50%",
89
- border: "2px solid",
90
- borderColor: "divider",
91
- borderTopColor: "primary.main",
92
- animation: "spin 0.8s linear infinite",
93
- "@keyframes spin": {
94
- to: { transform: "rotate(360deg)" }
95
- }
96
- }
97
- }
98
- )
99
- }
100
- )
101
- ]
102
- }
103
- ) : /* @__PURE__ */ r.jsx(p, { onClick: i, sx: { width: "100%", height: "100%", ...o }, children: /* @__PURE__ */ r.jsx(
104
- F,
105
- {
106
- src: s.url,
107
- alt: s.title ?? "",
108
- width: "100%",
109
- height: "100%",
110
- style: {
111
- objectFit: o?.objectFit ? o.objectFit : "cover",
112
- cursor: i ? "pointer" : "default",
113
- display: "block",
114
- width: "100%",
115
- height: "100%"
116
- }
117
- }
118
- ) });
119
- }, k = (s, o) => {
120
- let i = 1, e = 2;
121
- switch (o) {
122
- case "grid":
123
- i = 1, e = 2;
124
- break;
125
- case "masonry":
126
- i = 1, e = s % 3 === 0 ? 3 : s % 2 === 0 ? 2 : 4;
127
- break;
128
- case "spotlight":
129
- s === 0 ? (i = 2, e = 4) : (i = 1, e = 2);
130
- break;
131
- case "featured":
132
- s === 0 ? (i = 2, e = 6) : (i = 1, e = 2);
133
- break;
134
- case "highlight":
135
- s === 0 ? (i = 3, e = 6) : (i = 1, e = 2);
136
- break;
137
- case "custom":
138
- i = 1, e = 2;
139
- break;
140
- }
141
- return { colSpan: i, rowSpan: e };
142
- }, S = (s, o) => o === "custom" ? s : s.map((i, e) => {
143
- const { colSpan: l, rowSpan: c } = k(e, o);
144
- return { ...i, colSpan: l, rowSpan: c };
145
- }), B = ({
146
- mediaItems: s,
147
- variant: o = "masonry",
148
- loading: i = !1,
149
- skeletonCount: e = 6
150
- }) => {
151
- const [l, c] = g(null), [u, f] = g(() => S(s, o)), [d, h] = g(!1), n = $();
152
- return b(() => {
153
- f(S(s, o));
154
- }, [s, o]), /* @__PURE__ */ r.jsxs(p, { sx: { width: "100%", position: "relative", zIndex: 1 }, children: [
155
- /* @__PURE__ */ r.jsx(
156
- M,
157
- {
158
- selectedItem: l,
159
- isOpen: !!l,
160
- onClose: () => c(null),
161
- onItemChange: c,
162
- mediaItems: u
163
- }
164
- ),
165
- /* @__PURE__ */ r.jsx(E, { mode: "wait", children: !l && /* @__PURE__ */ r.jsx(
166
- I.div,
167
- {
168
- initial: "hidden",
169
- animate: "visible",
170
- exit: "hidden",
171
- variants: {
172
- hidden: { opacity: 0 },
173
- visible: {
174
- opacity: 1,
175
- transition: { staggerChildren: 0.1 }
176
- // Stagger child animations
177
- }
178
- },
179
- children: /* @__PURE__ */ r.jsx(
180
- p,
181
- {
182
- sx: {
183
- display: "grid",
184
- gridTemplateColumns: {
185
- xs: "1fr",
186
- sm: "repeat(3, 1fr)",
187
- md: "repeat(4, 1fr)"
188
- },
189
- gap: 1.5,
190
- gridAutoRows: "60px",
191
- position: "relative"
192
- // Ensure proper stacking context
193
- },
194
- children: i ? Array.from({ length: e }).map((t, a) => {
195
- const { colSpan: x, rowSpan: y } = k(a, o);
196
- return /* @__PURE__ */ r.jsx(
197
- w,
198
- {
199
- sx: {
200
- position: "relative",
201
- overflow: "hidden",
202
- borderRadius: 2,
203
- gridRow: `span ${y}`,
204
- gridColumn: `span ${x}`
205
- },
206
- children: /* @__PURE__ */ r.jsx(
207
- V,
208
- {
209
- variant: "rectangular",
210
- animation: "wave",
211
- sx: {
212
- width: "100%",
213
- height: "100%",
214
- transform: "none"
215
- }
216
- }
217
- )
218
- },
219
- a
220
- );
221
- }) : u.map((t, a) => /* @__PURE__ */ r.jsx(
222
- I.div,
223
- {
224
- layoutId: `media-${t.id}-${n}`,
225
- onClick: () => !d && c(t),
226
- variants: {
227
- hidden: { y: 50, scale: 0.9, opacity: 0 },
228
- visible: {
229
- y: 0,
230
- scale: 1,
231
- opacity: 1,
232
- transition: {
233
- type: "spring",
234
- stiffness: 350,
235
- damping: 25,
236
- delay: a * 0.05
237
- }
238
- }
239
- },
240
- whileHover: { filter: "brightness(1.1)", zIndex: 10 },
241
- drag: !0,
242
- dragConstraints: { left: 0, right: 0, top: 0, bottom: 0 },
243
- dragElastic: 1,
244
- onDragStart: () => h(!0),
245
- onDragEnd: (x, y) => {
246
- h(!1);
247
- const v = y.offset.x + y.offset.y;
248
- if (Math.abs(v) > 50) {
249
- const m = [...u], C = m[a], R = v > 0 ? Math.min(a + 1, u.length - 1) : Math.max(a - 1, 0);
250
- m.splice(a, 1), m.splice(R, 0, C), f(m);
251
- }
252
- },
253
- style: {
254
- position: "relative",
255
- gridRow: t.rowSpan ? `span ${t.rowSpan}` : "span 2",
256
- gridColumn: t.colSpan ? `span ${t.colSpan}` : "span 1"
257
- },
258
- children: /* @__PURE__ */ r.jsxs(
259
- w,
260
- {
261
- sx: {
262
- position: "relative",
263
- overflow: "hidden",
264
- borderRadius: 2,
265
- width: "100%",
266
- height: "100%",
267
- cursor: "grab",
268
- "&:active": { cursor: "grabbing" },
269
- "&:hover .hover-overlay": {
270
- opacity: 1
271
- }
272
- },
273
- children: [
274
- /* @__PURE__ */ r.jsx(
275
- A,
276
- {
277
- item: t,
278
- sx: { position: "absolute", inset: 0, width: "100%", height: "100%" },
279
- onClick: () => !d && c(t)
280
- }
281
- ),
282
- (t.title || t.desc) && /* @__PURE__ */ r.jsxs(
283
- p,
284
- {
285
- className: "hover-overlay",
286
- sx: {
287
- position: "absolute",
288
- inset: 0,
289
- display: "flex",
290
- flexDirection: "column",
291
- justifyContent: "flex-end",
292
- padding: 1.5,
293
- pointerEvents: "none",
294
- // Prevent blocking clicks
295
- opacity: 0,
296
- transition: "opacity 0.2s ease-in-out",
297
- backdropFilter: "blur(8px)"
298
- },
299
- children: [
300
- t.title && /* @__PURE__ */ r.jsx(
301
- j,
302
- {
303
- variant: "subtitle2",
304
- sx: {
305
- position: "relative",
306
- whiteSpace: "nowrap",
307
- overflow: "hidden",
308
- textOverflow: "ellipsis"
309
- },
310
- children: t.title
311
- }
312
- ),
313
- t.desc && /* @__PURE__ */ r.jsx(
314
- j,
315
- {
316
- variant: "caption",
317
- sx: {
318
- position: "relative",
319
- display: "-webkit-box",
320
- WebkitLineClamp: 2,
321
- WebkitBoxOrient: "vertical",
322
- overflow: "hidden"
323
- },
324
- children: t.desc
325
- }
326
- )
327
- ]
328
- }
329
- )
330
- ]
331
- }
332
- )
333
- },
334
- `${t.id}-${n}`
335
- ))
336
- }
337
- )
338
- }
339
- ) })
340
- ] });
341
- };
342
- B.displayName = "SGallery";
343
- export {
344
- A as MediaItem,
345
- B as SGallery,
346
- B as default
1
+ import "../createTheme-DuS5_nJb.js";
2
+ import e from "../s-lazy-image/s-lazy-image.js";
3
+ import { SImageModal as t } from "../s-image-modal/s-image-modal.js";
4
+ import { useEffect as n, useId as r, useRef as i, useState as a } from "react";
5
+ import { jsx as o, jsxs as s } from "react/jsx-runtime";
6
+ import { Box as c, Paper as l, Skeleton as u, Typography as d } from "@mui/material";
7
+ import { AnimatePresence as f, motion as p } from "framer-motion";
8
+ //#region lib/s-gallery/s-gallery.tsx
9
+ var m = ({ item: t, sx: r, onClick: l }) => {
10
+ let u = i(null), [d, f] = a(!1), [p, m] = a(!0);
11
+ return n(() => {
12
+ let e = new IntersectionObserver((e) => {
13
+ e.forEach((e) => f(e.isIntersecting));
14
+ }, {
15
+ root: null,
16
+ rootMargin: "50px",
17
+ threshold: .1
18
+ }), t = u.current;
19
+ return t && e.observe(t), () => {
20
+ t && e.unobserve(t);
21
+ };
22
+ }, []), n(() => {
23
+ let e = !0, t = async () => {
24
+ if (!(!u.current || !d || !e)) try {
25
+ u.current.readyState >= 3 ? (m(!1), await u.current.play()) : (m(!0), await new Promise((e) => {
26
+ u.current && (u.current.oncanplay = () => e());
27
+ }), e && (m(!1), await u.current.play()));
28
+ } catch (e) {
29
+ console.warn("Video playback failed:", e);
30
+ }
31
+ }, n = u.current;
32
+ return d ? t() : n && n.pause(), () => {
33
+ e = !1, n && (n.pause(), n.removeAttribute("src"), n.load());
34
+ };
35
+ }, [d]), t.type === "video" ? /* @__PURE__ */ s(c, {
36
+ sx: {
37
+ position: "relative",
38
+ overflow: "hidden",
39
+ width: "100%",
40
+ height: "100%",
41
+ ...r
42
+ },
43
+ children: [/* @__PURE__ */ o(c, {
44
+ component: "video",
45
+ ref: u,
46
+ onClick: l,
47
+ playsInline: !0,
48
+ muted: !0,
49
+ loop: !0,
50
+ preload: "auto",
51
+ sx: {
52
+ width: "100%",
53
+ height: "100%",
54
+ objectFit: "cover",
55
+ opacity: p ? .8 : 1,
56
+ transition: "opacity 0.2s",
57
+ transform: "translateZ(0)",
58
+ willChange: "transform",
59
+ display: "block"
60
+ },
61
+ children: /* @__PURE__ */ o("source", {
62
+ src: t.url,
63
+ type: "video/mp4"
64
+ })
65
+ }), p && /* @__PURE__ */ o(c, {
66
+ sx: {
67
+ position: "absolute",
68
+ inset: 0,
69
+ display: "flex",
70
+ alignItems: "center",
71
+ justifyContent: "center",
72
+ bgcolor: "action.disabled"
73
+ },
74
+ children: /* @__PURE__ */ o(c, { sx: {
75
+ width: 24,
76
+ height: 24,
77
+ borderRadius: "50%",
78
+ border: "2px solid",
79
+ borderColor: "divider",
80
+ borderTopColor: "primary.main",
81
+ animation: "spin 0.8s linear infinite",
82
+ "@keyframes spin": { to: { transform: "rotate(360deg)" } }
83
+ } })
84
+ })]
85
+ }) : /* @__PURE__ */ o(c, {
86
+ onClick: l,
87
+ sx: {
88
+ width: "100%",
89
+ height: "100%",
90
+ ...r
91
+ },
92
+ children: /* @__PURE__ */ o(e, {
93
+ src: t.url,
94
+ alt: t.title ?? "",
95
+ width: "100%",
96
+ height: "100%",
97
+ style: {
98
+ objectFit: r?.objectFit ? r.objectFit : "cover",
99
+ cursor: l ? "pointer" : "default",
100
+ display: "block",
101
+ width: "100%",
102
+ height: "100%"
103
+ }
104
+ })
105
+ });
106
+ }, h = (e, t) => {
107
+ let n = 1, r = 2;
108
+ switch (t) {
109
+ case "grid":
110
+ n = 1, r = 2;
111
+ break;
112
+ case "masonry":
113
+ n = 1, r = e % 3 == 0 ? 3 : e % 2 == 0 ? 2 : 4;
114
+ break;
115
+ case "spotlight":
116
+ e === 0 ? (n = 2, r = 4) : (n = 1, r = 2);
117
+ break;
118
+ case "featured":
119
+ e === 0 ? (n = 2, r = 6) : (n = 1, r = 2);
120
+ break;
121
+ case "highlight":
122
+ e === 0 ? (n = 3, r = 6) : (n = 1, r = 2);
123
+ break;
124
+ case "custom":
125
+ n = 1, r = 2;
126
+ break;
127
+ }
128
+ return {
129
+ colSpan: n,
130
+ rowSpan: r
131
+ };
132
+ }, g = (e, t) => t === "custom" ? e : e.map((e, n) => {
133
+ let { colSpan: r, rowSpan: i } = h(n, t);
134
+ return {
135
+ ...e,
136
+ colSpan: r,
137
+ rowSpan: i
138
+ };
139
+ }), _ = ({ mediaItems: e, variant: i = "masonry", loading: _ = !1, skeletonCount: v = 6 }) => {
140
+ let [y, b] = a(null), [x, S] = a(() => g(e, i)), [C, w] = a(!1), T = r();
141
+ return n(() => {
142
+ S(g(e, i));
143
+ }, [e, i]), /* @__PURE__ */ s(c, {
144
+ sx: {
145
+ width: "100%",
146
+ position: "relative",
147
+ zIndex: 1
148
+ },
149
+ children: [/* @__PURE__ */ o(t, {
150
+ selectedItem: y,
151
+ isOpen: !!y,
152
+ onClose: () => b(null),
153
+ onItemChange: b,
154
+ mediaItems: x
155
+ }), /* @__PURE__ */ o(f, {
156
+ mode: "wait",
157
+ children: !y && /* @__PURE__ */ o(p.div, {
158
+ initial: "hidden",
159
+ animate: "visible",
160
+ exit: "hidden",
161
+ variants: {
162
+ hidden: { opacity: 0 },
163
+ visible: {
164
+ opacity: 1,
165
+ transition: { staggerChildren: .1 }
166
+ }
167
+ },
168
+ children: /* @__PURE__ */ o(c, {
169
+ sx: {
170
+ display: "grid",
171
+ gridTemplateColumns: {
172
+ xs: "1fr",
173
+ sm: "repeat(3, 1fr)",
174
+ md: "repeat(4, 1fr)"
175
+ },
176
+ gap: 1.5,
177
+ gridAutoRows: "60px",
178
+ position: "relative"
179
+ },
180
+ children: _ ? Array.from({ length: v }).map((e, t) => {
181
+ let { colSpan: n, rowSpan: r } = h(t, i);
182
+ return /* @__PURE__ */ o(l, {
183
+ sx: {
184
+ position: "relative",
185
+ overflow: "hidden",
186
+ borderRadius: 2,
187
+ gridRow: `span ${r}`,
188
+ gridColumn: `span ${n}`
189
+ },
190
+ children: /* @__PURE__ */ o(u, {
191
+ variant: "rectangular",
192
+ animation: "wave",
193
+ sx: {
194
+ width: "100%",
195
+ height: "100%",
196
+ transform: "none"
197
+ }
198
+ })
199
+ }, t);
200
+ }) : x.map((e, t) => /* @__PURE__ */ o(p.div, {
201
+ layoutId: `media-${e.id}-${T}`,
202
+ onClick: () => !C && b(e),
203
+ variants: {
204
+ hidden: {
205
+ y: 50,
206
+ scale: .9,
207
+ opacity: 0
208
+ },
209
+ visible: {
210
+ y: 0,
211
+ scale: 1,
212
+ opacity: 1,
213
+ transition: {
214
+ type: "spring",
215
+ stiffness: 350,
216
+ damping: 25,
217
+ delay: t * .05
218
+ }
219
+ }
220
+ },
221
+ whileHover: {
222
+ filter: "brightness(1.1)",
223
+ zIndex: 10
224
+ },
225
+ drag: !0,
226
+ dragConstraints: {
227
+ left: 0,
228
+ right: 0,
229
+ top: 0,
230
+ bottom: 0
231
+ },
232
+ dragElastic: 1,
233
+ onDragStart: () => w(!0),
234
+ onDragEnd: (e, n) => {
235
+ w(!1);
236
+ let r = n.offset.x + n.offset.y;
237
+ if (Math.abs(r) > 50) {
238
+ let e = [...x], n = e[t], i = r > 0 ? Math.min(t + 1, x.length - 1) : Math.max(t - 1, 0);
239
+ e.splice(t, 1), e.splice(i, 0, n), S(e);
240
+ }
241
+ },
242
+ style: {
243
+ position: "relative",
244
+ gridRow: e.rowSpan ? `span ${e.rowSpan}` : "span 2",
245
+ gridColumn: e.colSpan ? `span ${e.colSpan}` : "span 1"
246
+ },
247
+ children: /* @__PURE__ */ s(l, {
248
+ sx: {
249
+ position: "relative",
250
+ overflow: "hidden",
251
+ borderRadius: 2,
252
+ width: "100%",
253
+ height: "100%",
254
+ cursor: "grab",
255
+ "&:active": { cursor: "grabbing" },
256
+ "&:hover .hover-overlay": { opacity: 1 }
257
+ },
258
+ children: [/* @__PURE__ */ o(m, {
259
+ item: e,
260
+ sx: {
261
+ position: "absolute",
262
+ inset: 0,
263
+ width: "100%",
264
+ height: "100%"
265
+ },
266
+ onClick: () => !C && b(e)
267
+ }), (e.title || e.desc) && /* @__PURE__ */ s(c, {
268
+ className: "hover-overlay",
269
+ sx: {
270
+ position: "absolute",
271
+ inset: 0,
272
+ display: "flex",
273
+ flexDirection: "column",
274
+ justifyContent: "flex-end",
275
+ padding: 1.5,
276
+ pointerEvents: "none",
277
+ opacity: 0,
278
+ transition: "opacity 0.2s ease-in-out",
279
+ backdropFilter: "blur(8px)"
280
+ },
281
+ children: [e.title && /* @__PURE__ */ o(d, {
282
+ variant: "subtitle2",
283
+ sx: {
284
+ position: "relative",
285
+ whiteSpace: "nowrap",
286
+ overflow: "hidden",
287
+ textOverflow: "ellipsis"
288
+ },
289
+ children: e.title
290
+ }), e.desc && /* @__PURE__ */ o(d, {
291
+ variant: "caption",
292
+ sx: {
293
+ position: "relative",
294
+ display: "-webkit-box",
295
+ WebkitLineClamp: 2,
296
+ WebkitBoxOrient: "vertical",
297
+ overflow: "hidden"
298
+ },
299
+ children: e.desc
300
+ })]
301
+ })]
302
+ })
303
+ }, `${e.id}-${T}`))
304
+ })
305
+ })
306
+ })]
307
+ });
347
308
  };
309
+ _.displayName = "SGallery";
310
+ //#endregion
311
+ export { m as MediaItem, _ as SGallery, _ as default };