dune-react 0.0.8 → 0.0.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 (227) hide show
  1. package/dist/components/puck-base/article-card.js +1 -1
  2. package/dist/components/puck-base/button.js +2 -1
  3. package/dist/components/puck-base/container.d.ts +7 -1
  4. package/dist/components/puck-base/container.js +2 -1
  5. package/dist/components/puck-base/content.d.ts +1 -4
  6. package/dist/components/puck-base/content.js +15 -17
  7. package/dist/components/puck-base/core/fields.d.ts +1 -127
  8. package/dist/components/puck-base/core/fields.js +1 -76
  9. package/dist/components/puck-base/core/styles.d.ts +1877 -0
  10. package/dist/components/puck-base/core/styles.js +286 -0
  11. package/dist/components/puck-base/core/types.d.ts +2 -2
  12. package/dist/components/puck-base/core/with-editable.d.ts +4 -1
  13. package/dist/components/puck-base/core/with-editable.js +51 -27
  14. package/dist/components/puck-base/editor-context.d.ts +8 -0
  15. package/dist/components/puck-base/fields/auto-field.d.ts +1 -0
  16. package/dist/components/puck-base/fields/auto-field.js +131 -49
  17. package/dist/components/puck-base/gradient-text.js +12 -3
  18. package/dist/components/puck-block/banner-sections/announcement-banner-1/announcement-banner.d.ts +9 -7
  19. package/dist/components/puck-block/banner-sections/announcement-banner-1/announcement-banner.js +11 -8
  20. package/dist/components/puck-block/banner-sections/announcement-banner-1/index.js +19 -37
  21. package/dist/components/puck-block/banner-sections/marquee-1/index.js +26 -24
  22. package/dist/components/puck-block/banner-sections/marquee-1/marquee.d.ts +9 -9
  23. package/dist/components/puck-block/banner-sections/marquee-1/marquee.js +28 -21
  24. package/dist/components/puck-block/banner-sections/props.d.ts +22 -0
  25. package/dist/components/puck-block/contact-sections/api/form-leads.d.ts +16 -0
  26. package/dist/components/puck-block/contact-sections/api/form-leads.js +25 -0
  27. package/dist/components/puck-block/contact-sections/contact-us-1/contact-us.d.ts +13 -4
  28. package/dist/components/puck-block/contact-sections/contact-us-1/contact-us.js +122 -121
  29. package/dist/components/puck-block/contact-sections/contact-us-1/index.js +87 -7
  30. package/dist/components/puck-block/contact-sections/contact-us-2/contact-us-2.d.ts +30 -0
  31. package/dist/components/puck-block/contact-sections/contact-us-2/contact-us-2.js +234 -0
  32. package/dist/components/puck-block/contact-sections/contact-us-2/index.d.ts +5 -0
  33. package/dist/components/puck-block/contact-sections/contact-us-2/index.js +74 -0
  34. package/dist/components/puck-block/contact-sections/contact-us-3/contact-us-3.d.ts +32 -0
  35. package/dist/components/puck-block/contact-sections/contact-us-3/contact-us-3.js +250 -0
  36. package/dist/components/puck-block/contact-sections/contact-us-3/index.d.ts +5 -0
  37. package/dist/components/puck-block/contact-sections/contact-us-3/index.js +114 -0
  38. package/dist/components/puck-block/contact-sections/props.d.ts +65 -0
  39. package/dist/components/puck-block/cta-sections/banner-cta-1/banner-cta.d.ts +12 -9
  40. package/dist/components/puck-block/cta-sections/banner-cta-1/banner-cta.js +28 -30
  41. package/dist/components/puck-block/cta-sections/banner-cta-1/index.js +23 -25
  42. package/dist/components/puck-block/cta-sections/cta-1/cta.d.ts +6 -4
  43. package/dist/components/puck-block/cta-sections/cta-1/cta.js +5 -7
  44. package/dist/components/puck-block/cta-sections/cta-1/index.js +5 -9
  45. package/dist/components/puck-block/cta-sections/gradient-cta-1/gradient-cta.d.ts +10 -10
  46. package/dist/components/puck-block/cta-sections/gradient-cta-1/gradient-cta.js +24 -20
  47. package/dist/components/puck-block/cta-sections/gradient-cta-1/index.js +36 -29
  48. package/dist/components/puck-block/cta-sections/newsletter-signup-1/index.js +13 -5
  49. package/dist/components/puck-block/cta-sections/newsletter-signup-1/newsletter-signup.d.ts +7 -3
  50. package/dist/components/puck-block/cta-sections/newsletter-signup-1/newsletter-signup.js +36 -32
  51. package/dist/components/puck-block/cta-sections/promo-section-1/index.js +4 -5
  52. package/dist/components/puck-block/cta-sections/promo-section-1/promo-section.d.ts +6 -4
  53. package/dist/components/puck-block/cta-sections/promo-section-1/promo-section.js +94 -79
  54. package/dist/components/puck-block/cta-sections/props.d.ts +47 -0
  55. package/dist/components/puck-block/faq-sections/accordion-1/accordion.d.ts +6 -4
  56. package/dist/components/puck-block/faq-sections/accordion-1/accordion.js +39 -33
  57. package/dist/components/puck-block/faq-sections/accordion-1/index.js +3 -5
  58. package/dist/components/puck-block/faq-sections/faq-1/faq.d.ts +9 -7
  59. package/dist/components/puck-block/faq-sections/faq-1/faq.js +50 -44
  60. package/dist/components/puck-block/faq-sections/faq-1/index.js +12 -14
  61. package/dist/components/puck-block/faq-sections/faq-2/faq-2.d.ts +18 -0
  62. package/dist/components/puck-block/faq-sections/faq-2/faq-2.js +54 -0
  63. package/dist/components/puck-block/faq-sections/faq-2/index.d.ts +5 -0
  64. package/dist/components/puck-block/faq-sections/faq-2/index.js +61 -0
  65. package/dist/components/puck-block/faq-sections/props.d.ts +30 -0
  66. package/dist/components/puck-block/feature-sections/bento-1/bento.d.ts +6 -4
  67. package/dist/components/puck-block/feature-sections/bento-1/bento.js +2 -4
  68. package/dist/components/puck-block/feature-sections/bento-1/index.js +4 -5
  69. package/dist/components/puck-block/feature-sections/feature-cards-1/feature-cards.d.ts +8 -7
  70. package/dist/components/puck-block/feature-sections/feature-cards-1/feature-cards.js +15 -7
  71. package/dist/components/puck-block/feature-sections/feature-cards-1/index.js +37 -18
  72. package/dist/components/puck-block/feature-sections/feature-showcase-1/feature-showcase.d.ts +6 -4
  73. package/dist/components/puck-block/feature-sections/feature-showcase-1/feature-showcase.js +4 -12
  74. package/dist/components/puck-block/feature-sections/feature-showcase-1/index.js +4 -5
  75. package/dist/components/puck-block/feature-sections/icon-grid-1/icon-grid.d.ts +6 -4
  76. package/dist/components/puck-block/feature-sections/icon-grid-1/icon-grid.js +59 -53
  77. package/dist/components/puck-block/feature-sections/icon-grid-1/index.js +7 -8
  78. package/dist/components/puck-block/feature-sections/product-features-1/index.js +4 -5
  79. package/dist/components/puck-block/feature-sections/product-features-1/product-features.d.ts +6 -4
  80. package/dist/components/puck-block/feature-sections/product-features-1/product-features.js +7 -29
  81. package/dist/components/puck-block/feature-sections/props.d.ts +48 -0
  82. package/dist/components/puck-block/footer-sections/footer-1/footer.d.ts +5 -3
  83. package/dist/components/puck-block/footer-sections/footer-1/footer.js +6 -6
  84. package/dist/components/puck-block/footer-sections/footer-1/index.js +3 -5
  85. package/dist/components/puck-block/footer-sections/props.d.ts +31 -0
  86. package/dist/components/puck-block/gallery-sections/gallery-1/gallery.d.ts +9 -7
  87. package/dist/components/puck-block/gallery-sections/gallery-1/gallery.js +49 -40
  88. package/dist/components/puck-block/gallery-sections/gallery-1/index.js +32 -34
  89. package/dist/components/puck-block/gallery-sections/gallery-2/gallery-2.d.ts +16 -0
  90. package/dist/components/puck-block/gallery-sections/gallery-2/gallery-2.js +86 -0
  91. package/dist/components/puck-block/gallery-sections/gallery-2/index.d.ts +5 -0
  92. package/dist/components/puck-block/gallery-sections/gallery-2/index.js +42 -0
  93. package/dist/components/puck-block/gallery-sections/gallery-3/gallery-3.d.ts +19 -0
  94. package/dist/components/puck-block/gallery-sections/gallery-3/gallery-3.js +119 -0
  95. package/dist/components/puck-block/gallery-sections/gallery-3/index.d.ts +5 -0
  96. package/dist/components/puck-block/gallery-sections/gallery-3/index.js +59 -0
  97. package/dist/components/puck-block/gallery-sections/props.d.ts +26 -0
  98. package/dist/components/puck-block/header-sections/header-1/header.d.ts +7 -5
  99. package/dist/components/puck-block/header-sections/header-1/header.js +8 -9
  100. package/dist/components/puck-block/header-sections/header-1/index.d.ts +1 -1
  101. package/dist/components/puck-block/header-sections/header-1/index.js +13 -12
  102. package/dist/components/puck-block/header-sections/props.d.ts +41 -0
  103. package/dist/components/puck-block/header-sections/sticky-nav-1/index.js +12 -12
  104. package/dist/components/puck-block/header-sections/sticky-nav-1/sticky-nav.d.ts +8 -6
  105. package/dist/components/puck-block/header-sections/sticky-nav-1/sticky-nav.js +5 -5
  106. package/dist/components/puck-block/hero-sections/fullscreen-hero-1/fullscreen-hero.d.ts +11 -4
  107. package/dist/components/puck-block/hero-sections/fullscreen-hero-1/fullscreen-hero.js +60 -23
  108. package/dist/components/puck-block/hero-sections/fullscreen-hero-1/index.js +18 -6
  109. package/dist/components/puck-block/hero-sections/gradient-hero-1/gradient-hero.d.ts +9 -5
  110. package/dist/components/puck-block/hero-sections/gradient-hero-1/gradient-hero.js +37 -24
  111. package/dist/components/puck-block/hero-sections/gradient-hero-1/index.js +18 -15
  112. package/dist/components/puck-block/hero-sections/grid-hero-1/grid-hero.d.ts +7 -6
  113. package/dist/components/puck-block/hero-sections/grid-hero-1/grid-hero.js +7 -10
  114. package/dist/components/puck-block/hero-sections/grid-hero-1/index.js +43 -11
  115. package/dist/components/puck-block/hero-sections/hero-1/hero.d.ts +6 -4
  116. package/dist/components/puck-block/hero-sections/hero-1/hero.js +5 -7
  117. package/dist/components/puck-block/hero-sections/hero-1/index.js +4 -4
  118. package/dist/components/puck-block/hero-sections/image-hero-1/image-hero.d.ts +14 -8
  119. package/dist/components/puck-block/hero-sections/image-hero-1/image-hero.js +64 -60
  120. package/dist/components/puck-block/hero-sections/image-hero-1/index.js +16 -34
  121. package/dist/components/puck-block/hero-sections/props.d.ts +71 -0
  122. package/dist/components/puck-block/hero-sections/split-hero-1/index.js +6 -5
  123. package/dist/components/puck-block/hero-sections/split-hero-1/split-hero.d.ts +8 -8
  124. package/dist/components/puck-block/hero-sections/split-hero-1/split-hero.js +48 -47
  125. package/dist/components/puck-block/hero-sections/video-hero-1/index.js +4 -3
  126. package/dist/components/puck-block/hero-sections/video-hero-1/video-hero.d.ts +6 -2
  127. package/dist/components/puck-block/hero-sections/video-hero-1/video-hero.js +30 -22
  128. package/dist/components/puck-block/index.d.ts +15 -0
  129. package/dist/components/puck-block/location-sections/location-1/index.d.ts +5 -0
  130. package/dist/components/puck-block/location-sections/location-1/index.js +108 -0
  131. package/dist/components/puck-block/location-sections/location-1/location.d.ts +28 -0
  132. package/dist/components/puck-block/location-sections/location-1/location.js +137 -0
  133. package/dist/components/puck-block/location-sections/location-2/index.d.ts +5 -0
  134. package/dist/components/puck-block/location-sections/location-2/index.js +123 -0
  135. package/dist/components/puck-block/location-sections/location-2/location.d.ts +30 -0
  136. package/dist/components/puck-block/location-sections/location-2/location.js +131 -0
  137. package/dist/components/puck-block/location-sections/location-3/index.d.ts +5 -0
  138. package/dist/components/puck-block/location-sections/location-3/index.js +84 -0
  139. package/dist/components/puck-block/location-sections/location-3/location.d.ts +24 -0
  140. package/dist/components/puck-block/location-sections/location-3/location.js +127 -0
  141. package/dist/components/puck-block/location-sections/props.d.ts +45 -0
  142. package/dist/components/puck-block/metrics-sections/props.d.ts +43 -0
  143. package/dist/components/puck-block/metrics-sections/stats-1/index.js +6 -7
  144. package/dist/components/puck-block/metrics-sections/stats-1/stats.d.ts +7 -5
  145. package/dist/components/puck-block/metrics-sections/stats-1/stats.js +61 -55
  146. package/dist/components/puck-block/metrics-sections/stats-2/index.d.ts +5 -0
  147. package/dist/components/puck-block/metrics-sections/stats-2/index.js +76 -0
  148. package/dist/components/puck-block/metrics-sections/stats-2/stats-2.d.ts +18 -0
  149. package/dist/components/puck-block/metrics-sections/stats-2/stats-2.js +57 -0
  150. package/dist/components/puck-block/metrics-sections/stats-3/index.d.ts +5 -0
  151. package/dist/components/puck-block/metrics-sections/stats-3/index.js +86 -0
  152. package/dist/components/puck-block/metrics-sections/stats-3/stats-3.d.ts +18 -0
  153. package/dist/components/puck-block/metrics-sections/stats-3/stats-3.js +56 -0
  154. package/dist/components/puck-block/pricing-sections/comparison-1/comparison.d.ts +7 -5
  155. package/dist/components/puck-block/pricing-sections/comparison-1/comparison.js +45 -39
  156. package/dist/components/puck-block/pricing-sections/comparison-1/index.js +5 -7
  157. package/dist/components/puck-block/pricing-sections/pricing-1/index.js +10 -11
  158. package/dist/components/puck-block/pricing-sections/pricing-1/pricing.d.ts +8 -6
  159. package/dist/components/puck-block/pricing-sections/pricing-1/pricing.js +47 -35
  160. package/dist/components/puck-block/pricing-sections/pricing-2/index.d.ts +5 -0
  161. package/dist/components/puck-block/pricing-sections/pricing-2/index.js +151 -0
  162. package/dist/components/puck-block/pricing-sections/pricing-2/pricing-2.d.ts +26 -0
  163. package/dist/components/puck-block/pricing-sections/pricing-2/pricing-2.js +71 -0
  164. package/dist/components/puck-block/pricing-sections/props.d.ts +46 -0
  165. package/dist/components/puck-block/showcase-sections/before-after-1/before-after.d.ts +22 -0
  166. package/dist/components/puck-block/showcase-sections/before-after-1/before-after.js +71 -0
  167. package/dist/components/puck-block/showcase-sections/before-after-1/index.d.ts +5 -0
  168. package/dist/components/puck-block/showcase-sections/before-after-1/index.js +73 -0
  169. package/dist/components/puck-block/showcase-sections/case-study-1/case-study.d.ts +6 -2
  170. package/dist/components/puck-block/showcase-sections/case-study-1/case-study.js +30 -28
  171. package/dist/components/puck-block/showcase-sections/case-study-1/index.js +4 -3
  172. package/dist/components/puck-block/showcase-sections/props.d.ts +48 -0
  173. package/dist/components/puck-block/showcase-sections/step-by-step-1/index.js +3 -5
  174. package/dist/components/puck-block/showcase-sections/step-by-step-1/step-by-step.d.ts +6 -4
  175. package/dist/components/puck-block/showcase-sections/step-by-step-1/step-by-step.js +38 -41
  176. package/dist/components/puck-block/team-sections/props.d.ts +39 -0
  177. package/dist/components/puck-block/team-sections/team-grid-1/index.js +4 -5
  178. package/dist/components/puck-block/team-sections/team-grid-1/team-grid.d.ts +6 -4
  179. package/dist/components/puck-block/team-sections/team-grid-1/team-grid.js +27 -41
  180. package/dist/components/puck-block/team-sections/team-grid-2/index.d.ts +5 -0
  181. package/dist/components/puck-block/team-sections/team-grid-2/index.js +62 -0
  182. package/dist/components/puck-block/team-sections/team-grid-2/team-grid-2.d.ts +23 -0
  183. package/dist/components/puck-block/team-sections/team-grid-2/team-grid-2.js +44 -0
  184. package/dist/components/puck-block/team-sections/team-profiles-1/index.d.ts +5 -0
  185. package/dist/components/puck-block/team-sections/team-profiles-1/index.js +53 -0
  186. package/dist/components/puck-block/team-sections/team-profiles-1/team-profiles.d.ts +23 -0
  187. package/dist/components/puck-block/team-sections/team-profiles-1/team-profiles.js +105 -0
  188. package/dist/components/puck-block/testimonial-sections/customers-1/customers.d.ts +9 -7
  189. package/dist/components/puck-block/testimonial-sections/customers-1/customers.js +8 -11
  190. package/dist/components/puck-block/testimonial-sections/customers-1/index.js +17 -17
  191. package/dist/components/puck-block/testimonial-sections/logo-marquee-1/index.js +15 -12
  192. package/dist/components/puck-block/testimonial-sections/logo-marquee-1/logo-marquee.d.ts +7 -3
  193. package/dist/components/puck-block/testimonial-sections/logo-marquee-1/logo-marquee.js +34 -24
  194. package/dist/components/puck-block/testimonial-sections/logo-wall-1/index.d.ts +5 -0
  195. package/dist/components/puck-block/testimonial-sections/logo-wall-1/index.js +51 -0
  196. package/dist/components/puck-block/testimonial-sections/logo-wall-1/logo-wall.d.ts +17 -0
  197. package/dist/components/puck-block/testimonial-sections/logo-wall-1/logo-wall.js +55 -0
  198. package/dist/components/puck-block/testimonial-sections/props.d.ts +34 -0
  199. package/dist/components/puck-block/testimonial-sections/review-section-1/index.js +16 -15
  200. package/dist/components/puck-block/testimonial-sections/review-section-1/review-section.d.ts +8 -6
  201. package/dist/components/puck-block/testimonial-sections/review-section-1/review-section.js +25 -19
  202. package/dist/components/puck-block/testimonial-sections/testimonials-1/index.js +17 -17
  203. package/dist/components/puck-block/testimonial-sections/testimonials-1/testimonials.d.ts +8 -6
  204. package/dist/components/puck-block/testimonial-sections/testimonials-1/testimonials.js +76 -63
  205. package/dist/components/puck-block/text-sections/articles-1/articles.d.ts +7 -4
  206. package/dist/components/puck-block/text-sections/articles-1/articles.js +42 -22
  207. package/dist/components/puck-block/text-sections/articles-1/index.js +31 -19
  208. package/dist/components/puck-block/text-sections/content-section-1/content-section.d.ts +7 -5
  209. package/dist/components/puck-block/text-sections/content-section-1/content-section.js +11 -12
  210. package/dist/components/puck-block/text-sections/content-section-1/index.js +14 -14
  211. package/dist/components/puck-block/text-sections/props.d.ts +58 -0
  212. package/dist/components/puck-block/text-sections/rich-text-1/index.js +13 -15
  213. package/dist/components/puck-block/text-sections/rich-text-1/rich-text.d.ts +7 -5
  214. package/dist/components/puck-block/text-sections/rich-text-1/rich-text.js +11 -11
  215. package/dist/components/puck-block/text-sections/tab-section-1/index.js +4 -5
  216. package/dist/components/puck-block/text-sections/tab-section-1/tab-section.d.ts +6 -4
  217. package/dist/components/puck-block/text-sections/tab-section-1/tab-section.js +6 -7
  218. package/dist/components/puck-block/text-sections/timeline-1/index.js +3 -5
  219. package/dist/components/puck-block/text-sections/timeline-1/timeline.d.ts +6 -4
  220. package/dist/components/puck-block/text-sections/timeline-1/timeline.js +3 -5
  221. package/dist/components/puck-block/text-sections/two-column-1/index.js +4 -6
  222. package/dist/components/puck-block/text-sections/two-column-1/two-column.d.ts +6 -4
  223. package/dist/components/puck-block/text-sections/two-column-1/two-column.js +5 -7
  224. package/dist/components/shadcn/navigation-menu.d.ts +1 -1
  225. package/dist/components/shadcn/navigation-menu.js +33 -0
  226. package/dist/index.js +106 -75
  227. package/package.json +1 -1
