dune-react 0.0.31 → 0.0.32

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 (345) hide show
  1. package/dist/components/puck-base/article-card.d.ts +2 -2
  2. package/dist/components/puck-base/article-card.js +2 -2
  3. package/dist/components/puck-base/card.d.ts +2 -2
  4. package/dist/components/puck-base/card.js +2 -2
  5. package/dist/components/puck-base/index.d.ts +2 -1
  6. package/dist/components/puck-base/media.d.ts +12 -0
  7. package/dist/components/puck-base/media.js +576 -0
  8. package/dist/components/puck-base/social-links.d.ts +7 -0
  9. package/dist/components/puck-base/social-links.js +23 -0
  10. package/dist/components/puck-block/banner-sections/css-marquee-banner/css-marquee-banner.js +6 -6
  11. package/dist/components/puck-block/banner-sections/css-marquee-banner/index.d.ts +1 -1
  12. package/dist/components/puck-block/banner-sections/css-marquee-banner/index.js +2 -2
  13. package/dist/components/puck-block/banner-sections/dismissible-banner/index.d.ts +42 -0
  14. package/dist/components/puck-block/banner-sections/dual-row-marquee/dual-row-marquee.js +10 -10
  15. package/dist/components/puck-block/banner-sections/dual-row-marquee/index.d.ts +2 -2
  16. package/dist/components/puck-block/banner-sections/dual-row-marquee/index.js +3 -3
  17. package/dist/components/puck-block/banner-sections/props.d.ts +9 -12
  18. package/dist/components/puck-block/contact-sections/centered-form/centered-form.js +1 -5
  19. package/dist/components/puck-block/contact-sections/contact-cards-grid/contact-cards-grid.js +1 -5
  20. package/dist/components/puck-block/contact-sections/contact-modal/contact-modal.js +1 -5
  21. package/dist/components/puck-block/contact-sections/form-with-media/form-with-media.js +4 -8
  22. package/dist/components/puck-block/contact-sections/form-with-media/index.d.ts +1 -1
  23. package/dist/components/puck-block/contact-sections/form-with-media/index.js +2 -2
  24. package/dist/components/puck-block/contact-sections/header-form-cards/header-form-cards.js +1 -5
  25. package/dist/components/puck-block/contact-sections/header-info-fullwidth/header-info-fullwidth.js +4 -8
  26. package/dist/components/puck-block/contact-sections/header-info-fullwidth/index.d.ts +1 -1
  27. package/dist/components/puck-block/contact-sections/header-info-fullwidth/index.js +2 -2
  28. package/dist/components/puck-block/contact-sections/info-cards-media/index.d.ts +1 -1
  29. package/dist/components/puck-block/contact-sections/info-cards-media/index.js +2 -2
  30. package/dist/components/puck-block/contact-sections/info-cards-media/info-cards-media.js +4 -8
  31. package/dist/components/puck-block/contact-sections/location-cards-grid/index.d.ts +1 -1
  32. package/dist/components/puck-block/contact-sections/location-cards-grid/index.js +2 -2
  33. package/dist/components/puck-block/contact-sections/location-cards-grid/location-cards-grid.js +10 -14
  34. package/dist/components/puck-block/contact-sections/props.d.ts +5 -16
  35. package/dist/components/puck-block/contact-sections/split-info-form/index.d.ts +1 -1
  36. package/dist/components/puck-block/contact-sections/split-info-form/split-info-form.d.ts +7 -2
  37. package/dist/components/puck-block/contact-sections/split-info-form/split-info-form.js +1 -2
  38. package/dist/components/puck-block/contact-sections/tab-locations/index.d.ts +57 -8
  39. package/dist/components/puck-block/contact-sections/tab-locations/index.js +7 -7
  40. package/dist/components/puck-block/contact-sections/tab-locations/tab-locations.js +40 -47
  41. package/dist/components/puck-block/cta-sections/feature-card-cta/feature-card-cta.d.ts +2 -2
  42. package/dist/components/puck-block/cta-sections/feature-card-cta/feature-card-cta.js +2 -2
  43. package/dist/components/puck-block/cta-sections/feature-card-cta/index.js +2 -2
  44. package/dist/components/puck-block/cta-sections/mouse-track-cta/index.d.ts +1 -1
  45. package/dist/components/puck-block/cta-sections/mouse-track-cta/index.js +2 -2
  46. package/dist/components/puck-block/cta-sections/mouse-track-cta/mouse-track-cta.d.ts +2 -2
  47. package/dist/components/puck-block/cta-sections/mouse-track-cta/mouse-track-cta.js +6 -6
  48. package/dist/components/puck-block/cta-sections/props.d.ts +3 -3
  49. package/dist/components/puck-block/cta-sections/side-media-cta/index.d.ts +1 -1
  50. package/dist/components/puck-block/cta-sections/side-media-cta/index.js +2 -2
  51. package/dist/components/puck-block/cta-sections/side-media-cta/side-media-cta.js +4 -4
  52. package/dist/components/puck-block/cta-sections/text-block-cta/index.d.ts +2 -2
  53. package/dist/components/puck-block/cta-sections/text-block-cta/index.js +3 -3
  54. package/dist/components/puck-block/cta-sections/text-block-cta/text-block-cta.d.ts +3 -3
  55. package/dist/components/puck-block/cta-sections/text-block-cta/text-block-cta.js +10 -10
  56. package/dist/components/puck-block/faq-sections/icon-card-faq/icon-card-faq.d.ts +2 -2
  57. package/dist/components/puck-block/faq-sections/icon-card-faq/icon-card-faq.js +2 -2
  58. package/dist/components/puck-block/faq-sections/icon-card-faq/index.js +2 -2
  59. package/dist/components/puck-block/faq-sections/props.d.ts +3 -3
  60. package/dist/components/puck-block/feature-sections/feature-cards-grid/component.d.ts +2 -2
  61. package/dist/components/puck-block/feature-sections/feature-cards-grid/component.js +6 -6
  62. package/dist/components/puck-block/feature-sections/feature-cards-grid/index.d.ts +1 -1
  63. package/dist/components/puck-block/feature-sections/feature-cards-grid/index.js +3 -3
  64. package/dist/components/puck-block/feature-sections/feature-list-split/component.d.ts +2 -2
  65. package/dist/components/puck-block/feature-sections/feature-list-split/component.js +6 -6
  66. package/dist/components/puck-block/feature-sections/feature-list-split/index.d.ts +1 -1
  67. package/dist/components/puck-block/feature-sections/feature-list-split/index.js +3 -3
  68. package/dist/components/puck-block/feature-sections/props.d.ts +3 -3
  69. package/dist/components/puck-block/feature-sections/tab-feature/component.d.ts +2 -2
  70. package/dist/components/puck-block/feature-sections/tab-feature/component.js +12 -12
  71. package/dist/components/puck-block/feature-sections/tab-feature/index.d.ts +1 -1
  72. package/dist/components/puck-block/feature-sections/tab-feature/index.js +2 -2
  73. package/dist/components/puck-block/feature-sections/text-media-split/component.js +5 -5
  74. package/dist/components/puck-block/feature-sections/text-media-split/index.d.ts +1 -1
  75. package/dist/components/puck-block/feature-sections/text-media-split/index.js +2 -2
  76. package/dist/components/puck-block/feature-sections/text-only-section/component.d.ts +2 -2
  77. package/dist/components/puck-block/feature-sections/text-only-section/component.js +2 -2
  78. package/dist/components/puck-block/feature-sections/text-only-section/index.d.ts +1 -1
  79. package/dist/components/puck-block/feature-sections/text-only-section/index.js +2 -2
  80. package/dist/components/puck-block/footer-sections/centered-minimal-footer/centered-minimal-footer.js +9 -9
  81. package/dist/components/puck-block/footer-sections/centered-minimal-footer/index.js +2 -2
  82. package/dist/components/puck-block/footer-sections/contact-links-footer/contact-links-footer.d.ts +7 -2
  83. package/dist/components/puck-block/footer-sections/contact-links-footer/contact-links-footer.js +9 -9
  84. package/dist/components/puck-block/footer-sections/contact-links-footer/index.d.ts +50 -10
  85. package/dist/components/puck-block/footer-sections/contact-links-footer/index.js +3 -2
  86. package/dist/components/puck-block/footer-sections/cta-links-footer/cta-links-footer.js +9 -9
  87. package/dist/components/puck-block/footer-sections/cta-links-footer/index.d.ts +50 -10
  88. package/dist/components/puck-block/footer-sections/cta-links-footer/index.js +3 -3
  89. package/dist/components/puck-block/footer-sections/links-newsletter-footer/index.d.ts +50 -10
  90. package/dist/components/puck-block/footer-sections/newsletter-top-links-footer/index.d.ts +50 -10
  91. package/dist/components/puck-block/footer-sections/props.d.ts +17 -10
  92. package/dist/components/puck-block/footer-sections/props.js +8 -0
  93. package/dist/components/puck-block/gallery-sections/asymmetric-grid/asymmetric-grid.js +7 -7
  94. package/dist/components/puck-block/gallery-sections/asymmetric-grid/index.d.ts +1 -1
  95. package/dist/components/puck-block/gallery-sections/asymmetric-grid/index.js +2 -2
  96. package/dist/components/puck-block/gallery-sections/fullscreen-portfolio/fullscreen-portfolio.js +12 -12
  97. package/dist/components/puck-block/gallery-sections/fullscreen-portfolio/index.d.ts +1 -1
  98. package/dist/components/puck-block/gallery-sections/fullscreen-portfolio/index.js +2 -2
  99. package/dist/components/puck-block/gallery-sections/image-carousel/image-carousel.js +12 -12
  100. package/dist/components/puck-block/gallery-sections/image-carousel/index.d.ts +1 -1
  101. package/dist/components/puck-block/gallery-sections/image-carousel/index.js +2 -2
  102. package/dist/components/puck-block/gallery-sections/interactive-portfolio/index.d.ts +1 -1
  103. package/dist/components/puck-block/gallery-sections/interactive-portfolio/index.js +2 -2
  104. package/dist/components/puck-block/gallery-sections/interactive-portfolio/interactive-portfolio.js +14 -14
  105. package/dist/components/puck-block/gallery-sections/masonry-grid/index.d.ts +1 -1
  106. package/dist/components/puck-block/gallery-sections/masonry-grid/index.js +2 -2
  107. package/dist/components/puck-block/gallery-sections/masonry-grid/masonry-grid.js +7 -7
  108. package/dist/components/puck-block/gallery-sections/portfolio-cards/index.d.ts +1 -1
  109. package/dist/components/puck-block/gallery-sections/portfolio-cards/index.js +2 -2
  110. package/dist/components/puck-block/gallery-sections/portfolio-cards/portfolio-cards.js +6 -6
  111. package/dist/components/puck-block/gallery-sections/portfolio-divider/index.d.ts +1 -1
  112. package/dist/components/puck-block/gallery-sections/portfolio-divider/index.js +2 -2
  113. package/dist/components/puck-block/gallery-sections/portfolio-divider/portfolio-divider.js +9 -9
  114. package/dist/components/puck-block/gallery-sections/props.d.ts +8 -8
  115. package/dist/components/puck-block/gallery-sections/scroll-parallax/index.d.ts +1 -1
  116. package/dist/components/puck-block/gallery-sections/scroll-parallax/index.js +2 -2
  117. package/dist/components/puck-block/gallery-sections/scroll-parallax/scroll-parallax.js +11 -11
  118. package/dist/components/puck-block/gallery-sections/scroll-parallax-portfolio/index.d.ts +1 -1
  119. package/dist/components/puck-block/gallery-sections/scroll-parallax-portfolio/index.js +5 -5
  120. package/dist/components/puck-block/gallery-sections/scroll-parallax-portfolio/scroll-parallax-portfolio.js +26 -26
  121. package/dist/components/puck-block/gallery-sections/split-carousel/index.d.ts +1 -1
  122. package/dist/components/puck-block/gallery-sections/split-carousel/index.js +2 -2
  123. package/dist/components/puck-block/gallery-sections/split-carousel/split-carousel.js +6 -6
  124. package/dist/components/puck-block/gallery-sections/static-grid/index.d.ts +1 -1
  125. package/dist/components/puck-block/gallery-sections/static-grid/index.js +2 -2
  126. package/dist/components/puck-block/gallery-sections/static-grid/static-grid.js +7 -7
  127. package/dist/components/puck-block/header-sections/centered-navbar/centered-navbar.js +31 -24
  128. package/dist/components/puck-block/header-sections/centered-navbar/index.d.ts +81 -0
  129. package/dist/components/puck-block/header-sections/centered-navbar/index.js +8 -4
  130. package/dist/components/puck-block/header-sections/drawer-navbar/drawer-navbar.js +32 -25
  131. package/dist/components/puck-block/header-sections/drawer-navbar/index.d.ts +81 -0
  132. package/dist/components/puck-block/header-sections/drawer-navbar/index.js +5 -3
  133. package/dist/components/puck-block/header-sections/floating-bordered-navbar/floating-bordered-navbar.js +27 -22
  134. package/dist/components/puck-block/header-sections/floating-bordered-navbar/index.d.ts +80 -3
  135. package/dist/components/puck-block/header-sections/floating-bordered-navbar/index.js +3 -3
  136. package/dist/components/puck-block/header-sections/fullscreen-overlay-navbar/fullscreen-overlay-navbar.js +23 -18
  137. package/dist/components/puck-block/header-sections/fullscreen-overlay-navbar/index.d.ts +80 -3
  138. package/dist/components/puck-block/header-sections/fullscreen-overlay-navbar/index.js +3 -3
  139. package/dist/components/puck-block/header-sections/mega-menu-navbar/index.d.ts +53 -0
  140. package/dist/components/puck-block/header-sections/mega-menu-navbar/index.js +3 -3
  141. package/dist/components/puck-block/header-sections/mega-menu-navbar/mega-menu-navbar.js +13 -6
  142. package/dist/components/puck-block/header-sections/props.d.ts +17 -5
  143. package/dist/components/puck-block/header-sections/props.js +8 -0
  144. package/dist/components/puck-block/header-sections/standard-navbar/index.d.ts +53 -0
  145. package/dist/components/puck-block/header-sections/standard-navbar/index.js +5 -4
  146. package/dist/components/puck-block/header-sections/standard-navbar/standard-navbar.js +9 -5
  147. package/dist/components/puck-block/hero-sections/carousel-hero/component.js +8 -8
  148. package/dist/components/puck-block/hero-sections/carousel-hero/index.d.ts +1 -1
  149. package/dist/components/puck-block/hero-sections/carousel-hero/index.js +2 -2
  150. package/dist/components/puck-block/hero-sections/column-scroll-hero/component.d.ts +3 -3
  151. package/dist/components/puck-block/hero-sections/column-scroll-hero/component.js +14 -14
  152. package/dist/components/puck-block/hero-sections/column-scroll-hero/index.d.ts +2 -2
  153. package/dist/components/puck-block/hero-sections/column-scroll-hero/index.js +3 -3
  154. package/dist/components/puck-block/hero-sections/dual-marquee-hero/component.js +11 -11
  155. package/dist/components/puck-block/hero-sections/dual-marquee-hero/index.d.ts +1 -1
  156. package/dist/components/puck-block/hero-sections/dual-marquee-hero/index.js +2 -2
  157. package/dist/components/puck-block/hero-sections/fullscreen-hero/index.d.ts +1 -1
  158. package/dist/components/puck-block/hero-sections/fullscreen-video-hero/component.js +5 -5
  159. package/dist/components/puck-block/hero-sections/fullscreen-video-hero/index.d.ts +1 -1
  160. package/dist/components/puck-block/hero-sections/fullscreen-video-hero/index.js +2 -2
  161. package/dist/components/puck-block/hero-sections/grid-expand-hero/component.js +16 -16
  162. package/dist/components/puck-block/hero-sections/grid-expand-hero/index.d.ts +1 -1
  163. package/dist/components/puck-block/hero-sections/grid-expand-hero/index.js +2 -2
  164. package/dist/components/puck-block/hero-sections/horizontal-marquee-hero/component.js +11 -11
  165. package/dist/components/puck-block/hero-sections/horizontal-marquee-hero/index.d.ts +1 -1
  166. package/dist/components/puck-block/hero-sections/horizontal-marquee-hero/index.js +2 -2
  167. package/dist/components/puck-block/hero-sections/media-text-hero/index.d.ts +1 -1
  168. package/dist/components/puck-block/hero-sections/mouse-track-hero/component.d.ts +3 -3
  169. package/dist/components/puck-block/hero-sections/mouse-track-hero/component.js +6 -6
  170. package/dist/components/puck-block/hero-sections/mouse-track-hero/index.js +3 -3
  171. package/dist/components/puck-block/hero-sections/multi-image-grid-hero/index.d.ts +1 -1
  172. package/dist/components/puck-block/hero-sections/multi-image-grid-hero/index.js +2 -2
  173. package/dist/components/puck-block/hero-sections/multi-image-grid-hero/multi-image-grid-hero.js +7 -7
  174. package/dist/components/puck-block/hero-sections/overlapping-image-hero/index.js +4 -4
  175. package/dist/components/puck-block/hero-sections/overlapping-image-hero/overlapping-image-hero.d.ts +4 -4
  176. package/dist/components/puck-block/hero-sections/overlapping-image-hero/overlapping-image-hero.js +16 -16
  177. package/dist/components/puck-block/hero-sections/parallax-images-hero/component.js +12 -12
  178. package/dist/components/puck-block/hero-sections/parallax-images-hero/index.d.ts +1 -1
  179. package/dist/components/puck-block/hero-sections/parallax-images-hero/index.js +2 -2
  180. package/dist/components/puck-block/hero-sections/props.d.ts +3 -3
  181. package/dist/components/puck-block/hero-sections/scatter-parallax-hero/component.js +5 -5
  182. package/dist/components/puck-block/hero-sections/scatter-parallax-hero/index.d.ts +1 -1
  183. package/dist/components/puck-block/hero-sections/scatter-parallax-hero/index.js +2 -2
  184. package/dist/components/puck-block/hero-sections/scroll-expand-video-hero/component.js +5 -5
  185. package/dist/components/puck-block/hero-sections/scroll-expand-video-hero/index.d.ts +1 -1
  186. package/dist/components/puck-block/hero-sections/scroll-expand-video-hero/index.js +2 -2
  187. package/dist/components/puck-block/hero-sections/scroll-zoom-hero/component.js +9 -9
  188. package/dist/components/puck-block/hero-sections/scroll-zoom-hero/index.d.ts +1 -1
  189. package/dist/components/puck-block/hero-sections/scroll-zoom-hero/index.js +2 -2
  190. package/dist/components/puck-block/hero-sections/split-hero/index.d.ts +1 -1
  191. package/dist/components/puck-block/hero-sections/stacked-hero/index.d.ts +1 -1
  192. package/dist/components/puck-block/hero-sections/sticky-expand-hero/component.js +12 -12
  193. package/dist/components/puck-block/hero-sections/sticky-expand-hero/index.d.ts +1 -1
  194. package/dist/components/puck-block/hero-sections/sticky-expand-hero/index.js +2 -2
  195. package/dist/components/puck-block/hero-sections/sticky-video-hero/component.d.ts +2 -2
  196. package/dist/components/puck-block/hero-sections/sticky-video-hero/component.js +13 -13
  197. package/dist/components/puck-block/hero-sections/sticky-video-hero/index.d.ts +1 -1
  198. package/dist/components/puck-block/hero-sections/sticky-video-hero/index.js +3 -3
  199. package/dist/components/puck-block/hero-sections/tab-hero/component.d.ts +2 -2
  200. package/dist/components/puck-block/hero-sections/tab-hero/component.js +6 -6
  201. package/dist/components/puck-block/hero-sections/tab-hero/index.d.ts +1 -1
  202. package/dist/components/puck-block/hero-sections/tab-hero/index.js +2 -2
  203. package/dist/components/puck-block/hero-sections/three-image-parallax-hero/component.d.ts +4 -4
  204. package/dist/components/puck-block/hero-sections/three-image-parallax-hero/component.js +4 -4
  205. package/dist/components/puck-block/hero-sections/three-image-parallax-hero/index.js +4 -4
  206. package/dist/components/puck-block/hero-sections/vertical-gallery-hero/component.js +11 -11
  207. package/dist/components/puck-block/hero-sections/vertical-gallery-hero/index.d.ts +1 -1
  208. package/dist/components/puck-block/hero-sections/vertical-gallery-hero/index.js +2 -2
  209. package/dist/components/puck-block/hero-sections/zoom-grid-hero/component.js +7 -7
  210. package/dist/components/puck-block/hero-sections/zoom-grid-hero/index.d.ts +1 -1
  211. package/dist/components/puck-block/hero-sections/zoom-grid-hero/index.js +2 -2
  212. package/dist/components/puck-block/metrics-sections/center-media-stats/center-media-stats.js +5 -5
  213. package/dist/components/puck-block/metrics-sections/center-media-stats/index.d.ts +1 -1
  214. package/dist/components/puck-block/metrics-sections/center-media-stats/index.js +2 -2
  215. package/dist/components/puck-block/metrics-sections/header-stats-row/header-stats-row.js +4 -4
  216. package/dist/components/puck-block/metrics-sections/header-stats-row/index.d.ts +1 -1
  217. package/dist/components/puck-block/metrics-sections/header-stats-row/index.js +2 -2
  218. package/dist/components/puck-block/metrics-sections/mixed-grid-stats/index.d.ts +2 -2
  219. package/dist/components/puck-block/metrics-sections/mixed-grid-stats/index.js +3 -3
  220. package/dist/components/puck-block/metrics-sections/mixed-grid-stats/mixed-grid-stats.d.ts +2 -2
  221. package/dist/components/puck-block/metrics-sections/mixed-grid-stats/mixed-grid-stats.js +7 -7
  222. package/dist/components/puck-block/metrics-sections/props.d.ts +6 -6
  223. package/dist/components/puck-block/metrics-sections/split-stats/index.d.ts +1 -1
  224. package/dist/components/puck-block/metrics-sections/split-stats/index.js +2 -2
  225. package/dist/components/puck-block/metrics-sections/split-stats/split-stats.js +4 -4
  226. package/dist/components/puck-block/metrics-sections/tab-stats/index.d.ts +2 -2
  227. package/dist/components/puck-block/metrics-sections/tab-stats/index.js +3 -3
  228. package/dist/components/puck-block/metrics-sections/tab-stats/tab-stats.d.ts +3 -3
  229. package/dist/components/puck-block/metrics-sections/tab-stats/tab-stats.js +11 -11
  230. package/dist/components/puck-block/pricing-sections/props.d.ts +2 -2
  231. package/dist/components/puck-block/pricing-sections/single-pricing-card/component.d.ts +2 -2
  232. package/dist/components/puck-block/pricing-sections/single-pricing-card/component.js +3 -3
  233. package/dist/components/puck-block/pricing-sections/split-pricing/component.d.ts +2 -2
  234. package/dist/components/puck-block/pricing-sections/split-pricing/component.js +2 -2
  235. package/dist/components/puck-block/pricing-sections/tab-pricing-grid/component.d.ts +2 -2
  236. package/dist/components/puck-block/pricing-sections/tab-single-pricing/component.d.ts +2 -2
  237. package/dist/components/puck-block/registry.generated.d.ts +694 -118
  238. package/dist/components/puck-block/showcase-sections/compact-timeline/component.d.ts +2 -2
  239. package/dist/components/puck-block/showcase-sections/compact-timeline/component.js +3 -3
  240. package/dist/components/puck-block/showcase-sections/compact-timeline/index.d.ts +2 -2
  241. package/dist/components/puck-block/showcase-sections/compact-timeline/index.js +2 -2
  242. package/dist/components/puck-block/showcase-sections/horizontal-timeline/component.d.ts +2 -2
  243. package/dist/components/puck-block/showcase-sections/horizontal-timeline/component.js +3 -3
  244. package/dist/components/puck-block/showcase-sections/horizontal-timeline/index.d.ts +2 -2
  245. package/dist/components/puck-block/showcase-sections/horizontal-timeline/index.js +2 -2
  246. package/dist/components/puck-block/showcase-sections/props.d.ts +2 -2
  247. package/dist/components/puck-block/showcase-sections/single-column-timeline/component.d.ts +2 -2
  248. package/dist/components/puck-block/showcase-sections/single-column-timeline/component.js +3 -3
  249. package/dist/components/puck-block/showcase-sections/single-column-timeline/index.d.ts +2 -2
  250. package/dist/components/puck-block/showcase-sections/single-column-timeline/index.js +2 -2
  251. package/dist/components/puck-block/showcase-sections/sticky-scroll-timeline/component.d.ts +2 -2
  252. package/dist/components/puck-block/showcase-sections/sticky-scroll-timeline/component.js +3 -3
  253. package/dist/components/puck-block/showcase-sections/sticky-scroll-timeline/index.d.ts +2 -2
  254. package/dist/components/puck-block/showcase-sections/sticky-scroll-timeline/index.js +2 -2
  255. package/dist/components/puck-block/showcase-sections/tab-timeline/component.d.ts +2 -2
  256. package/dist/components/puck-block/showcase-sections/tab-timeline/component.js +8 -8
  257. package/dist/components/puck-block/showcase-sections/tab-timeline/index.d.ts +2 -2
  258. package/dist/components/puck-block/showcase-sections/tab-timeline/index.js +2 -2
  259. package/dist/components/puck-block/showcase-sections/zigzag-timeline/component.d.ts +2 -2
  260. package/dist/components/puck-block/showcase-sections/zigzag-timeline/component.js +3 -3
  261. package/dist/components/puck-block/showcase-sections/zigzag-timeline/index.d.ts +2 -2
  262. package/dist/components/puck-block/showcase-sections/zigzag-timeline/index.js +2 -2
  263. package/dist/components/puck-block/team-sections/props.d.ts +2 -3
  264. package/dist/components/puck-block/team-sections/team-carousel/component.d.ts +2 -2
  265. package/dist/components/puck-block/team-sections/team-carousel/component.js +3 -3
  266. package/dist/components/puck-block/team-sections/team-grid/component.d.ts +2 -2
  267. package/dist/components/puck-block/team-sections/team-grid/component.js +3 -3
  268. package/dist/components/puck-block/team-sections/team-inline-card/component.d.ts +2 -2
  269. package/dist/components/puck-block/team-sections/team-inline-card/component.js +3 -3
  270. package/dist/components/puck-block/team-sections/team-sticky-scatter/component.d.ts +2 -2
  271. package/dist/components/puck-block/team-sections/team-sticky-scatter/component.js +3 -3
  272. package/dist/components/puck-block/team-sections/team-two-column/component.d.ts +2 -2
  273. package/dist/components/puck-block/team-sections/team-two-column/component.js +3 -3
  274. package/dist/components/puck-block/testimonial-sections/bento-testimonial/component.d.ts +4 -4
  275. package/dist/components/puck-block/testimonial-sections/bento-testimonial/component.js +8 -8
  276. package/dist/components/puck-block/testimonial-sections/centered-testimonial/component.d.ts +3 -3
  277. package/dist/components/puck-block/testimonial-sections/centered-testimonial/component.js +4 -4
  278. package/dist/components/puck-block/testimonial-sections/centered-testimonial/index.js +3 -3
  279. package/dist/components/puck-block/testimonial-sections/halfscreen-testimonial-carousel/component.d.ts +3 -3
  280. package/dist/components/puck-block/testimonial-sections/halfscreen-testimonial-carousel/component.js +3 -3
  281. package/dist/components/puck-block/testimonial-sections/image-testimonial/component.d.ts +3 -3
  282. package/dist/components/puck-block/testimonial-sections/image-testimonial/component.js +10 -10
  283. package/dist/components/puck-block/testimonial-sections/image-testimonial/index.d.ts +1 -1
  284. package/dist/components/puck-block/testimonial-sections/image-testimonial/index.js +3 -3
  285. package/dist/components/puck-block/testimonial-sections/image-testimonial-carousel/component.d.ts +3 -3
  286. package/dist/components/puck-block/testimonial-sections/image-testimonial-carousel/component.js +7 -7
  287. package/dist/components/puck-block/testimonial-sections/image-testimonial-carousel/index.d.ts +1 -1
  288. package/dist/components/puck-block/testimonial-sections/image-testimonial-carousel/index.js +3 -3
  289. package/dist/components/puck-block/testimonial-sections/marquee-testimonial/component.d.ts +2 -2
  290. package/dist/components/puck-block/testimonial-sections/marquee-testimonial/component.js +2 -2
  291. package/dist/components/puck-block/testimonial-sections/masonry-testimonial/component.d.ts +2 -2
  292. package/dist/components/puck-block/testimonial-sections/masonry-testimonial/component.js +2 -2
  293. package/dist/components/puck-block/testimonial-sections/props.d.ts +3 -4
  294. package/dist/components/puck-block/testimonial-sections/sticky-testimonial/component.d.ts +3 -2
  295. package/dist/components/puck-block/testimonial-sections/sticky-testimonial/component.js +6 -3
  296. package/dist/components/puck-block/testimonial-sections/tab-testimonial/component.d.ts +4 -4
  297. package/dist/components/puck-block/testimonial-sections/tab-testimonial/component.js +5 -5
  298. package/dist/components/puck-block/testimonial-sections/testimonial-card-grid/component.d.ts +4 -4
  299. package/dist/components/puck-block/testimonial-sections/testimonial-card-grid/component.js +6 -6
  300. package/dist/components/puck-block/testimonial-sections/testimonial-carousel/component.d.ts +3 -3
  301. package/dist/components/puck-block/testimonial-sections/testimonial-carousel/component.js +3 -3
  302. package/dist/components/puck-block/text-sections/blog-article/component.d.ts +4 -7
  303. package/dist/components/puck-block/text-sections/blog-article/component.js +9 -17
  304. package/dist/components/puck-block/text-sections/blog-article/index.d.ts +39 -14
  305. package/dist/components/puck-block/text-sections/blog-article/index.js +4 -10
  306. package/dist/components/puck-block/text-sections/props.d.ts +3 -3
  307. package/dist/components/puck-block/text-sections/prose-content/component.d.ts +2 -2
  308. package/dist/components/puck-block/text-sections/prose-content/component.js +3 -3
  309. package/dist/components/puck-block/text-sections/prose-content/index.d.ts +1 -1
  310. package/dist/components/puck-block/text-sections/prose-content/index.js +2 -2
  311. package/dist/components/puck-block/text-sections/prose-sidebar/component.d.ts +2 -2
  312. package/dist/components/puck-block/text-sections/prose-sidebar/index.d.ts +1 -1
  313. package/dist/components/puck-block/text-sections/side-media-content/component.js +5 -5
  314. package/dist/components/puck-block/text-sections/side-media-content/index.d.ts +1 -1
  315. package/dist/components/puck-block/text-sections/side-media-content/index.js +2 -2
  316. package/dist/components/puck-block/text-sections/sticky-text-multi-image/component.d.ts +2 -2
  317. package/dist/components/puck-block/text-sections/sticky-text-multi-image/component.js +4 -4
  318. package/dist/components/puck-block/text-sections/sticky-text-multi-image/index.d.ts +2 -2
  319. package/dist/components/puck-block/text-sections/sticky-text-multi-image/index.js +2 -2
  320. package/dist/components/puck-block/text-sections/text-header/component.d.ts +2 -2
  321. package/dist/components/puck-block/text-sections/text-header/index.d.ts +1 -1
  322. package/dist/components/puck-core/core/context/editor-context.d.ts +2 -0
  323. package/dist/components/puck-core/core/fields.d.ts +2 -2
  324. package/dist/components/puck-core/core/props/content.d.ts +3 -3
  325. package/dist/components/puck-core/core/props/index.d.ts +2 -2
  326. package/dist/components/puck-core/core/props/index.js +7 -0
  327. package/dist/components/puck-core/core/props/interactive.d.ts +44 -1
  328. package/dist/components/puck-core/core/props/interactive.js +24 -1
  329. package/dist/components/puck-core/core/props/media.d.ts +8 -8
  330. package/dist/components/puck-core/core/props/media.js +21 -21
  331. package/dist/components/puck-core/core/social-icons.d.ts +5 -0
  332. package/dist/components/puck-core/core/social-icons.js +48 -0
  333. package/dist/components/puck-core/core/with-editable.js +9 -2
  334. package/dist/components/puck-core/fields/media-upload-field.d.ts +7 -0
  335. package/dist/components/puck-core/fields/{image-upload-field.js → media-upload-field.js} +71 -28
  336. package/dist/components/puck-core/index.d.ts +2 -2
  337. package/dist/components/shadcn/tabs.d.ts +2 -1
  338. package/dist/components/shadcn/tabs.js +21 -3
  339. package/dist/components/shadcn/video-iframe.d.ts +2 -1
  340. package/dist/components/shadcn/video-iframe.js +7 -6
  341. package/dist/index.js +15 -12
  342. package/package.json +1 -1
  343. package/dist/components/puck-base/image.d.ts +0 -6
  344. package/dist/components/puck-base/image.js +0 -360
  345. package/dist/components/puck-core/fields/image-upload-field.d.ts +0 -7
