dune-react 0.0.9 → 0.0.11

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 (210) hide show
  1. package/dist/components/puck-base/article-card.js +1 -1
  2. package/dist/components/puck-base/button.d.ts +0 -1
  3. package/dist/components/puck-base/button.js +5 -4
  4. package/dist/components/puck-base/card.js +0 -1
  5. package/dist/components/puck-base/content.js +0 -1
  6. package/dist/components/puck-base/core/fields.d.ts +2 -150
  7. package/dist/components/puck-base/core/fields.js +7 -83
  8. package/dist/components/puck-base/core/styles.d.ts +1946 -0
  9. package/dist/components/puck-base/core/styles.js +250 -0
  10. package/dist/components/puck-base/core/with-editable.d.ts +5 -7
  11. package/dist/components/puck-base/core/with-editable.js +69 -64
  12. package/dist/components/puck-base/{action-field.d.ts → fields/action-field.d.ts} +1 -1
  13. package/dist/components/puck-base/{action-field.js → fields/action-field.js} +91 -16
  14. package/dist/components/puck-base/fields/auto-field.d.ts +0 -1
  15. package/dist/components/puck-base/fields/auto-field.js +2 -90
  16. package/dist/components/puck-base/form.js +0 -1
  17. package/dist/components/puck-base/index.d.ts +1 -1
  18. package/dist/components/puck-base/navigation-menu.d.ts +18 -0
  19. package/dist/components/puck-base/navigation-menu.js +202 -0
  20. package/dist/components/puck-block/banner-sections/announcement-banner-1/announcement-banner.d.ts +9 -7
  21. package/dist/components/puck-block/banner-sections/announcement-banner-1/announcement-banner.js +11 -8
  22. package/dist/components/puck-block/banner-sections/announcement-banner-1/index.js +19 -37
  23. package/dist/components/puck-block/banner-sections/marquee-1/index.js +26 -24
  24. package/dist/components/puck-block/banner-sections/marquee-1/marquee.d.ts +9 -9
  25. package/dist/components/puck-block/banner-sections/marquee-1/marquee.js +28 -21
  26. package/dist/components/puck-block/banner-sections/props.d.ts +22 -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 +114 -105
  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 +15 -11
  31. package/dist/components/puck-block/contact-sections/contact-us-2/contact-us-2.js +27 -22
  32. package/dist/components/puck-block/contact-sections/contact-us-2/index.js +54 -52
  33. package/dist/components/puck-block/contact-sections/contact-us-3/contact-us-3.d.ts +15 -12
  34. package/dist/components/puck-block/contact-sections/contact-us-3/contact-us-3.js +29 -24
  35. package/dist/components/puck-block/contact-sections/contact-us-3/index.js +73 -60
  36. package/dist/components/puck-block/contact-sections/props.d.ts +65 -0
  37. package/dist/components/puck-block/cta-sections/banner-cta-1/banner-cta.d.ts +13 -9
  38. package/dist/components/puck-block/cta-sections/banner-cta-1/banner-cta.js +28 -30
  39. package/dist/components/puck-block/cta-sections/banner-cta-1/index.js +23 -25
  40. package/dist/components/puck-block/cta-sections/cta-1/cta.d.ts +6 -4
  41. package/dist/components/puck-block/cta-sections/cta-1/cta.js +5 -7
  42. package/dist/components/puck-block/cta-sections/cta-1/index.js +5 -9
  43. package/dist/components/puck-block/cta-sections/gradient-cta-1/gradient-cta.d.ts +10 -10
  44. package/dist/components/puck-block/cta-sections/gradient-cta-1/gradient-cta.js +48 -22
  45. package/dist/components/puck-block/cta-sections/gradient-cta-1/index.js +36 -29
  46. package/dist/components/puck-block/cta-sections/newsletter-signup-1/index.js +13 -5
  47. package/dist/components/puck-block/cta-sections/newsletter-signup-1/newsletter-signup.d.ts +7 -3
  48. package/dist/components/puck-block/cta-sections/newsletter-signup-1/newsletter-signup.js +35 -32
  49. package/dist/components/puck-block/cta-sections/promo-section-1/index.js +5 -7
  50. package/dist/components/puck-block/cta-sections/promo-section-1/promo-section.d.ts +6 -4
  51. package/dist/components/puck-block/cta-sections/promo-section-1/promo-section.js +93 -79
  52. package/dist/components/puck-block/cta-sections/props.d.ts +47 -0
  53. package/dist/components/puck-block/faq-sections/accordion-1/accordion.d.ts +6 -4
  54. package/dist/components/puck-block/faq-sections/accordion-1/accordion.js +44 -33
  55. package/dist/components/puck-block/faq-sections/accordion-1/index.js +3 -5
  56. package/dist/components/puck-block/faq-sections/faq-1/faq.d.ts +9 -7
  57. package/dist/components/puck-block/faq-sections/faq-1/faq.js +50 -44
  58. package/dist/components/puck-block/faq-sections/faq-1/index.js +12 -14
  59. package/dist/components/puck-block/faq-sections/faq-2/faq-2.d.ts +6 -4
  60. package/dist/components/puck-block/faq-sections/faq-2/faq-2.js +4 -6
  61. package/dist/components/puck-block/faq-sections/faq-2/index.js +4 -5
  62. package/dist/components/puck-block/faq-sections/props.d.ts +30 -0
  63. package/dist/components/puck-block/feature-sections/bento-1/bento.d.ts +6 -4
  64. package/dist/components/puck-block/feature-sections/bento-1/bento.js +2 -4
  65. package/dist/components/puck-block/feature-sections/bento-1/index.js +4 -5
  66. package/dist/components/puck-block/feature-sections/feature-cards-1/feature-cards.d.ts +6 -4
  67. package/dist/components/puck-block/feature-sections/feature-cards-1/feature-cards.js +2 -4
  68. package/dist/components/puck-block/feature-sections/feature-cards-1/index.js +4 -7
  69. package/dist/components/puck-block/feature-sections/feature-showcase-1/feature-showcase.d.ts +6 -4
  70. package/dist/components/puck-block/feature-sections/feature-showcase-1/feature-showcase.js +2 -4
  71. package/dist/components/puck-block/feature-sections/feature-showcase-1/index.js +4 -5
  72. package/dist/components/puck-block/feature-sections/icon-grid-1/icon-grid.d.ts +6 -4
  73. package/dist/components/puck-block/feature-sections/icon-grid-1/icon-grid.js +59 -53
  74. package/dist/components/puck-block/feature-sections/icon-grid-1/index.js +7 -8
  75. package/dist/components/puck-block/feature-sections/product-features-1/index.js +4 -5
  76. package/dist/components/puck-block/feature-sections/product-features-1/product-features.d.ts +6 -4
  77. package/dist/components/puck-block/feature-sections/product-features-1/product-features.js +2 -4
  78. package/dist/components/puck-block/feature-sections/props.d.ts +48 -0
  79. package/dist/components/puck-block/footer-sections/footer-1/footer.d.ts +5 -3
  80. package/dist/components/puck-block/footer-sections/footer-1/footer.js +6 -6
  81. package/dist/components/puck-block/footer-sections/footer-1/index.js +3 -5
  82. package/dist/components/puck-block/footer-sections/props.d.ts +31 -0
  83. package/dist/components/puck-block/gallery-sections/gallery-1/gallery.d.ts +9 -7
  84. package/dist/components/puck-block/gallery-sections/gallery-1/gallery.js +48 -40
  85. package/dist/components/puck-block/gallery-sections/gallery-1/index.js +33 -35
  86. package/dist/components/puck-block/gallery-sections/gallery-2/gallery-2.d.ts +6 -4
  87. package/dist/components/puck-block/gallery-sections/gallery-2/gallery-2.js +19 -13
  88. package/dist/components/puck-block/gallery-sections/gallery-2/index.js +4 -6
  89. package/dist/components/puck-block/gallery-sections/gallery-3/gallery-3.d.ts +7 -5
  90. package/dist/components/puck-block/gallery-sections/gallery-3/gallery-3.js +5 -7
  91. package/dist/components/puck-block/gallery-sections/gallery-3/index.js +13 -14
  92. package/dist/components/puck-block/gallery-sections/props.d.ts +26 -0
  93. package/dist/components/puck-block/header-sections/header-1/header.d.ts +11 -6
  94. package/dist/components/puck-block/header-sections/header-1/header.js +34 -28
  95. package/dist/components/puck-block/header-sections/header-1/index.d.ts +1 -1
  96. package/dist/components/puck-block/header-sections/header-1/index.js +26 -30
  97. package/dist/components/puck-block/header-sections/props.d.ts +41 -0
  98. package/dist/components/puck-block/header-sections/sticky-nav-1/index.js +12 -12
  99. package/dist/components/puck-block/header-sections/sticky-nav-1/sticky-nav.d.ts +8 -6
  100. package/dist/components/puck-block/header-sections/sticky-nav-1/sticky-nav.js +5 -5
  101. package/dist/components/puck-block/hero-sections/fullscreen-hero-1/fullscreen-hero.d.ts +7 -5
  102. package/dist/components/puck-block/hero-sections/fullscreen-hero-1/fullscreen-hero.js +19 -5
  103. package/dist/components/puck-block/hero-sections/fullscreen-hero-1/index.js +17 -17
  104. package/dist/components/puck-block/hero-sections/gradient-hero-1/gradient-hero.d.ts +8 -4
  105. package/dist/components/puck-block/hero-sections/gradient-hero-1/gradient-hero.js +36 -26
  106. package/dist/components/puck-block/hero-sections/gradient-hero-1/index.js +19 -15
  107. package/dist/components/puck-block/hero-sections/grid-hero-1/grid-hero.d.ts +7 -6
  108. package/dist/components/puck-block/hero-sections/grid-hero-1/grid-hero.js +8 -11
  109. package/dist/components/puck-block/hero-sections/grid-hero-1/index.js +43 -11
  110. package/dist/components/puck-block/hero-sections/hero-1/hero.d.ts +6 -4
  111. package/dist/components/puck-block/hero-sections/hero-1/hero.js +6 -8
  112. package/dist/components/puck-block/hero-sections/hero-1/index.js +4 -4
  113. package/dist/components/puck-block/hero-sections/image-hero-1/image-hero.d.ts +9 -7
  114. package/dist/components/puck-block/hero-sections/image-hero-1/image-hero.js +65 -59
  115. package/dist/components/puck-block/hero-sections/image-hero-1/index.js +35 -36
  116. package/dist/components/puck-block/hero-sections/props.d.ts +71 -0
  117. package/dist/components/puck-block/hero-sections/split-hero-1/index.js +6 -5
  118. package/dist/components/puck-block/hero-sections/split-hero-1/split-hero.d.ts +8 -8
  119. package/dist/components/puck-block/hero-sections/split-hero-1/split-hero.js +48 -47
  120. package/dist/components/puck-block/hero-sections/video-hero-1/index.js +4 -3
  121. package/dist/components/puck-block/hero-sections/video-hero-1/video-hero.d.ts +6 -2
  122. package/dist/components/puck-block/hero-sections/video-hero-1/video-hero.js +30 -22
  123. package/dist/components/puck-block/location-sections/location-1/index.js +44 -42
  124. package/dist/components/puck-block/location-sections/location-1/location.d.ts +8 -6
  125. package/dist/components/puck-block/location-sections/location-1/location.js +8 -15
  126. package/dist/components/puck-block/location-sections/location-2/index.js +66 -57
  127. package/dist/components/puck-block/location-sections/location-2/location.d.ts +12 -6
  128. package/dist/components/puck-block/location-sections/location-2/location.js +8 -14
  129. package/dist/components/puck-block/location-sections/location-3/index.js +25 -24
  130. package/dist/components/puck-block/location-sections/location-3/location.d.ts +10 -6
  131. package/dist/components/puck-block/location-sections/location-3/location.js +12 -11
  132. package/dist/components/puck-block/location-sections/props.d.ts +45 -0
  133. package/dist/components/puck-block/metrics-sections/props.d.ts +43 -0
  134. package/dist/components/puck-block/metrics-sections/stats-1/index.js +6 -7
  135. package/dist/components/puck-block/metrics-sections/stats-1/stats.d.ts +7 -5
  136. package/dist/components/puck-block/metrics-sections/stats-1/stats.js +61 -55
  137. package/dist/components/puck-block/metrics-sections/stats-2/index.js +4 -7
  138. package/dist/components/puck-block/metrics-sections/stats-2/stats-2.d.ts +6 -4
  139. package/dist/components/puck-block/metrics-sections/stats-2/stats-2.js +4 -7
  140. package/dist/components/puck-block/metrics-sections/stats-3/index.js +19 -29
  141. package/dist/components/puck-block/metrics-sections/stats-3/stats-3.d.ts +7 -6
  142. package/dist/components/puck-block/metrics-sections/stats-3/stats-3.js +22 -13
  143. package/dist/components/puck-block/pricing-sections/comparison-1/comparison.d.ts +7 -5
  144. package/dist/components/puck-block/pricing-sections/comparison-1/comparison.js +45 -39
  145. package/dist/components/puck-block/pricing-sections/comparison-1/index.js +5 -7
  146. package/dist/components/puck-block/pricing-sections/pricing-1/index.js +10 -13
  147. package/dist/components/puck-block/pricing-sections/pricing-1/pricing.d.ts +8 -6
  148. package/dist/components/puck-block/pricing-sections/pricing-1/pricing.js +47 -35
  149. package/dist/components/puck-block/pricing-sections/pricing-2/index.js +7 -12
  150. package/dist/components/puck-block/pricing-sections/pricing-2/pricing-2.d.ts +6 -4
  151. package/dist/components/puck-block/pricing-sections/pricing-2/pricing-2.js +60 -57
  152. package/dist/components/puck-block/pricing-sections/props.d.ts +46 -0
  153. package/dist/components/puck-block/showcase-sections/before-after-1/before-after.d.ts +7 -5
  154. package/dist/components/puck-block/showcase-sections/before-after-1/before-after.js +8 -10
  155. package/dist/components/puck-block/showcase-sections/before-after-1/index.js +6 -8
  156. package/dist/components/puck-block/showcase-sections/case-study-1/case-study.d.ts +6 -2
  157. package/dist/components/puck-block/showcase-sections/case-study-1/case-study.js +29 -21
  158. package/dist/components/puck-block/showcase-sections/case-study-1/index.js +4 -3
  159. package/dist/components/puck-block/showcase-sections/props.d.ts +48 -0
  160. package/dist/components/puck-block/showcase-sections/step-by-step-1/index.js +3 -5
  161. package/dist/components/puck-block/showcase-sections/step-by-step-1/step-by-step.d.ts +6 -4
  162. package/dist/components/puck-block/showcase-sections/step-by-step-1/step-by-step.js +38 -41
  163. package/dist/components/puck-block/team-sections/props.d.ts +39 -0
  164. package/dist/components/puck-block/team-sections/team-grid-1/index.js +5 -6
  165. package/dist/components/puck-block/team-sections/team-grid-1/team-grid.d.ts +6 -4
  166. package/dist/components/puck-block/team-sections/team-grid-1/team-grid.js +23 -17
  167. package/dist/components/puck-block/team-sections/team-grid-2/index.js +4 -7
  168. package/dist/components/puck-block/team-sections/team-grid-2/team-grid-2.d.ts +6 -4
  169. package/dist/components/puck-block/team-sections/team-grid-2/team-grid-2.js +5 -7
  170. package/dist/components/puck-block/team-sections/team-profiles-1/index.js +4 -5
  171. package/dist/components/puck-block/team-sections/team-profiles-1/team-profiles.d.ts +6 -4
  172. package/dist/components/puck-block/team-sections/team-profiles-1/team-profiles.js +5 -7
  173. package/dist/components/puck-block/testimonial-sections/customers-1/customers.d.ts +9 -7
  174. package/dist/components/puck-block/testimonial-sections/customers-1/customers.js +8 -11
  175. package/dist/components/puck-block/testimonial-sections/customers-1/index.js +17 -17
  176. package/dist/components/puck-block/testimonial-sections/logo-marquee-1/index.js +15 -12
  177. package/dist/components/puck-block/testimonial-sections/logo-marquee-1/logo-marquee.d.ts +7 -3
  178. package/dist/components/puck-block/testimonial-sections/logo-marquee-1/logo-marquee.js +33 -24
  179. package/dist/components/puck-block/testimonial-sections/logo-wall-1/index.js +17 -16
  180. package/dist/components/puck-block/testimonial-sections/logo-wall-1/logo-wall.d.ts +6 -4
  181. package/dist/components/puck-block/testimonial-sections/logo-wall-1/logo-wall.js +5 -7
  182. package/dist/components/puck-block/testimonial-sections/props.d.ts +34 -0
  183. package/dist/components/puck-block/testimonial-sections/review-section-1/index.js +17 -16
  184. package/dist/components/puck-block/testimonial-sections/review-section-1/review-section.d.ts +8 -6
  185. package/dist/components/puck-block/testimonial-sections/review-section-1/review-section.js +22 -17
  186. package/dist/components/puck-block/testimonial-sections/testimonials-1/index.js +17 -17
  187. package/dist/components/puck-block/testimonial-sections/testimonials-1/testimonials.d.ts +8 -6
  188. package/dist/components/puck-block/testimonial-sections/testimonials-1/testimonials.js +100 -67
  189. package/dist/components/puck-block/text-sections/articles-1/articles.d.ts +7 -5
  190. package/dist/components/puck-block/text-sections/articles-1/articles.js +41 -34
  191. package/dist/components/puck-block/text-sections/articles-1/index.js +24 -25
  192. package/dist/components/puck-block/text-sections/content-section-1/content-section.d.ts +7 -5
  193. package/dist/components/puck-block/text-sections/content-section-1/content-section.js +6 -9
  194. package/dist/components/puck-block/text-sections/content-section-1/index.js +14 -16
  195. package/dist/components/puck-block/text-sections/props.d.ts +58 -0
  196. package/dist/components/puck-block/text-sections/rich-text-1/index.js +13 -15
  197. package/dist/components/puck-block/text-sections/rich-text-1/rich-text.d.ts +7 -5
  198. package/dist/components/puck-block/text-sections/rich-text-1/rich-text.js +11 -11
  199. package/dist/components/puck-block/text-sections/tab-section-1/index.js +4 -5
  200. package/dist/components/puck-block/text-sections/tab-section-1/tab-section.d.ts +6 -4
  201. package/dist/components/puck-block/text-sections/tab-section-1/tab-section.js +10 -8
  202. package/dist/components/puck-block/text-sections/timeline-1/index.js +3 -5
  203. package/dist/components/puck-block/text-sections/timeline-1/timeline.d.ts +6 -4
  204. package/dist/components/puck-block/text-sections/timeline-1/timeline.js +3 -5
  205. package/dist/components/puck-block/text-sections/two-column-1/index.js +4 -6
  206. package/dist/components/puck-block/text-sections/two-column-1/two-column.d.ts +6 -4
  207. package/dist/components/puck-block/text-sections/two-column-1/two-column.js +5 -7
  208. package/dist/components/shadcn/navigation-menu.js +8 -33
  209. package/dist/index.js +3 -2
  210. package/package.json +2 -2