@@ -1,40 +1,50 @@
1
1
  import { jsxs, jsx } from "react/jsx-runtime";
2
2
  import { CompoundContainer } from "../../../puck-base/container.js";
3
+ import { CompoundImage } from "../../../puck-base/image.js";
3
4
  const SPEED_DURATION = {
4
5
  slow: "40s",
5
6
  normal: "25s",
6
7
  fast: "15s"
7
8
  };
8
9
  const LogoMarquee = ({
9
- padding,
10
10
  heading,
11
11
  logos = [],
12
- speed = "normal"
13
- }) => /* @__PURE__ */ jsxs(CompoundContainer, { padding, sectionStyle: "muted", children: [
14
- heading && /* @__PURE__ */ jsx("p", { className: "text-muted-foreground mb-8 text-center text-sm font-medium tracking-wider uppercase", children: heading }),
15
- /* @__PURE__ */ jsx("div", { className: "relative overflow-hidden", children: /* @__PURE__ */ jsx(
16
- "div",
17
- {
18
- className: "flex w-max animate-[marquee_var(--marquee-speed)_linear_infinite] items-center gap-12",
19
- style: { "--marquee-speed": SPEED_DURATION[speed] },
20
- children: [...logos, ...logos].map((logo, i) => /* @__PURE__ */ jsx(
12
+ styles
13
+ }) => /* @__PURE__ */ jsxs(
14
+ CompoundContainer,
15
+ {
16
+ padding: styles == null ? void 0 : styles.padding,
17
+ sectionStyle: (styles == null ? void 0 : styles.sectionStyle) ?? "muted",
18
+ backgroundColor: styles == null ? void 0 : styles.backgroundColor,
19
+ children: [
20
+ heading && /* @__PURE__ */ jsx("p", { className: "text-muted-foreground mb-8 text-center text-sm font-medium tracking-wider uppercase", children: heading }),
21
+ /* @__PURE__ */ jsx("div", { className: "relative overflow-hidden", children: /* @__PURE__ */ jsx(
21
22
  "div",
22
23
  {
23
- className: "h-8 flex-shrink-0 opacity-60 transition-opacity hover:opacity-100 md:h-10",
24
- children: logo.src ? /* @__PURE__ */ jsx(
25
- "img",
24
+ className: "flex w-max animate-[marquee_var(--marquee-speed)_linear_infinite] items-center gap-12",
25
+ style: {
26
+ "--marquee-speed": SPEED_DURATION[(styles == null ? void 0 : styles.speed) ?? "normal"]
27
+ },
28
+ children: [...logos, ...logos].map((logo, i) => /* @__PURE__ */ jsx(
29
+ "div",
26
30
  {
27
- src: logo.src,
28
- alt: logo.alt || "",
29
- className: "h-full w-auto object-contain"
30
- }
31
- ) : /* @__PURE__ */ jsx("div", { className: "bg-border/50 text-muted-foreground flex h-full w-24 items-center justify-center rounded text-xs", children: "Logo" })
32
- },
33
- i
34
- ))
35
- }
36
- ) })
37
- ] });
31
+ className: "h-8 flex-shrink-0 opacity-60 transition-opacity hover:opacity-100 md:h-10",
32
+ children: logo.src ? /* @__PURE__ */ jsx(
33
+ CompoundImage,
34
+ {
35
+ src: logo.src,
36
+ alt: logo.alt || "",
37
+ className: "h-full w-auto object-contain"
38
+ }
39
+ ) : /* @__PURE__ */ jsx("div", { className: "bg-border/50 text-muted-foreground flex h-full w-24 items-center justify-center rounded text-xs", children: "Logo" })
40
+ },
41
+ i
42
+ ))
43
+ }
44
+ ) })
45
+ ]
46
+ }
47
+ );
38
48
  export {
39
49
  LogoMarquee
40
50
  };
