@mantine-bites/lightbox 1.0.0-beta.1 → 1.0.0-beta.10

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 (349) hide show
  1. package/README.md +3 -4
  2. package/dist/cjs/Lightbox.cjs +38 -242
  3. package/dist/cjs/Lightbox.cjs.map +1 -1
  4. package/dist/cjs/Lightbox.context-value.cjs +47 -0
  5. package/dist/cjs/Lightbox.context-value.cjs.map +1 -0
  6. package/dist/cjs/Lightbox.context.cjs.map +1 -1
  7. package/dist/cjs/Lightbox.defaults.cjs +29 -0
  8. package/dist/cjs/Lightbox.defaults.cjs.map +1 -0
  9. package/dist/cjs/Lightbox.module.css.cjs +1 -1
  10. package/dist/cjs/LightboxSlide.cjs +72 -5
  11. package/dist/cjs/LightboxSlide.cjs.map +1 -1
  12. package/dist/cjs/LightboxSlide.context.cjs +12 -0
  13. package/dist/cjs/LightboxSlide.context.cjs.map +1 -0
  14. package/dist/cjs/components/EnterFullscreen.cjs +30 -0
  15. package/dist/cjs/components/EnterFullscreen.cjs.map +1 -0
  16. package/dist/cjs/components/ExitFullscreen.cjs +30 -0
  17. package/dist/cjs/components/ExitFullscreen.cjs.map +1 -0
  18. package/dist/cjs/components/LightboxAutoplayButton.cjs +43 -0
  19. package/dist/cjs/components/LightboxAutoplayButton.cjs.map +1 -0
  20. package/dist/cjs/components/LightboxCarousel.cjs +29 -0
  21. package/dist/cjs/components/LightboxCarousel.cjs.map +1 -0
  22. package/dist/cjs/components/LightboxCarouselSlide.context.cjs +12 -0
  23. package/dist/cjs/components/LightboxCarouselSlide.context.cjs.map +1 -0
  24. package/dist/cjs/components/LightboxCloseButton.cjs +33 -0
  25. package/dist/cjs/components/LightboxCloseButton.cjs.map +1 -0
  26. package/dist/cjs/components/LightboxContent.cjs +38 -0
  27. package/dist/cjs/components/LightboxContent.cjs.map +1 -0
  28. package/dist/cjs/components/LightboxControls.cjs +68 -0
  29. package/dist/cjs/components/LightboxControls.cjs.map +1 -0
  30. package/dist/cjs/components/LightboxCounter.cjs +34 -0
  31. package/dist/cjs/components/LightboxCounter.cjs.map +1 -0
  32. package/dist/cjs/components/LightboxFullscreenButton.cjs +41 -0
  33. package/dist/cjs/components/LightboxFullscreenButton.cjs.map +1 -0
  34. package/dist/cjs/components/LightboxOverlay.cjs +40 -0
  35. package/dist/cjs/components/LightboxOverlay.cjs.map +1 -0
  36. package/dist/cjs/components/LightboxPreset.cjs +32 -0
  37. package/dist/cjs/components/LightboxPreset.cjs.map +1 -0
  38. package/dist/cjs/components/LightboxRoot.cjs +260 -0
  39. package/dist/cjs/components/LightboxRoot.cjs.map +1 -0
  40. package/dist/cjs/components/LightboxSlide.cjs +154 -0
  41. package/dist/cjs/components/LightboxSlide.cjs.map +1 -0
  42. package/dist/cjs/components/LightboxSlide.context.cjs +12 -0
  43. package/dist/cjs/components/LightboxSlide.context.cjs.map +1 -0
  44. package/dist/cjs/components/LightboxSlides.cjs +108 -0
  45. package/dist/cjs/components/LightboxSlides.cjs.map +1 -0
  46. package/dist/cjs/components/LightboxThumbnail.cjs +40 -0
  47. package/dist/cjs/components/LightboxThumbnail.cjs.map +1 -0
  48. package/dist/cjs/components/LightboxThumbnail.context.cjs +12 -0
  49. package/dist/cjs/components/LightboxThumbnail.context.cjs.map +1 -0
  50. package/dist/cjs/components/LightboxThumbnails.cjs +121 -0
  51. package/dist/cjs/components/LightboxThumbnails.cjs.map +1 -0
  52. package/dist/cjs/components/LightboxToolbar.cjs +94 -0
  53. package/dist/cjs/components/LightboxToolbar.cjs.map +1 -0
  54. package/dist/cjs/components/LightboxZoomButton.cjs +39 -0
  55. package/dist/cjs/components/LightboxZoomButton.cjs.map +1 -0
  56. package/dist/cjs/components/Pause.cjs +28 -0
  57. package/dist/cjs/components/Pause.cjs.map +1 -0
  58. package/dist/cjs/components/Play.cjs +22 -0
  59. package/dist/cjs/components/Play.cjs.map +1 -0
  60. package/dist/cjs/components/QuestionMark.cjs +28 -0
  61. package/dist/cjs/components/QuestionMark.cjs.map +1 -0
  62. package/dist/cjs/components/ZoomIn.cjs +30 -0
  63. package/dist/cjs/components/ZoomIn.cjs.map +1 -0
  64. package/dist/cjs/components/ZoomOut.cjs +29 -0
  65. package/dist/cjs/components/ZoomOut.cjs.map +1 -0
  66. package/dist/cjs/components/icons/EnterFullscreen.cjs +30 -0
  67. package/dist/cjs/components/icons/EnterFullscreen.cjs.map +1 -0
  68. package/dist/cjs/components/icons/ExitFullscreen.cjs +30 -0
  69. package/dist/cjs/components/icons/ExitFullscreen.cjs.map +1 -0
  70. package/dist/cjs/components/icons/Pause.cjs +28 -0
  71. package/dist/cjs/components/icons/Pause.cjs.map +1 -0
  72. package/dist/cjs/components/icons/Play.cjs +22 -0
  73. package/dist/cjs/components/icons/Play.cjs.map +1 -0
  74. package/dist/cjs/components/icons/ZoomIn.cjs +30 -0
  75. package/dist/cjs/components/icons/ZoomIn.cjs.map +1 -0
  76. package/dist/cjs/components/icons/ZoomOut.cjs +29 -0
  77. package/dist/cjs/components/icons/ZoomOut.cjs.map +1 -0
  78. package/dist/cjs/context/LightboxContext.cjs +12 -0
  79. package/dist/cjs/context/LightboxContext.cjs.map +1 -0
  80. package/dist/cjs/context/LightboxSlideContext.cjs +12 -0
  81. package/dist/cjs/context/LightboxSlideContext.cjs.map +1 -0
  82. package/dist/cjs/context/LightboxThumbnailContext.cjs +12 -0
  83. package/dist/cjs/context/LightboxThumbnailContext.cjs.map +1 -0
  84. package/dist/cjs/hooks/useAutoPlay.cjs +77 -0
  85. package/dist/cjs/hooks/useAutoPlay.cjs.map +1 -0
  86. package/dist/cjs/hooks/useCarouselOptions.cjs +30 -0
  87. package/dist/cjs/hooks/useCarouselOptions.cjs.map +1 -0
  88. package/dist/cjs/hooks/useFullscreen.cjs +39 -0
  89. package/dist/cjs/hooks/useFullscreen.cjs.map +1 -0
  90. package/dist/cjs/hooks/useKeyboardNavigation.cjs +29 -0
  91. package/dist/cjs/hooks/useKeyboardNavigation.cjs.map +1 -0
  92. package/dist/cjs/hooks/useLightbox.cjs +116 -0
  93. package/dist/cjs/hooks/useLightbox.cjs.map +1 -0
  94. package/dist/cjs/hooks/useLightboxRootOptions.cjs +20 -0
  95. package/dist/cjs/hooks/useLightboxRootOptions.cjs.map +1 -0
  96. package/dist/cjs/hooks/useSlideInteractions.cjs +94 -0
  97. package/dist/cjs/hooks/useSlideInteractions.cjs.map +1 -0
  98. package/dist/cjs/hooks/useThumbnails.cjs +61 -0
  99. package/dist/cjs/hooks/useThumbnails.cjs.map +1 -0
  100. package/dist/cjs/hooks/useZoom.cjs +264 -0
  101. package/dist/cjs/hooks/useZoom.cjs.map +1 -0
  102. package/dist/cjs/index.cjs +26 -2
  103. package/dist/cjs/index.cjs.map +1 -1
  104. package/dist/cjs/styles/Lightbox.module.css.cjs +7 -0
  105. package/dist/cjs/styles/Lightbox.module.css.cjs.map +1 -0
  106. package/dist/cjs/utils/fullscreen.cjs +41 -0
  107. package/dist/cjs/utils/fullscreen.cjs.map +1 -0
  108. package/dist/cjs/utils/pointer.cjs +50 -0
  109. package/dist/cjs/utils/pointer.cjs.map +1 -0
  110. package/dist/cjs/utils/zoom.cjs +91 -0
  111. package/dist/cjs/utils/zoom.cjs.map +1 -0
  112. package/dist/esm/Lightbox.context-value.mjs +45 -0
  113. package/dist/esm/Lightbox.context-value.mjs.map +1 -0
  114. package/dist/esm/Lightbox.context.mjs.map +1 -1
  115. package/dist/esm/Lightbox.defaults.mjs +27 -0
  116. package/dist/esm/Lightbox.defaults.mjs.map +1 -0
  117. package/dist/esm/Lightbox.mjs +40 -244
  118. package/dist/esm/Lightbox.mjs.map +1 -1
  119. package/dist/esm/Lightbox.module.css.mjs +1 -1
  120. package/dist/esm/LightboxSlide.context.mjs +9 -0
  121. package/dist/esm/LightboxSlide.context.mjs.map +1 -0
  122. package/dist/esm/LightboxSlide.mjs +73 -6
  123. package/dist/esm/LightboxSlide.mjs.map +1 -1
  124. package/dist/esm/components/EnterFullscreen.mjs +28 -0
  125. package/dist/esm/components/EnterFullscreen.mjs.map +1 -0
  126. package/dist/esm/components/ExitFullscreen.mjs +28 -0
  127. package/dist/esm/components/ExitFullscreen.mjs.map +1 -0
  128. package/dist/esm/components/LightboxAutoplayButton.mjs +41 -0
  129. package/dist/esm/components/LightboxAutoplayButton.mjs.map +1 -0
  130. package/dist/esm/components/LightboxCarousel.mjs +27 -0
  131. package/dist/esm/components/LightboxCarousel.mjs.map +1 -0
  132. package/dist/esm/components/LightboxCarouselSlide.context.mjs +9 -0
  133. package/dist/esm/components/LightboxCarouselSlide.context.mjs.map +1 -0
  134. package/dist/esm/components/LightboxCloseButton.mjs +31 -0
  135. package/dist/esm/components/LightboxCloseButton.mjs.map +1 -0
  136. package/dist/esm/components/LightboxContent.mjs +36 -0
  137. package/dist/esm/components/LightboxContent.mjs.map +1 -0
  138. package/dist/esm/components/LightboxControls.mjs +66 -0
  139. package/dist/esm/components/LightboxControls.mjs.map +1 -0
  140. package/dist/esm/components/LightboxCounter.mjs +32 -0
  141. package/dist/esm/components/LightboxCounter.mjs.map +1 -0
  142. package/dist/esm/components/LightboxFullscreenButton.mjs +39 -0
  143. package/dist/esm/components/LightboxFullscreenButton.mjs.map +1 -0
  144. package/dist/esm/components/LightboxOverlay.mjs +38 -0
  145. package/dist/esm/components/LightboxOverlay.mjs.map +1 -0
  146. package/dist/esm/components/LightboxPreset.mjs +30 -0
  147. package/dist/esm/components/LightboxPreset.mjs.map +1 -0
  148. package/dist/esm/components/LightboxRoot.mjs +258 -0
  149. package/dist/esm/components/LightboxRoot.mjs.map +1 -0
  150. package/dist/esm/components/LightboxSlide.context.mjs +9 -0
  151. package/dist/esm/components/LightboxSlide.context.mjs.map +1 -0
  152. package/dist/esm/components/LightboxSlide.mjs +152 -0
  153. package/dist/esm/components/LightboxSlide.mjs.map +1 -0
  154. package/dist/esm/components/LightboxSlides.mjs +106 -0
  155. package/dist/esm/components/LightboxSlides.mjs.map +1 -0
  156. package/dist/esm/components/LightboxThumbnail.context.mjs +9 -0
  157. package/dist/esm/components/LightboxThumbnail.context.mjs.map +1 -0
  158. package/dist/esm/components/LightboxThumbnail.mjs +38 -0
  159. package/dist/esm/components/LightboxThumbnail.mjs.map +1 -0
  160. package/dist/esm/components/LightboxThumbnails.mjs +119 -0
  161. package/dist/esm/components/LightboxThumbnails.mjs.map +1 -0
  162. package/dist/esm/components/LightboxToolbar.mjs +92 -0
  163. package/dist/esm/components/LightboxToolbar.mjs.map +1 -0
  164. package/dist/esm/components/LightboxZoomButton.mjs +37 -0
  165. package/dist/esm/components/LightboxZoomButton.mjs.map +1 -0
  166. package/dist/esm/components/Pause.mjs +26 -0
  167. package/dist/esm/components/Pause.mjs.map +1 -0
  168. package/dist/esm/components/Play.mjs +20 -0
  169. package/dist/esm/components/Play.mjs.map +1 -0
  170. package/dist/esm/components/QuestionMark.mjs +26 -0
  171. package/dist/esm/components/QuestionMark.mjs.map +1 -0
  172. package/dist/esm/components/ZoomIn.mjs +28 -0
  173. package/dist/esm/components/ZoomIn.mjs.map +1 -0
  174. package/dist/esm/components/ZoomOut.mjs +27 -0
  175. package/dist/esm/components/ZoomOut.mjs.map +1 -0
  176. package/dist/esm/components/icons/EnterFullscreen.mjs +28 -0
  177. package/dist/esm/components/icons/EnterFullscreen.mjs.map +1 -0
  178. package/dist/esm/components/icons/ExitFullscreen.mjs +28 -0
  179. package/dist/esm/components/icons/ExitFullscreen.mjs.map +1 -0
  180. package/dist/esm/components/icons/Pause.mjs +26 -0
  181. package/dist/esm/components/icons/Pause.mjs.map +1 -0
  182. package/dist/esm/components/icons/Play.mjs +20 -0
  183. package/dist/esm/components/icons/Play.mjs.map +1 -0
  184. package/dist/esm/components/icons/ZoomIn.mjs +28 -0
  185. package/dist/esm/components/icons/ZoomIn.mjs.map +1 -0
  186. package/dist/esm/components/icons/ZoomOut.mjs +27 -0
  187. package/dist/esm/components/icons/ZoomOut.mjs.map +1 -0
  188. package/dist/esm/context/LightboxContext.mjs +9 -0
  189. package/dist/esm/context/LightboxContext.mjs.map +1 -0
  190. package/dist/esm/context/LightboxSlideContext.mjs +9 -0
  191. package/dist/esm/context/LightboxSlideContext.mjs.map +1 -0
  192. package/dist/esm/context/LightboxThumbnailContext.mjs +9 -0
  193. package/dist/esm/context/LightboxThumbnailContext.mjs.map +1 -0
  194. package/dist/esm/hooks/useAutoPlay.mjs +75 -0
  195. package/dist/esm/hooks/useAutoPlay.mjs.map +1 -0
  196. package/dist/esm/hooks/useCarouselOptions.mjs +28 -0
  197. package/dist/esm/hooks/useCarouselOptions.mjs.map +1 -0
  198. package/dist/esm/hooks/useFullscreen.mjs +37 -0
  199. package/dist/esm/hooks/useFullscreen.mjs.map +1 -0
  200. package/dist/esm/hooks/useKeyboardNavigation.mjs +27 -0
  201. package/dist/esm/hooks/useKeyboardNavigation.mjs.map +1 -0
  202. package/dist/esm/hooks/useLightbox.mjs +114 -0
  203. package/dist/esm/hooks/useLightbox.mjs.map +1 -0
  204. package/dist/esm/hooks/useLightboxRootOptions.mjs +18 -0
  205. package/dist/esm/hooks/useLightboxRootOptions.mjs.map +1 -0
  206. package/dist/esm/hooks/useSlideInteractions.mjs +92 -0
  207. package/dist/esm/hooks/useSlideInteractions.mjs.map +1 -0
  208. package/dist/esm/hooks/useThumbnails.mjs +59 -0
  209. package/dist/esm/hooks/useThumbnails.mjs.map +1 -0
  210. package/dist/esm/hooks/useZoom.mjs +262 -0
  211. package/dist/esm/hooks/useZoom.mjs.map +1 -0
  212. package/dist/esm/index.mjs +13 -1
  213. package/dist/esm/index.mjs.map +1 -1
  214. package/dist/esm/styles/Lightbox.module.css.mjs +5 -0
  215. package/dist/esm/styles/Lightbox.module.css.mjs.map +1 -0
  216. package/dist/esm/utils/fullscreen.mjs +36 -0
  217. package/dist/esm/utils/fullscreen.mjs.map +1 -0
  218. package/dist/esm/utils/pointer.mjs +41 -0
  219. package/dist/esm/utils/pointer.mjs.map +1 -0
  220. package/dist/esm/utils/zoom.mjs +82 -0
  221. package/dist/esm/utils/zoom.mjs.map +1 -0
  222. package/dist/styles.css +1 -1
  223. package/dist/styles.layer.css +1 -1
  224. package/dist/types/Lightbox.context-value.d.ts +16 -0
  225. package/dist/types/Lightbox.context-value.d.ts.map +1 -0
  226. package/dist/types/Lightbox.context.d.ts +29 -0
  227. package/dist/types/Lightbox.context.d.ts.map +1 -1
  228. package/dist/types/Lightbox.d.ts +53 -35
  229. package/dist/types/Lightbox.d.ts.map +1 -1
  230. package/dist/types/Lightbox.defaults.d.ts +24 -0
  231. package/dist/types/Lightbox.defaults.d.ts.map +1 -0
  232. package/dist/types/Lightbox.story.d.ts +5 -5
  233. package/dist/types/Lightbox.story.d.ts.map +1 -1
  234. package/dist/types/LightboxSlide.context.d.ts +8 -0
  235. package/dist/types/LightboxSlide.context.d.ts.map +1 -0
  236. package/dist/types/LightboxSlide.d.ts +0 -3
  237. package/dist/types/LightboxSlide.d.ts.map +1 -1
  238. package/dist/types/__tests__/Lightbox.test.d.ts +2 -0
  239. package/dist/types/__tests__/Lightbox.test.d.ts.map +1 -0
  240. package/dist/types/__tests__/LightboxSimple.test.d.ts +2 -0
  241. package/dist/types/__tests__/LightboxSimple.test.d.ts.map +1 -0
  242. package/dist/types/__tests__/pointer.test.d.ts +2 -0
  243. package/dist/types/__tests__/pointer.test.d.ts.map +1 -0
  244. package/dist/types/__tests__/zoom.test.d.ts +2 -0
  245. package/dist/types/__tests__/zoom.test.d.ts.map +1 -0
  246. package/dist/types/components/EnterFullscreen.d.ts +3 -0
  247. package/dist/types/components/EnterFullscreen.d.ts.map +1 -0
  248. package/dist/types/components/ExitFullscreen.d.ts +3 -0
  249. package/dist/types/components/ExitFullscreen.d.ts.map +1 -0
  250. package/dist/types/components/LightboxAutoplayButton.d.ts +17 -0
  251. package/dist/types/components/LightboxAutoplayButton.d.ts.map +1 -0
  252. package/dist/types/components/LightboxCarousel.d.ts +6 -0
  253. package/dist/types/components/LightboxCarousel.d.ts.map +1 -0
  254. package/dist/types/components/LightboxCarouselSlide.context.d.ts +10 -0
  255. package/dist/types/components/LightboxCarouselSlide.context.d.ts.map +1 -0
  256. package/dist/types/components/LightboxCloseButton.d.ts +17 -0
  257. package/dist/types/components/LightboxCloseButton.d.ts.map +1 -0
  258. package/dist/types/components/LightboxContent.d.ts +14 -0
  259. package/dist/types/components/LightboxContent.d.ts.map +1 -0
  260. package/dist/types/components/LightboxControls.d.ts +19 -0
  261. package/dist/types/components/LightboxControls.d.ts.map +1 -0
  262. package/dist/types/components/LightboxCounter.d.ts +19 -0
  263. package/dist/types/components/LightboxCounter.d.ts.map +1 -0
  264. package/dist/types/components/LightboxFullscreenButton.d.ts +17 -0
  265. package/dist/types/components/LightboxFullscreenButton.d.ts.map +1 -0
  266. package/dist/types/components/LightboxOverlay.d.ts +4 -0
  267. package/dist/types/components/LightboxOverlay.d.ts.map +1 -0
  268. package/dist/types/components/LightboxPreset.d.ts +10 -0
  269. package/dist/types/components/LightboxPreset.d.ts.map +1 -0
  270. package/dist/types/components/LightboxRoot.d.ts +80 -0
  271. package/dist/types/components/LightboxRoot.d.ts.map +1 -0
  272. package/dist/types/components/LightboxSlide.context.d.ts +8 -0
  273. package/dist/types/components/LightboxSlide.context.d.ts.map +1 -0
  274. package/dist/types/components/LightboxSlide.d.ts +17 -0
  275. package/dist/types/components/LightboxSlide.d.ts.map +1 -0
  276. package/dist/types/components/LightboxSlides.d.ts +24 -0
  277. package/dist/types/components/LightboxSlides.d.ts.map +1 -0
  278. package/dist/types/components/LightboxThumbnail.context.d.ts +8 -0
  279. package/dist/types/components/LightboxThumbnail.context.d.ts.map +1 -0
  280. package/dist/types/components/LightboxThumbnail.d.ts +17 -0
  281. package/dist/types/components/LightboxThumbnail.d.ts.map +1 -0
  282. package/dist/types/components/LightboxThumbnails.d.ts +20 -0
  283. package/dist/types/components/LightboxThumbnails.d.ts.map +1 -0
  284. package/dist/types/components/LightboxToolbar.d.ts +17 -0
  285. package/dist/types/components/LightboxToolbar.d.ts.map +1 -0
  286. package/dist/types/components/LightboxZoomButton.d.ts +17 -0
  287. package/dist/types/components/LightboxZoomButton.d.ts.map +1 -0
  288. package/dist/types/components/Pause.d.ts +3 -0
  289. package/dist/types/components/Pause.d.ts.map +1 -0
  290. package/dist/types/components/Play.d.ts +3 -0
  291. package/dist/types/components/Play.d.ts.map +1 -0
  292. package/dist/types/components/QuestionMark.d.ts +3 -0
  293. package/dist/types/components/QuestionMark.d.ts.map +1 -0
  294. package/dist/types/components/ZoomIn.d.ts +3 -0
  295. package/dist/types/components/ZoomIn.d.ts.map +1 -0
  296. package/dist/types/components/ZoomOut.d.ts +3 -0
  297. package/dist/types/components/ZoomOut.d.ts.map +1 -0
  298. package/dist/types/components/icons/EnterFullscreen.d.ts +3 -0
  299. package/dist/types/components/icons/EnterFullscreen.d.ts.map +1 -0
  300. package/dist/types/components/icons/ExitFullscreen.d.ts +3 -0
  301. package/dist/types/components/icons/ExitFullscreen.d.ts.map +1 -0
  302. package/dist/types/components/icons/Pause.d.ts +3 -0
  303. package/dist/types/components/icons/Pause.d.ts.map +1 -0
  304. package/dist/types/components/icons/Play.d.ts +3 -0
  305. package/dist/types/components/icons/Play.d.ts.map +1 -0
  306. package/dist/types/components/icons/ZoomIn.d.ts +3 -0
  307. package/dist/types/components/icons/ZoomIn.d.ts.map +1 -0
  308. package/dist/types/components/icons/ZoomOut.d.ts +3 -0
  309. package/dist/types/components/icons/ZoomOut.d.ts.map +1 -0
  310. package/dist/types/context/LightboxContext.d.ts +46 -0
  311. package/dist/types/context/LightboxContext.d.ts.map +1 -0
  312. package/dist/types/context/LightboxSlideContext.d.ts +8 -0
  313. package/dist/types/context/LightboxSlideContext.d.ts.map +1 -0
  314. package/dist/types/context/LightboxThumbnailContext.d.ts +8 -0
  315. package/dist/types/context/LightboxThumbnailContext.d.ts.map +1 -0
  316. package/dist/types/hooks/useAutoPlay.d.ts +11 -0
  317. package/dist/types/hooks/useAutoPlay.d.ts.map +1 -0
  318. package/dist/types/hooks/useAutoPlay.test.d.ts +2 -0
  319. package/dist/types/hooks/useAutoPlay.test.d.ts.map +1 -0
  320. package/dist/types/hooks/useCarouselOptions.d.ts +20 -0
  321. package/dist/types/hooks/useCarouselOptions.d.ts.map +1 -0
  322. package/dist/types/hooks/useFullscreen.d.ts +11 -0
  323. package/dist/types/hooks/useFullscreen.d.ts.map +1 -0
  324. package/dist/types/hooks/useKeyboardNavigation.d.ts +10 -0
  325. package/dist/types/hooks/useKeyboardNavigation.d.ts.map +1 -0
  326. package/dist/types/hooks/useLightbox.d.ts +30 -0
  327. package/dist/types/hooks/useLightbox.d.ts.map +1 -0
  328. package/dist/types/hooks/useLightboxRootOptions.d.ts +12 -0
  329. package/dist/types/hooks/useLightboxRootOptions.d.ts.map +1 -0
  330. package/dist/types/hooks/useSlideInteractions.d.ts +26 -0
  331. package/dist/types/hooks/useSlideInteractions.d.ts.map +1 -0
  332. package/dist/types/hooks/useThumbnails.d.ts +15 -0
  333. package/dist/types/hooks/useThumbnails.d.ts.map +1 -0
  334. package/dist/types/hooks/useZoom.d.ts +24 -0
  335. package/dist/types/hooks/useZoom.d.ts.map +1 -0
  336. package/dist/types/index.d.mts +27 -3
  337. package/dist/types/index.d.ts +27 -3
  338. package/dist/types/index.d.ts.map +1 -1
  339. package/dist/types/stories/Lightbox.story.d.ts +11 -0
  340. package/dist/types/stories/Lightbox.story.d.ts.map +1 -0
  341. package/dist/types/utils/fullscreen.d.ts +21 -0
  342. package/dist/types/utils/fullscreen.d.ts.map +1 -0
  343. package/dist/types/utils/pointer.d.ts +63 -0
  344. package/dist/types/utils/pointer.d.ts.map +1 -0
  345. package/dist/types/utils/zoom.d.ts +69 -0
  346. package/dist/types/utils/zoom.d.ts.map +1 -0
  347. package/dist/types/utils/zoom.test.d.ts +2 -0
  348. package/dist/types/utils/zoom.test.d.ts.map +1 -0
  349. package/package.json +2 -3
