@opensite/ui 0.8.9 → 0.9.1
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.
- package/dist/about-company-profile.cjs +32 -4
- package/dist/about-company-profile.js +32 -4
- package/dist/about-culture-tabs.cjs +38 -8
- package/dist/about-culture-tabs.js +38 -8
- package/dist/about-developer-profile.cjs +37 -5
- package/dist/about-developer-profile.js +37 -5
- package/dist/about-developer-story.cjs +31 -3
- package/dist/about-developer-story.js +31 -3
- package/dist/about-expandable-values.cjs +43 -9
- package/dist/about-expandable-values.js +43 -9
- package/dist/about-interactive-tabs.cjs +63 -4
- package/dist/about-interactive-tabs.js +63 -4
- package/dist/about-location-info-hero.cjs +28 -2
- package/dist/about-location-info-hero.js +28 -2
- package/dist/about-minimal-story.cjs +35 -4
- package/dist/about-minimal-story.js +35 -4
- package/dist/about-mission-dual-image.cjs +30 -2
- package/dist/about-mission-dual-image.js +30 -2
- package/dist/about-mission-features.cjs +36 -4
- package/dist/about-mission-features.js +36 -4
- package/dist/about-mission-principles.cjs +39 -6
- package/dist/about-mission-principles.js +39 -6
- package/dist/about-network-spotlight.cjs +33 -5
- package/dist/about-network-spotlight.js +33 -5
- package/dist/about-startup-team.cjs +47 -6
- package/dist/about-startup-team.js +47 -6
- package/dist/about-stats-showcase.cjs +31 -4
- package/dist/about-stats-showcase.js +31 -4
- package/dist/about-stats-sidebar.cjs +29 -3
- package/dist/about-stats-sidebar.js +29 -3
- package/dist/about-story-expertise.cjs +44 -8
- package/dist/about-story-expertise.js +44 -8
- package/dist/about-story-gallery.cjs +28 -1
- package/dist/about-story-gallery.js +28 -1
- package/dist/about-story-hero.cjs +36 -4
- package/dist/about-story-hero.js +36 -4
- package/dist/about-streamline-team.cjs +32 -4
- package/dist/about-streamline-team.js +32 -4
- package/dist/about-vision-gallery.cjs +32 -3
- package/dist/about-vision-gallery.js +32 -3
- package/dist/alternating-blocks.cjs +5 -1
- package/dist/alternating-blocks.js +5 -1
- package/dist/banner-announcement-dismissible.cjs +377 -1
- package/dist/banner-announcement-dismissible.d.cts +7 -1
- package/dist/banner-announcement-dismissible.d.ts +7 -1
- package/dist/banner-announcement-dismissible.js +378 -2
- package/dist/banner-countdown-sale.cjs +388 -8
- package/dist/banner-countdown-sale.d.cts +11 -1
- package/dist/banner-countdown-sale.d.ts +11 -1
- package/dist/banner-countdown-sale.js +379 -3
- package/dist/banner-delivery-countdown.cjs +377 -1
- package/dist/banner-delivery-countdown.d.cts +11 -1
- package/dist/banner-delivery-countdown.d.ts +11 -1
- package/dist/banner-delivery-countdown.js +378 -2
- package/dist/banner-event-promo.cjs +377 -1
- package/dist/banner-event-promo.d.cts +7 -1
- package/dist/banner-event-promo.d.ts +7 -1
- package/dist/banner-event-promo.js +378 -2
- package/dist/banner-floating-offer.cjs +379 -3
- package/dist/banner-floating-offer.d.cts +7 -1
- package/dist/banner-floating-offer.d.ts +7 -1
- package/dist/banner-floating-offer.js +380 -4
- package/dist/banner-gdpr-rights.cjs +398 -31
- package/dist/banner-gdpr-rights.d.cts +7 -1
- package/dist/banner-gdpr-rights.d.ts +7 -1
- package/dist/banner-gdpr-rights.js +399 -32
- package/dist/banner-privacy-notice.cjs +399 -32
- package/dist/banner-privacy-notice.d.cts +7 -1
- package/dist/banner-privacy-notice.d.ts +7 -1
- package/dist/banner-privacy-notice.js +400 -33
- package/dist/banner-promo-cta.cjs +382 -12
- package/dist/banner-promo-cta.d.cts +7 -1
- package/dist/banner-promo-cta.d.ts +7 -1
- package/dist/banner-promo-cta.js +383 -13
- package/dist/banner-social-follow.cjs +395 -28
- package/dist/banner-social-follow.d.cts +7 -1
- package/dist/banner-social-follow.d.ts +7 -1
- package/dist/banner-social-follow.js +396 -29
- package/dist/banner-survey-incentive.cjs +377 -1
- package/dist/banner-survey-incentive.d.cts +7 -1
- package/dist/banner-survey-incentive.d.ts +7 -1
- package/dist/banner-survey-incentive.js +378 -2
- package/dist/community-initiatives.cjs +43 -10
- package/dist/community-initiatives.js +43 -10
- package/dist/components.cjs +76 -36
- package/dist/components.js +76 -36
- package/dist/contact-floating-banner.cjs +378 -2
- package/dist/contact-floating-banner.d.cts +7 -1
- package/dist/contact-floating-banner.d.ts +7 -1
- package/dist/contact-floating-banner.js +379 -2
- package/dist/cta-accent-background.cjs +28 -1
- package/dist/cta-accent-background.js +28 -1
- package/dist/cta-app-download-newsletter.cjs +30 -2
- package/dist/cta-app-download-newsletter.js +30 -2
- package/dist/cta-documentation-links.cjs +28 -2
- package/dist/cta-documentation-links.js +28 -2
- package/dist/cta-feature-cards-grid.cjs +34 -3
- package/dist/cta-feature-cards-grid.js +34 -3
- package/dist/cta-feature-checklist.cjs +27 -1
- package/dist/cta-feature-checklist.js +27 -1
- package/dist/cta-feature-list.cjs +33 -2
- package/dist/cta-feature-list.js +33 -2
- package/dist/cta-gradient-logos-floating.cjs +28 -1
- package/dist/cta-gradient-logos-floating.js +28 -1
- package/dist/cta-minimal-separator.cjs +27 -1
- package/dist/cta-minimal-separator.js +27 -1
- package/dist/cta-platform-demo.cjs +28 -1
- package/dist/cta-platform-demo.js +28 -1
- package/dist/cta-simple-centered.cjs +28 -1
- package/dist/cta-simple-centered.js +28 -1
- package/dist/cta-split-gradient-image.cjs +28 -1
- package/dist/cta-split-gradient-image.js +28 -1
- package/dist/cta-split-image-logos.cjs +29 -2
- package/dist/cta-split-image-logos.js +29 -2
- package/dist/cta-split-image.cjs +29 -2
- package/dist/cta-split-image.js +29 -2
- package/dist/cta-stacked-cards.cjs +28 -1
- package/dist/cta-stacked-cards.js +28 -1
- package/dist/faq-badge-support.cjs +33 -5
- package/dist/faq-badge-support.js +33 -5
- package/dist/faq-bordered-badge.cjs +31 -3
- package/dist/faq-bordered-badge.js +31 -3
- package/dist/faq-card-categories.cjs +60 -4
- package/dist/faq-card-categories.js +60 -4
- package/dist/faq-categorized-sections.cjs +31 -3
- package/dist/faq-categorized-sections.js +31 -3
- package/dist/faq-centered-accordion.cjs +31 -3
- package/dist/faq-centered-accordion.js +31 -3
- package/dist/faq-gradient-categories.cjs +31 -3
- package/dist/faq-gradient-categories.js +31 -3
- package/dist/faq-icon-benefits.cjs +40 -5
- package/dist/faq-icon-benefits.js +40 -5
- package/dist/faq-muted-cards.cjs +29 -2
- package/dist/faq-muted-cards.js +29 -2
- package/dist/faq-numbered-grid.cjs +32 -3
- package/dist/faq-numbered-grid.js +32 -3
- package/dist/faq-numbered-list.cjs +32 -3
- package/dist/faq-numbered-list.js +32 -3
- package/dist/faq-profile-sidebar.cjs +36 -6
- package/dist/faq-profile-sidebar.js +36 -6
- package/dist/faq-sidebar-navigation.cjs +30 -3
- package/dist/faq-sidebar-navigation.js +30 -3
- package/dist/faq-simple-accordion.cjs +29 -2
- package/dist/faq-simple-accordion.js +29 -2
- package/dist/feature-accordion-image.cjs +28 -2
- package/dist/feature-accordion-image.js +28 -2
- package/dist/feature-badge-grid-six.cjs +27 -1
- package/dist/feature-badge-grid-six.js +27 -1
- package/dist/feature-bento-image-grid.cjs +27 -1
- package/dist/feature-bento-image-grid.js +27 -1
- package/dist/feature-bento-utilities.cjs +56 -4
- package/dist/feature-bento-utilities.js +56 -4
- package/dist/feature-capabilities-grid.cjs +29 -3
- package/dist/feature-capabilities-grid.js +29 -3
- package/dist/feature-card-grid-linked.cjs +29 -2
- package/dist/feature-card-grid-linked.js +29 -2
- package/dist/feature-carousel-progress.cjs +28 -2
- package/dist/feature-carousel-progress.js +28 -2
- package/dist/feature-category-image-cards.cjs +28 -2
- package/dist/feature-category-image-cards.js +28 -2
- package/dist/feature-checklist-image.cjs +30 -2
- package/dist/feature-checklist-image.js +30 -2
- package/dist/feature-checklist-three-column.cjs +35 -5
- package/dist/feature-checklist-three-column.js +35 -5
- package/dist/feature-icon-grid-accent.cjs +28 -2
- package/dist/feature-icon-grid-accent.js +28 -2
- package/dist/feature-icon-grid-bordered.cjs +9 -4
- package/dist/feature-icon-grid-bordered.js +9 -4
- package/dist/feature-icon-grid-muted.cjs +28 -2
- package/dist/feature-icon-grid-muted.js +28 -2
- package/dist/feature-icon-tabs-content.cjs +56 -5
- package/dist/feature-icon-tabs-content.js +56 -5
- package/dist/feature-image-cards-three-column.cjs +27 -1
- package/dist/feature-image-cards-three-column.js +27 -1
- package/dist/feature-integration-cards.cjs +28 -2
- package/dist/feature-integration-cards.js +28 -2
- package/dist/feature-pattern-grid-links.cjs +28 -2
- package/dist/feature-pattern-grid-links.js +28 -2
- package/dist/feature-utility-cards-grid.cjs +9 -4
- package/dist/feature-utility-cards-grid.js +9 -4
- package/dist/footer-comprehensive-links.cjs +231 -151
- package/dist/footer-comprehensive-links.js +231 -151
- package/dist/hero-ad-campaign-expert.cjs +24 -2
- package/dist/hero-ad-campaign-expert.js +24 -2
- package/dist/hero-adaptable-product-grid.cjs +27 -1
- package/dist/hero-adaptable-product-grid.js +27 -1
- package/dist/hero-ai-powered-carousel.cjs +27 -1
- package/dist/hero-ai-powered-carousel.js +27 -1
- package/dist/hero-announcement-badge.cjs +27 -1
- package/dist/hero-announcement-badge.js +27 -1
- package/dist/hero-architecture-fullscreen.cjs +50 -2
- package/dist/hero-architecture-fullscreen.js +50 -2
- package/dist/hero-badge-image-split.cjs +27 -1
- package/dist/hero-badge-image-split.js +27 -1
- package/dist/hero-business-carousel-dots.cjs +27 -1
- package/dist/hero-business-carousel-dots.js +27 -1
- package/dist/hero-centered-gradient-cta.cjs +28 -2
- package/dist/hero-centered-gradient-cta.js +28 -2
- package/dist/hero-centered-image-grid.cjs +27 -1
- package/dist/hero-centered-image-grid.js +27 -1
- package/dist/hero-centered-screenshot.cjs +50 -2
- package/dist/hero-centered-screenshot.js +50 -2
- package/dist/hero-coming-soon-countdown.cjs +37 -7
- package/dist/hero-coming-soon-countdown.js +37 -7
- package/dist/hero-community-survey-cta.cjs +27 -1
- package/dist/hero-community-survey-cta.js +27 -1
- package/dist/hero-conversation-intelligence.cjs +50 -2
- package/dist/hero-conversation-intelligence.js +50 -2
- package/dist/hero-conversion-video-play.cjs +55 -3
- package/dist/hero-conversion-video-play.js +55 -3
- package/dist/hero-creative-studio-stacked.cjs +28 -2
- package/dist/hero-creative-studio-stacked.js +28 -2
- package/dist/hero-crm-streamlined.cjs +27 -1
- package/dist/hero-crm-streamlined.js +27 -1
- package/dist/hero-customer-support-layered.cjs +51 -3
- package/dist/hero-customer-support-layered.js +51 -3
- package/dist/hero-dashed-border-features.cjs +27 -1
- package/dist/hero-dashed-border-features.js +27 -1
- package/dist/hero-design-showcase-logos.cjs +27 -1
- package/dist/hero-design-showcase-logos.js +27 -1
- package/dist/hero-design-system-3d.cjs +32 -2
- package/dist/hero-design-system-3d.js +32 -2
- package/dist/hero-developer-tools-code.cjs +27 -1
- package/dist/hero-developer-tools-code.js +27 -1
- package/dist/hero-digital-agency-fullscreen.cjs +33 -3
- package/dist/hero-digital-agency-fullscreen.js +33 -3
- package/dist/hero-ecommerce-product-showcase.cjs +32 -6
- package/dist/hero-ecommerce-product-showcase.js +32 -6
- package/dist/hero-enterprise-security.cjs +34 -4
- package/dist/hero-enterprise-security.js +34 -4
- package/dist/hero-event-registration.cjs +35 -5
- package/dist/hero-event-registration.js +35 -5
- package/dist/hero-feature-cards-grid.cjs +82 -4
- package/dist/hero-feature-cards-grid.js +82 -4
- package/dist/hero-gradient-avatars-rating.cjs +30 -4
- package/dist/hero-gradient-avatars-rating.js +30 -4
- package/dist/hero-gradient-client-focused.cjs +27 -1
- package/dist/hero-gradient-client-focused.js +27 -1
- package/dist/hero-grid-pattern-efficiency.cjs +28 -2
- package/dist/hero-grid-pattern-efficiency.js +28 -2
- package/dist/hero-grid-pattern-solutions.cjs +27 -1
- package/dist/hero-grid-pattern-solutions.js +27 -1
- package/dist/hero-image-left-content.cjs +27 -1
- package/dist/hero-image-left-content.js +27 -1
- package/dist/hero-innovation-image-grid.cjs +27 -1
- package/dist/hero-innovation-image-grid.js +27 -1
- package/dist/hero-logo-centered-screenshot.cjs +27 -1
- package/dist/hero-logo-centered-screenshot.js +27 -1
- package/dist/hero-marketplace-scattered-images.cjs +27 -1
- package/dist/hero-marketplace-scattered-images.js +27 -1
- package/dist/hero-mentorship-video-split.cjs +7 -3
- package/dist/hero-mentorship-video-split.js +7 -3
- package/dist/hero-minimal-centered-dark.cjs +55 -3
- package/dist/hero-minimal-centered-dark.js +55 -3
- package/dist/hero-mobile-app-download.cjs +34 -4
- package/dist/hero-mobile-app-download.js +34 -4
- package/dist/hero-newsletter-minimal.cjs +29 -3
- package/dist/hero-newsletter-minimal.js +29 -3
- package/dist/hero-overlay-cta-grid.cjs +33 -3
- package/dist/hero-overlay-cta-grid.js +33 -3
- package/dist/hero-pattern-badge-logos.cjs +28 -2
- package/dist/hero-pattern-badge-logos.js +28 -2
- package/dist/hero-pattern-logo-tech-stack.cjs +33 -3
- package/dist/hero-pattern-logo-tech-stack.js +33 -3
- package/dist/hero-platform-features-grid.cjs +28 -2
- package/dist/hero-platform-features-grid.js +28 -2
- package/dist/hero-portfolio-creative.cjs +29 -3
- package/dist/hero-portfolio-creative.js +29 -3
- package/dist/hero-pricing-comparison.cjs +52 -4
- package/dist/hero-pricing-comparison.js +52 -4
- package/dist/hero-product-showcase-floating.cjs +34 -4
- package/dist/hero-product-showcase-floating.js +34 -4
- package/dist/hero-productivity-launcher-video.cjs +29 -3
- package/dist/hero-productivity-launcher-video.js +29 -3
- package/dist/hero-saas-dashboard-preview.cjs +34 -4
- package/dist/hero-saas-dashboard-preview.js +34 -4
- package/dist/hero-shared-inbox-layered.cjs +51 -3
- package/dist/hero-shared-inbox-layered.js +51 -3
- package/dist/hero-simple-centered-image.cjs +27 -1
- package/dist/hero-simple-centered-image.js +27 -1
- package/dist/hero-software-growth-video-dialog.cjs +50 -2
- package/dist/hero-software-growth-video-dialog.js +50 -2
- package/dist/hero-spiral-pattern-cards.cjs +28 -2
- package/dist/hero-spiral-pattern-cards.js +28 -2
- package/dist/hero-split-icon-cards.cjs +34 -4
- package/dist/hero-split-icon-cards.js +34 -4
- package/dist/hero-split-image-newsletter.cjs +28 -2
- package/dist/hero-split-image-newsletter.js +28 -2
- package/dist/hero-split-spiral-shapes.cjs +28 -2
- package/dist/hero-split-spiral-shapes.js +28 -2
- package/dist/hero-startup-launch-cta.cjs +28 -2
- package/dist/hero-startup-launch-cta.js +28 -2
- package/dist/hero-stats-social-proof.cjs +34 -4
- package/dist/hero-stats-social-proof.js +34 -4
- package/dist/hero-tech-carousel.cjs +27 -1
- package/dist/hero-tech-carousel.js +27 -1
- package/dist/hero-ui-library-showcase.cjs +27 -1
- package/dist/hero-ui-library-showcase.js +27 -1
- package/dist/hero-video-background-dark.cjs +28 -2
- package/dist/hero-video-background-dark.js +28 -2
- package/dist/hero-video-dialog-gradient.cjs +27 -1
- package/dist/hero-video-dialog-gradient.js +27 -1
- package/dist/hero-welcome-asymmetric-images.cjs +30 -2
- package/dist/hero-welcome-asymmetric-images.js +30 -2
- package/dist/index.cjs +104 -36
- package/dist/index.d.cts +1 -1
- package/dist/index.d.ts +1 -1
- package/dist/index.js +102 -37
- package/dist/link-page-bento-layout.cjs +57 -28
- package/dist/link-page-bento-layout.d.cts +1 -5
- package/dist/link-page-bento-layout.d.ts +1 -5
- package/dist/link-page-bento-layout.js +57 -28
- package/dist/link-page-grid-cards.cjs +52 -23
- package/dist/link-page-grid-cards.d.cts +1 -5
- package/dist/link-page-grid-cards.d.ts +1 -5
- package/dist/link-page-grid-cards.js +52 -23
- package/dist/link-page-minimal-profile.cjs +46 -18
- package/dist/link-page-minimal-profile.d.cts +1 -5
- package/dist/link-page-minimal-profile.d.ts +1 -5
- package/dist/link-page-minimal-profile.js +46 -18
- package/dist/link-page-newsletter-social.cjs +53 -28
- package/dist/link-page-newsletter-social.d.cts +1 -5
- package/dist/link-page-newsletter-social.d.ts +1 -5
- package/dist/link-page-newsletter-social.js +53 -28
- package/dist/link-tree-block.cjs +122 -34
- package/dist/link-tree-block.d.cts +1 -8
- package/dist/link-tree-block.d.ts +1 -8
- package/dist/link-tree-block.js +122 -34
- package/dist/media-hover-ctas.cjs +28 -2
- package/dist/media-hover-ctas.js +28 -2
- package/dist/process-expandable-timeline.cjs +66 -10
- package/dist/process-expandable-timeline.js +66 -10
- package/dist/process-hover-cards.cjs +39 -6
- package/dist/process-hover-cards.js +39 -6
- package/dist/process-icon-timeline.cjs +53 -3
- package/dist/process-icon-timeline.js +53 -3
- package/dist/process-mission-principles.cjs +44 -6
- package/dist/process-mission-principles.js +44 -6
- package/dist/process-numbered-services.cjs +76 -22
- package/dist/process-numbered-services.js +76 -22
- package/dist/process-roadmap-timeline.cjs +63 -9
- package/dist/process-roadmap-timeline.js +63 -9
- package/dist/process-scroll-image.cjs +71 -32
- package/dist/process-scroll-image.js +71 -32
- package/dist/process-steps-grid.cjs +61 -5
- package/dist/process-steps-grid.js +61 -5
- package/dist/process-sticky-steps.cjs +49 -69
- package/dist/process-sticky-steps.d.cts +1 -13
- package/dist/process-sticky-steps.d.ts +1 -13
- package/dist/process-sticky-steps.js +49 -69
- package/dist/project-zigzag-layout.cjs +379 -3
- package/dist/project-zigzag-layout.d.cts +8 -1
- package/dist/project-zigzag-layout.d.ts +8 -1
- package/dist/project-zigzag-layout.js +380 -3
- package/dist/registry.cjs +2759 -2476
- package/dist/registry.js +2759 -2476
- package/dist/team-media-showcase.cjs +59 -4
- package/dist/team-media-showcase.d.cts +4 -0
- package/dist/team-media-showcase.d.ts +4 -0
- package/dist/team-media-showcase.js +59 -4
- package/dist/testimonials-carousel-image.d.cts +6 -0
- package/dist/testimonials-carousel-image.d.ts +6 -0
- package/dist/utils.cjs +58 -0
- package/dist/utils.d.cts +113 -1
- package/dist/utils.d.ts +113 -1
- package/dist/utils.js +56 -1
- package/package.json +1 -1
|
@@ -41,6 +41,32 @@ function getNestedCardTextColor(parentBg, options) {
|
|
|
41
41
|
const isDark = parentBg === "dark" || parentBg === "secondary" || parentBg === "primary";
|
|
42
42
|
return isDark ? "text-foreground" : "";
|
|
43
43
|
}
|
|
44
|
+
function getTextColor(parentBg, variant = "default", options) {
|
|
45
|
+
const isDark = parentBg === "dark" || parentBg === "secondary" || parentBg === "primary";
|
|
46
|
+
if (isDark) {
|
|
47
|
+
switch (variant) {
|
|
48
|
+
case "default":
|
|
49
|
+
return "text-foreground";
|
|
50
|
+
case "muted":
|
|
51
|
+
return "text-foreground/80";
|
|
52
|
+
case "subtle":
|
|
53
|
+
return "text-foreground/60";
|
|
54
|
+
case "accent":
|
|
55
|
+
return "text-accent-foreground";
|
|
56
|
+
}
|
|
57
|
+
} else {
|
|
58
|
+
switch (variant) {
|
|
59
|
+
case "default":
|
|
60
|
+
return "text-foreground";
|
|
61
|
+
case "muted":
|
|
62
|
+
return "text-muted-foreground";
|
|
63
|
+
case "subtle":
|
|
64
|
+
return "text-muted-foreground/70";
|
|
65
|
+
case "accent":
|
|
66
|
+
return "text-primary";
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
}
|
|
44
70
|
function normalizePhoneNumber(input) {
|
|
45
71
|
const trimmed = input.trim();
|
|
46
72
|
if (trimmed.toLowerCase().startsWith("tel:")) {
|
|
@@ -981,16 +1007,14 @@ function LinkPageBentoLayout({
|
|
|
981
1007
|
regularLinkIconClassName,
|
|
982
1008
|
regularLinkLabelClassName,
|
|
983
1009
|
footerClassName,
|
|
984
|
-
|
|
985
|
-
background,
|
|
1010
|
+
background = "white",
|
|
986
1011
|
spacing,
|
|
987
1012
|
pattern,
|
|
988
1013
|
patternOpacity,
|
|
989
1014
|
patternClassName,
|
|
990
1015
|
optixFlowConfig
|
|
991
1016
|
}) {
|
|
992
|
-
const
|
|
993
|
-
const resolvedBackground = background ?? (isDark ? "dark" : "white");
|
|
1017
|
+
const resolvedBackground = background;
|
|
994
1018
|
const resolvedAvatar = avatar || (avatarUrl ? {
|
|
995
1019
|
src: avatarUrl,
|
|
996
1020
|
alt: typeof name === "string" ? name : "Profile avatar"
|
|
@@ -1001,10 +1025,11 @@ function LinkPageBentoLayout({
|
|
|
1001
1025
|
if (socialLinksSlot) return socialLinksSlot;
|
|
1002
1026
|
if (!socialLinks || socialLinks.length === 0) return null;
|
|
1003
1027
|
return /* @__PURE__ */ jsx("div", { className: cn("flex items-center gap-2 pt-1", socialLinksClassName), children: socialLinks.map((social, index) => {
|
|
1004
|
-
const
|
|
1028
|
+
const { iconName, ...socialPressableProps } = social;
|
|
1029
|
+
const icon = social.icon || (iconName ? /* @__PURE__ */ jsx(
|
|
1005
1030
|
DynamicIcon,
|
|
1006
1031
|
{
|
|
1007
|
-
name:
|
|
1032
|
+
name: iconName,
|
|
1008
1033
|
size: 18,
|
|
1009
1034
|
className: socialIconClassName
|
|
1010
1035
|
}
|
|
@@ -1013,12 +1038,13 @@ function LinkPageBentoLayout({
|
|
|
1013
1038
|
return /* @__PURE__ */ jsx(
|
|
1014
1039
|
Pressable,
|
|
1015
1040
|
{
|
|
1016
|
-
|
|
1041
|
+
...socialPressableProps,
|
|
1017
1042
|
"aria-label": ariaLabel,
|
|
1018
1043
|
className: cn(
|
|
1019
1044
|
"rounded-full p-2 transition-all duration-200",
|
|
1020
1045
|
"hover:scale-110 active:scale-95",
|
|
1021
|
-
|
|
1046
|
+
getTextColor(resolvedBackground, "muted"),
|
|
1047
|
+
"hover:opacity-80",
|
|
1022
1048
|
socialLinkClassName,
|
|
1023
1049
|
social.className
|
|
1024
1050
|
),
|
|
@@ -1027,7 +1053,7 @@ function LinkPageBentoLayout({
|
|
|
1027
1053
|
social.id ?? index
|
|
1028
1054
|
);
|
|
1029
1055
|
}) });
|
|
1030
|
-
}, [socialLinksSlot, socialLinks, socialLinksClassName, socialIconClassName,
|
|
1056
|
+
}, [socialLinksSlot, socialLinks, socialLinksClassName, socialIconClassName, resolvedBackground, socialLinkClassName]);
|
|
1031
1057
|
const renderFeaturedLinks = useMemo(() => {
|
|
1032
1058
|
if (featuredLinksSlot) return featuredLinksSlot;
|
|
1033
1059
|
if (!featuredLinks || featuredLinks.length === 0) return null;
|
|
@@ -1040,14 +1066,15 @@ function LinkPageBentoLayout({
|
|
|
1040
1066
|
className: linkClassName,
|
|
1041
1067
|
featured: _featured,
|
|
1042
1068
|
// Destructure to prevent passing to DOM
|
|
1069
|
+
iconName,
|
|
1043
1070
|
...pressableProps
|
|
1044
1071
|
} = link;
|
|
1045
1072
|
const imageSource = link.image?.src ?? link.imageUrl;
|
|
1046
1073
|
const imageAlt = link.image?.alt || (typeof label === "string" ? label : "");
|
|
1047
|
-
const iconElement = icon || (
|
|
1074
|
+
const iconElement = icon || (iconName ? /* @__PURE__ */ jsx(
|
|
1048
1075
|
DynamicIcon,
|
|
1049
1076
|
{
|
|
1050
|
-
name:
|
|
1077
|
+
name: iconName,
|
|
1051
1078
|
size: 18,
|
|
1052
1079
|
className: featuredLinkIconClassName
|
|
1053
1080
|
}
|
|
@@ -1059,7 +1086,7 @@ function LinkPageBentoLayout({
|
|
|
1059
1086
|
className: cn(
|
|
1060
1087
|
"group relative aspect-4/3 overflow-hidden rounded-2xl transition-all duration-200",
|
|
1061
1088
|
"hover:scale-[1.02] active:scale-[0.98]",
|
|
1062
|
-
|
|
1089
|
+
"border border-border bg-muted",
|
|
1063
1090
|
featuredLinkClassName,
|
|
1064
1091
|
linkClassName
|
|
1065
1092
|
),
|
|
@@ -1075,7 +1102,7 @@ function LinkPageBentoLayout({
|
|
|
1075
1102
|
className: cn(
|
|
1076
1103
|
"group relative aspect-4/3 overflow-hidden rounded-2xl transition-all duration-200",
|
|
1077
1104
|
"hover:scale-[1.02] active:scale-[0.98]",
|
|
1078
|
-
|
|
1105
|
+
"border border-border bg-muted",
|
|
1079
1106
|
featuredLinkClassName,
|
|
1080
1107
|
linkClassName
|
|
1081
1108
|
),
|
|
@@ -1098,7 +1125,7 @@ function LinkPageBentoLayout({
|
|
|
1098
1125
|
{
|
|
1099
1126
|
className: cn(
|
|
1100
1127
|
"absolute inset-0 transition-opacity",
|
|
1101
|
-
imageSource ? "bg-linear-to-t from-black/80 via-black/40 to-transparent" :
|
|
1128
|
+
imageSource ? "bg-linear-to-t from-black/80 via-black/40 to-transparent" : "bg-linear-to-t from-neutral-200/50 to-transparent",
|
|
1102
1129
|
featuredLinkOverlayClassName
|
|
1103
1130
|
)
|
|
1104
1131
|
}
|
|
@@ -1123,7 +1150,7 @@ function LinkPageBentoLayout({
|
|
|
1123
1150
|
{
|
|
1124
1151
|
className: cn(
|
|
1125
1152
|
"mt-0.5 text-xs",
|
|
1126
|
-
imageSource ? "text-background/70" : "
|
|
1153
|
+
imageSource ? "text-background/70" : getTextColor(resolvedBackground, "muted"),
|
|
1127
1154
|
featuredLinkDescriptionClassName
|
|
1128
1155
|
),
|
|
1129
1156
|
children: description
|
|
@@ -1135,7 +1162,7 @@ function LinkPageBentoLayout({
|
|
|
1135
1162
|
link.id ?? index
|
|
1136
1163
|
);
|
|
1137
1164
|
});
|
|
1138
|
-
}, [featuredLinksSlot, featuredLinks,
|
|
1165
|
+
}, [featuredLinksSlot, featuredLinks, resolvedBackground, featuredLinkClassName, featuredLinkImageClassName, optixFlowConfig, featuredLinkOverlayClassName, featuredLinkIconClassName, featuredLinkLabelClassName, featuredLinkDescriptionClassName]);
|
|
1139
1166
|
const renderRegularLinks = useMemo(() => {
|
|
1140
1167
|
if (regularLinksSlot) return regularLinksSlot;
|
|
1141
1168
|
if (!regularLinks || regularLinks.length === 0) return null;
|
|
@@ -1145,12 +1172,13 @@ function LinkPageBentoLayout({
|
|
|
1145
1172
|
icon,
|
|
1146
1173
|
children,
|
|
1147
1174
|
className: linkClassName,
|
|
1175
|
+
iconName,
|
|
1148
1176
|
...pressableProps
|
|
1149
1177
|
} = link;
|
|
1150
|
-
const iconElement = icon || (
|
|
1178
|
+
const iconElement = icon || (iconName ? /* @__PURE__ */ jsx(
|
|
1151
1179
|
DynamicIcon,
|
|
1152
1180
|
{
|
|
1153
|
-
name:
|
|
1181
|
+
name: iconName,
|
|
1154
1182
|
size: 20,
|
|
1155
1183
|
className: regularLinkIconClassName
|
|
1156
1184
|
}
|
|
@@ -1162,7 +1190,7 @@ function LinkPageBentoLayout({
|
|
|
1162
1190
|
className: cn(
|
|
1163
1191
|
"group flex items-center gap-3 rounded-xl p-3 transition-all duration-200",
|
|
1164
1192
|
"hover:scale-[1.02] active:scale-[0.98]",
|
|
1165
|
-
|
|
1193
|
+
"border border-border bg-muted/50 hover:opacity-80",
|
|
1166
1194
|
regularLinkClassName,
|
|
1167
1195
|
linkClassName
|
|
1168
1196
|
),
|
|
@@ -1178,7 +1206,7 @@ function LinkPageBentoLayout({
|
|
|
1178
1206
|
className: cn(
|
|
1179
1207
|
"group flex items-center gap-3 rounded-xl p-3 transition-all duration-200",
|
|
1180
1208
|
"hover:scale-[1.02] active:scale-[0.98]",
|
|
1181
|
-
|
|
1209
|
+
"border border-border bg-muted/50 hover:opacity-80",
|
|
1182
1210
|
regularLinkClassName,
|
|
1183
1211
|
linkClassName
|
|
1184
1212
|
),
|
|
@@ -1211,7 +1239,7 @@ function LinkPageBentoLayout({
|
|
|
1211
1239
|
link.id ?? index
|
|
1212
1240
|
);
|
|
1213
1241
|
});
|
|
1214
|
-
}, [regularLinksSlot, regularLinks,
|
|
1242
|
+
}, [regularLinksSlot, regularLinks, resolvedBackground, regularLinkClassName, regularLinkIconWrapperClassName, regularLinkIconClassName, regularLinkLabelClassName]);
|
|
1215
1243
|
const renderLinks = useMemo(() => {
|
|
1216
1244
|
if (linksSlot) return linksSlot;
|
|
1217
1245
|
if (!links || links.length === 0) return null;
|
|
@@ -1236,8 +1264,7 @@ function LinkPageBentoLayout({
|
|
|
1236
1264
|
"div",
|
|
1237
1265
|
{
|
|
1238
1266
|
className: cn(
|
|
1239
|
-
"h-20 w-20 overflow-hidden rounded-full",
|
|
1240
|
-
isDark ? "ring-2 ring-white/20" : "ring-2 ring-neutral-200",
|
|
1267
|
+
"h-20 w-20 overflow-hidden rounded-full ring-2 ring-neutral-200",
|
|
1241
1268
|
avatarClassName
|
|
1242
1269
|
),
|
|
1243
1270
|
children: /* @__PURE__ */ jsx(
|
|
@@ -1266,7 +1293,8 @@ function LinkPageBentoLayout({
|
|
|
1266
1293
|
"p",
|
|
1267
1294
|
{
|
|
1268
1295
|
className: cn(
|
|
1269
|
-
"max-w-xs text-sm
|
|
1296
|
+
"max-w-xs text-sm",
|
|
1297
|
+
getTextColor(resolvedBackground, "muted"),
|
|
1270
1298
|
bioClassName
|
|
1271
1299
|
),
|
|
1272
1300
|
children: bio
|
|
@@ -1277,7 +1305,7 @@ function LinkPageBentoLayout({
|
|
|
1277
1305
|
]
|
|
1278
1306
|
}
|
|
1279
1307
|
);
|
|
1280
|
-
}, [profileSlot, resolvedAvatar,
|
|
1308
|
+
}, [profileSlot, resolvedAvatar, resolvedBackground, avatarClassName, optixFlowConfig, name, nameClassName, bio, bioClassName, renderSocialLinks, headerClassName]);
|
|
1281
1309
|
const renderFooter = useMemo(() => {
|
|
1282
1310
|
if (footerSlot) return footerSlot;
|
|
1283
1311
|
if (!footerAction) return null;
|
|
@@ -1296,7 +1324,8 @@ function LinkPageBentoLayout({
|
|
|
1296
1324
|
{
|
|
1297
1325
|
className: cn(
|
|
1298
1326
|
"flex items-center justify-center gap-1.5 text-xs transition-opacity hover:opacity-80",
|
|
1299
|
-
"
|
|
1327
|
+
getTextColor(resolvedBackground, "muted"),
|
|
1328
|
+
"opacity-50",
|
|
1300
1329
|
footerClassName,
|
|
1301
1330
|
actionClassName
|
|
1302
1331
|
),
|
|
@@ -1308,13 +1337,13 @@ function LinkPageBentoLayout({
|
|
|
1308
1337
|
] })
|
|
1309
1338
|
}
|
|
1310
1339
|
);
|
|
1311
|
-
}, [footerSlot, footerAction,
|
|
1340
|
+
}, [footerSlot, footerAction, resolvedBackground, footerClassName]);
|
|
1312
1341
|
return /* @__PURE__ */ jsx(
|
|
1313
1342
|
Section,
|
|
1314
1343
|
{
|
|
1315
1344
|
background: resolvedBackground,
|
|
1316
1345
|
spacing,
|
|
1317
|
-
className
|
|
1346
|
+
className,
|
|
1318
1347
|
pattern,
|
|
1319
1348
|
patternOpacity,
|
|
1320
1349
|
patternClassName,
|
|
@@ -62,6 +62,32 @@ function getNestedCardTextColor(parentBg, options) {
|
|
|
62
62
|
const isDark = parentBg === "dark" || parentBg === "secondary" || parentBg === "primary";
|
|
63
63
|
return isDark ? "text-foreground" : "";
|
|
64
64
|
}
|
|
65
|
+
function getTextColor(parentBg, variant = "default", options) {
|
|
66
|
+
const isDark = parentBg === "dark" || parentBg === "secondary" || parentBg === "primary";
|
|
67
|
+
if (isDark) {
|
|
68
|
+
switch (variant) {
|
|
69
|
+
case "default":
|
|
70
|
+
return "text-foreground";
|
|
71
|
+
case "muted":
|
|
72
|
+
return "text-foreground/80";
|
|
73
|
+
case "subtle":
|
|
74
|
+
return "text-foreground/60";
|
|
75
|
+
case "accent":
|
|
76
|
+
return "text-accent-foreground";
|
|
77
|
+
}
|
|
78
|
+
} else {
|
|
79
|
+
switch (variant) {
|
|
80
|
+
case "default":
|
|
81
|
+
return "text-foreground";
|
|
82
|
+
case "muted":
|
|
83
|
+
return "text-muted-foreground";
|
|
84
|
+
case "subtle":
|
|
85
|
+
return "text-muted-foreground/70";
|
|
86
|
+
case "accent":
|
|
87
|
+
return "text-primary";
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
}
|
|
65
91
|
function normalizePhoneNumber(input) {
|
|
66
92
|
const trimmed = input.trim();
|
|
67
93
|
if (trimmed.toLowerCase().startsWith("tel:")) {
|
|
@@ -994,16 +1020,14 @@ function LinkPageGridCards({
|
|
|
994
1020
|
cardLabelClassName,
|
|
995
1021
|
cardDescriptionClassName,
|
|
996
1022
|
footerClassName,
|
|
997
|
-
|
|
998
|
-
background,
|
|
1023
|
+
background = "gray",
|
|
999
1024
|
spacing,
|
|
1000
1025
|
pattern,
|
|
1001
1026
|
patternOpacity,
|
|
1002
1027
|
patternClassName,
|
|
1003
1028
|
optixFlowConfig
|
|
1004
1029
|
}) {
|
|
1005
|
-
const
|
|
1006
|
-
const resolvedBackground = background ?? (isDark ? "dark" : "gray");
|
|
1030
|
+
const resolvedBackground = background;
|
|
1007
1031
|
const resolvedAvatar = avatar || (avatarUrl ? {
|
|
1008
1032
|
src: avatarUrl,
|
|
1009
1033
|
alt: typeof name === "string" ? name : "Profile avatar"
|
|
@@ -1022,8 +1046,7 @@ function LinkPageGridCards({
|
|
|
1022
1046
|
"div",
|
|
1023
1047
|
{
|
|
1024
1048
|
className: cn(
|
|
1025
|
-
"h-20 w-20 overflow-hidden rounded-2xl shadow-lg",
|
|
1026
|
-
isDark ? "ring-2 ring-white/10" : "ring-2 ring-neutral-200",
|
|
1049
|
+
"h-20 w-20 overflow-hidden rounded-2xl shadow-lg ring-2 ring-neutral-200",
|
|
1027
1050
|
avatarClassName
|
|
1028
1051
|
),
|
|
1029
1052
|
children: /* @__PURE__ */ jsxRuntime.jsx(
|
|
@@ -1052,7 +1075,8 @@ function LinkPageGridCards({
|
|
|
1052
1075
|
"p",
|
|
1053
1076
|
{
|
|
1054
1077
|
className: cn(
|
|
1055
|
-
"text-sm
|
|
1078
|
+
"text-sm",
|
|
1079
|
+
getTextColor(resolvedBackground, "muted"),
|
|
1056
1080
|
bioClassName
|
|
1057
1081
|
),
|
|
1058
1082
|
children: bio
|
|
@@ -1062,7 +1086,7 @@ function LinkPageGridCards({
|
|
|
1062
1086
|
]
|
|
1063
1087
|
}
|
|
1064
1088
|
);
|
|
1065
|
-
}, [profileSlot, resolvedAvatar,
|
|
1089
|
+
}, [profileSlot, resolvedAvatar, resolvedBackground, avatarClassName, optixFlowConfig, name, nameClassName, bio, bioClassName, headerClassName]);
|
|
1066
1090
|
const renderSocialLinks = React.useMemo(() => {
|
|
1067
1091
|
if (socialLinksSlot) return socialLinksSlot;
|
|
1068
1092
|
if (!socialLinks || socialLinks.length === 0) return null;
|
|
@@ -1074,10 +1098,11 @@ function LinkPageGridCards({
|
|
|
1074
1098
|
socialLinksClassName
|
|
1075
1099
|
),
|
|
1076
1100
|
children: socialLinks.map((social, index) => {
|
|
1077
|
-
const
|
|
1101
|
+
const { iconName, ...socialPressableProps } = social;
|
|
1102
|
+
const icon = social.icon || (iconName ? /* @__PURE__ */ jsxRuntime.jsx(
|
|
1078
1103
|
DynamicIcon,
|
|
1079
1104
|
{
|
|
1080
|
-
name:
|
|
1105
|
+
name: iconName,
|
|
1081
1106
|
size: 18,
|
|
1082
1107
|
className: socialIconClassName
|
|
1083
1108
|
}
|
|
@@ -1086,12 +1111,13 @@ function LinkPageGridCards({
|
|
|
1086
1111
|
return /* @__PURE__ */ jsxRuntime.jsx(
|
|
1087
1112
|
Pressable,
|
|
1088
1113
|
{
|
|
1089
|
-
|
|
1114
|
+
...socialPressableProps,
|
|
1090
1115
|
"aria-label": ariaLabel,
|
|
1091
1116
|
className: cn(
|
|
1092
1117
|
"rounded-lg p-2 transition-all duration-200",
|
|
1093
1118
|
"hover:scale-110 active:scale-95",
|
|
1094
|
-
|
|
1119
|
+
"bg-card hover:opacity-80",
|
|
1120
|
+
getTextColor(resolvedBackground, "muted"),
|
|
1095
1121
|
socialLinkClassName,
|
|
1096
1122
|
social.className
|
|
1097
1123
|
),
|
|
@@ -1102,7 +1128,7 @@ function LinkPageGridCards({
|
|
|
1102
1128
|
})
|
|
1103
1129
|
}
|
|
1104
1130
|
);
|
|
1105
|
-
}, [socialLinksSlot, socialLinks, socialLinksClassName, socialIconClassName,
|
|
1131
|
+
}, [socialLinksSlot, socialLinks, socialLinksClassName, socialIconClassName, resolvedBackground, socialLinkClassName]);
|
|
1106
1132
|
const renderLinks = React.useMemo(() => {
|
|
1107
1133
|
if (linksSlot) return linksSlot;
|
|
1108
1134
|
if (!links || links.length === 0) return null;
|
|
@@ -1121,12 +1147,13 @@ function LinkPageGridCards({
|
|
|
1121
1147
|
icon,
|
|
1122
1148
|
children,
|
|
1123
1149
|
className: linkClassName,
|
|
1150
|
+
iconName,
|
|
1124
1151
|
...pressableProps
|
|
1125
1152
|
} = link;
|
|
1126
|
-
const iconElement = icon || (
|
|
1153
|
+
const iconElement = icon || (iconName ? /* @__PURE__ */ jsxRuntime.jsx(
|
|
1127
1154
|
DynamicIcon,
|
|
1128
1155
|
{
|
|
1129
|
-
name:
|
|
1156
|
+
name: iconName,
|
|
1130
1157
|
size: 24,
|
|
1131
1158
|
className: cardIconClassName
|
|
1132
1159
|
}
|
|
@@ -1138,7 +1165,7 @@ function LinkPageGridCards({
|
|
|
1138
1165
|
className: cn(
|
|
1139
1166
|
"group flex flex-col items-center gap-2 rounded-xl p-4 transition-all duration-200",
|
|
1140
1167
|
"hover:scale-[1.03] active:scale-[0.97]",
|
|
1141
|
-
|
|
1168
|
+
"border border-border bg-card shadow-sm hover:shadow-md",
|
|
1142
1169
|
cardClassName,
|
|
1143
1170
|
linkClassName
|
|
1144
1171
|
),
|
|
@@ -1154,7 +1181,7 @@ function LinkPageGridCards({
|
|
|
1154
1181
|
className: cn(
|
|
1155
1182
|
"group flex flex-col items-center gap-2 rounded-xl p-4 transition-all duration-200",
|
|
1156
1183
|
"hover:scale-[1.03] active:scale-[0.97]",
|
|
1157
|
-
|
|
1184
|
+
"border border-border bg-card shadow-sm hover:shadow-md",
|
|
1158
1185
|
cardClassName,
|
|
1159
1186
|
linkClassName
|
|
1160
1187
|
),
|
|
@@ -1167,7 +1194,7 @@ function LinkPageGridCards({
|
|
|
1167
1194
|
"flex h-12 w-12 items-center justify-center rounded-xl transition-colors",
|
|
1168
1195
|
getNestedCardBg(resolvedBackground),
|
|
1169
1196
|
getNestedCardTextColor(resolvedBackground),
|
|
1170
|
-
|
|
1197
|
+
"group-hover:opacity-80",
|
|
1171
1198
|
cardIconWrapperClassName
|
|
1172
1199
|
),
|
|
1173
1200
|
children: iconElement
|
|
@@ -1188,7 +1215,8 @@ function LinkPageGridCards({
|
|
|
1188
1215
|
"span",
|
|
1189
1216
|
{
|
|
1190
1217
|
className: cn(
|
|
1191
|
-
"block text-xs
|
|
1218
|
+
"block text-xs",
|
|
1219
|
+
getTextColor(resolvedBackground, "muted"),
|
|
1192
1220
|
cardDescriptionClassName
|
|
1193
1221
|
),
|
|
1194
1222
|
children: description
|
|
@@ -1202,7 +1230,7 @@ function LinkPageGridCards({
|
|
|
1202
1230
|
})
|
|
1203
1231
|
}
|
|
1204
1232
|
);
|
|
1205
|
-
}, [linksSlot, links, columns, gridClassName, cardIconClassName,
|
|
1233
|
+
}, [linksSlot, links, columns, gridClassName, cardIconClassName, resolvedBackground, cardClassName, cardIconWrapperClassName, cardLabelClassName, cardDescriptionClassName]);
|
|
1206
1234
|
const renderFooter = React.useMemo(() => {
|
|
1207
1235
|
if (footerSlot) return footerSlot;
|
|
1208
1236
|
if (!footerAction) return null;
|
|
@@ -1221,7 +1249,8 @@ function LinkPageGridCards({
|
|
|
1221
1249
|
{
|
|
1222
1250
|
className: cn(
|
|
1223
1251
|
"flex items-center justify-center gap-1.5 text-xs transition-opacity hover:opacity-80",
|
|
1224
|
-
"
|
|
1252
|
+
getTextColor(resolvedBackground, "muted"),
|
|
1253
|
+
"opacity-50",
|
|
1225
1254
|
footerClassName,
|
|
1226
1255
|
actionClassName
|
|
1227
1256
|
),
|
|
@@ -1233,13 +1262,13 @@ function LinkPageGridCards({
|
|
|
1233
1262
|
] })
|
|
1234
1263
|
}
|
|
1235
1264
|
);
|
|
1236
|
-
}, [footerSlot, footerAction,
|
|
1265
|
+
}, [footerSlot, footerAction, resolvedBackground, footerClassName]);
|
|
1237
1266
|
return /* @__PURE__ */ jsxRuntime.jsx(
|
|
1238
1267
|
Section,
|
|
1239
1268
|
{
|
|
1240
1269
|
background: resolvedBackground,
|
|
1241
1270
|
spacing,
|
|
1242
|
-
className
|
|
1271
|
+
className,
|
|
1243
1272
|
pattern,
|
|
1244
1273
|
patternOpacity,
|
|
1245
1274
|
patternClassName,
|
|
@@ -141,10 +141,6 @@ interface LinkPageGridCardsProps {
|
|
|
141
141
|
* Additional CSS classes for the footer
|
|
142
142
|
*/
|
|
143
143
|
footerClassName?: string;
|
|
144
|
-
/**
|
|
145
|
-
* Theme variation: "light" or "dark"
|
|
146
|
-
*/
|
|
147
|
-
theme?: "light" | "dark";
|
|
148
144
|
/**
|
|
149
145
|
* Background style for the section
|
|
150
146
|
*/
|
|
@@ -196,6 +192,6 @@ interface LinkPageGridCardsProps {
|
|
|
196
192
|
* />
|
|
197
193
|
* ```
|
|
198
194
|
*/
|
|
199
|
-
declare function LinkPageGridCards({ name, bio, avatar, avatarUrl, profileSlot, links, linksSlot, socialLinks, socialLinksSlot, columns, footerAction, footerSlot, className, containerClassName, contentClassName, headerClassName, avatarClassName, nameClassName, bioClassName, socialLinksClassName, socialLinkClassName, socialIconClassName, gridClassName, cardClassName, cardIconWrapperClassName, cardIconClassName, cardLabelClassName, cardDescriptionClassName, footerClassName,
|
|
195
|
+
declare function LinkPageGridCards({ name, bio, avatar, avatarUrl, profileSlot, links, linksSlot, socialLinks, socialLinksSlot, columns, footerAction, footerSlot, className, containerClassName, contentClassName, headerClassName, avatarClassName, nameClassName, bioClassName, socialLinksClassName, socialLinkClassName, socialIconClassName, gridClassName, cardClassName, cardIconWrapperClassName, cardIconClassName, cardLabelClassName, cardDescriptionClassName, footerClassName, background, spacing, pattern, patternOpacity, patternClassName, optixFlowConfig, }: LinkPageGridCardsProps): React.JSX.Element;
|
|
200
196
|
|
|
201
197
|
export { type GridCardLink, type GridCardSocialLink, LinkPageGridCards, type LinkPageGridCardsProps };
|
|
@@ -141,10 +141,6 @@ interface LinkPageGridCardsProps {
|
|
|
141
141
|
* Additional CSS classes for the footer
|
|
142
142
|
*/
|
|
143
143
|
footerClassName?: string;
|
|
144
|
-
/**
|
|
145
|
-
* Theme variation: "light" or "dark"
|
|
146
|
-
*/
|
|
147
|
-
theme?: "light" | "dark";
|
|
148
144
|
/**
|
|
149
145
|
* Background style for the section
|
|
150
146
|
*/
|
|
@@ -196,6 +192,6 @@ interface LinkPageGridCardsProps {
|
|
|
196
192
|
* />
|
|
197
193
|
* ```
|
|
198
194
|
*/
|
|
199
|
-
declare function LinkPageGridCards({ name, bio, avatar, avatarUrl, profileSlot, links, linksSlot, socialLinks, socialLinksSlot, columns, footerAction, footerSlot, className, containerClassName, contentClassName, headerClassName, avatarClassName, nameClassName, bioClassName, socialLinksClassName, socialLinkClassName, socialIconClassName, gridClassName, cardClassName, cardIconWrapperClassName, cardIconClassName, cardLabelClassName, cardDescriptionClassName, footerClassName,
|
|
195
|
+
declare function LinkPageGridCards({ name, bio, avatar, avatarUrl, profileSlot, links, linksSlot, socialLinks, socialLinksSlot, columns, footerAction, footerSlot, className, containerClassName, contentClassName, headerClassName, avatarClassName, nameClassName, bioClassName, socialLinksClassName, socialLinkClassName, socialIconClassName, gridClassName, cardClassName, cardIconWrapperClassName, cardIconClassName, cardLabelClassName, cardDescriptionClassName, footerClassName, background, spacing, pattern, patternOpacity, patternClassName, optixFlowConfig, }: LinkPageGridCardsProps): React.JSX.Element;
|
|
200
196
|
|
|
201
197
|
export { type GridCardLink, type GridCardSocialLink, LinkPageGridCards, type LinkPageGridCardsProps };
|