@@ -0,0 +1,5 @@
1
+ import { ComponentConfig } from "@puckeditor/core";
2
+ import { LogoWall1Props } from "./logo-wall";
3
+ export type { LogoWall1Props };
4
+ export declare const conf: ComponentConfig<LogoWall1Props>;
5
+ export default conf;
@@ -0,0 +1,51 @@
1
+ import { image, getPlaceholderImageUrl } from "../../../puck-base/core/fields.js";
2
+ import { LogoWall1 } from "./logo-wall.js";
3
+ import { createStylesDefaults, createStylesField } from "../../../puck-base/core/styles.js";
4
+ const logoPlaceholder = (name) => ({
5
+ src: getPlaceholderImageUrl("200x200", name),
6
+ alt: name
7
+ });
8
+ const logoWallStylesField = createStylesField({
9
+ columns: {
10
+ type: "radio",
11
+ label: "Columns",
12
+ options: [
13
+ { label: "3", value: 3 },
14
+ { label: "4", value: 4 },
15
+ { label: "5", value: 5 },
16
+ { label: "6", value: 6 }
17
+ ]
18
+ }
19
+ });
20
+ const conf = {
21
+ fields: {
22
+ heading: { type: "text", contentEditable: true },
23
+ description: { type: "textarea", contentEditable: true },
24
+ logos: {
25
+ type: "array",
26
+ max: 20,
27
+ getItemSummary: (item, index = 0) => item.alt || `Logo ${index + 1}`,
28
+ arrayFields: {
29
+ ...image.objectFields
30
+ },
31
+ defaultItemProps: logoPlaceholder("Brand")
32
+ },
33
+ styles: logoWallStylesField
34
+ },
35
+ defaultProps: {
36
+ heading: "Brands and tools we use",
37
+ description: "We partner with industry-leading platforms and manufacturers to deliver the best experience.",
38
+ logos: [
39
+ logoPlaceholder("Partner 1"),
40
+ logoPlaceholder("Partner 2"),
41
+ logoPlaceholder("Partner 3"),
42
+ logoPlaceholder("Partner 4"),
43
+ logoPlaceholder("Partner 5")
44
+ ],
45
+ styles: createStylesDefaults({ columns: 5 })
46
+ },
47
+ render: LogoWall1
48
+ };
49
+ export {
50
+ conf
51
+ };
@@ -0,0 +1,17 @@
1
+ import { CompoundContainerProps } from "@/components/puck-base/container";
2
+ import { PuckComponent } from "@puckeditor/core";
3
+ export interface LogoWall1Props {
4
+ heading?: string;
5
+ description?: string;
6
+ logos?: {
7
+ src: string;
8
+ alt: string;
9
+ }[];
10
+ styles?: {
11
+ padding?: CompoundContainerProps["padding"];
12
+ sectionStyle?: CompoundContainerProps["sectionStyle"];
13
+ backgroundColor?: string;
14
+ columns?: 3 | 4 | 5 | 6;
15
+ };
16
+ }
17
+ export declare const LogoWall1: PuckComponent<LogoWall1Props>;
@@ -0,0 +1,55 @@
1
+ import { jsx, jsxs } from "react/jsx-runtime";
2
+ import { CompoundContainer } from "../../../puck-base/container.js";
3
+ import { CompoundImage } from "../../../puck-base/image.js";
4
+ import { cn } from "../../../../utils/css-utils.js";
5
+ const LogoWall1 = ({
6
+ heading,
7
+ description,
8
+ logos = [],
9
+ styles
10
+ }) => {
11
+ const columns = (styles == null ? void 0 : styles.columns) ?? 5;
12
+ return /* @__PURE__ */ jsx(
13
+ CompoundContainer,
14
+ {
15
+ padding: styles == null ? void 0 : styles.padding,
16
+ sectionStyle: styles == null ? void 0 : styles.sectionStyle,
17
+ backgroundColor: styles == null ? void 0 : styles.backgroundColor,
18
+ children: /* @__PURE__ */ jsxs("div", { className: "flex flex-col gap-8 md:gap-16", children: [
19
+ /* @__PURE__ */ jsx("div", { className: "flex max-w-3xl flex-col gap-4", children: /* @__PURE__ */ jsxs("div", { className: "flex flex-col gap-4", children: [
20
+ heading && /* @__PURE__ */ jsx("h2", { className: "font-serif font-regular max-w-xl text-3xl tracking-tighter md:text-4xl", children: heading }),
21
+ description && /* @__PURE__ */ jsx("p", { className: "text-muted-foreground max-w-xl text-base leading-relaxed", children: description })
22
+ ] }) }),
23
+ logos && logos.length > 0 && /* @__PURE__ */ jsx(
24
+ "div",
25
+ {
26
+ className: cn("grid grid-cols-2 gap-4", {
27
+ "md:grid-cols-3": columns === 3,
28
+ "sm:grid-cols-2 md:grid-cols-4": columns === 4,
29
+ "sm:grid-cols-3 lg:grid-cols-5": columns === 5,
30
+ "sm:grid-cols-3 lg:grid-cols-6": columns === 6
31
+ }),
32
+ children: logos.map((logo, i) => /* @__PURE__ */ jsx(
33
+ "div",
34
+ {
35
+ className: "flex aspect-square items-center justify-center rounded-3xl bg-foreground/5 p-8 transition-colors duration-200 hover:bg-foreground/40",
36
+ children: logo.src && /* @__PURE__ */ jsx(
37
+ CompoundImage,
38
+ {
39
+ src: logo.src,
40
+ alt: logo.alt || "",
41
+ className: "h-full w-full object-contain"
42
+ }
43
+ )
44
+ },
45
+ i
46
+ ))
47
+ }
48
+ )
49
+ ] })
50
+ }
51
+ );
52
+ };
53
+ export {
54
+ LogoWall1
55
+ };
@@ -0,0 +1,34 @@
1
+ type TestimonialVariant = "customers-1" | "logo-marquee-1" | "logo-wall-1" | "review-section-1" | "testimonials-1";
2
+ type TestimonialPadding = {
3
+ top?: "none" | "small" | "medium" | "large";
4
+ bottom?: "none" | "small" | "medium" | "large";
5
+ };
6
+ type TestimonialSectionStyle = "default" | "dark" | "muted" | "inverted" | "custom";
7
+ type TestimonialImage = {
8
+ src: string;
9
+ alt?: string;
10
+ };
11
+ type TestimonialItem = {
12
+ title?: string;
13
+ quote?: string;
14
+ name?: string;
15
+ image?: TestimonialImage;
16
+ url?: string;
17
+ rating?: number;
18
+ company?: string;
19
+ };
20
+ type TestimonialSectionProps = {
21
+ variant?: TestimonialVariant;
22
+ heading?: string;
23
+ description?: string;
24
+ items?: TestimonialItem[];
25
+ logos?: TestimonialImage[];
26
+ styles?: {
27
+ padding?: TestimonialPadding;
28
+ sectionStyle?: TestimonialSectionStyle;
29
+ backgroundColor?: string;
30
+ layout?: "section" | "inline" | "grid" | "list" | "cards" | "quote";
31
+ speed?: "slow" | "normal" | "fast";
32
+ columns?: 3 | 4 | 5 | 6;
33
+ };
34
+ };
@@ -1,5 +1,6 @@
1
- import { paddingDefaults, backgroundColor, sectionStyle, padding, image, heading } from "../../../puck-base/core/fields.js";
1
+ import { image, heading } from "../../../puck-base/core/fields.js";
2
2
  import { ReviewSection } from "./review-section.js";