@@ -0,0 +1,50 @@
1
+ 'use client';
2
+ 'use strict';
3
+
4
+ const POINTER_MOVE_THRESHOLD = 2;
5
+ const isEventTargetWithinSelector = (target, selector) => target instanceof HTMLElement && Boolean(target.closest(selector));
6
+ const isImageTarget = (target) => isEventTargetWithinSelector(target, "img");
7
+ const getPointerCoordinate = (value, fallback) => Number.isFinite(value) ? value : fallback;
8
+ const hasPointerMoved = ({
9
+ startX,
10
+ startY,
11
+ endX,
12
+ endY,
13
+ threshold = POINTER_MOVE_THRESHOLD
14
+ }) => Math.abs(endX - startX) > threshold || Math.abs(endY - startY) > threshold;
15
+ const createOutsideClosePointerState = ({
16
+ pointerId,
17
+ clientX,
18
+ clientY,
19
+ startedOutsideContent
20
+ }) => ({
21
+ pointerId,
22
+ startX: getPointerCoordinate(clientX, 0),
23
+ startY: getPointerCoordinate(clientY, 0),
24
+ startedOutsideContent,
25
+ moved: false
26
+ });
27
+ const updateOutsideClosePointerState = (state, { clientX, clientY }) => {
28
+ const endX = getPointerCoordinate(clientX, state.startX);
29
+ const endY = getPointerCoordinate(clientY, state.startY);
30
+ if (!state.moved && hasPointerMoved({
31
+ startX: state.startX,
32
+ startY: state.startY,
33
+ endX,
34
+ endY
35
+ })) {
36
+ return { ...state, moved: true };
37
+ }
38
+ return state;
39
+ };
40
+ const shouldCloseFromOutsidePointerState = (state) => state.startedOutsideContent && !state.moved;
41
+
42
+ exports.POINTER_MOVE_THRESHOLD = POINTER_MOVE_THRESHOLD;
43
+ exports.createOutsideClosePointerState = createOutsideClosePointerState;
44
+ exports.getPointerCoordinate = getPointerCoordinate;
45
+ exports.hasPointerMoved = hasPointerMoved;
46
+ exports.isEventTargetWithinSelector = isEventTargetWithinSelector;
47
+ exports.isImageTarget = isImageTarget;
48
+ exports.shouldCloseFromOutsidePointerState = shouldCloseFromOutsidePointerState;
49
+ exports.updateOutsideClosePointerState = updateOutsideClosePointerState;
50
+ //# sourceMappingURL=pointer.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pointer.cjs","sources":["../../../src/utils/pointer.ts"],"sourcesContent":["/** Minimum pointer movement in pixels before a gesture is considered a drag. */\nexport const POINTER_MOVE_THRESHOLD = 2;\n\n/** Tracks the state of a pointer used to detect outside-content close gestures. */\nexport interface OutsideClosePointerState {\n\t/** Identifier of the tracked pointer. */\n\tpointerId: number;\n\t/** Horizontal position where the pointer was initially pressed. */\n\tstartX: number;\n\t/** Vertical position where the pointer was initially pressed. */\n\tstartY: number;\n\t/** Whether the pointer press originated outside the slide content area. */\n\tstartedOutsideContent: boolean;\n\t/** Whether the pointer has moved beyond the drag threshold since pressing. */\n\tmoved: boolean;\n}\n\ninterface CreateOutsideClosePointerStateInput {\n\tpointerId: number;\n\tclientX: number;\n\tclientY: number;\n\tstartedOutsideContent: boolean;\n}\n\ninterface PointerMoveInput {\n\tstartX: number;\n\tstartY: number;\n\tendX: number;\n\tendY: number;\n\tthreshold?: number;\n}\n\n/**\n * Returns `true` if the event target is an element (or descendant) matching\n * the given CSS selector.\n */\nexport const isEventTargetWithinSelector = (\n\ttarget: EventTarget | null,\n\tselector: string,\n) => target instanceof HTMLElement && Boolean(target.closest(selector));\n\n/** Returns `true` if the event target is or is inside an `<img>` element. */\nexport const isImageTarget = (target: EventTarget | null) =>\n\tisEventTargetWithinSelector(target, \"img\");\n\n/**\n * Returns `value` if it is a finite number, otherwise returns `fallback`.\n * Useful for sanitising pointer coordinates that may be `NaN` or `Infinity`.\n */\nexport const getPointerCoordinate = (value: number, fallback: number) =>\n\tNumber.isFinite(value) ? value : fallback;\n\n/**\n * Returns `true` if the pointer has moved more than `threshold` pixels in\n * either axis between the start and end positions.\n */\nexport const hasPointerMoved = ({\n\tstartX,\n\tstartY,\n\tendX,\n\tendY,\n\tthreshold = POINTER_MOVE_THRESHOLD,\n}: PointerMoveInput) =>\n\tMath.abs(endX - startX) > threshold || Math.abs(endY - startY) > threshold;\n\n/** Creates the initial tracking state for an outside-close pointer gesture. */\nexport const createOutsideClosePointerState = ({\n\tpointerId,\n\tclientX,\n\tclientY,\n\tstartedOutsideContent,\n}: CreateOutsideClosePointerStateInput): OutsideClosePointerState => ({\n\tpointerId,\n\tstartX: getPointerCoordinate(clientX, 0),\n\tstartY: getPointerCoordinate(clientY, 0),\n\tstartedOutsideContent,\n\tmoved: false,\n});\n\n/**\n * Returns an updated copy of the pointer state after a pointer move event.\n * Sets `moved` to `true` once the pointer has exceeded the drag threshold.\n */\nexport const updateOutsideClosePointerState = (\n\tstate: OutsideClosePointerState,\n\t{ clientX, clientY }: { clientX: number; clientY: number },\n): OutsideClosePointerState => {\n\tconst endX = getPointerCoordinate(clientX, state.startX);\n\tconst endY = getPointerCoordinate(clientY, state.startY);\n\n\tif (\n\t\t!state.moved &&\n\t\thasPointerMoved({\n\t\t\tstartX: state.startX,\n\t\t\tstartY: state.startY,\n\t\t\tendX,\n\t\t\tendY,\n\t\t})\n\t) {\n\t\treturn { ...state, moved: true };\n\t}\n\n\treturn state;\n};\n\n/**\n * Returns `true` if the pointer gesture should trigger a close action.\n * The action triggers when the press started outside the content and the\n * pointer did not drag.\n */\nexport const shouldCloseFromOutsidePointerState = (\n\tstate: OutsideClosePointerState,\n) => state.startedOutsideContent && !state.moved;\n"],"names":[],"mappings":"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"}
@@ -0,0 +1,91 @@
1
+ 'use client';
2
+ 'use strict';
3
+
4
+ const DEFAULT_ZOOM_SCALE = 2;
5
+ const ZERO_ZOOM_OFFSET = { x: 0, y: 0 };
6
+ const clampZoomOffset = ({
7
+ containerWidth,
8
+ containerHeight,
9
+ imageWidth,
10
+ imageHeight,
11
+ zoomScale,
12
+ nextX,
13
+ nextY
14
+ }) => {
15
+ const scaledWidth = imageWidth * zoomScale;
16
+ const scaledHeight = imageHeight * zoomScale;
17
+ const maxX = Math.max(0, (scaledWidth - containerWidth) / 2);
18
+ const maxY = Math.max(0, (scaledHeight - containerHeight) / 2);
19
+ return {
20
+ x: Math.min(Math.max(nextX, -maxX), maxX),
21
+ y: Math.min(Math.max(nextY, -maxY), maxY)
22
+ };
23
+ };
24
+ const getInitialZoomOffset = ({
25
+ containerRect,
26
+ imageRect,
27
+ zoomScale,
28
+ pointerClientX,
29
+ pointerClientY
30
+ }) => {
31
+ const centerX = containerRect.left + containerRect.width / 2;
32
+ const centerY = containerRect.top + containerRect.height / 2;
33
+ const rawOffsetX = -(pointerClientX - centerX) * zoomScale;
34
+ const rawOffsetY = -(pointerClientY - centerY) * zoomScale;
35
+ return clampZoomOffset({
36
+ containerWidth: containerRect.width,
37
+ containerHeight: containerRect.height,
38
+ imageWidth: imageRect.width,
39
+ imageHeight: imageRect.height,
40
+ zoomScale,
41
+ nextX: rawOffsetX,
42
+ nextY: rawOffsetY
43
+ });
44
+ };
45
+ const getZoomTransform = ({
46
+ isZoomed,
47
+ offset,
48
+ scale
49
+ }) => `translate(${isZoomed ? offset.x : 0}px, ${isZoomed ? offset.y : 0}px) scale(${isZoomed ? scale : 1})`;
50
+ const RESOLUTION_EPSILON = 1.01;
51
+ const getImageMeasurements = (image) => {
52
+ const rect = image.getBoundingClientRect();
53
+ return {
54
+ naturalWidth: image.naturalWidth,
55
+ naturalHeight: image.naturalHeight,
56
+ renderedWidth: rect.width,
57
+ renderedHeight: rect.height
58
+ };
59
+ };
60
+ const getImageMaxZoomScale = (image) => {
61
+ const { naturalWidth, naturalHeight, renderedWidth, renderedHeight } = getImageMeasurements(image);
62
+ if (!naturalWidth || !naturalHeight || !renderedWidth || !renderedHeight) {
63
+ return DEFAULT_ZOOM_SCALE;
64
+ }
65
+ return Math.min(naturalWidth / renderedWidth, naturalHeight / renderedHeight);
66
+ };
67
+ const getTargetZoomScale = ({
68
+ image,
69
+ containerWidth,
70
+ containerHeight
71
+ }) => {
72
+ const { renderedWidth, renderedHeight } = getImageMeasurements(image);
73
+ const fillWidthScale = renderedWidth > 0 ? containerWidth / renderedWidth : DEFAULT_ZOOM_SCALE;
74
+ const fillHeightScale = renderedHeight > 0 ? containerHeight / renderedHeight : DEFAULT_ZOOM_SCALE;
75
+ const fillViewportScale = Math.max(fillWidthScale, fillHeightScale);
76
+ const maxZoomScale = getImageMaxZoomScale(image);
77
+ const fallbackStepScale = Math.min(maxZoomScale, DEFAULT_ZOOM_SCALE);
78
+ const targetScale = fillViewportScale > 1 ? fillViewportScale : fallbackStepScale;
79
+ return Math.max(1, Math.min(maxZoomScale, targetScale));
80
+ };
81
+ const canZoomImageElement = (image) => getImageMaxZoomScale(image) > RESOLUTION_EPSILON;
82
+
83
+ exports.DEFAULT_ZOOM_SCALE = DEFAULT_ZOOM_SCALE;
84
+ exports.ZERO_ZOOM_OFFSET = ZERO_ZOOM_OFFSET;
85
+ exports.canZoomImageElement = canZoomImageElement;
86
+ exports.clampZoomOffset = clampZoomOffset;
87
+ exports.getImageMaxZoomScale = getImageMaxZoomScale;
88
+ exports.getInitialZoomOffset = getInitialZoomOffset;
89
+ exports.getTargetZoomScale = getTargetZoomScale;
90
+ exports.getZoomTransform = getZoomTransform;
91
+ //# sourceMappingURL=zoom.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"zoom.cjs","sources":["../../../src/utils/zoom.ts"],"sourcesContent":["/** Pixel offset representing a translation applied to a zoomed image. */\nexport interface ZoomOffset {\n\t/** Horizontal translation in pixels. */\n\tx: number;\n\t/** Vertical translation in pixels. */\n\ty: number;\n}\n\n/** Default zoom scale applied when zooming in on an image. */\nexport const DEFAULT_ZOOM_SCALE = 2;\n\n/** Zero-offset value representing no translation on a zoomed image. */\nexport const ZERO_ZOOM_OFFSET: ZoomOffset = { x: 0, y: 0 };\n\ninterface ClampZoomOffsetInput {\n\tcontainerWidth: number;\n\tcontainerHeight: number;\n\timageWidth: number;\n\timageHeight: number;\n\tzoomScale: number;\n\tnextX: number;\n\tnextY: number;\n}\n\ninterface InitialZoomOffsetInput {\n\tcontainerRect: DOMRect;\n\timageRect: DOMRect;\n\tzoomScale: number;\n\tpointerClientX: number;\n\tpointerClientY: number;\n}\n\n/**\n * Clamps a proposed zoom pan offset so the image cannot be panned beyond its\n * edges relative to the container at the given zoom scale.\n */\nexport const clampZoomOffset = ({\n\tcontainerWidth,\n\tcontainerHeight,\n\timageWidth,\n\timageHeight,\n\tzoomScale,\n\tnextX,\n\tnextY,\n}: ClampZoomOffsetInput): ZoomOffset => {\n\tconst scaledWidth = imageWidth * zoomScale;\n\tconst scaledHeight = imageHeight * zoomScale;\n\tconst maxX = Math.max(0, (scaledWidth - containerWidth) / 2);\n\tconst maxY = Math.max(0, (scaledHeight - containerHeight) / 2);\n\n\treturn {\n\t\tx: Math.min(Math.max(nextX, -maxX), maxX),\n\t\ty: Math.min(Math.max(nextY, -maxY), maxY),\n\t};\n};\n\n/**\n * Calculates the initial pan offset when zooming so the clicked/tapped point\n * moves toward the viewport center, then clamps it to valid pan bounds.\n */\nexport const getInitialZoomOffset = ({\n\tcontainerRect,\n\timageRect,\n\tzoomScale,\n\tpointerClientX,\n\tpointerClientY,\n}: InitialZoomOffsetInput): ZoomOffset => {\n\tconst centerX = containerRect.left + containerRect.width / 2;\n\tconst centerY = containerRect.top + containerRect.height / 2;\n\tconst rawOffsetX = -(pointerClientX - centerX) * zoomScale;\n\tconst rawOffsetY = -(pointerClientY - centerY) * zoomScale;\n\n\treturn clampZoomOffset({\n\t\tcontainerWidth: containerRect.width,\n\t\tcontainerHeight: containerRect.height,\n\t\timageWidth: imageRect.width,\n\t\timageHeight: imageRect.height,\n\t\tzoomScale,\n\t\tnextX: rawOffsetX,\n\t\tnextY: rawOffsetY,\n\t});\n};\n\n/**\n * Returns a CSS `transform` string that applies the zoom pan offset and scale.\n * When not zoomed, returns identity values regardless of the stored offset.\n */\nexport const getZoomTransform = ({\n\tisZoomed,\n\toffset,\n\tscale,\n}: {\n\tisZoomed: boolean;\n\toffset: ZoomOffset;\n\tscale: number;\n}) =>\n\t`translate(${isZoomed ? offset.x : 0}px, ${isZoomed ? offset.y : 0}px) scale(${\n\t\tisZoomed ? scale : 1\n\t})`;\n\nconst RESOLUTION_EPSILON = 1.01;\n\nconst getImageMeasurements = (image: HTMLImageElement) => {\n\tconst rect = image.getBoundingClientRect();\n\treturn {\n\t\tnaturalWidth: image.naturalWidth,\n\t\tnaturalHeight: image.naturalHeight,\n\t\trenderedWidth: rect.width,\n\t\trenderedHeight: rect.height,\n\t};\n};\n\n/**\n * Returns the maximum zoom scale at which the image would still be rendered at\n * its native resolution (1:1 pixel ratio). Falls back to `DEFAULT_ZOOM_SCALE`\n * when image dimensions are unavailable.\n */\nexport const getImageMaxZoomScale = (image: HTMLImageElement) => {\n\tconst { naturalWidth, naturalHeight, renderedWidth, renderedHeight } =\n\t\tgetImageMeasurements(image);\n\n\tif (!naturalWidth || !naturalHeight || !renderedWidth || !renderedHeight) {\n\t\treturn DEFAULT_ZOOM_SCALE;\n\t}\n\n\treturn Math.min(naturalWidth / renderedWidth, naturalHeight / renderedHeight);\n};\n\n/**\n * Calculates the zoom scale that should be applied when the user triggers a\n * zoom action. Prefers a scale that fills the container viewport; falls back to\n * the native-resolution scale or `DEFAULT_ZOOM_SCALE` when the image is small.\n */\nexport const getTargetZoomScale = ({\n\timage,\n\tcontainerWidth,\n\tcontainerHeight,\n}: {\n\timage: HTMLImageElement;\n\tcontainerWidth: number;\n\tcontainerHeight: number;\n}) => {\n\tconst { renderedWidth, renderedHeight } = getImageMeasurements(image);\n\tconst fillWidthScale =\n\t\trenderedWidth > 0 ? containerWidth / renderedWidth : DEFAULT_ZOOM_SCALE;\n\tconst fillHeightScale =\n\t\trenderedHeight > 0 ? containerHeight / renderedHeight : DEFAULT_ZOOM_SCALE;\n\tconst fillViewportScale = Math.max(fillWidthScale, fillHeightScale);\n\tconst maxZoomScale = getImageMaxZoomScale(image);\n\tconst fallbackStepScale = Math.min(maxZoomScale, DEFAULT_ZOOM_SCALE);\n\tconst targetScale =\n\t\tfillViewportScale > 1 ? fillViewportScale : fallbackStepScale;\n\n\treturn Math.max(1, Math.min(maxZoomScale, targetScale));\n};\n\n/**\n * Returns `true` if the image has sufficient resolution to be meaningfully\n * zoomed (i.e. its max zoom scale exceeds the resolution epsilon threshold).\n */\nexport const canZoomImageElement = (image: HTMLImageElement) =>\n\tgetImageMaxZoomScale(image) > RESOLUTION_EPSILON;\n"],"names":[],"mappings":"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"}
@@ -0,0 +1,45 @@
1
+ 'use client';
2
+ function buildLightboxContextValue({
3
+ getStyles,
4
+ transitionStyles,
5
+ overlayProps,
6
+ onClose,
7
+ withZoom,
8
+ lightbox
9
+ }) {
10
+ return {
11
+ getStyles,
12
+ transitionStyles,
13
+ overlayProps,
14
+ mergedRef: lightbox.mergedRef,
15
+ mergedCarouselOptions: lightbox.mergedCarouselOptions,
16
+ onCarouselEmblaApi: lightbox.handleEmblaApi,
17
+ currentIndex: lightbox.currentIndex,
18
+ counterText: lightbox.counterText,
19
+ emblaOptions: lightbox.mergedThumbnailEmblaOptions,
20
+ onEmblaApi: lightbox.handleThumbnailsEmblaApi,
21
+ withZoom,
22
+ isFullscreen: lightbox.isFullscreen,
23
+ onToggleFullscreen: lightbox.toggleFullscreen,
24
+ canUseAutoPlay: lightbox.canUseAutoPlay,
25
+ isPlaying: lightbox.isPlaying,
26
+ onToggleAutoPlay: lightbox.toggleAutoPlay,
27
+ onToggleZoom: lightbox.toggleZoom,
28
+ isZoomed: lightbox.isZoomed,
29
+ isDraggingZoom: lightbox.isDraggingZoom,
30
+ canZoomCurrent: lightbox.canZoomCurrent,
31
+ zoomOffset: lightbox.zoomOffset,
32
+ zoomScale: lightbox.zoomScale,
33
+ activeZoomContainerRef: lightbox.activeZoomContainerRef,
34
+ updateCanZoomAvailability: lightbox.updateCanZoomAvailability,
35
+ handleZoomPointerDown: lightbox.handleZoomPointerDown,
36
+ handleZoomPointerMove: lightbox.handleZoomPointerMove,
37
+ handleZoomPointerEnd: lightbox.handleZoomPointerEnd,
38
+ onClose,
39
+ handleOutsideClick: lightbox.handleOutsideClick,
40
+ onThumbnailClick: lightbox.handleThumbnailClick
41
+ };
42
+ }
43
+
44
+ export { buildLightboxContextValue };
45
+ //# sourceMappingURL=Lightbox.context-value.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Lightbox.context-value.mjs","sources":["../../src/Lightbox.context-value.ts"],"sourcesContent":["import type { GetStylesApi, OverlayProps } from \"@mantine/core\";\nimport type { CSSProperties } from \"react\";\nimport type { UseLightboxOutput } from \"./hooks/useLightbox.js\";\nimport type { LightboxContext } from \"./Lightbox.context.js\";\nimport type { LightboxFactory } from \"./Lightbox.js\";\n\ninterface BuildLightboxContextValueInput {\n\tgetStyles: GetStylesApi<LightboxFactory>;\n\ttransitionStyles: CSSProperties;\n\toverlayProps: OverlayProps;\n\tonClose: () => void;\n\twithZoom: boolean | undefined;\n\tlightbox: UseLightboxOutput;\n}\n\nexport function buildLightboxContextValue({\n\tgetStyles,\n\ttransitionStyles,\n\toverlayProps,\n\tonClose,\n\twithZoom,\n\tlightbox,\n}: BuildLightboxContextValueInput): LightboxContext {\n\treturn {\n\t\tgetStyles,\n\t\ttransitionStyles,\n\t\toverlayProps,\n\t\tmergedRef: lightbox.mergedRef,\n\t\tmergedCarouselOptions: lightbox.mergedCarouselOptions,\n\t\tonCarouselEmblaApi: lightbox.handleEmblaApi,\n\t\tcurrentIndex: lightbox.currentIndex,\n\t\tcounterText: lightbox.counterText,\n\t\temblaOptions: lightbox.mergedThumbnailEmblaOptions,\n\t\tonEmblaApi: lightbox.handleThumbnailsEmblaApi,\n\t\twithZoom,\n\t\tisFullscreen: lightbox.isFullscreen,\n\t\tonToggleFullscreen: lightbox.toggleFullscreen,\n\t\tcanUseAutoPlay: lightbox.canUseAutoPlay,\n\t\tisPlaying: lightbox.isPlaying,\n\t\tonToggleAutoPlay: lightbox.toggleAutoPlay,\n\t\tonToggleZoom: lightbox.toggleZoom,\n\t\tisZoomed: lightbox.isZoomed,\n\t\tisDraggingZoom: lightbox.isDraggingZoom,\n\t\tcanZoomCurrent: lightbox.canZoomCurrent,\n\t\tzoomOffset: lightbox.zoomOffset,\n\t\tzoomScale: lightbox.zoomScale,\n\t\tactiveZoomContainerRef: lightbox.activeZoomContainerRef,\n\t\tupdateCanZoomAvailability: lightbox.updateCanZoomAvailability,\n\t\thandleZoomPointerDown: lightbox.handleZoomPointerDown,\n\t\thandleZoomPointerMove: lightbox.handleZoomPointerMove,\n\t\thandleZoomPointerEnd: lightbox.handleZoomPointerEnd,\n\t\tonClose,\n\t\thandleOutsideClick: lightbox.handleOutsideClick,\n\t\tonThumbnailClick: lightbox.handleThumbnailClick,\n\t};\n}\n"],"names":[],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"Lightbox.context.mjs","sources":["../../src/Lightbox.context.ts"],"sourcesContent":["import { createSafeContext, type GetStylesApi } from \"@mantine/core\";\nimport type { LightboxFactory } from \"./Lightbox.js\";\n\nexport interface LightboxContext {\n\tgetStyles: GetStylesApi<LightboxFactory>;\n}\n\nexport const [LightboxProvider, useLightboxContext] =\n\tcreateSafeContext<LightboxContext>(\n\t\t\"Lightbox component was not found in the tree\",\n\t);\n"],"names":[],"mappings":";;;AAEY,CAAA,CAAA,CAAA,CAAA,CAAA,CAAC,CAAC,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAgB,CAAA,CAAE,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAkB,CAAC,GAAG,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAiB,CAAA;AACvE,CAAA,CAAE,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA;AACF,CAAA,CAAA;;"}
1
+ {"version":3,"file":"Lightbox.context.mjs","sources":["../../src/Lightbox.context.ts"],"sourcesContent":["import { createSafeContext, type GetStylesApi } from \"@mantine/core\";\nimport type { EmblaCarouselType } from \"embla-carousel\";\nimport type { PointerEvent as ReactPointerEvent, RefObject } from \"react\";\nimport type { LightboxFactory } from \"./Lightbox.js\";\nimport type { ZoomOffset } from \"./utils/zoom.js\";\n\nexport interface LightboxContext {\n\tgetStyles: GetStylesApi<LightboxFactory>;\n\topened: boolean;\n\tcurrentIndex: number;\n\tslideCount: number | null;\n\tslidesEmblaRef: RefObject<EmblaCarouselType | null>;\n\tthumbnailsEmblaRef: RefObject<EmblaCarouselType | null>;\n\tsetCurrentIndex: (index: number) => void;\n\tsetSlideCount: (count: number | null) => void;\n\tonClose: () => void;\n\tonOutsideClick: () => void;\n\tonThumbnailClick: (index: number) => void;\n\tonScrollPrev: () => void;\n\tonScrollNext: () => void;\n\torientation: \"horizontal\" | \"vertical\";\n\t// Zoom\n\twithZoom: boolean;\n\tisZoomed: boolean;\n\tisZoomedRef: RefObject<boolean>;\n\tisDraggingZoom: boolean;\n\tcanZoomCurrent: boolean;\n\tzoomOffset: ZoomOffset;\n\tzoomScale: number;\n\tactiveZoomContainerRef: RefObject<HTMLDivElement | null>;\n\ttoggleZoom: () => void;\n\tupdateCanZoomAvailability: () => void;\n\thandleZoomPointerDown: (event: ReactPointerEvent<HTMLDivElement>) => void;\n\thandleZoomPointerMove: (event: ReactPointerEvent<HTMLDivElement>) => void;\n\thandleZoomPointerEnd: (event: ReactPointerEvent<HTMLDivElement>) => void;\n}\n\nexport const [LightboxProvider, useLightboxContext] =\n\tcreateSafeContext<LightboxContext>(\n\t\t\"Lightbox component was not found in the tree\",\n\t);\n"],"names":[],"mappings":";;;AAEY,CAAA,CAAA,CAAA,CAAA,CAAA,CAAC,CAAC,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAgB,CAAA,CAAE,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAkB,CAAC,GAAG,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAiB,CAAA;AACvE,CAAA,CAAE,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA;AACF,CAAA,CAAA;;"}
@@ -0,0 +1,27 @@
1
+ 'use client';
2
+ const LIGHTBOX_DEFAULT_PROPS = {
3
+ closeOnClickOutside: true,
4
+ keepMounted: false,
5
+ trapFocus: true,
6
+ lockScroll: true,
7
+ returnFocus: true,
8
+ withinPortal: true,
9
+ controlSize: 36,
10
+ carouselOptions: {},
11
+ thumbnailCarouselOptions: {
12
+ dragFree: true
13
+ },
14
+ overlayProps: {
15
+ fixed: true,
16
+ backgroundOpacity: 0.9,
17
+ color: "#18181B",
18
+ zIndex: 200
19
+ },
20
+ transitionProps: {
21
+ transition: "fade",
22
+ duration: 250
23
+ }
24
+ };
25
+
26
+ export { LIGHTBOX_DEFAULT_PROPS };
27
+ //# sourceMappingURL=Lightbox.defaults.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Lightbox.defaults.mjs","sources":["../../src/Lightbox.defaults.ts"],"sourcesContent":["export const LIGHTBOX_DEFAULT_PROPS = {\n\tcloseOnClickOutside: true,\n\tkeepMounted: false,\n\ttrapFocus: true,\n\tlockScroll: true,\n\treturnFocus: true,\n\twithinPortal: true,\n\tcontrolSize: 36,\n\tcarouselOptions: {},\n\tthumbnailCarouselOptions: {\n\t\tdragFree: true,\n\t},\n\toverlayProps: {\n\t\tfixed: true,\n\t\tbackgroundOpacity: 0.9,\n\t\tcolor: \"#18181B\",\n\t\tzIndex: 200,\n\t},\n\ttransitionProps: {\n\t\ttransition: \"fade\",\n\t\tduration: 250,\n\t},\n} as const;\n"],"names":[],"mappings":";AACY,CAAA,CAAA,CAAA,CAAA,CAAA,CAAC,sBAAsB,CAAA,CAAA,CAAG,CAAA;AACtC,CAAA,CAAE,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAmB,EAAE,CAAA,CAAA,CAAA,CAAI,CAAA;AAC3B,CAAA,CAAE,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAW,EAAE,CAAA,CAAA,CAAA,CAAA,CAAK,CAAA;AACpB,CAAA,CAAE,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAS,EAAE,CAAA,CAAA,CAAA,CAAI,CAAA;AACjB,CAAA,CAAE,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAU,EAAE,CAAA,CAAA,CAAA,CAAI,CAAA;AAClB,CAAA,CAAE,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAW,EAAE,CAAA,CAAA,CAAA,CAAI,CAAA;AACnB,CAAA,CAAE,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAY,EAAE,CAAA,CAAA,CAAA,CAAI,CAAA;AACpB,CAAA,CAAE,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAW,EAAE,CAAA,CAAE,CAAA;AACjB,CAAA,CAAE,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAe,EAAE,CAAA,CAAE,CAAA;AACrB,CAAA,CAAE,wBAAwB,CAAA,CAAE,CAAA;AAC5B,CAAA,CAAA,CAAA,CAAI,QAAQ,CAAA,CAAE,CAAA,CAAA,CAAA,CAAA;AACd,CAAA,CAAA,CAAG,CAAA;AACH,CAAA,CAAE,YAAY,CAAA,CAAE,CAAA;AAChB,CAAA,CAAA,CAAA,CAAI,CAAA,CAAA,CAAA,CAAA,CAAK,EAAE,CAAA,CAAA,CAAA,CAAI,CAAA;AACf,CAAA,CAAA,CAAA,CAAI,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAiB,EAAE,CAAA,CAAA,CAAG,CAAA;AAC1B,CAAA,CAAA,CAAA,CAAI,CAAA,CAAA,CAAA,CAAA,CAAK,EAAE,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAS,CAAA;AACpB,CAAA,CAAA,CAAA,CAAI,MAAM,CAAA,CAAE,CAAA,CAAA,CAAA;AACZ,CAAA,CAAA,CAAG,CAAA;AACH,CAAA,CAAE,eAAe,CAAA,CAAE,CAAA;AACnB,CAAA,CAAA,CAAA,CAAI,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAU,EAAE,CAAA,CAAA,CAAA,CAAA,CAAA,CAAM,CAAA;AACtB,CAAA,CAAA,CAAA,CAAI,QAAQ,CAAA,CAAE,CAAA,CAAA,CAAA;AACd,CAAA,CAAA,CAAA;AACA,CAAA,CAAA;;"}
@@ -1,264 +1,60 @@
1
1
  'use client';