@@ -1,4 +1,4 @@
1
- export { ImageUploadField } from "./fields/image-upload-field";
1
+ export { MediaUploadField } from "./fields/media-upload-field";
2
2
  export { ActionField, ACTION_TYPE_FIELD_MAP, ACTION_TYPE_OPTIONS, PageActionFields, ExternalActionFields, EmailActionFields, PhoneActionFields, SectionActionFields, DownloadActionFields, type ActionTypeFieldProps, AutoField, type FieldDef, type AutoFieldProps, type FieldsPanelProps, } from "./fields";
3
3
  export { type IconName, type Feature, type ActionType, type Action, resolveActionUrl, } from "./core/types";
4
4
  export { withEditable } from "./core/with-editable";
@@ -10,4 +10,4 @@ export { SectionWrapper, type SectionWrapperProps } from "./section-wrapper";
10
10
  export { EditorContextProvider, useEditorContext } from "./core/context/editor-context";
11
11
  export { SectionIdProvider, useSectionId } from "./core/context/section-id-context";
12
12
  export { default as useUpload, type UploadFileItem, type UploadStatus, type UseUploadOptions } from "./use-upload";
13
- export { icon, action, actionDefaults, button, buttons, badge, image, images, padding, paddingDefaults, paddingLevel, heading, description, features, contentFields, contentFieldsWithFeatures, card, cards, field, fieldDefaults, form, formDefaults, getPlaceholderImageUrl, image16x9Placeholder, image1x1Placeholder, image9x16Placeholder, sectionStyle, sectionOverlay, backgroundColor, backgroundImage, } from "./core/fields";
13
+ export { icon, action, actionDefaults, button, buttons, badge, media, medias, padding, paddingDefaults, paddingLevel, heading, description, features, contentFields, contentFieldsWithFeatures, card, cards, field, fieldDefaults, form, formDefaults, getPlaceholderMediaUrl, media16x9Placeholder, media1x1Placeholder, media9x16Placeholder, sectionStyle, sectionOverlay, backgroundColor, backgroundImage, } from "./core/fields";
@@ -7,4 +7,5 @@ declare const tabsListVariants: (props?: ({
7
7
  declare function TabsList({ className, variant, ...props }: TabsPrimitive.List.Props & VariantProps<typeof tabsListVariants>): import("react/jsx-runtime").JSX.Element;
8
8
  declare function TabsTrigger({ className, ...props }: TabsPrimitive.Tab.Props): import("react/jsx-runtime").JSX.Element;
9
9
  declare function TabsContent({ className, ...props }: TabsPrimitive.Panel.Props): import("react/jsx-runtime").JSX.Element;
10
- export { Tabs, TabsList, TabsTrigger, TabsContent, tabsListVariants };
10
+ declare function TabsIndicator({ className, ...props }: TabsPrimitive.Indicator.Props): import("react/jsx-runtime").JSX.Element;
11
+ export { Tabs, TabsList, TabsTrigger, TabsContent, TabsIndicator, tabsListVariants };
@@ -22,7 +22,7 @@ function Tabs({
22
22
  );
23
23
  }
24
24
  const tabsListVariants = cva(
25
- "group/tabs-list inline-flex w-fit items-center justify-center rounded-lg p-[3px] text-muted-foreground group-data-horizontal/tabs:h-9 group-data-vertical/tabs:h-fit group-data-vertical/tabs:flex-col data-[variant=line]:rounded-none",
25
+ "group/tabs-list inline-flex w-fit items-center justify-center rounded-lg p-[3px] text-muted-foreground group-data-horizontal/tabs:h-8 group-data-vertical/tabs:h-fit group-data-vertical/tabs:flex-col data-[variant=line]:rounded-none",
26
26
  {
27
27
  variants: {
28
28
  variant: {
@@ -56,7 +56,7 @@ function TabsTrigger({ className, ...props }) {
56
56
  {
57
57
  "data-slot": "tabs-trigger",
58
58
  className: cn(
59
- "relative inline-flex h-[calc(100%-1px)] flex-1 items-center justify-center gap-1.5 rounded-md border border-transparent px-2 py-1 text-sm font-medium whitespace-nowrap text-foreground/60 transition-all group-data-vertical/tabs:w-full group-data-vertical/tabs:justify-start hover:text-foreground focus-visible:border-ring focus-visible:ring-[3px] focus-visible:ring-ring/50 focus-visible:outline-1 focus-visible:outline-ring disabled:pointer-events-none disabled:opacity-50 aria-disabled:pointer-events-none aria-disabled:opacity-50 dark:text-muted-foreground dark:hover:text-foreground group-data-[variant=default]/tabs-list:data-active:shadow-sm group-data-[variant=line]/tabs-list:data-active:shadow-none [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4",
59
+ "relative inline-flex h-[calc(100%-1px)] flex-1 items-center justify-center gap-1.5 rounded-md border border-transparent px-1.5 py-0.5 text-sm font-medium whitespace-nowrap text-foreground/60 transition-all group-data-vertical/tabs:w-full group-data-vertical/tabs:justify-start hover:text-foreground focus-visible:border-ring focus-visible:ring-[3px] focus-visible:ring-ring/50 focus-visible:outline-1 focus-visible:outline-ring disabled:pointer-events-none disabled:opacity-50 has-data-[icon=inline-end]:pr-1 has-data-[icon=inline-start]:pl-1 aria-disabled:pointer-events-none aria-disabled:opacity-50 dark:text-muted-foreground dark:hover:text-foreground group-data-[variant=default]/tabs-list:data-active:shadow-sm group-data-[variant=line]/tabs-list:data-active:shadow-none [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4",
60
60
  "group-data-[variant=line]/tabs-list:bg-transparent group-data-[variant=line]/tabs-list:data-active:bg-transparent dark:group-data-[variant=line]/tabs-list:data-active:border-transparent dark:group-data-[variant=line]/tabs-list:data-active:bg-transparent",
61
61
  "data-active:bg-background data-active:text-foreground dark:data-active:border-input dark:data-active:bg-input/30 dark:data-active:text-foreground",
62
62
  "after:absolute after:bg-foreground after:opacity-0 after:transition-opacity group-data-horizontal/tabs:after:inset-x-0 group-data-horizontal/tabs:after:bottom-[-5px] group-data-horizontal/tabs:after:h-0.5 group-data-vertical/tabs:after:inset-y-0 group-data-vertical/tabs:after:-right-1 group-data-vertical/tabs:after:w-0.5 group-data-[variant=line]/tabs-list:data-active:after:opacity-100",
@@ -71,7 +71,24 @@ function TabsContent({ className, ...props }) {
71
71
  Tabs$1.Panel,
72
72
  {
73
73
  "data-slot": "tabs-content",
74
- className: cn("flex-1 outline-none", className),
74
+ className: cn("flex-1 text-sm outline-none", className),
75
+ ...props
76
+ }
77
+ );
78
+ }
79
+ function TabsIndicator({ className, ...props }) {
80
+ return /* @__PURE__ */ jsx(
81
+ Tabs$1.Indicator,
82
+ {
83
+ "data-slot": "tabs-indicator",
84
+ className: cn(
85
+ "absolute bottom-0 h-0.5 rounded-full bg-foreground transition-all duration-200 ease-out",
86
+ "group-data-vertical/tabs:bottom-auto group-data-vertical/tabs:left-0 group-data-vertical/tabs:h-auto group-data-vertical/tabs:w-0.5",
87
+ className
88
+ ),
89
+ style: {
90
+ transitionProperty: "left, right, top, bottom, width, height"
91
+ },
75
92
  ...props
76
93
  }
77
94
  );
@@ -79,6 +96,7 @@ function TabsContent({ className, ...props }) {
79
96
  export {
80
97
  Tabs,
81
98
  TabsContent,
99
+ TabsIndicator,
82
100
  TabsList,
83
101
  TabsTrigger,
84
102
  tabsListVariants
@@ -1,6 +1,7 @@
1
1
  interface VideoIframeProps {
2
2
  video: string;
3
3
  className?: string;
4
+ autoplay?: boolean;
4
5
  }
5
- export declare function VideoIframe({ video, className }: VideoIframeProps): import("react/jsx-runtime").JSX.Element;
6
+ export declare function VideoIframe({ video, className, autoplay }: VideoIframeProps): import("react/jsx-runtime").JSX.Element;
6
7
  export {};
@@ -3,16 +3,17 @@ import { jsxs, jsx } from "react/jsx-runtime";
3
3
  import { useState } from "react";
4
4
  import { cn } from "../../utils/css-utils.js";
5
5
  import { CgSpinner } from "../../node_modules/.pnpm/react-icons@5.6.0_react@19.2.4/node_modules/react-icons/cg/index.js";
6
- function getEmbedUrl(url) {
6
+ function getEmbedUrl(url, autoplay = true) {
7
+ const ap = autoplay ? "?autoplay=1" : "";
7
8
  const ytMatch = url.match(
8
- /(?:youtube\.com\/(?:watch\?v=|embed\/)|youtu\.be\/)([a-zA-Z0-9_-]+)/
9
+ /(?:youtube\.com\/(?:watch\?v=|embed\/|shorts\/)|youtu\.be\/)([a-zA-Z0-9_-]+)/
9
10
  );
10
- if (ytMatch) return `https://www.youtube.com/embed/${ytMatch[1]}?autoplay=1`;
11
+ if (ytMatch) return `https://www.youtube.com/embed/${ytMatch[1]}${ap}`;
11
12
  const vimeoMatch = url.match(/vimeo\.com\/(\d+)/);
12
- if (vimeoMatch) return `https://player.vimeo.com/video/${vimeoMatch[1]}?autoplay=1`;
13
+ if (vimeoMatch) return `https://player.vimeo.com/video/${vimeoMatch[1]}${ap}`;
13
14
  return url;
14
15
  }
15
- function VideoIframe({ video, className }) {
16
+ function VideoIframe({ video, className, autoplay = true }) {
16
17
  const [loaded, setLoaded] = useState(false);
17
18
  return /* @__PURE__ */ jsxs("div", { className: cn("relative aspect-video w-full", className), children: [
18
19
  !loaded && /* @__PURE__ */ jsx("div", { className: "absolute inset-0 flex items-center justify-center", children: /* @__PURE__ */ jsx(CgSpinner, { className: "size-8 animate-spin text-muted-foreground" }) }),
@@ -20,7 +21,7 @@ function VideoIframe({ video, className }) {
20
21
  "iframe",
21
22
  {
22
23
  className: "size-full",
23
- src: getEmbedUrl(video),
24
+ src: getEmbedUrl(video, autoplay),
24
25
  allow: "autoplay; fullscreen",
25
26
  allowFullScreen: true,
26
27
  onLoad: () => setLoaded(true)
package/dist/index.js CHANGED
@@ -139,7 +139,8 @@ import { CompoundContainer } from "./components/puck-base/container.js";
139
139
  import { CompoundContent } from "./components/puck-base/content.js";
140
140
  import { CompoundField, fieldTypes } from "./components/puck-base/field.js";
141
141
  import { CompoundForm, formMethods } from "./components/puck-base/form.js";
142
- import { CompoundImage } from "./components/puck-base/image.js";
142
+ import { CompoundMedia } from "./components/puck-base/media.js";
143
+ import { CompoundSocialLinks } from "./components/puck-base/social-links.js";
143
144
  import { ContextMenu, ContextMenuCheckboxItem, ContextMenuContent, ContextMenuGroup, ContextMenuItem, ContextMenuLabel, ContextMenuPortal, ContextMenuRadioGroup, ContextMenuRadioItem, ContextMenuSeparator, ContextMenuShortcut, ContextMenuSub, ContextMenuSubContent, ContextMenuSubTrigger, ContextMenuTrigger } from "./components/shadcn/context-menu.js";
144
145
  import { Cover } from "./components/ui-block/cover/index.js";
145
146
  import { Dialog, DialogClose, DialogContent, DialogDescription, DialogFooter, DialogHeader, DialogOverlay, DialogPortal, DialogTitle, DialogTrigger } from "./components/shadcn/dialog.js";
@@ -153,7 +154,6 @@ import { Field, FieldContent, FieldDescription, FieldError, FieldGroup, FieldLab
153
154
  import { Form, FormControl, FormDescription, FormField, FormItem, FormLabel, FormMessage } from "./components/shadcn/form.js";
154
155
  import { GradientText } from "./components/puck-base/gradient-text.js";
155
156
  import { HoverCard, HoverCardContent, HoverCardTrigger } from "./components/shadcn/hover-card.js";
156
- import { ImageUploadField } from "./components/puck-core/fields/image-upload-field.js";
157
157
  import { InlineEditable } from "./components/puck-core/inline-editable.js";
158
158
  import { Input } from "./components/shadcn/input.js";
159
159
  import { InputGroup, InputGroupAddon, InputGroupButton, InputGroupInput, InputGroupText, InputGroupTextarea } from "./components/shadcn/input-group.js";
@@ -162,6 +162,7 @@ import { Item, ItemActions, ItemContent, ItemDescription, ItemFooter, ItemGroup,
162
162
  import { Kbd, KbdGroup } from "./components/shadcn/kbd.js";
163
163
  import { Label } from "./components/shadcn/label.js";
164
164
  import { LayoutTextFlip } from "./components/shadcn/layout-text-flip.js";
165
+ import { MediaUploadField } from "./components/puck-core/fields/media-upload-field.js";
165
166
  import { Menubar, MenubarCheckboxItem, MenubarContent, MenubarGroup, MenubarItem, MenubarLabel, MenubarMenu, MenubarPortal, MenubarRadioGroup, MenubarRadioItem, MenubarSeparator, MenubarShortcut, MenubarSub, MenubarSubContent, MenubarSubTrigger, MenubarTrigger } from "./components/shadcn/menubar.js";
166
167
  import { MobileNav, MobileNavHeader, MobileNavMenu, MobileNavToggle, NavBody, NavItems, Navbar, NavbarButton, NavbarLogo } from "./components/shadcn/resizable-navbar.js";
167
168
  import { NativeSelect, NativeSelectOptGroup, NativeSelectOption } from "./components/shadcn/native-select.js";
@@ -186,7 +187,7 @@ import { Spinner } from "./components/shadcn/spinner.js";
186
187
  import { Spotlight } from "./components/ui-block/spotlight/index.js";
187
188
  import { Switch } from "./components/shadcn/switch.js";
188
189
  import { Table, TableBody, TableCaption, TableCell, TableFooter, TableHead, TableHeader, TableRow } from "./components/shadcn/table.js";
189
- import { Tabs, TabsContent, TabsList, TabsTrigger, tabsListVariants } from "./components/shadcn/tabs.js";
190
+ import { Tabs, TabsContent, TabsIndicator, TabsList, TabsTrigger, tabsListVariants } from "./components/shadcn/tabs.js";
190
191
  import { Textarea } from "./components/shadcn/textarea.js";
191
192
  import { Toaster } from "./components/shadcn/sonner.js";
192
193
  import { Toggle, toggleVariants } from "./components/shadcn/toggle.js";
@@ -207,7 +208,7 @@ import { filterEmptyValues } from "./utils/utils-common.js";
207
208
  import { findComponentById, getRandomAdjective } from "./components/puck-core/core/utils.js";
208
209
  import { formatLargeNumber, getUrlWithParams } from "./utils/utils-api.js";
209
210
  import { formatTimeAgo, formatTimeString, getTimeDetails, getTimestamp, sleep, timeAgo } from "./utils/utils-time.js";
210
- import { getPlaceholderImageUrl, imageField, image16x9Placeholder, image1x1Placeholder, image9x16Placeholder, imagesField } from "./components/puck-core/core/props/media.js";
211
+ import { getPlaceholderMediaUrl, mediaField, media16x9Placeholder, media1x1Placeholder, media9x16Placeholder, mediasField } from "./components/puck-core/core/props/media.js";
211
212
  import { nanoid } from "./utils/utils-random.js";
212
213
  import { usePuckAppState, usePuckConfig, usePuckDispatch, usePuckGetSelectorForId, usePuckHistory } from "./components/puck-core/core/hooks.js";
213
214
  import { withEditable } from "./components/puck-core/core/with-editable.js";
@@ -325,7 +326,8 @@ export {
325
326
  CompoundContent,
326
327
  CompoundField,
327
328
  CompoundForm,
328
- CompoundImage,
329
+ CompoundMedia,
330
+ CompoundSocialLinks,
329
331
  default15 as ContactCardsGridConf,
330
332
  default16 as ContactLinksFooterConf,
331
333
  default17 as ContactModalConf,
@@ -438,7 +440,6 @@ export {
438
440
  default40 as ImageCarouselConf,
439
441
  default41 as ImageTestimonialCarouselConf,
440
442
  default42 as ImageTestimonialConf,
441
- ImageUploadField,
442
443
  default43 as InfoCardsMediaConf,
443
444
  InlineEditable,
444
445
  default44 as InlineImageHeroConf,
@@ -475,6 +476,7 @@ export {
475
476
  default47 as MarqueeTestimonialConf,
476
477
  default48 as MasonryGridConf,
477
478
  default49 as MasonryTestimonialConf,
479
+ MediaUploadField,
478
480
  default50 as MegaMenuNavbarConf,
479
481
  Menubar,
480
482
  MenubarCheckboxItem,
@@ -645,6 +647,7 @@ export {
645
647
  TableRow,
646
648
  Tabs,
647
649
  TabsContent,
650
+ TabsIndicator,
648
651
  TabsList,
649
652
  TabsTrigger,
650
653
  default95 as TeamCarouselConf,
@@ -715,21 +718,21 @@ export {
715
718
  formatTimeString,
716
719
  getBase64Client,
717
720
  getComponentDefaultProps,
718
- getPlaceholderImageUrl,
721
+ getPlaceholderMediaUrl,
719
722
  getRandomAdjective,
720
723
  getTimeDetails,
721
724
  getTimestamp,
722
725
  getUrlWithParams,
723
726
  headingField as heading,
724
727
  iconField as icon,
725
- imageField as image,
726
- image16x9Placeholder,
727
- image1x1Placeholder,
728
- image9x16Placeholder,
729
- imagesField as images,
730
728
  isValidFileSize,
731
729
  isValidFileType,
732
730
  liquidGlass,
731
+ mediaField as media,
732
+ media16x9Placeholder,
733
+ media1x1Placeholder,
734
+ media9x16Placeholder,
735
+ mediasField as medias,
733
736
  nanoid,
734
737
  navigationMenuTriggerStyle,
735
738
  padding,
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "dune-react",
3
- "version": "0.0.31",
3
+ "version": "0.0.32",
4
4
  "license": "MIT",
5
5
  "type": "module",
6
6
  "scripts": {
@@ -1,6 +0,0 @@
1
- export interface CompoundImageProps {
2
- src: string;
3
- alt?: string;
4
- className?: string;
5
- }
6
- export declare const CompoundImage: (props: CompoundImageProps) => import("react/jsx-runtime").JSX.Element;
@@ -1,360 +0,0 @@
1
- "use client";
2
- import { jsxs, Fragment, jsx } from "react/jsx-runtime";
3
- import { useState, useEffect, useRef, useCallback } from "react";
4
- import Cropper from "react-easy-crop";
5
- import { Pencil, Search, Upload, Loader2, Check } from "lucide-react";
6
- import { cn } from "../../utils/css-utils.js";
7
- import { withEditable } from "../puck-core/core/with-editable.js";
8
- import { Button } from "../shadcn/button.js";
9
- import { Dialog, DialogContent, DialogHeader, DialogTitle, DialogFooter } from "../shadcn/dialog.js";
10
- import { Input } from "../shadcn/input.js";
11
- import { Label } from "../shadcn/label.js";
12
- import { ScrollArea } from "../shadcn/scroll-area.js";
13
- import { Slider } from "../shadcn/slider.js";
14
- import { Tabs, TabsList, TabsTrigger } from "../shadcn/tabs.js";
15
- import useUpload from "../puck-core/use-upload.js";
16
- import { useEditorContext } from "../puck-core/core/context/editor-context.js";
17
- import { imageField } from "../puck-core/core/props/media.js";
18
- const createImage = (url) => new Promise((resolve, reject) => {
19
- const image = new Image();
20
- image.addEventListener("load", () => resolve(image));
21
- image.addEventListener("error", (error) => reject(error));
22
- image.setAttribute("crossOrigin", "anonymous");
23
- image.src = url;
24
- });
25
- const getCroppedImg = async (imageSrc, pixelCrop, rotation) => {
26
- const image = await createImage(imageSrc);
27
- const canvas = document.createElement("canvas");
28
- const ctx = canvas.getContext("2d");
29
- const maxSize = Math.max(image.width, image.height);
30
- const safeArea = 2 * (maxSize / 2 * Math.sqrt(2));
31
- canvas.width = safeArea;
32
- canvas.height = safeArea;
33
- ctx.translate(safeArea / 2, safeArea / 2);
34
- ctx.rotate(rotation * Math.PI / 180);
35
- ctx.translate(-safeArea / 2, -safeArea / 2);
36
- ctx.drawImage(
37
- image,
38
- safeArea / 2 - image.width * 0.5,
39
- safeArea / 2 - image.height * 0.5
40
- );
41
- const data = ctx.getImageData(0, 0, safeArea, safeArea);
42
- canvas.width = pixelCrop.width;
43
- canvas.height = pixelCrop.height;
44
- ctx.putImageData(
45
- data,
46
- Math.round(0 - safeArea / 2 + image.width * 0.5 - pixelCrop.x),
47
- Math.round(0 - safeArea / 2 + image.height * 0.5 - pixelCrop.y)
48
- );
49
- return new Promise((resolve) => {
50
- canvas.toBlob((blob) => resolve(blob), "image/jpeg", 0.95);
51
- });
52
- };
53
- const DEFAULT_LIBRARY_IMAGES = [];
54
- function CompoundImageBase(props) {
55
- return /* @__PURE__ */ jsx(
56
- "img",
57
- {
58
- src: props.src,
59
- alt: props.alt,
60
- className: cn("block h-full w-full", props.className)
61
- }
62
- );
63
- }
64
- function ImageEditDialog({
65
- open,
66
- onOpenChange,
67
- initialData,
68
- onSave
69
- }) {
70
- const [tab, setTab] = useState("library");
71
- const [alt, setAlt] = useState(initialData.alt ?? "");
72
- const [libraryImages, setLibraryImages] = useState(
73
- DEFAULT_LIBRARY_IMAGES
74
- );
75
- const [isLoadingImages, setIsLoadingImages] = useState(false);
76
- const { fetchLibraryImages } = useEditorContext();
77
- useEffect(() => {
78
- if (!open || !fetchLibraryImages) return;
79
- setIsLoadingImages(true);
80
- fetchLibraryImages().then((images) => {
81
- if (images.length > 0) setLibraryImages(images);
82
- }).catch(() => {
83
- }).finally(() => setIsLoadingImages(false));
84
- }, [open, fetchLibraryImages]);
85
- const [crop, setCrop] = useState({ x: 0, y: 0 });
86
- const [zoom, setZoom] = useState(1);
87
- const [rotation, setRotation] = useState(0);
88
- const [croppedAreaPixels, setCroppedAreaPixels] = useState(null);
89
- const [selectedImg, setSelectedImg] = useState(null);
90
- const replaceInputRef = useRef(null);
91
- const handleClose = useCallback(() => {
92
- onOpenChange(false);
93
- setCrop({ x: 0, y: 0 });
94
- setZoom(1);
95
- setRotation(0);
96
- setSelectedImg(null);
97
- }, [onOpenChange]);
98
- const { upload: uploadCrop, isUploading: isCropUploading } = useUpload({
99
- onSuccess: (url) => {
100
- onSave({ src: url, alt });
101
- handleClose();
102
- }
103
- });
104
- const { upload: uploadReplace, isUploading: isReplaceUploading } = useUpload({
105
- onSuccess: (url) => {
106
- onSave({ src: url, alt });
107
- handleClose();
108
- }
109
- });
110
- const handleCropSave = useCallback(async () => {
111
- if (!croppedAreaPixels || !initialData.src) return;
112
- try {
113
- const croppedBlob = await getCroppedImg(
114
- initialData.src,
115
- croppedAreaPixels,
116
- rotation
117
- );
118
- const file = new File([croppedBlob], "cropped-image.jpg", {
119
- type: "image/jpeg"
120
- });
121
- await uploadCrop(file);
122
- } catch (error) {
123
- console.error("Crop failed:", error);
124
- }
125
- }, [croppedAreaPixels, initialData.src, rotation, uploadCrop]);
126
- const handleFileReplace = useCallback(
127
- (e) => {
128
- var _a;
129
- const file = (_a = e.target.files) == null ? void 0 : _a[0];
130
- if (file) uploadReplace(file);
131
- e.target.value = "";
132
- },
133
- [uploadReplace]
134
- );
135
- const handleLibraryDone = useCallback(() => {
136
- if (!selectedImg) return;
137
- onSave({ src: selectedImg, alt });
138
- handleClose();
139
- }, [selectedImg, alt, onSave, handleClose]);
140
- return /* @__PURE__ */ jsx(Dialog, { open, onOpenChange: (o) => !o && handleClose(), children: /* @__PURE__ */ jsxs(DialogContent, { className: "flex max-h-[80vh] max-w-lg flex-col gap-0 overflow-hidden p-0", children: [
141
- /* @__PURE__ */ jsx(DialogHeader, { className: "px-6 pt-5 pb-0", children: /* @__PURE__ */ jsx(DialogTitle, { className: "text-base font-semibold", children: "Edit Image" }) }),
142
- /* @__PURE__ */ jsxs(
143
- Tabs,
144
- {
145
- value: tab,
146
- onValueChange: (v) => setTab(v),
147
- className: "flex flex-1 flex-col overflow-hidden",
148
- children: [
149
- /* @__PURE__ */ jsxs(TabsList, { className: "mx-6 mt-3 bg-transparent", children: [
150
- /* @__PURE__ */ jsxs(TabsTrigger, { value: "adjust", children: [
151
- /* @__PURE__ */ jsx(Pencil, {}),
152
- "Crop"
153
- ] }),
154
- /* @__PURE__ */ jsxs(TabsTrigger, { value: "library", children: [
155
- /* @__PURE__ */ jsx(Search, {}),
156
- "Library"
157
- ] }),
158
- /* @__PURE__ */ jsxs(TabsTrigger, { value: "upload", children: [
159
- /* @__PURE__ */ jsx(Upload, {}),
160
- "Upload"
161
- ] })
162
- ] }),
163
- /* @__PURE__ */ jsxs("div", { className: "mt-3 flex-1 overflow-hidden", children: [
164
- /* @__PURE__ */ jsxs("div", { className: cn("flex flex-col", tab !== "adjust" && "hidden"), children: [
165
- /* @__PURE__ */ jsx("div", { className: "bg-muted relative h-64", children: /* @__PURE__ */ jsx(
166
- Cropper,
167
- {
168
- image: initialData.src,
169
- crop,
170
- zoom,
171
- rotation,
172
- aspect: 16 / 9,
173
- onCropChange: setCrop,
174
- onZoomChange: setZoom,
175
- onRotationChange: setRotation,
176
- onCropComplete: (_, pixels) => setCroppedAreaPixels(pixels)
177
- }
178
- ) }),
179
- /* @__PURE__ */ jsxs("div", { className: "grid grid-cols-2 gap-4 px-6 py-3", children: [
180
- /* @__PURE__ */ jsxs("div", { className: "flex gap-4", children: [
181
- /* @__PURE__ */ jsx("label", { className: "text-xs font-medium text-gray-500", children: "Zoom" }),
182
- /* @__PURE__ */ jsx(
183
- Slider,
184
- {
185
- className: "flex",
186
- value: [zoom],
187
- onValueChange: (vals) => setZoom(Array.isArray(vals) ? vals[0] ?? 1 : vals),
188
- min: 1,
189
- max: 3,
190
- step: 0.1
191
- }
192
- )
193
- ] }),
194
- /* @__PURE__ */ jsxs("div", { className: "flex gap-4", children: [
195
- /* @__PURE__ */ jsx("label", { className: "text-xs font-medium text-gray-500", children: "Rotation" }),
196
- /* @__PURE__ */ jsx(
197
- Slider,
198
- {
199
- className: "flex",
200
- value: [rotation],
201
- onValueChange: (vals) => setRotation(Array.isArray(vals) ? vals[0] ?? 0 : vals),
202
- min: 0,
203
- max: 360,
204
- step: 1
205
- }
206
- )
207
- ] })
208
- ] })
209
- ] }),
210
- /* @__PURE__ */ jsx(
211
- "div",
212
- {
213
- className: cn(
214
- "flex flex-col gap-3 px-6 py-4",
215
- tab !== "library" && "hidden"
216
- ),
217
- children: /* @__PURE__ */ jsx(ScrollArea, { className: "h-[280px]", children: isLoadingImages ? /* @__PURE__ */ jsx("div", { className: "flex h-full items-center justify-center py-20", children: /* @__PURE__ */ jsx(Loader2, { className: "h-6 w-6 animate-spin text-gray-400" }) }) : libraryImages.length === 0 ? /* @__PURE__ */ jsxs("div", { className: "flex h-full flex-col items-center justify-center py-20 text-center", children: [
218
- /* @__PURE__ */ jsx(Search, { className: "h-8 w-8 text-gray-300" }),
219
- /* @__PURE__ */ jsx("p", { className: "mt-3 text-sm font-medium text-gray-500", children: "No images available" }),
220
- /* @__PURE__ */ jsx("p", { className: "mt-1 text-xs text-gray-400", children: "Try uploading an image instead" })
221
- ] }) : /* @__PURE__ */ jsx("div", { className: "grid grid-cols-3 gap-2", children: libraryImages.map((src) => {
222
- const isSelected = selectedImg === src;
223
- return /* @__PURE__ */ jsxs(
224
- "button",
225
- {
226
- type: "button",
227
- onClick: () => setSelectedImg(src),
228
- className: `relative aspect-4/3 overflow-hidden rounded-lg border-2 transition-all ${isSelected ? "border-blue-500 ring-2 ring-blue-100" : "border-transparent hover:border-gray-300"}`,
229
- children: [
230
- /* @__PURE__ */ jsx(
231
- "img",
232
- {
233
- src,
234
- alt: "",
235
- className: "h-full w-full object-cover"
236
- }
237
- ),
238
- isSelected && /* @__PURE__ */ jsx("div", { className: "absolute top-1.5 right-1.5 flex h-5 w-5 items-center justify-center rounded-full bg-blue-500 shadow-sm", children: /* @__PURE__ */ jsx(Check, { className: "h-3 w-3 text-white" }) })
239
- ]
240
- },
241
- src
242
- );
243
- }) }) })
244
- }
245
- ),
246
- /* @__PURE__ */ jsxs(
247
- "div",
248
- {
249
- className: cn(
250
- "flex flex-col items-center justify-center gap-4 px-6 py-14",
251
- tab !== "upload" && "hidden"
252
- ),
253
- children: [
254
- /* @__PURE__ */ jsx("div", { className: "flex h-14 w-14 items-center justify-center rounded-full bg-gray-100", children: /* @__PURE__ */ jsx(Upload, { className: "h-6 w-6 text-gray-400" }) }),
255
- /* @__PURE__ */ jsxs("div", { className: "text-center", children: [
256
- /* @__PURE__ */ jsx("p", { className: "text-sm font-medium text-gray-700", children: "Upload a new image to replace the current one" }),
257
- /* @__PURE__ */ jsx("p", { className: "mt-1 text-xs text-gray-400", children: "Supports JPG, PNG, WebP formats" })
258
- ] }),
259
- /* @__PURE__ */ jsxs(
260
- Button,
261
- {
262
- variant: "outline",
263
- size: "sm",
264
- onClick: () => {
265
- var _a;
266
- return (_a = replaceInputRef.current) == null ? void 0 : _a.click();
267
- },
268
- disabled: isReplaceUploading,
269
- children: [
270
- isReplaceUploading ? /* @__PURE__ */ jsx(Loader2, { className: "mr-1.5 h-3.5 w-3.5 animate-spin" }) : /* @__PURE__ */ jsx(Upload, { className: "mr-1.5 h-3.5 w-3.5" }),
271
- "Choose File"
272
- ]
273
- }
274
- ),
275
- /* @__PURE__ */ jsx(
276
- "input",
277
- {
278
- ref: replaceInputRef,
279
- type: "file",
280
- accept: "image/*",
281
- onChange: handleFileReplace,
282
- className: "hidden"
283
- }
284
- )
285
- ]
286
- }
287
- )
288
- ] })
289
- ]
290
- }
291
- ),
292
- /* @__PURE__ */ jsx("div", { className: "border-t px-6 py-3", children: /* @__PURE__ */ jsxs("div", { className: "flex gap-2", children: [
293
- /* @__PURE__ */ jsx(Label, { className: "flex-none", children: "Alt Text" }),
294
- /* @__PURE__ */ jsx(
295
- Input,
296
- {
297
- value: alt,
298
- onChange: (e) => setAlt(e.target.value),
299
- placeholder: "Image description..."
300
- }
301
- )
302
- ] }) }),
303
- /* @__PURE__ */ jsxs(DialogFooter, { className: "border-t px-6 py-3", children: [
304
- /* @__PURE__ */ jsx(Button, { variant: "ghost", size: "sm", onClick: handleClose, children: "Cancel" }),
305
- /* @__PURE__ */ jsxs(
306
- Button,
307
- {
308
- size: "sm",
309
- disabled: tab === "library" && !selectedImg || tab === "adjust" && isCropUploading,
310
- onClick: () => {
311
- if (tab === "library") handleLibraryDone();
312
- else if (tab === "adjust") handleCropSave();
313
- else if (tab === "upload") {
314
- onSave({ alt });
315
- handleClose();
316
- }
317
- },
318
- children: [
319
- isCropUploading && /* @__PURE__ */ jsx(Loader2, { className: "mr-1.5 h-3.5 w-3.5 animate-spin" }),
320
- "Done"
321
- ]
322
- }
323
- )
324
- ] })
325
- ] }) });
326
- }
327
- const EditableImage = withEditable(CompoundImageBase, {
328
- type: "image",
329
- fields: imageField.objectFields
330
- });
331
- const CompoundImage = (props) => {
332
- const [dialogOpen, setDialogOpen] = useState(false);
333
- const [dialogData, setDialogData] = useState(null);
334
- const [onSaveCallback, setOnSaveCallback] = useState(null);
335
- return /* @__PURE__ */ jsxs(Fragment, { children: [
336
- /* @__PURE__ */ jsx(
337
- EditableImage,
338
- {
339
- ...props,
340
- onEdit: (currentProps, onSave) => {
341
- setDialogData(currentProps);
342
- setOnSaveCallback(() => onSave);
343
- setDialogOpen(true);
344
- }
345
- }
346
- ),
347
- dialogOpen && dialogData && onSaveCallback && /* @__PURE__ */ jsx(
348
- ImageEditDialog,
349
- {
350
- open: dialogOpen,
351
- onOpenChange: setDialogOpen,
352
- initialData: dialogData,
353
- onSave: onSaveCallback
354
- }
355
- )
356
- ] });
357
- };
358
- export {
359
- CompoundImage
360
- };
@@ -1,7 +0,0 @@
1
- interface ImageUploadFieldProps {
2
- name: string;
3
- value: string;
4
- onChange: (value: string) => void;
5
- }
6
- export declare function ImageUploadField({ name, value, onChange, }: ImageUploadFieldProps): import("react/jsx-runtime").JSX.Element;
7
- export {};