@@ -7,19 +7,16 @@ import { Carousel, CarouselContent, CarouselItem } from "../../../shadcn/carouse
7
7
  import { CompoundContainer } from "../../../puck-base/container.js";
8
8
  import { CompoundImage } from "../../../puck-base/image.js";
9
9
  const Customers = ({
10
- padding,
11
- sectionStyle,
12
- backgroundColor,
13
- layout = "section",
14
10
  heading,
15
- customers
11
+ items,
12
+ styles
16
13
  }) => {
17
14
  const [api, setApi] = useState();
18
15
  const [currentIndex, setCurrentIndex] = useState(0);
19
16
  const [isPaused, setIsPaused] = useState(false);
20
17
  const prefersReducedMotion = usePrefersReducedMotion();
21
- const isSectionLayout = layout === "section";
22
- const isInlineLayout = layout === "inline";
18
+ const isSectionLayout = ((styles == null ? void 0 : styles.layout) ?? "section") === "section";
19
+ const isInlineLayout = (styles == null ? void 0 : styles.layout) === "inline";
23
20
  useEffect(() => {
24
21
  if (!api || prefersReducedMotion || isPaused) {
25
22
  return;
@@ -38,9 +35,9 @@ const Customers = ({
38
35
  return /* @__PURE__ */ jsx(
39
36
  CompoundContainer,
40
37
  {
41
- padding,
42
- sectionStyle,
43
- backgroundColor,
38
+ padding: styles == null ? void 0 : styles.padding,
39
+ sectionStyle: styles == null ? void 0 : styles.sectionStyle,
40
+ backgroundColor: styles == null ? void 0 : styles.backgroundColor,
44
41
  children: /* @__PURE__ */ jsxs(
45
42
  "div",
46
43
  {
@@ -80,7 +77,7 @@ const Customers = ({
80
77
  onMouseOut: () => {
81
78
  setIsPaused(false);
82
79
  },
83
- children: /* @__PURE__ */ jsx(CarouselContent, { children: customers.map((customer, index) => {
80
+ children: /* @__PURE__ */ jsx(CarouselContent, { children: items.map((customer, index) => {
84
81
  var _a;
85
82
  return /* @__PURE__ */ jsx(CarouselItem, { className: "basis-1/4 lg:basis-1/6", children: /* @__PURE__ */ jsx("div", { className: "bg-muted flex aspect-square items-center justify-center rounded-md p-6", children: ((_a = customer.image) == null ? void 0 : _a.src) ? /* @__PURE__ */ jsx(
86
83
  CompoundImage,
@@ -1,9 +1,20 @@
1
- import { paddingDefaults, padding, image1x1Placeholder, image, heading, getPlaceholderImageUrl } from "../../../puck-base/core/fields.js";
1
+ import { image1x1Placeholder, image, heading, getPlaceholderImageUrl } from "../../../puck-base/core/fields.js";
2
2
  import { Customers } from "./customers.js";
3
+ import { createStylesDefaults, createStylesField } from "../../../puck-base/core/styles.js";
4
+ const customersStylesField = createStylesField({
5
+ layout: {
6
+ type: "radio",
7
+ label: "Layout",
8
+ options: [
9
+ { label: "Section", value: "section" },
10
+ { label: "Inline", value: "inline" }
11
+ ]
12
+ }
13
+ });
3
14
  const conf = {
4
15
  fields: {
5
16
  heading,
6
- customers: {
17
+ items: {
7
18
  type: "array",
8
19
  max: 15,
9
20
  getItemSummary: (item, index = 0) => item.name || `Customer ${index + 1}`,
@@ -16,29 +27,18 @@ const conf = {
16
27
  image: image1x1Placeholder
17
28
  }
18
29
  },
19
- layout: {
20
- type: "radio",
21
- options: [
22
- {
23
- label: "section",
24
- value: "section"
25
- },
26
- { label: "inline", value: "inline" }
27
- ]
28
- },
29
- padding
30
+ styles: customersStylesField
30
31
  },
31
32
  defaultProps: {
32
- padding: paddingDefaults,
33
- layout: "section",
34
33
  heading: "Trusted by hundreds of businesses worldwide",
35
- customers: Array.from({ length: 10 }).map((_, index) => ({
34
+ items: Array.from({ length: 10 }).map((_, index) => ({
36
35
  name: `Customer ${index + 1}`,
37
36
  image: {
38
37
  src: getPlaceholderImageUrl("1000x1000", `Customer ${index + 1}`),
39
38
  alt: ""
40
39
  }
41
- }))
40
+ })),
41
+ styles: createStylesDefaults({ layout: "section" })
42
42
  },
43
43
  render: Customers
44
44
  };
@@ -1,9 +1,21 @@
1
- import { paddingDefaults, padding, getPlaceholderImageUrl } from "../../../puck-base/core/fields.js";
1
+ import { getPlaceholderImageUrl } from "../../../puck-base/core/fields.js";
2
2
  import { LogoMarquee } from "./logo-marquee.js";
3
+ import { createStylesDefaults, createStylesField } from "../../../puck-base/core/styles.js";
3
4
  const logoPlaceholder = (name) => ({
4
5
  src: getPlaceholderImageUrl("200x60", name),
5
6
  alt: name
6
7
  });
8
+ const marqueeStylesField = createStylesField({
9
+ speed: {
10
+ type: "radio",
11
+ label: "Speed",
12
+ options: [
13
+ { label: "Slow", value: "slow" },
14
+ { label: "Normal", value: "normal" },
15
+ { label: "Fast", value: "fast" }
16
+ ]
17
+ }
18
+ });
7
19
  const conf = {
8
20
  fields: {
9
21
  heading: { type: "text", contentEditable: true },
@@ -17,15 +29,7 @@ const conf = {
17
29
  },
18
30
  defaultItemProps: logoPlaceholder("Brand")
19
31
  },
20
- speed: {
21
- type: "radio",
22
- options: [
23
- { label: "Slow", value: "slow" },
24
- { label: "Normal", value: "normal" },
25
- { label: "Fast", value: "fast" }
26
- ]
27
- },
28
- padding
32
+ styles: marqueeStylesField
29
33
  },
30
34
  defaultProps: {
31
35
  heading: "Trusted by industry leaders",
@@ -36,8 +40,7 @@ const conf = {
36
40
  logoPlaceholder("DataFlow"),
37
41
  logoPlaceholder("CloudNet")
38
42
  ],
39
- speed: "normal",
40
- padding: paddingDefaults
43
+ styles: createStylesDefaults({ sectionStyle: "muted", speed: "normal" })
41
44
  },
42
45
  render: LogoMarquee
43
46
  };
@@ -1,11 +1,15 @@
1
1
  import { CompoundContainerProps } from "@/components/puck-base/container";
2
2
  export interface LogoMarqueeProps {
3
- padding?: CompoundContainerProps["padding"];
4
3
  heading?: string;
5
4
  logos?: Array<{
6
5
  src: string;
7
6
  alt: string;
8
7
  }>;
9
- speed?: "slow" | "normal" | "fast";
8
+ styles?: {
9
+ padding?: CompoundContainerProps["padding"];
10
+ sectionStyle?: CompoundContainerProps["sectionStyle"];
11
+ backgroundColor?: string;
12
+ speed?: "slow" | "normal" | "fast";
13
+ };
10
14
  }
11
- export declare const LogoMarquee: ({ padding, heading, logos, speed, }: LogoMarqueeProps) => import("react/jsx-runtime").JSX.Element;
15
+ export declare const LogoMarquee: ({ heading, logos, styles, }: LogoMarqueeProps) => import("react/jsx-runtime").JSX.Element;
@@ -7,35 +7,44 @@ const SPEED_DURATION = {
7
7
  fast: "15s"
8
8
  };
9
9
  const LogoMarquee = ({
10
- padding,
11
10
  heading,
12
11
  logos = [],
13
- speed = "normal"
14
- }) => /* @__PURE__ */ jsxs(CompoundContainer, { padding, sectionStyle: "muted", children: [
15
- heading && /* @__PURE__ */ jsx("p", { className: "text-muted-foreground mb-8 text-center text-sm font-medium tracking-wider uppercase", children: heading }),
16
- /* @__PURE__ */ jsx("div", { className: "relative overflow-hidden", children: /* @__PURE__ */ jsx(
17
- "div",
18
- {
19
- className: "flex w-max animate-[marquee_var(--marquee-speed)_linear_infinite] items-center gap-12",
20
- style: { "--marquee-speed": SPEED_DURATION[speed] },
21
- 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,
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(
22
22
  "div",
23
23
  {
24
- className: "h-8 flex-shrink-0 opacity-60 transition-opacity hover:opacity-100 md:h-10",
25
- children: logo.src ? /* @__PURE__ */ jsx(
26
- CompoundImage,
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",
27
30
  {
28
- src: logo.src,
29
- alt: logo.alt || "",
30
- className: "h-full w-auto object-contain"
31
- }
32
- ) : /* @__PURE__ */ jsx("div", { className: "bg-border/50 text-muted-foreground flex h-full w-24 items-center justify-center rounded text-xs", children: "Logo" })
33
- },
34
- i
35
- ))
36
- }
37
- ) })
38
- ] });
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
+ );
39
48
  export {
40
49
  LogoMarquee
41
50
  };
@@ -1,9 +1,22 @@
1
- import { paddingDefaults, backgroundColor, sectionStyle, padding, image, getPlaceholderImageUrl } from "../../../puck-base/core/fields.js";
1
+ import { image, getPlaceholderImageUrl } from "../../../puck-base/core/fields.js";
2
2
  import { LogoWall1 } from "./logo-wall.js";
3
+ import { createStylesDefaults, createStylesField } from "../../../puck-base/core/styles.js";
3
4
  const logoPlaceholder = (name) => ({
4
5
  src: getPlaceholderImageUrl("200x200", name),
5
6
  alt: name
6
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
+ });
7
20
  const conf = {
8
21
  fields: {
9
22
  heading: { type: "text", contentEditable: true },
@@ -17,31 +30,19 @@ const conf = {
17
30
  },
18
31
  defaultItemProps: logoPlaceholder("Brand")
19
32
  },
20
- columns: {
21
- type: "radio",
22
- options: [
23
- { label: "3", value: 3 },
24
- { label: "4", value: 4 },
25
- { label: "5", value: 5 },
26
- { label: "6", value: 6 }
27
- ]
28
- },
29
- padding,
30
- sectionStyle,
31
- backgroundColor
33
+ styles: logoWallStylesField
32
34
  },
33
35
  defaultProps: {
34
- padding: paddingDefaults,
35
36
  heading: "Brands and tools we use",
36
37
  description: "We partner with industry-leading platforms and manufacturers to deliver the best experience.",
37
- columns: 5,
38
38
  logos: [
39
39
  logoPlaceholder("Partner 1"),
40
40
  logoPlaceholder("Partner 2"),
41
41
  logoPlaceholder("Partner 3"),
42
42
  logoPlaceholder("Partner 4"),
43
43
  logoPlaceholder("Partner 5")
44
- ]
44
+ ],
45
+ styles: createStylesDefaults({ columns: 5 })
45
46
  },
46
47
  render: LogoWall1
47
48
  };
@@ -3,13 +3,15 @@ import { PuckComponent } from "@puckeditor/core";
3
3
  export interface LogoWall1Props {
4
4
  heading?: string;
5
5
  description?: string;
6
- columns?: 3 | 4 | 5 | 6;
7
6
  logos?: {
8
7
  src: string;
9
8
  alt: string;
10
9
  }[];
11
- padding?: CompoundContainerProps["padding"];
12
- sectionStyle?: CompoundContainerProps["sectionStyle"];
13
- backgroundColor?: string;
10
+ styles?: {
11
+ padding?: CompoundContainerProps["padding"];
12
+ sectionStyle?: CompoundContainerProps["sectionStyle"];
13
+ backgroundColor?: string;
14
+ columns?: 3 | 4 | 5 | 6;
15
+ };
14
16
  }
15
17
  export declare const LogoWall1: PuckComponent<LogoWall1Props>;
@@ -5,18 +5,16 @@ import { cn } from "../../../../utils/css-utils.js";
5
5
  const LogoWall1 = ({
6
6
  heading,
7
7
  description,
8
- columns = 5,
9
8
  logos = [],
10
- padding,
11
- sectionStyle,
12
- backgroundColor
9
+ styles
13
10
  }) => {
11
+ const columns = (styles == null ? void 0 : styles.columns) ?? 5;
14
12
  return /* @__PURE__ */ jsx(
15
13
  CompoundContainer,
16
14
  {
17
- padding,
18
- sectionStyle,
19
- backgroundColor,
15
+ padding: styles == null ? void 0 : styles.padding,
16
+ sectionStyle: styles == null ? void 0 : styles.sectionStyle,
17
+ backgroundColor: styles == null ? void 0 : styles.backgroundColor,
20
18
  children: /* @__PURE__ */ jsxs("div", { className: "flex flex-col gap-8 md:gap-16", children: [
21
19
  /* @__PURE__ */ jsx("div", { className: "flex max-w-3xl flex-col gap-4", children: /* @__PURE__ */ jsxs("div", { className: "flex flex-col gap-4", children: [
22
20
  heading && /* @__PURE__ */ jsx("h2", { className: "font-serif font-regular max-w-xl text-3xl tracking-tighter md:text-4xl", children: heading }),
@@ -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,20 +1,31 @@
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",
6
7
  avatar: {
7
- src: "https://dummyimage.com/200x200/f5f4f4/101010.png&text=AJ",
8
+ src: "https://picsum.photos/seed/AJ/200/200",
8
9
  alt: "Reviewer avatar"
9
10
  },
10
11
  rating: 5,
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;
@@ -4,24 +4,29 @@ import { CompoundImage } from "../../../puck-base/image.js";
4
4
  import { cn } from "../../../../utils/css-utils.js";
5
5
  import { Star } from "lucide-react";
6
6
  const ReviewSection = ({
7
- padding,
8
- sectionStyle,
9
- backgroundColor,
10
7
  heading,
11
- reviews = [],
12
- layout = "grid"
13
- }) => /* @__PURE__ */ jsx(CompoundContainer, { padding, sectionStyle, backgroundColor, children: /* @__PURE__ */ jsxs("div", { className: "flex flex-col gap-10", children: [
14
- heading && /* @__PURE__ */ jsx("h2", { className: "text-3xl font-bold tracking-tight md:text-4xl", children: heading }),
15
- /* @__PURE__ */ jsx(
16
- "div",
17
- {
18
- className: cn(
19
- layout === "grid" ? "grid grid-cols-1 gap-6 md:grid-cols-2 lg:grid-cols-3" : "flex max-w-2xl flex-col gap-6"
20
- ),
21
- children: reviews.map((review, index) => /* @__PURE__ */ jsx(ReviewCard, { review }, index))
22
- }
23
- )
24
- ] }) });
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
+ );
25
30
  const ReviewCard = ({ review }) => {
26
31
  var _a;
27
32
  return /* @__PURE__ */ jsxs("div", { className: "border-border bg-card text-card-foreground flex flex-col gap-4 rounded-xl border p-6", children: [
@@ -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;