2
- import { jsx, jsxs } from 'react/jsx-runtime';
3
- import { Carousel } from '@mantine/carousel';
4
- import { createVarsResolver, factory, useProps, useStyles, Modal, Box, ActionIcon, CloseIcon, Text, UnstyledButton } from '@mantine/core';
5
- import { Children, isValidElement, useRef, useState, useCallback, useEffect } from 'react';
6
- import { LightboxProvider } from './Lightbox.context.mjs';
7
- import classes from './Lightbox.module.css.mjs';
8
- import { LightboxSlide } from './LightboxSlide.mjs';
2
+ import { jsxs, jsx } from 'react/jsx-runtime';
3
+ import { factory, useProps } from '@mantine/core';
4
+ import { LightboxAutoplayButton } from './components/LightboxAutoplayButton.mjs';
5
+ import { LightboxCloseButton } from './components/LightboxCloseButton.mjs';
6
+ import { LightboxControls } from './components/LightboxControls.mjs';
7
+ import { LightboxCounter } from './components/LightboxCounter.mjs';
8
+ import { LightboxFullscreenButton } from './components/LightboxFullscreenButton.mjs';
9
+ import { LightboxRoot } from './components/LightboxRoot.mjs';
10
+ import { LightboxSlide } from './components/LightboxSlide.mjs';
11
+ import { LightboxSlides } from './components/LightboxSlides.mjs';
12
+ import { LightboxThumbnail } from './components/LightboxThumbnail.mjs';
13
+ import { LightboxThumbnails } from './components/LightboxThumbnails.mjs';
14
+ import { LightboxToolbar } from './components/LightboxToolbar.mjs';
15
+ import { LightboxZoomButton } from './components/LightboxZoomButton.mjs';
9
16
 