3
+ import { createStylesDefaults, createStylesField } from "../../../puck-base/core/styles.js";
3
4
  const defaultReview = {
4
5
  author: "Alex Johnson",
5
6
  role: "Verified Buyer",
@@ -11,10 +12,20 @@ const defaultReview = {
11
12
  content: "Absolutely love this product! The quality exceeded my expectations and the customer service was fantastic.",
12
13
  date: "2 days ago"
13
14
  };
15
+ const reviewStylesField = createStylesField({
16
+ layout: {
17
+ type: "select",
18
+ label: "Layout",
19
+ options: [
20
+ { label: "Grid", value: "grid" },
21
+ { label: "List", value: "list" }
22
+ ]
23
+ }
24
+ });
14
25
  const conf = {
15
26
  fields: {
16
27
  heading,
17
- reviews: {
28
+ items: {
18
29
  type: "array",
19
30
  max: 12,
20
31
  getItemSummary: (item, index = 0) => item.author || `Review ${index + 1}`,
@@ -28,21 +39,11 @@ const conf = {
28
39
  },
29
40
  defaultItemProps: defaultReview
30
41
  },
31
- layout: {
32
- type: "select",
33
- options: [
34
- { label: "Grid", value: "grid" },
35
- { label: "List", value: "list" }
36
- ]
37
- },
38
- padding,
39
- sectionStyle,
40
- backgroundColor
42
+ styles: reviewStylesField
41
43
  },
42
44
  defaultProps: {
43
45
  heading: "What Our Customers Say",
44
- layout: "grid",
45
- reviews: [
46
+ items: [
46
47
  {
47
48
  ...defaultReview,
48
49
  author: "Alex Johnson",
@@ -62,7 +63,7 @@ const conf = {
62
63
  content: "Best purchase I've made this year. Highly recommend to everyone!"
63
64
  }
64
65
  ],
65
- padding: paddingDefaults
66
+ styles: createStylesDefaults({ layout: "grid" })
66
67
  },
67
68
  render: ReviewSection
68
69
  };
@@ -11,11 +11,13 @@ export interface Review {
11
11
  date?: string;
12
12
  }
13
13
  export interface ReviewSectionProps {
14
- padding?: CompoundContainerProps["padding"];
15
- sectionStyle?: CompoundContainerProps["sectionStyle"];
16
- backgroundColor?: string;
17
14
  heading?: string;
18
- reviews?: Review[];
19
- layout?: "grid" | "list";
15
+ items?: Review[];
16
+ styles?: {
17
+ padding?: CompoundContainerProps["padding"];
18
+ sectionStyle?: CompoundContainerProps["sectionStyle"];
19
+ backgroundColor?: string;
20
+ layout?: "grid" | "list";
21
+ };
20
22
  }
21
- export declare const ReviewSection: ({ padding, sectionStyle, backgroundColor, heading, reviews, layout, }: ReviewSectionProps) => import("react/jsx-runtime").JSX.Element;
23
+ export declare const ReviewSection: ({ heading, items, styles, }: ReviewSectionProps) => import("react/jsx-runtime").JSX.Element;
@@ -1,26 +1,32 @@
1
1
  import { jsx, jsxs } from "react/jsx-runtime";
2
2
  import { CompoundContainer } from "../../../puck-base/container.js";
3
+ import { CompoundImage } from "../../../puck-base/image.js";
3
4
  import { cn } from "../../../../utils/css-utils.js";
4
5
  import { Star } from "lucide-react";
5
6
  const ReviewSection = ({
6
- padding,
7
- sectionStyle,
8
- backgroundColor,
9
7
  heading,
10
- reviews = [],
11
- layout = "grid"
12
- }) => /* @__PURE__ */ jsx(CompoundContainer, { padding, sectionStyle, backgroundColor, children: /* @__PURE__ */ jsxs("div", { className: "flex flex-col gap-10", children: [
13
- heading && /* @__PURE__ */ jsx("h2", { className: "text-3xl font-bold tracking-tight md:text-4xl", children: heading }),
14
- /* @__PURE__ */ jsx(
15
- "div",
16
- {
17
- className: cn(
18
- layout === "grid" ? "grid grid-cols-1 gap-6 md:grid-cols-2 lg:grid-cols-3" : "flex max-w-2xl flex-col gap-6"
19
- ),
20
- children: reviews.map((review, index) => /* @__PURE__ */ jsx(ReviewCard, { review }, index))
21
- }
22
- )
23
- ] }) });
8
+ items = [],
9
+ styles
10
+ }) => /* @__PURE__ */ jsx(
11
+ CompoundContainer,
12
+ {
13
+ padding: styles == null ? void 0 : styles.padding,
14
+ sectionStyle: styles == null ? void 0 : styles.sectionStyle,
15
+ backgroundColor: styles == null ? void 0 : styles.backgroundColor,
16
+ children: /* @__PURE__ */ jsxs("div", { className: "flex flex-col gap-10", children: [
17
+ heading && /* @__PURE__ */ jsx("h2", { className: "text-3xl font-bold tracking-tight md:text-4xl", children: heading }),
18
+ /* @__PURE__ */ jsx(
19
+ "div",
20
+ {
21
+ className: cn(
22
+ ((styles == null ? void 0 : styles.layout) ?? "grid") === "grid" ? "grid grid-cols-1 gap-6 md:grid-cols-2 lg:grid-cols-3" : "flex max-w-2xl flex-col gap-6"
23
+ ),
24
+ children: items.map((review, index) => /* @__PURE__ */ jsx(ReviewCard, { review }, index))
25
+ }
26
+ )
27
+ ] })
28
+ }
29
+ );
24
30
  const ReviewCard = ({ review }) => {
25
31
  var _a;
26
32
  return /* @__PURE__ */ jsxs("div", { className: "border-border bg-card text-card-foreground flex flex-col gap-4 rounded-xl border p-6", children: [
@@ -36,8 +42,8 @@ const ReviewCard = ({ review }) => {
36
42
  )) }),
37
43
  /* @__PURE__ */ jsx("p", { className: "text-sm leading-relaxed", children: review.content }),
38
44
  /* @__PURE__ */ jsxs("div", { className: "mt-auto flex items-center gap-3", children: [
39
- ((_a = review.avatar) == null ? void 0 : _a.src) && /* @__PURE__ */ jsx("div", { className: "bg-muted h-10 w-10 overflow-hidden rounded-full", children: /* @__PURE__ */ jsx(
40
- "img",
45
+ ((_a = review.avatar) == null ? void 0 : _a.src) && /* @__PURE__ */ jsx("div", { className: "bg-muted h-10 w-10 overflow-hidden rounded-full [&>span]:h-full [&>span]:w-full", children: /* @__PURE__ */ jsx(
46
+ CompoundImage,
41
47
  {
42
48
  src: review.avatar.src,
43
49
  alt: review.avatar.alt ?? review.author,
@@ -1,5 +1,6 @@
1
- import { paddingDefaults, backgroundColor, sectionStyle, padding, image, heading } from "../../../puck-base/core/fields.js";
1
+ import { image, heading } from "../../../puck-base/core/fields.js";
2
2
  import { Testimonials } from "./testimonials.js";
3
+ import { createStylesDefaults, createStylesField } from "../../../puck-base/core/styles.js";
3
4
  const defaultTestimonial = {
4
5
  title: "Best decision ever",
5
6
  quote: "Our goal was to streamline SMB trade, making it easier and faster than ever and we did it together.",
@@ -11,18 +12,20 @@ const defaultTestimonial = {
11
12
  }
12
13
  }
13
14
  };
15
+ const testimonialStylesField = createStylesField({
16
+ layout: {
17
+ type: "radio",
18
+ label: "Layout",
19
+ options: [
20
+ { label: "Cards", value: "cards" },
21
+ { label: "Quote", value: "quote" }
22
+ ]
23
+ }
24
+ });
14
25
  const conf = {
15
26
  fields: {
16
- layout: {
17
- label: "layout",
18
- type: "radio",
19
- options: [
20
- { label: "cards", value: "cards" },
21
- { label: "quote", value: "quote" }
22
- ]
23
- },
24
27
  heading,
25
- testimonials: {
28
+ items: {
26
29
  type: "array",
27
30
  max: 10,
28
31
  getItemSummary: (item, index = 0) => item.author.name || `Testimonial ${index + 1}`,
@@ -42,18 +45,15 @@ const conf = {
42
45
  instructions: "Generate at least 3 testimonials"
43
46
  }
44
47
  },
45
- padding,
46
- sectionStyle,
47
- backgroundColor
48
+ styles: testimonialStylesField
48
49
  },
49
50
  defaultProps: {
50
- layout: "cards",
51
- padding: paddingDefaults,
52
51
  heading: "Trusted by hundreds of businesses worldwide",
53
- testimonials: Array.from({ length: 5 }).map((_, index) => ({
52
+ items: Array.from({ length: 5 }).map((_, index) => ({
54
53
  ...defaultTestimonial,
55
54
  title: `Best decision ${index}`
56
- }))
55
+ })),
56
+ styles: createStylesDefaults({ layout: "cards" })
57
57
  },
58
58
  render: Testimonials
59
59
  };
@@ -1,12 +1,8 @@
1
1
  import { CompoundContainerProps } from "@/components/puck-base/container";
2
2
  import { CompoundImageProps } from "@/components/puck-base/image";
3
3
  export interface TestimonialsProps {
4
- layout?: "cards" | "quote";
5
- padding?: CompoundContainerProps["padding"];
6
- sectionStyle?: CompoundContainerProps["sectionStyle"];
7
- backgroundColor?: string;
8
4
  heading: string;
9
- testimonials: {
5
+ items: {
10
6
  title: string;
11
7
  quote: string;
12
8
  author: {
@@ -14,5 +10,11 @@ export interface TestimonialsProps {
14
10
  image?: CompoundImageProps;
15
11
  };
16
12
  }[];
13
+ styles?: {
14
+ layout?: "cards" | "quote";
15
+ padding?: CompoundContainerProps["padding"];
16
+ sectionStyle?: CompoundContainerProps["sectionStyle"];
17
+ backgroundColor?: string;
18
+ };
17
19
  }
18
- export declare const Testimonials: ({ layout, padding, sectionStyle, backgroundColor, heading, testimonials, }: TestimonialsProps) => import("react/jsx-runtime").JSX.Element;
20
+ export declare const Testimonials: ({ heading, items: testimonials, styles, }: TestimonialsProps) => import("react/jsx-runtime").JSX.Element;
@@ -7,12 +7,9 @@ import { Avatar, AvatarImage, AvatarFallback } from "../../../shadcn/avatar.js";
7
7
  import { usePrefersReducedMotion } from "../../../../hooks/use-prefers-reduced-motion.js";
8
8
  import { CompoundContainer } from "../../../puck-base/container.js";
9
9
  const Testimonials = ({
10
- layout,
11
- padding,
12
- sectionStyle,
13
- backgroundColor,
14
10
  heading,
15
- testimonials
11
+ items: testimonials,
12
+ styles
16
13
  }) => {
17
14
  var _a;
18
15
  const [api, setApi] = useState();
@@ -33,7 +30,7 @@ const Testimonials = ({
33
30
  }, 4e3);
34
31
  }, [api, currentIndex, prefersReducedMotion]);
35
32
  const items = testimonials ?? [];
36
- if (layout === "quote") {
33
+ if ((styles == null ? void 0 : styles.layout) === "quote") {
37
34
  const safeIndex = items.length > 0 ? currentIndex % items.length : 0;
38
35
  const testimonial = items[safeIndex];
39
36
  const prev = () => {
@@ -42,66 +39,82 @@ const Testimonials = ({
42
39
  const next = () => {
43
40
  setCurrentIndex((i) => (i + 1) % items.length);
44
41
  };
45
- return /* @__PURE__ */ jsx(CompoundContainer, { padding, sectionStyle, backgroundColor, children: /* @__PURE__ */ jsxs("div", { className: "flex flex-col items-center text-center py-12", children: [
46
- /* @__PURE__ */ jsx("p", { className: "text-sm font-medium uppercase tracking-widest text-muted-foreground", children: heading }),
47
- testimonial && /* @__PURE__ */ jsxs(Fragment, { children: [
48
- /* @__PURE__ */ jsxs("h2", { className: "font-serif text-2xl font-bold italic md:text-4xl max-w-4xl mx-auto mt-6", children: [
49
- "“",
50
- testimonial.quote,
51
- ""
52
- ] }),
53
- /* @__PURE__ */ jsx("p", { className: "text-muted-foreground mt-4", children: (_a = testimonial.author) == null ? void 0 : _a.name })
54
- ] }),
55
- items.length > 1 && /* @__PURE__ */ jsxs("div", { className: "flex items-center justify-center gap-4 mt-8", children: [
56
- /* @__PURE__ */ jsx(
57
- "button",
58
- {
59
- onClick: prev,
60
- className: "rounded-full border border-current/30 p-2 hover:bg-white/10 transition-colors",
61
- children: /* @__PURE__ */ jsx(ChevronLeft, { className: "h-5 w-5" })
62
- }
63
- ),
64
- /* @__PURE__ */ jsx(
65
- "button",
66
- {
67
- onClick: next,
68
- className: "rounded-full border border-current/30 p-2 hover:bg-white/10 transition-colors",
69
- children: /* @__PURE__ */ jsx(ChevronRight, { className: "h-5 w-5" })
70
- }
71
- )
72
- ] })
73
- ] }) });
74
- }
75
- return /* @__PURE__ */ jsx(CompoundContainer, { padding, sectionStyle, backgroundColor, children: /* @__PURE__ */ jsxs("div", { className: "flex flex-col gap-10", children: [
76
- /* @__PURE__ */ jsx("h2", { className: "font-regular text-start text-3xl tracking-tighter md:text-5xl lg:max-w-xl", children: heading }),
77
- /* @__PURE__ */ jsx(Carousel, { setApi, className: "w-full", children: /* @__PURE__ */ jsx(CarouselContent, { children: items.map((testimonial, index) => {
78
- var _a2, _b, _c, _d, _e, _f;
79
- return /* @__PURE__ */ jsx(CarouselItem, { className: "me-4 lg:basis-1/2", children: /* @__PURE__ */ jsxs("div", { className: "bg-muted flex aspect-video h-full flex-col justify-between rounded-md p-6 lg:col-span-2", children: [
80
- /* @__PURE__ */ jsx(User, { className: "h-8 w-8 stroke-1" }),
81
- /* @__PURE__ */ jsxs("div", { className: "flex flex-col gap-4", children: [
82
- /* @__PURE__ */ jsxs("div", { className: "flex flex-col", children: [
83
- /* @__PURE__ */ jsx("h3", { className: "text-xl tracking-tight", children: testimonial.title }),
84
- /* @__PURE__ */ jsx("p", { className: "text-muted-foreground max-w-xs text-base", children: testimonial.quote })
85
- ] }),
86
- /* @__PURE__ */ jsxs("p", { className: "flex flex-row items-center gap-2 text-sm", children: [
87
- /* @__PURE__ */ jsx("span", { className: "text-muted-foreground", children: "By" }),
88
- " ",
89
- /* @__PURE__ */ jsxs(Avatar, { className: "h-6 w-6", children: [
90
- /* @__PURE__ */ jsx(
91
- AvatarImage,
92
- {
93
- src: (_b = (_a2 = testimonial.author) == null ? void 0 : _a2.image) == null ? void 0 : _b.src,
94
- alt: (_d = (_c = testimonial.author) == null ? void 0 : _c.image) == null ? void 0 : _d.alt
95
- }
96
- ),
97
- /* @__PURE__ */ jsx(AvatarFallback, { children: getInitials(((_e = testimonial.author) == null ? void 0 : _e.name) ?? "") })
42
+ return /* @__PURE__ */ jsx(
43
+ CompoundContainer,
44
+ {
45
+ padding: styles == null ? void 0 : styles.padding,
46
+ sectionStyle: styles == null ? void 0 : styles.sectionStyle,
47
+ backgroundColor: styles == null ? void 0 : styles.backgroundColor,
48
+ children: /* @__PURE__ */ jsxs("div", { className: "flex flex-col items-center text-center py-12", children: [
49
+ /* @__PURE__ */ jsx("p", { className: "text-sm font-medium uppercase tracking-widest text-muted-foreground", children: heading }),
50
+ testimonial && /* @__PURE__ */ jsxs(Fragment, { children: [
51
+ /* @__PURE__ */ jsxs("h2", { className: "font-serif text-2xl font-bold italic md:text-4xl max-w-4xl mx-auto mt-6", children: [
52
+ "",
53
+ testimonial.quote,
54
+ ""
98
55
  ] }),
99
- /* @__PURE__ */ jsx("span", { children: (_f = testimonial.author) == null ? void 0 : _f.name })
56
+ /* @__PURE__ */ jsx("p", { className: "text-muted-foreground mt-4", children: (_a = testimonial.author) == null ? void 0 : _a.name })
57
+ ] }),
58
+ items.length > 1 && /* @__PURE__ */ jsxs("div", { className: "flex items-center justify-center gap-4 mt-8", children: [
59
+ /* @__PURE__ */ jsx(
60
+ "button",
61
+ {
62
+ onClick: prev,
63
+ className: "rounded-full border border-current/30 p-2 hover:bg-white/10 transition-colors",
64
+ children: /* @__PURE__ */ jsx(ChevronLeft, { className: "h-5 w-5" })
65
+ }
66
+ ),
67
+ /* @__PURE__ */ jsx(
68
+ "button",
69
+ {
70
+ onClick: next,
71
+ className: "rounded-full border border-current/30 p-2 hover:bg-white/10 transition-colors",
72
+ children: /* @__PURE__ */ jsx(ChevronRight, { className: "h-5 w-5" })
73
+ }
74
+ )
100
75
  ] })
101
76
  ] })
102
- ] }) }, index);
103
- }) }) })
104
- ] }) });
77
+ }
78
+ );
79
+ }
80
+ return /* @__PURE__ */ jsx(
81
+ CompoundContainer,
82
+ {
83
+ padding: styles == null ? void 0 : styles.padding,
84
+ sectionStyle: styles == null ? void 0 : styles.sectionStyle,
85
+ backgroundColor: styles == null ? void 0 : styles.backgroundColor,
86
+ children: /* @__PURE__ */ jsxs("div", { className: "flex flex-col gap-10", children: [
87
+ /* @__PURE__ */ jsx("h2", { className: "font-regular text-start text-3xl tracking-tighter md:text-5xl lg:max-w-xl", children: heading }),
88
+ /* @__PURE__ */ jsx(Carousel, { setApi, className: "w-full", children: /* @__PURE__ */ jsx(CarouselContent, { children: items.map((testimonial, index) => {
89
+ var _a2, _b, _c, _d, _e, _f;
90
+ return /* @__PURE__ */ jsx(CarouselItem, { className: "me-4 lg:basis-1/2", children: /* @__PURE__ */ jsxs("div", { className: "bg-muted flex aspect-video h-full flex-col justify-between rounded-md p-6 lg:col-span-2", children: [
91
+ /* @__PURE__ */ jsx(User, { className: "h-8 w-8 stroke-1" }),
92
+ /* @__PURE__ */ jsxs("div", { className: "flex flex-col gap-4", children: [
93
+ /* @__PURE__ */ jsxs("div", { className: "flex flex-col", children: [
94
+ /* @__PURE__ */ jsx("h3", { className: "text-xl tracking-tight", children: testimonial.title }),
95
+ /* @__PURE__ */ jsx("p", { className: "text-muted-foreground max-w-xs text-base", children: testimonial.quote })
96
+ ] }),
97
+ /* @__PURE__ */ jsxs("p", { className: "flex flex-row items-center gap-2 text-sm", children: [
98
+ /* @__PURE__ */ jsx("span", { className: "text-muted-foreground", children: "By" }),
99
+ " ",
100
+ /* @__PURE__ */ jsxs(Avatar, { className: "h-6 w-6", children: [
101
+ /* @__PURE__ */ jsx(
102
+ AvatarImage,
103
+ {
104
+ src: (_b = (_a2 = testimonial.author) == null ? void 0 : _a2.image) == null ? void 0 : _b.src,
105
+ alt: (_d = (_c = testimonial.author) == null ? void 0 : _c.image) == null ? void 0 : _d.alt
106
+ }
107
+ ),
108
+ /* @__PURE__ */ jsx(AvatarFallback, { children: getInitials(((_e = testimonial.author) == null ? void 0 : _e.name) ?? "") })
109
+ ] }),
110
+ /* @__PURE__ */ jsx("span", { children: (_f = testimonial.author) == null ? void 0 : _f.name })
111
+ ] })
112
+ ] })
113
+ ] }) }, index);
114
+ }) }) })
115
+ ] })
116
+ }
117
+ );
105
118
  };
106
119
  function getInitials(name, maxInitials) {
107
120
  if (!name) {