10
17
  const defaultProps = {
11
- loop: true,
18
+ withToolbar: true,
12
19
  withControls: true,
13
20
  withThumbnails: true,
14
21
  withCounter: true
15
22
  };
16
- const varsResolver = createVarsResolver((_theme) => ({
17
- root: {
18
- "--lightbox-color": "var(--mantine-color-white)",
19
- "--lightbox-thumbnail-size": "48px",
20
- "--lightbox-thumbnail-radius": "var(--mantine-radius-sm)",
21
- "--lightbox-thumbnail-highlight": "var(--mantine-primary-color-filled)"
22
- }
23
- }));
24
- const QuestionMark = () => /* @__PURE__ */ jsxs(
25
- "svg",
26
- {
27
- "aria-hidden": "true",
28
- xmlns: "http://www.w3.org/2000/svg",
29
- width: "16",
30
- height: "16",
31
- viewBox: "0 0 24 24",
32
- fill: "none",
33
- stroke: "currentColor",
34
- strokeWidth: "2",
35
- strokeLinecap: "round",
36
- strokeLinejoin: "round",
37
- children: [
38
- /* @__PURE__ */ jsx("path", { d: "M9.09 9a3 3 0 0 1 5.83 1c0 2-3 3-3 3" }),
39
- /* @__PURE__ */ jsx("path", { d: "M12 17h.01" })
40
- ]
41
- }
42
- );
43
- const ChevronLeft = () => /* @__PURE__ */ jsx(
44
- "svg",
45
- {
46
- "aria-hidden": "true",
47
- xmlns: "http://www.w3.org/2000/svg",
48
- width: "24",
49
- height: "24",
50
- viewBox: "0 0 24 24",
51
- fill: "none",
52
- stroke: "currentColor",
53
- strokeWidth: "2",
54
- strokeLinecap: "round",
55
- strokeLinejoin: "round",
56
- children: /* @__PURE__ */ jsx("path", { d: "m15 18-6-6 6-6" })
57
- }
58
- );
59
- const ChevronRight = () => /* @__PURE__ */ jsx(
60
- "svg",
61
- {
62
- "aria-hidden": "true",
63
- xmlns: "http://www.w3.org/2000/svg",
64
- width: "24",
65
- height: "24",
66
- viewBox: "0 0 24 24",
67
- fill: "none",
68
- stroke: "currentColor",
69
- strokeWidth: "2",
70
- strokeLinecap: "round",
71
- strokeLinejoin: "round",
72
- children: /* @__PURE__ */ jsx("path", { d: "m9 18 6-6-6-6" })
73
- }
74
- );
75
23
  const Lightbox = factory((_props, ref) => {
76
24
  const props = useProps("Lightbox", defaultProps, _props);
77
25
  const {
78
- classNames,
79
- className,
80
- style,
81
- styles,
82
- unstyled,
83
- vars,
84
- opened,
85
- onClose,
86
- initialSlide,
87
- onSlideChange,
88
- loop,
26
+ images,
27
+ withToolbar,
89
28
  withControls,
90
29
  withThumbnails,
91
30
  withCounter,
92
- withZoom: _withZoom,
93
- withFullscreen: _withFullscreen,
94
- withAutoPlay: _withAutoPlay,
95
- counterFormatter,
96
- previousControlIcon,
97
- nextControlIcon,
98
- children,
99
- ...others
31
+ slidesProps,
32
+ thumbnailsProps,
33
+ controlsProps,
34
+ counterProps,
35
+ ...rootProps
100
36
  } = props;
101
- const getStyles = useStyles({
102
- name: "Lightbox",
103
- classes,
104
- props,
105
- className,
106
- style,
107
- classNames,
108
- styles,
109
- unstyled,
110
- vars,
111
- varsResolver
112
- });
113
- const slides = Children.toArray(children).filter(isValidElement);
114
- const total = slides.length;
115
- const emblaRef = useRef(null);
116
- const [currentIndex, setCurrentIndex] = useState(initialSlide ?? 0);
117
- const [canScrollPrev, setCanScrollPrev] = useState(false);
118
- const [canScrollNext, setCanScrollNext] = useState(false);
119
- const handleSlideChange = useCallback(
120
- (index) => {
121
- setCurrentIndex(index);
122
- onSlideChange?.(index);
123
- },
124
- [onSlideChange]
125
- );
126
- const updateCanScroll = useCallback(() => {
127
- const api = emblaRef.current;
128
- if (api) {
129
- setCanScrollPrev(api.canScrollPrev());
130
- setCanScrollNext(api.canScrollNext());
131
- }
132
- }, []);
133
- const handleEmblaApi = useCallback(
134
- (api) => {
135
- emblaRef.current = api;
136
- updateCanScroll();
137
- api.on("select", updateCanScroll);
138
- api.on("init", updateCanScroll);
139
- },
140
- [updateCanScroll]
141
- );
142
- useEffect(() => {
143
- if (!opened) {
144
- return;
145
- }
146
- const handleKeyDown = (event) => {
147
- if (event.key === "ArrowLeft") {
148
- emblaRef.current?.scrollPrev();
149
- } else if (event.key === "ArrowRight") {
150
- emblaRef.current?.scrollNext();
151
- }
152
- };
153
- document.addEventListener("keydown", handleKeyDown);
154
- return () => document.removeEventListener("keydown", handleKeyDown);
155
- }, [opened]);
156
- const counterText = counterFormatter ? counterFormatter(currentIndex, total) : `${currentIndex + 1} / ${total}`;
157
- return /* @__PURE__ */ jsx(
158
- Modal,
159
- {
160
- opened,
161
- onClose,
162
- fullScreen: true,
163
- withCloseButton: false,
164
- radius: 0,
165
- padding: 0,
166
- xOffset: 0,
167
- yOffset: 0,
168
- styles: {
169
- inner: {
170
- left: 0,
171
- right: 0
172
- },
173
- content: {
174
- background: "transparent"
175
- }
176
- },
177
- overlayProps: {
178
- style: {
179
- backgroundColor: "rgba(24, 24, 27, .95)"
180
- }
181
- },
182
- children: /* @__PURE__ */ jsx(LightboxProvider, { value: { getStyles }, children: /* @__PURE__ */ jsxs(Box, { ref, ...getStyles("root"), ...others, children: [
183
- /* @__PURE__ */ jsx(ActionIcon.Group, { ...getStyles("toolbar"), children: /* @__PURE__ */ jsx(
184
- ActionIcon,
185
- {
186
- variant: "default",
187
- size: "lg",
188
- onClick: onClose,
189
- "aria-label": "Close lightbox",
190
- ...getStyles("closeButton"),
191
- children: /* @__PURE__ */ jsx(CloseIcon, {})
192
- }
193
- ) }),
194
- withCounter && /* @__PURE__ */ jsx(Text, { size: "sm", ...getStyles("counter"), children: counterText }),
195
- withControls && /* @__PURE__ */ jsx(
196
- ActionIcon,
197
- {
198
- variant: "filled",
199
- color: "gray",
200
- size: "xl",
201
- radius: "xl",
202
- onClick: () => emblaRef.current?.scrollPrev(),
203
- disabled: !canScrollPrev,
204
- "aria-label": "Previous image",
205
- "data-position": "previous",
206
- ...getStyles("control"),
207
- children: previousControlIcon ?? /* @__PURE__ */ jsx(ChevronLeft, {})
208
- }
209
- ),
210
- /* @__PURE__ */ jsx(
211
- Carousel,
212
- {
213
- withControls: false,
214
- height: "100%",
215
- slideSize: "100%",
216
- slideGap: 0,
217
- emblaOptions: { loop },
218
- initialSlide,
219
- onSlideChange: handleSlideChange,
220
- getEmblaApi: handleEmblaApi,
221
- ...getStyles("slides"),
222
- children
223
- }
224
- ),
225
- withControls && /* @__PURE__ */ jsx(
226
- ActionIcon,
227
- {
228
- variant: "filled",
229
- color: "gray",
230
- size: "xl",
231
- radius: "xl",
232
- onClick: () => emblaRef.current?.scrollNext(),
233
- disabled: !canScrollNext,
234
- "aria-label": "Next image",
235
- "data-position": "next",
236
- ...getStyles("control"),
237
- children: nextControlIcon ?? /* @__PURE__ */ jsx(ChevronRight, {})
238
- }
239
- ),
240
- withThumbnails && /* @__PURE__ */ jsx(Box, { ...getStyles("thumbnails"), children: slides.map((slide, i) => {
241
- const { thumbnail } = slide.props;
242
- return /* @__PURE__ */ jsx(
243
- UnstyledButton,
244
- {
245
- onClick: () => emblaRef.current?.scrollTo(i),
246
- "aria-label": `Go to slide ${i + 1}`,
247
- "aria-current": i === currentIndex ? "true" : void 0,
248
- "data-active": i === currentIndex || void 0,
249
- ...getStyles("thumbnailButton"),
250
- children: thumbnail ?? /* @__PURE__ */ jsx(Box, { ...getStyles("thumbnailPlaceholder"), children: /* @__PURE__ */ jsx(QuestionMark, {}) })
251
- },
252
- slide.key ?? i
253
- );
254
- }) })
255
- ] }) })
256
- }
257
- );
37
+ return /* @__PURE__ */ jsxs(LightboxRoot, { ref, ...rootProps, children: [
38
+ withToolbar && /* @__PURE__ */ jsx(LightboxToolbar, {}),
39
+ withCounter && /* @__PURE__ */ jsx(LightboxCounter, { ...counterProps }),
40
+ withControls && /* @__PURE__ */ jsx(LightboxControls, { ...controlsProps }),
41
+ /* @__PURE__ */ jsx(LightboxSlides, { ...slidesProps, children: images.map((img) => /* @__PURE__ */ jsx(LightboxSlide, { children: /* @__PURE__ */ jsx("img", { src: img.src, alt: img.alt }) }, img.src)) }),
42
+ withThumbnails && /* @__PURE__ */ jsx(LightboxThumbnails, { ...thumbnailsProps, children: images.map((img) => /* @__PURE__ */ jsx(LightboxThumbnail, { children: /* @__PURE__ */ jsx("img", { src: img.src, alt: img.alt }) }, img.src)) })
43
+ ] });
258
44
  });
259
45
  Lightbox.displayName = "Lightbox";
260
- Lightbox.classes = classes;
46
+ Lightbox.Root = LightboxRoot;
47
+ Lightbox.Toolbar = LightboxToolbar;
48
+ Lightbox.Counter = LightboxCounter;
49
+ Lightbox.Controls = LightboxControls;
50
+ Lightbox.Slides = LightboxSlides;
261
51
  Lightbox.Slide = LightboxSlide;
52
+ Lightbox.Thumbnails = LightboxThumbnails;
53
+ Lightbox.Thumbnail = LightboxThumbnail;
54
+ Lightbox.CloseButton = LightboxCloseButton;
55
+ Lightbox.ZoomButton = LightboxZoomButton;
56
+ Lightbox.FullscreenButton = LightboxFullscreenButton;
57
+ Lightbox.AutoplayButton = LightboxAutoplayButton;
262
58
 
263
59
  export { Lightbox };
264
60
  //# sourceMappingURL=Lightbox.mjs.map