@barkajs/barka 0.1.0
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/CLAUDE.md +64 -0
- package/INVARIANTS.json +43 -0
- package/LICENSE +19 -0
- package/README.md +566 -0
- package/dist/app.d.ts +22 -0
- package/dist/app.d.ts.map +1 -0
- package/dist/app.js +464 -0
- package/dist/app.js.map +1 -0
- package/dist/built-in-theme/components/cta/cta.d.ts +5 -0
- package/dist/built-in-theme/components/cta/cta.d.ts.map +1 -0
- package/dist/built-in-theme/components/cta/cta.js +6 -0
- package/dist/built-in-theme/components/cta/cta.js.map +1 -0
- package/dist/built-in-theme/components/features/features.d.ts +5 -0
- package/dist/built-in-theme/components/features/features.d.ts.map +1 -0
- package/dist/built-in-theme/components/features/features.js +7 -0
- package/dist/built-in-theme/components/features/features.js.map +1 -0
- package/dist/built-in-theme/components/hero/hero.d.ts +5 -0
- package/dist/built-in-theme/components/hero/hero.d.ts.map +1 -0
- package/dist/built-in-theme/components/hero/hero.js +6 -0
- package/dist/built-in-theme/components/hero/hero.js.map +1 -0
- package/dist/built-in-theme/components/text/text.d.ts +4 -0
- package/dist/built-in-theme/components/text/text.d.ts.map +1 -0
- package/dist/built-in-theme/components/text/text.js +7 -0
- package/dist/built-in-theme/components/text/text.js.map +1 -0
- package/dist/built-in-theme/layouts/article.d.ts +4 -0
- package/dist/built-in-theme/layouts/article.d.ts.map +1 -0
- package/dist/built-in-theme/layouts/article.js +11 -0
- package/dist/built-in-theme/layouts/article.js.map +1 -0
- package/dist/built-in-theme/layouts/base.d.ts +7 -0
- package/dist/built-in-theme/layouts/base.d.ts.map +1 -0
- package/dist/built-in-theme/layouts/base.js +21 -0
- package/dist/built-in-theme/layouts/base.js.map +1 -0
- package/dist/built-in-theme/layouts/landing-page.d.ts +6 -0
- package/dist/built-in-theme/layouts/landing-page.d.ts.map +1 -0
- package/dist/built-in-theme/layouts/landing-page.js +6 -0
- package/dist/built-in-theme/layouts/landing-page.js.map +1 -0
- package/dist/built-in-theme/layouts/page.d.ts +4 -0
- package/dist/built-in-theme/layouts/page.d.ts.map +1 -0
- package/dist/built-in-theme/layouts/page.js +7 -0
- package/dist/built-in-theme/layouts/page.js.map +1 -0
- package/dist/cli/build.d.ts +11 -0
- package/dist/cli/build.d.ts.map +1 -0
- package/dist/cli/build.js +271 -0
- package/dist/cli/build.js.map +1 -0
- package/dist/cli/create-app.d.ts +4 -0
- package/dist/cli/create-app.d.ts.map +1 -0
- package/dist/cli/create-app.js +179 -0
- package/dist/cli/create-app.js.map +1 -0
- package/dist/cli/db-init.d.ts +6 -0
- package/dist/cli/db-init.d.ts.map +1 -0
- package/dist/cli/db-init.js +28 -0
- package/dist/cli/db-init.js.map +1 -0
- package/dist/cli/dev.d.ts +10 -0
- package/dist/cli/dev.d.ts.map +1 -0
- package/dist/cli/dev.js +68 -0
- package/dist/cli/dev.js.map +1 -0
- package/dist/cli/export-cmd.d.ts +6 -0
- package/dist/cli/export-cmd.d.ts.map +1 -0
- package/dist/cli/export-cmd.js +12 -0
- package/dist/cli/export-cmd.js.map +1 -0
- package/dist/cli/import-cmd.d.ts +6 -0
- package/dist/cli/import-cmd.d.ts.map +1 -0
- package/dist/cli/import-cmd.js +11 -0
- package/dist/cli/import-cmd.js.map +1 -0
- package/dist/cli/index.d.ts +3 -0
- package/dist/cli/index.d.ts.map +1 -0
- package/dist/cli/index.js +163 -0
- package/dist/cli/index.js.map +1 -0
- package/dist/cli/init-cmd.d.ts +20 -0
- package/dist/cli/init-cmd.d.ts.map +1 -0
- package/dist/cli/init-cmd.js +116 -0
- package/dist/cli/init-cmd.js.map +1 -0
- package/dist/cli/sync-cmd.d.ts +5 -0
- package/dist/cli/sync-cmd.d.ts.map +1 -0
- package/dist/cli/sync-cmd.js +17 -0
- package/dist/cli/sync-cmd.js.map +1 -0
- package/dist/content-engine.d.ts +50 -0
- package/dist/content-engine.d.ts.map +1 -0
- package/dist/content-engine.js +240 -0
- package/dist/content-engine.js.map +1 -0
- package/dist/db/connection.d.ts +9 -0
- package/dist/db/connection.d.ts.map +1 -0
- package/dist/db/connection.js +121 -0
- package/dist/db/connection.js.map +1 -0
- package/dist/db/schema.d.ts +1178 -0
- package/dist/db/schema.d.ts.map +1 -0
- package/dist/db/schema.js +79 -0
- package/dist/db/schema.js.map +1 -0
- package/dist/index.d.ts +12 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +8 -0
- package/dist/index.js.map +1 -0
- package/dist/lib/auth.d.ts +14 -0
- package/dist/lib/auth.d.ts.map +1 -0
- package/dist/lib/auth.js +40 -0
- package/dist/lib/auth.js.map +1 -0
- package/dist/lib/config-files.d.ts +8 -0
- package/dist/lib/config-files.d.ts.map +1 -0
- package/dist/lib/config-files.js +72 -0
- package/dist/lib/config-files.js.map +1 -0
- package/dist/lib/content-files.d.ts +5 -0
- package/dist/lib/content-files.d.ts.map +1 -0
- package/dist/lib/content-files.js +156 -0
- package/dist/lib/content-files.js.map +1 -0
- package/dist/lib/i18n.d.ts +33 -0
- package/dist/lib/i18n.d.ts.map +1 -0
- package/dist/lib/i18n.js +247 -0
- package/dist/lib/i18n.js.map +1 -0
- package/dist/lib/multisite.d.ts +23 -0
- package/dist/lib/multisite.d.ts.map +1 -0
- package/dist/lib/multisite.js +73 -0
- package/dist/lib/multisite.js.map +1 -0
- package/dist/lib/paths.d.ts +6 -0
- package/dist/lib/paths.d.ts.map +1 -0
- package/dist/lib/paths.js +25 -0
- package/dist/lib/paths.js.map +1 -0
- package/dist/lib/schema-loader.d.ts +25 -0
- package/dist/lib/schema-loader.d.ts.map +1 -0
- package/dist/lib/schema-loader.js +45 -0
- package/dist/lib/schema-loader.js.map +1 -0
- package/dist/lib/seo.d.ts +18 -0
- package/dist/lib/seo.d.ts.map +1 -0
- package/dist/lib/seo.js +212 -0
- package/dist/lib/seo.js.map +1 -0
- package/dist/lib/sync.d.ts +33 -0
- package/dist/lib/sync.d.ts.map +1 -0
- package/dist/lib/sync.js +308 -0
- package/dist/lib/sync.js.map +1 -0
- package/dist/lib/taxonomy.d.ts +29 -0
- package/dist/lib/taxonomy.d.ts.map +1 -0
- package/dist/lib/taxonomy.js +170 -0
- package/dist/lib/taxonomy.js.map +1 -0
- package/dist/lib/template-renderer.d.ts +6 -0
- package/dist/lib/template-renderer.d.ts.map +1 -0
- package/dist/lib/template-renderer.js +80 -0
- package/dist/lib/template-renderer.js.map +1 -0
- package/dist/lib/theme-loader.d.ts +5 -0
- package/dist/lib/theme-loader.d.ts.map +1 -0
- package/dist/lib/theme-loader.js +199 -0
- package/dist/lib/theme-loader.js.map +1 -0
- package/dist/lib/theme-types.d.ts +39 -0
- package/dist/lib/theme-types.d.ts.map +1 -0
- package/dist/lib/theme-types.js +2 -0
- package/dist/lib/theme-types.js.map +1 -0
- package/dist/lib/types.d.ts +91 -0
- package/dist/lib/types.d.ts.map +1 -0
- package/dist/lib/types.js +2 -0
- package/dist/lib/types.js.map +1 -0
- package/dist/routes/admin/content-edit.d.ts +10 -0
- package/dist/routes/admin/content-edit.d.ts.map +1 -0
- package/dist/routes/admin/content-edit.js +325 -0
- package/dist/routes/admin/content-edit.js.map +1 -0
- package/dist/routes/admin/content-list.d.ts +10 -0
- package/dist/routes/admin/content-list.d.ts.map +1 -0
- package/dist/routes/admin/content-list.js +162 -0
- package/dist/routes/admin/content-list.js.map +1 -0
- package/dist/routes/admin/content.d.ts +3 -0
- package/dist/routes/admin/content.d.ts.map +1 -0
- package/dist/routes/admin/content.js +12 -0
- package/dist/routes/admin/content.js.map +1 -0
- package/dist/routes/admin/dashboard.d.ts +4 -0
- package/dist/routes/admin/dashboard.d.ts.map +1 -0
- package/dist/routes/admin/dashboard.js +121 -0
- package/dist/routes/admin/dashboard.js.map +1 -0
- package/dist/routes/admin/export-route.d.ts +10 -0
- package/dist/routes/admin/export-route.d.ts.map +1 -0
- package/dist/routes/admin/export-route.js +19 -0
- package/dist/routes/admin/export-route.js.map +1 -0
- package/dist/routes/admin/index.d.ts +9 -0
- package/dist/routes/admin/index.d.ts.map +1 -0
- package/dist/routes/admin/index.js +27 -0
- package/dist/routes/admin/index.js.map +1 -0
- package/dist/routes/admin/layout.d.ts +17 -0
- package/dist/routes/admin/layout.d.ts.map +1 -0
- package/dist/routes/admin/layout.js +110 -0
- package/dist/routes/admin/layout.js.map +1 -0
- package/dist/routes/admin/login.d.ts +5 -0
- package/dist/routes/admin/login.d.ts.map +1 -0
- package/dist/routes/admin/login.js +113 -0
- package/dist/routes/admin/login.js.map +1 -0
- package/dist/routes/admin/media.d.ts +10 -0
- package/dist/routes/admin/media.d.ts.map +1 -0
- package/dist/routes/admin/media.js +192 -0
- package/dist/routes/admin/media.js.map +1 -0
- package/dist/routes/admin/middleware.d.ts +8 -0
- package/dist/routes/admin/middleware.d.ts.map +1 -0
- package/dist/routes/admin/middleware.js +29 -0
- package/dist/routes/admin/middleware.js.map +1 -0
- package/dist/routes/admin/section-builder.d.ts +10 -0
- package/dist/routes/admin/section-builder.d.ts.map +1 -0
- package/dist/routes/admin/section-builder.js +487 -0
- package/dist/routes/admin/section-builder.js.map +1 -0
- package/dist/routes/admin/settings.d.ts +10 -0
- package/dist/routes/admin/settings.d.ts.map +1 -0
- package/dist/routes/admin/settings.js +209 -0
- package/dist/routes/admin/settings.js.map +1 -0
- package/dist/routes/admin/site-switcher.d.ts +3 -0
- package/dist/routes/admin/site-switcher.d.ts.map +1 -0
- package/dist/routes/admin/site-switcher.js +36 -0
- package/dist/routes/admin/site-switcher.js.map +1 -0
- package/dist/routes/admin/taxonomy.d.ts +10 -0
- package/dist/routes/admin/taxonomy.d.ts.map +1 -0
- package/dist/routes/admin/taxonomy.js +297 -0
- package/dist/routes/admin/taxonomy.js.map +1 -0
- package/dist/routes/admin/users.d.ts +10 -0
- package/dist/routes/admin/users.d.ts.map +1 -0
- package/dist/routes/admin/users.js +227 -0
- package/dist/routes/admin/users.js.map +1 -0
- package/package.json +75 -0
- package/src/built-in-theme/components/cta/cta.tsx +18 -0
- package/src/built-in-theme/components/cta/schema.yaml +17 -0
- package/src/built-in-theme/components/features/features.tsx +18 -0
- package/src/built-in-theme/components/features/schema.yaml +22 -0
- package/src/built-in-theme/components/hero/hero.tsx +18 -0
- package/src/built-in-theme/components/hero/schema.yaml +17 -0
- package/src/built-in-theme/components/text/schema.yaml +12 -0
- package/src/built-in-theme/components/text/text.tsx +11 -0
- package/src/built-in-theme/layouts/article.tsx +20 -0
- package/src/built-in-theme/layouts/base.tsx +50 -0
- package/src/built-in-theme/layouts/landing-page.tsx +15 -0
- package/src/built-in-theme/layouts/page.tsx +11 -0
- package/src/built-in-theme/theme.yaml +4 -0
- package/starters/blank/config/content-types.yaml +47 -0
- package/starters/blank/config/section-types.yaml +115 -0
- package/starters/blank/config/settings.yaml +12 -0
- package/starters/blank/content/landing-pages/homepage.yaml +55 -0
- package/starters/blank/content/pages/about.md +27 -0
- package/starters/blank/starter.yaml +14 -0
- package/starters/blank/themes/starter/_types.ts +93 -0
- package/starters/blank/themes/starter/components/blog-listing/blog-listing.tsx +102 -0
- package/starters/blank/themes/starter/components/blog-listing/schema.yaml +21 -0
- package/starters/blank/themes/starter/components/columns/columns.tsx +101 -0
- package/starters/blank/themes/starter/components/columns/schema.yaml +23 -0
- package/starters/blank/themes/starter/components/counters/counters.css +13 -0
- package/starters/blank/themes/starter/components/counters/counters.tsx +81 -0
- package/starters/blank/themes/starter/components/counters/schema.yaml +23 -0
- package/starters/blank/themes/starter/components/cta/cta.tsx +57 -0
- package/starters/blank/themes/starter/components/cta/schema.yaml +30 -0
- package/starters/blank/themes/starter/components/faq/faq.tsx +77 -0
- package/starters/blank/themes/starter/components/faq/schema.yaml +20 -0
- package/starters/blank/themes/starter/components/features/features.tsx +82 -0
- package/starters/blank/themes/starter/components/features/schema.yaml +19 -0
- package/starters/blank/themes/starter/components/form/form.tsx +126 -0
- package/starters/blank/themes/starter/components/form/schema.yaml +18 -0
- package/starters/blank/themes/starter/components/gallery/gallery.tsx +85 -0
- package/starters/blank/themes/starter/components/gallery/schema.yaml +27 -0
- package/starters/blank/themes/starter/components/hero/hero.tsx +77 -0
- package/starters/blank/themes/starter/components/hero/schema.yaml +26 -0
- package/starters/blank/themes/starter/components/logo-slider/logo-slider.css +21 -0
- package/starters/blank/themes/starter/components/logo-slider/logo-slider.tsx +81 -0
- package/starters/blank/themes/starter/components/logo-slider/schema.yaml +23 -0
- package/starters/blank/themes/starter/components/pricing/pricing.tsx +141 -0
- package/starters/blank/themes/starter/components/pricing/schema.yaml +44 -0
- package/starters/blank/themes/starter/components/testimonials/schema.yaml +26 -0
- package/starters/blank/themes/starter/components/testimonials/testimonials.tsx +100 -0
- package/starters/blank/themes/starter/components/text/schema.yaml +12 -0
- package/starters/blank/themes/starter/components/text/text.tsx +62 -0
- package/starters/blank/themes/starter/components/text-with-image/schema.yaml +30 -0
- package/starters/blank/themes/starter/components/text-with-image/text-with-image.tsx +86 -0
- package/starters/blank/themes/starter/components/video/schema.yaml +19 -0
- package/starters/blank/themes/starter/components/video/video.tsx +98 -0
- package/starters/blank/themes/starter/layouts/article.tsx +42 -0
- package/starters/blank/themes/starter/layouts/base.tsx +92 -0
- package/starters/blank/themes/starter/layouts/landing-page.tsx +14 -0
- package/starters/blank/themes/starter/layouts/page.tsx +29 -0
- package/starters/blank/themes/starter/partials/footer.tsx +22 -0
- package/starters/blank/themes/starter/partials/header.tsx +32 -0
- package/starters/blank/themes/starter/static/style.css +125 -0
- package/starters/blank/themes/starter/theme.yaml +16 -0
- package/starters/kadoservices/config/content-types.yaml +239 -0
- package/starters/kadoservices/config/languages.yaml +12 -0
- package/starters/kadoservices/config/section-types.yaml +379 -0
- package/starters/kadoservices/config/settings.yaml +15 -0
- package/starters/kadoservices/config/sites.yaml +14 -0
- package/starters/kadoservices/config/taxonomies.yaml +61 -0
- package/starters/kadoservices/config/translations/de.yaml +120 -0
- package/starters/kadoservices/config/translations/en.yaml +120 -0
- package/starters/kadoservices/config/translations/pl.yaml +120 -0
- package/starters/kadoservices/content/articles/employer-branding-strategies.md +61 -0
- package/starters/kadoservices/content/articles/hiring-trends-2026.md +61 -0
- package/starters/kadoservices/content/articles/hiring-trends-2026.pl.md +61 -0
- package/starters/kadoservices/content/articles/labor-law-changes.md +78 -0
- package/starters/kadoservices/content/articles/temporary-staffing-guide.md +76 -0
- package/starters/kadoservices/content/articles/temporary-staffing-guide.pl.md +76 -0
- package/starters/kadoservices/content/case-studies/finance-rpo-program.md +68 -0
- package/starters/kadoservices/content/case-studies/manufacturing-mass-recruitment.md +65 -0
- package/starters/kadoservices/content/case-studies/manufacturing-mass-recruitment.pl.md +65 -0
- package/starters/kadoservices/content/case-studies/retail-seasonal-staffing.md +69 -0
- package/starters/kadoservices/content/industries/finance-shared-services.md +59 -0
- package/starters/kadoservices/content/industries/healthcare.md +64 -0
- package/starters/kadoservices/content/industries/it-technology.md +61 -0
- package/starters/kadoservices/content/industries/logistics.md +54 -0
- package/starters/kadoservices/content/industries/manufacturing.md +61 -0
- package/starters/kadoservices/content/industries/retail.md +56 -0
- package/starters/kadoservices/content/landing-pages/homepage.pl.yaml +198 -0
- package/starters/kadoservices/content/landing-pages/homepage.yaml +198 -0
- package/starters/kadoservices/content/locations/gdansk.md +32 -0
- package/starters/kadoservices/content/locations/krakow.md +30 -0
- package/starters/kadoservices/content/locations/warsaw.md +30 -0
- package/starters/kadoservices/content/locations/wroclaw.md +32 -0
- package/starters/kadoservices/content/pages/about.md +58 -0
- package/starters/kadoservices/content/pages/about.pl.md +58 -0
- package/starters/kadoservices/content/pages/careers.md +55 -0
- package/starters/kadoservices/content/pages/clients.md +65 -0
- package/starters/kadoservices/content/pages/contact.md +74 -0
- package/starters/kadoservices/content/pages/contact.pl.md +74 -0
- package/starters/kadoservices/content/pages/faq.md +76 -0
- package/starters/kadoservices/content/services/employer-branding.md +70 -0
- package/starters/kadoservices/content/services/hr-consulting.md +64 -0
- package/starters/kadoservices/content/services/outsourcing-rpo.md +78 -0
- package/starters/kadoservices/content/services/outsourcing-rpo.pl.md +67 -0
- package/starters/kadoservices/content/services/payroll-hr-admin.md +66 -0
- package/starters/kadoservices/content/services/permanent-recruitment.md +78 -0
- package/starters/kadoservices/content/services/permanent-recruitment.pl.md +78 -0
- package/starters/kadoservices/content/services/temporary-staffing.md +78 -0
- package/starters/kadoservices/content/team/anna-kowalska.md +26 -0
- package/starters/kadoservices/content/team/jan-lewandowski.md +26 -0
- package/starters/kadoservices/content/team/katarzyna-zielinska.md +26 -0
- package/starters/kadoservices/content/team/maria-wisniewska.md +28 -0
- package/starters/kadoservices/content/team/tomasz-nowak.md +26 -0
- package/starters/kadoservices/starter.yaml +15 -0
- package/starters/kadoservices/themes/kadoservices/_types.ts +93 -0
- package/starters/kadoservices/themes/kadoservices/components/blog-listing/blog-listing.tsx +197 -0
- package/starters/kadoservices/themes/kadoservices/components/blog-listing/schema.yaml +21 -0
- package/starters/kadoservices/themes/kadoservices/components/columns/columns.tsx +104 -0
- package/starters/kadoservices/themes/kadoservices/components/columns/schema.yaml +23 -0
- package/starters/kadoservices/themes/kadoservices/components/counters/counters.css +13 -0
- package/starters/kadoservices/themes/kadoservices/components/counters/counters.tsx +103 -0
- package/starters/kadoservices/themes/kadoservices/components/counters/schema.yaml +23 -0
- package/starters/kadoservices/themes/kadoservices/components/cta/cta.tsx +100 -0
- package/starters/kadoservices/themes/kadoservices/components/cta/schema.yaml +30 -0
- package/starters/kadoservices/themes/kadoservices/components/faq/faq.tsx +77 -0
- package/starters/kadoservices/themes/kadoservices/components/faq/schema.yaml +20 -0
- package/starters/kadoservices/themes/kadoservices/components/features/features.tsx +151 -0
- package/starters/kadoservices/themes/kadoservices/components/features/schema.yaml +19 -0
- package/starters/kadoservices/themes/kadoservices/components/form/form.tsx +135 -0
- package/starters/kadoservices/themes/kadoservices/components/form/schema.yaml +18 -0
- package/starters/kadoservices/themes/kadoservices/components/gallery/gallery.tsx +90 -0
- package/starters/kadoservices/themes/kadoservices/components/gallery/schema.yaml +27 -0
- package/starters/kadoservices/themes/kadoservices/components/hero/hero.tsx +175 -0
- package/starters/kadoservices/themes/kadoservices/components/hero/schema.yaml +26 -0
- package/starters/kadoservices/themes/kadoservices/components/logo-slider/logo-slider.css +21 -0
- package/starters/kadoservices/themes/kadoservices/components/logo-slider/logo-slider.tsx +83 -0
- package/starters/kadoservices/themes/kadoservices/components/logo-slider/schema.yaml +23 -0
- package/starters/kadoservices/themes/kadoservices/components/pricing/pricing.tsx +161 -0
- package/starters/kadoservices/themes/kadoservices/components/pricing/schema.yaml +44 -0
- package/starters/kadoservices/themes/kadoservices/components/testimonials/schema.yaml +26 -0
- package/starters/kadoservices/themes/kadoservices/components/testimonials/testimonials.css +13 -0
- package/starters/kadoservices/themes/kadoservices/components/testimonials/testimonials.tsx +150 -0
- package/starters/kadoservices/themes/kadoservices/components/text/schema.yaml +12 -0
- package/starters/kadoservices/themes/kadoservices/components/text/text.tsx +67 -0
- package/starters/kadoservices/themes/kadoservices/components/text-with-image/schema.yaml +30 -0
- package/starters/kadoservices/themes/kadoservices/components/text-with-image/text-with-image.tsx +92 -0
- package/starters/kadoservices/themes/kadoservices/components/video/schema.yaml +19 -0
- package/starters/kadoservices/themes/kadoservices/components/video/video.tsx +103 -0
- package/starters/kadoservices/themes/kadoservices/layouts/404.tsx +96 -0
- package/starters/kadoservices/themes/kadoservices/layouts/article.tsx +140 -0
- package/starters/kadoservices/themes/kadoservices/layouts/base.tsx +669 -0
- package/starters/kadoservices/themes/kadoservices/layouts/case-study.tsx +240 -0
- package/starters/kadoservices/themes/kadoservices/layouts/index--articles.tsx +250 -0
- package/starters/kadoservices/themes/kadoservices/layouts/index--case-studies.tsx +232 -0
- package/starters/kadoservices/themes/kadoservices/layouts/index--services.tsx +237 -0
- package/starters/kadoservices/themes/kadoservices/layouts/index.tsx +96 -0
- package/starters/kadoservices/themes/kadoservices/layouts/industry.tsx +121 -0
- package/starters/kadoservices/themes/kadoservices/layouts/landing-page.tsx +14 -0
- package/starters/kadoservices/themes/kadoservices/layouts/page--about.tsx +158 -0
- package/starters/kadoservices/themes/kadoservices/layouts/page--careers.tsx +214 -0
- package/starters/kadoservices/themes/kadoservices/layouts/page--contact.tsx +218 -0
- package/starters/kadoservices/themes/kadoservices/layouts/page.tsx +45 -0
- package/starters/kadoservices/themes/kadoservices/layouts/service.tsx +235 -0
- package/starters/kadoservices/themes/kadoservices/partials/footer.tsx +109 -0
- package/starters/kadoservices/themes/kadoservices/partials/header.tsx +53 -0
- package/starters/kadoservices/themes/kadoservices/static/images/article-platform-engineering.jpg +0 -0
- package/starters/kadoservices/themes/kadoservices/static/images/barka-logo.png +0 -0
- package/starters/kadoservices/themes/kadoservices/static/images/case-study-banking-dashboard.jpg +0 -0
- package/starters/kadoservices/themes/kadoservices/static/images/case-study-banking.png +0 -0
- package/starters/kadoservices/themes/kadoservices/static/images/case-study-ecommerce-dashboard.jpg +0 -0
- package/starters/kadoservices/themes/kadoservices/static/images/case-study-healthcare-dashboard.jpg +0 -0
- package/starters/kadoservices/themes/kadoservices/static/images/case-study-healthcare.png +0 -0
- package/starters/kadoservices/themes/kadoservices/static/images/case-study-retail.png +0 -0
- package/starters/kadoservices/themes/kadoservices/static/images/handshake.jpg +0 -0
- package/starters/kadoservices/themes/kadoservices/static/images/hero-bg.jpg +0 -0
- package/starters/kadoservices/themes/kadoservices/static/images/hero-bg.png +0 -0
- package/starters/kadoservices/themes/kadoservices/static/images/lokatech-logo.png +0 -0
- package/starters/kadoservices/themes/kadoservices/static/images/office-warsaw.png +0 -0
- package/starters/kadoservices/themes/kadoservices/static/images/office.jpg +0 -0
- package/starters/kadoservices/themes/kadoservices/static/images/team-anna-kowalska.png +0 -0
- package/starters/kadoservices/themes/kadoservices/static/images/team-collaboration.jpg +0 -0
- package/starters/kadoservices/themes/kadoservices/static/images/team-jan-nowak.png +0 -0
- package/starters/kadoservices/themes/kadoservices/static/images/team-katarzyna-kaminska.png +0 -0
- package/starters/kadoservices/themes/kadoservices/static/images/team-maria-wisniewska.png +0 -0
- package/starters/kadoservices/themes/kadoservices/static/images/team-meeting.jpg +0 -0
- package/starters/kadoservices/themes/kadoservices/static/images/team-strategy-session.jpg +0 -0
- package/starters/kadoservices/themes/kadoservices/static/images/team-tomasz-lewandowski.png +0 -0
- package/starters/kadoservices/themes/kadoservices/static/style.css +542 -0
- package/starters/kadoservices/themes/kadoservices/theme.yaml +21 -0
- package/starters/kadoservices/themes/starter/_types.ts +93 -0
- package/starters/kadoservices/themes/starter/components/blog-listing/blog-listing.tsx +102 -0
- package/starters/kadoservices/themes/starter/components/blog-listing/schema.yaml +21 -0
- package/starters/kadoservices/themes/starter/components/columns/columns.tsx +101 -0
- package/starters/kadoservices/themes/starter/components/columns/schema.yaml +23 -0
- package/starters/kadoservices/themes/starter/components/counters/counters.css +13 -0
- package/starters/kadoservices/themes/starter/components/counters/counters.tsx +81 -0
- package/starters/kadoservices/themes/starter/components/counters/schema.yaml +23 -0
- package/starters/kadoservices/themes/starter/components/cta/cta.tsx +57 -0
- package/starters/kadoservices/themes/starter/components/cta/schema.yaml +30 -0
- package/starters/kadoservices/themes/starter/components/faq/faq.tsx +77 -0
- package/starters/kadoservices/themes/starter/components/faq/schema.yaml +20 -0
- package/starters/kadoservices/themes/starter/components/features/features.tsx +82 -0
- package/starters/kadoservices/themes/starter/components/features/schema.yaml +19 -0
- package/starters/kadoservices/themes/starter/components/form/form.tsx +126 -0
- package/starters/kadoservices/themes/starter/components/form/schema.yaml +18 -0
- package/starters/kadoservices/themes/starter/components/gallery/gallery.tsx +85 -0
- package/starters/kadoservices/themes/starter/components/gallery/schema.yaml +27 -0
- package/starters/kadoservices/themes/starter/components/hero/hero.tsx +77 -0
- package/starters/kadoservices/themes/starter/components/hero/schema.yaml +26 -0
- package/starters/kadoservices/themes/starter/components/logo-slider/logo-slider.css +21 -0
- package/starters/kadoservices/themes/starter/components/logo-slider/logo-slider.tsx +81 -0
- package/starters/kadoservices/themes/starter/components/logo-slider/schema.yaml +23 -0
- package/starters/kadoservices/themes/starter/components/pricing/pricing.tsx +141 -0
- package/starters/kadoservices/themes/starter/components/pricing/schema.yaml +44 -0
- package/starters/kadoservices/themes/starter/components/testimonials/schema.yaml +26 -0
- package/starters/kadoservices/themes/starter/components/testimonials/testimonials.tsx +100 -0
- package/starters/kadoservices/themes/starter/components/text/schema.yaml +12 -0
- package/starters/kadoservices/themes/starter/components/text/text.tsx +62 -0
- package/starters/kadoservices/themes/starter/components/text-with-image/schema.yaml +30 -0
- package/starters/kadoservices/themes/starter/components/text-with-image/text-with-image.tsx +86 -0
- package/starters/kadoservices/themes/starter/components/video/schema.yaml +19 -0
- package/starters/kadoservices/themes/starter/components/video/video.tsx +98 -0
- package/starters/kadoservices/themes/starter/layouts/article.tsx +42 -0
- package/starters/kadoservices/themes/starter/layouts/base.tsx +92 -0
- package/starters/kadoservices/themes/starter/layouts/landing-page.tsx +14 -0
- package/starters/kadoservices/themes/starter/layouts/page.tsx +29 -0
- package/starters/kadoservices/themes/starter/partials/footer.tsx +22 -0
- package/starters/kadoservices/themes/starter/partials/header.tsx +32 -0
- package/starters/kadoservices/themes/starter/static/style.css +125 -0
- package/starters/kadoservices/themes/starter/theme.yaml +16 -0
- package/starters/lokatech/config/content-types.yaml +226 -0
- package/starters/lokatech/config/languages.yaml +12 -0
- package/starters/lokatech/config/section-types.yaml +379 -0
- package/starters/lokatech/config/settings.yaml +15 -0
- package/starters/lokatech/config/sites.yaml +21 -0
- package/starters/lokatech/config/taxonomies.yaml +65 -0
- package/starters/lokatech/config/translations/de.yaml +108 -0
- package/starters/lokatech/config/translations/en.yaml +108 -0
- package/starters/lokatech/config/translations/pl.yaml +108 -0
- package/starters/lokatech/content/articles/ai-in-enterprise.md +51 -0
- package/starters/lokatech/content/articles/api-gateway-patterns-enterprise.md +35 -0
- package/starters/lokatech/content/articles/design-system-enterprise-scale.md +35 -0
- package/starters/lokatech/content/articles/domain-driven-design-bounded-contexts.md +35 -0
- package/starters/lokatech/content/articles/engineering-team-scaling-50-to-200.md +33 -0
- package/starters/lokatech/content/articles/event-driven-architecture-microservices.md +35 -0
- package/starters/lokatech/content/articles/future-of-cloud-native.md +47 -0
- package/starters/lokatech/content/articles/getting-started.md +83 -0
- package/starters/lokatech/content/articles/headless-cms-composable-architecture.md +35 -0
- package/starters/lokatech/content/articles/kubernetes-cost-optimization-finops.md +33 -0
- package/starters/lokatech/content/articles/legacy-modernization-strangler-fig.md +35 -0
- package/starters/lokatech/content/articles/llm-fine-tuning-enterprise-data.md +33 -0
- package/starters/lokatech/content/articles/observability-opentelemetry-stack.md +35 -0
- package/starters/lokatech/content/articles/platform-engineering-internal-developer-portals.md +33 -0
- package/starters/lokatech/content/articles/platform-engineering-internal-developer-portals.pl.md +33 -0
- package/starters/lokatech/content/articles/rag-retrieval-augmented-generation-production.md +35 -0
- package/starters/lokatech/content/articles/remote-engineering-culture-distributed-teams.md +35 -0
- package/starters/lokatech/content/articles/supply-chain-security-sbom.md +35 -0
- package/starters/lokatech/content/articles/welcome.md +42 -0
- package/starters/lokatech/content/articles/welcome.pl.md +39 -0
- package/starters/lokatech/content/articles/zero-trust-network-architecture.md +35 -0
- package/starters/lokatech/content/articles/zero-trust-security.md +55 -0
- package/starters/lokatech/content/case-studies/banking-platform-modernization.md +67 -0
- package/starters/lokatech/content/case-studies/ecommerce-platform-rewrite.md +64 -0
- package/starters/lokatech/content/case-studies/govtech-citizen-portal.md +59 -0
- package/starters/lokatech/content/case-studies/healthcare-data-pipeline.md +67 -0
- package/starters/lokatech/content/case-studies/healthcare-data-pipeline.pl.md +60 -0
- package/starters/lokatech/content/case-studies/insurance-claims-automation.md +58 -0
- package/starters/lokatech/content/case-studies/manufacturing-iot-digital-twin.md +58 -0
- package/starters/lokatech/content/case-studies/retail-cloud-migration.md +49 -0
- package/starters/lokatech/content/case-studies/telecom-5g-platform.md +57 -0
- package/starters/lokatech/content/industries/energy-utilities.md +35 -0
- package/starters/lokatech/content/industries/financial-services.md +35 -0
- package/starters/lokatech/content/industries/healthcare.md +35 -0
- package/starters/lokatech/content/industries/manufacturing.md +35 -0
- package/starters/lokatech/content/industries/retail-ecommerce.md +35 -0
- package/starters/lokatech/content/industries/telecom-media.md +35 -0
- package/starters/lokatech/content/landing-pages/homepage.pl.yaml +182 -0
- package/starters/lokatech/content/landing-pages/homepage.yaml +236 -0
- package/starters/lokatech/content/locations/berlin.md +22 -0
- package/starters/lokatech/content/locations/krakow.md +22 -0
- package/starters/lokatech/content/locations/london.md +22 -0
- package/starters/lokatech/content/locations/warsaw.md +22 -0
- package/starters/lokatech/content/locations/wroclaw.md +22 -0
- package/starters/lokatech/content/pages/about.md +55 -0
- package/starters/lokatech/content/pages/about.pl.md +36 -0
- package/starters/lokatech/content/pages/careers.md +50 -0
- package/starters/lokatech/content/pages/contact.md +51 -0
- package/starters/lokatech/content/pages/contact.pl.md +51 -0
- package/starters/lokatech/content/pages/security-compliance.md +66 -0
- package/starters/lokatech/content/services/cloud-infrastructure.md +73 -0
- package/starters/lokatech/content/services/custom-software-development.md +74 -0
- package/starters/lokatech/content/services/custom-software-development.pl.md +80 -0
- package/starters/lokatech/content/services/cybersecurity.md +72 -0
- package/starters/lokatech/content/services/data-ai.md +74 -0
- package/starters/lokatech/content/services/digital-transformation.md +70 -0
- package/starters/lokatech/content/services/it-outsourcing.md +72 -0
- package/starters/lokatech/content/team/anna-kowalska.md +21 -0
- package/starters/lokatech/content/team/jan-nowak.md +21 -0
- package/starters/lokatech/content/team/katarzyna-kaminska.md +20 -0
- package/starters/lokatech/content/team/maria-wisniewska.md +20 -0
- package/starters/lokatech/content/team/tomasz-lewandowski.md +20 -0
- package/starters/lokatech/starter.yaml +15 -0
- package/starters/lokatech/themes/lokatech/_types.ts +93 -0
- package/starters/lokatech/themes/lokatech/components/blog-listing/blog-listing.tsx +197 -0
- package/starters/lokatech/themes/lokatech/components/blog-listing/schema.yaml +21 -0
- package/starters/lokatech/themes/lokatech/components/columns/columns.tsx +104 -0
- package/starters/lokatech/themes/lokatech/components/columns/schema.yaml +23 -0
- package/starters/lokatech/themes/lokatech/components/counters/counters.css +13 -0
- package/starters/lokatech/themes/lokatech/components/counters/counters.tsx +103 -0
- package/starters/lokatech/themes/lokatech/components/counters/schema.yaml +23 -0
- package/starters/lokatech/themes/lokatech/components/cta/cta.tsx +100 -0
- package/starters/lokatech/themes/lokatech/components/cta/schema.yaml +30 -0
- package/starters/lokatech/themes/lokatech/components/faq/faq.tsx +77 -0
- package/starters/lokatech/themes/lokatech/components/faq/schema.yaml +20 -0
- package/starters/lokatech/themes/lokatech/components/features/features.tsx +149 -0
- package/starters/lokatech/themes/lokatech/components/features/schema.yaml +19 -0
- package/starters/lokatech/themes/lokatech/components/form/form.tsx +135 -0
- package/starters/lokatech/themes/lokatech/components/form/schema.yaml +18 -0
- package/starters/lokatech/themes/lokatech/components/gallery/gallery.tsx +90 -0
- package/starters/lokatech/themes/lokatech/components/gallery/schema.yaml +27 -0
- package/starters/lokatech/themes/lokatech/components/hero/hero.tsx +167 -0
- package/starters/lokatech/themes/lokatech/components/hero/schema.yaml +26 -0
- package/starters/lokatech/themes/lokatech/components/logo-slider/logo-slider.css +21 -0
- package/starters/lokatech/themes/lokatech/components/logo-slider/logo-slider.tsx +83 -0
- package/starters/lokatech/themes/lokatech/components/logo-slider/schema.yaml +23 -0
- package/starters/lokatech/themes/lokatech/components/pricing/pricing.tsx +161 -0
- package/starters/lokatech/themes/lokatech/components/pricing/schema.yaml +44 -0
- package/starters/lokatech/themes/lokatech/components/testimonials/schema.yaml +26 -0
- package/starters/lokatech/themes/lokatech/components/testimonials/testimonials.css +13 -0
- package/starters/lokatech/themes/lokatech/components/testimonials/testimonials.tsx +150 -0
- package/starters/lokatech/themes/lokatech/components/text/schema.yaml +12 -0
- package/starters/lokatech/themes/lokatech/components/text/text.tsx +67 -0
- package/starters/lokatech/themes/lokatech/components/text-with-image/schema.yaml +30 -0
- package/starters/lokatech/themes/lokatech/components/text-with-image/text-with-image.tsx +92 -0
- package/starters/lokatech/themes/lokatech/components/video/schema.yaml +19 -0
- package/starters/lokatech/themes/lokatech/components/video/video.tsx +103 -0
- package/starters/lokatech/themes/lokatech/layouts/404.tsx +96 -0
- package/starters/lokatech/themes/lokatech/layouts/article.tsx +140 -0
- package/starters/lokatech/themes/lokatech/layouts/base.tsx +672 -0
- package/starters/lokatech/themes/lokatech/layouts/case-study.tsx +233 -0
- package/starters/lokatech/themes/lokatech/layouts/index--articles.tsx +246 -0
- package/starters/lokatech/themes/lokatech/layouts/index--case-studies.tsx +230 -0
- package/starters/lokatech/themes/lokatech/layouts/index--services.tsx +237 -0
- package/starters/lokatech/themes/lokatech/layouts/index.tsx +96 -0
- package/starters/lokatech/themes/lokatech/layouts/industry.tsx +121 -0
- package/starters/lokatech/themes/lokatech/layouts/landing-page.tsx +14 -0
- package/starters/lokatech/themes/lokatech/layouts/page--about.tsx +158 -0
- package/starters/lokatech/themes/lokatech/layouts/page--careers.tsx +125 -0
- package/starters/lokatech/themes/lokatech/layouts/page--contact.tsx +235 -0
- package/starters/lokatech/themes/lokatech/layouts/page.tsx +45 -0
- package/starters/lokatech/themes/lokatech/layouts/service.tsx +235 -0
- package/starters/lokatech/themes/lokatech/partials/footer.tsx +109 -0
- package/starters/lokatech/themes/lokatech/partials/header.tsx +53 -0
- package/starters/lokatech/themes/lokatech/static/images/article-platform-engineering.jpg +0 -0
- package/starters/lokatech/themes/lokatech/static/images/barka-logo.png +0 -0
- package/starters/lokatech/themes/lokatech/static/images/case-study-banking-dashboard.jpg +0 -0
- package/starters/lokatech/themes/lokatech/static/images/case-study-banking.png +0 -0
- package/starters/lokatech/themes/lokatech/static/images/case-study-ecommerce-dashboard.jpg +0 -0
- package/starters/lokatech/themes/lokatech/static/images/case-study-healthcare-dashboard.jpg +0 -0
- package/starters/lokatech/themes/lokatech/static/images/case-study-healthcare.png +0 -0
- package/starters/lokatech/themes/lokatech/static/images/case-study-retail.png +0 -0
- package/starters/lokatech/themes/lokatech/static/images/hero-bg.png +0 -0
- package/starters/lokatech/themes/lokatech/static/images/lokatech-logo.png +0 -0
- package/starters/lokatech/themes/lokatech/static/images/office-warsaw.png +0 -0
- package/starters/lokatech/themes/lokatech/static/images/team-anna-kowalska.png +0 -0
- package/starters/lokatech/themes/lokatech/static/images/team-collaboration.jpg +0 -0
- package/starters/lokatech/themes/lokatech/static/images/team-jan-nowak.png +0 -0
- package/starters/lokatech/themes/lokatech/static/images/team-katarzyna-kaminska.png +0 -0
- package/starters/lokatech/themes/lokatech/static/images/team-maria-wisniewska.png +0 -0
- package/starters/lokatech/themes/lokatech/static/images/team-strategy-session.jpg +0 -0
- package/starters/lokatech/themes/lokatech/static/images/team-tomasz-lewandowski.png +0 -0
- package/starters/lokatech/themes/lokatech/static/style.css +495 -0
- package/starters/lokatech/themes/lokatech/theme.yaml +21 -0
- package/starters/lokatech/themes/starter/_types.ts +93 -0
- package/starters/lokatech/themes/starter/components/blog-listing/blog-listing.tsx +102 -0
- package/starters/lokatech/themes/starter/components/blog-listing/schema.yaml +21 -0
- package/starters/lokatech/themes/starter/components/columns/columns.tsx +101 -0
- package/starters/lokatech/themes/starter/components/columns/schema.yaml +23 -0
- package/starters/lokatech/themes/starter/components/counters/counters.css +13 -0
- package/starters/lokatech/themes/starter/components/counters/counters.tsx +81 -0
- package/starters/lokatech/themes/starter/components/counters/schema.yaml +23 -0
- package/starters/lokatech/themes/starter/components/cta/cta.tsx +57 -0
- package/starters/lokatech/themes/starter/components/cta/schema.yaml +30 -0
- package/starters/lokatech/themes/starter/components/faq/faq.tsx +77 -0
- package/starters/lokatech/themes/starter/components/faq/schema.yaml +20 -0
- package/starters/lokatech/themes/starter/components/features/features.tsx +82 -0
- package/starters/lokatech/themes/starter/components/features/schema.yaml +19 -0
- package/starters/lokatech/themes/starter/components/form/form.tsx +126 -0
- package/starters/lokatech/themes/starter/components/form/schema.yaml +18 -0
- package/starters/lokatech/themes/starter/components/gallery/gallery.tsx +85 -0
- package/starters/lokatech/themes/starter/components/gallery/schema.yaml +27 -0
- package/starters/lokatech/themes/starter/components/hero/hero.tsx +77 -0
- package/starters/lokatech/themes/starter/components/hero/schema.yaml +26 -0
- package/starters/lokatech/themes/starter/components/logo-slider/logo-slider.css +21 -0
- package/starters/lokatech/themes/starter/components/logo-slider/logo-slider.tsx +81 -0
- package/starters/lokatech/themes/starter/components/logo-slider/schema.yaml +23 -0
- package/starters/lokatech/themes/starter/components/pricing/pricing.tsx +141 -0
- package/starters/lokatech/themes/starter/components/pricing/schema.yaml +44 -0
- package/starters/lokatech/themes/starter/components/testimonials/schema.yaml +26 -0
- package/starters/lokatech/themes/starter/components/testimonials/testimonials.tsx +100 -0
- package/starters/lokatech/themes/starter/components/text/schema.yaml +12 -0
- package/starters/lokatech/themes/starter/components/text/text.tsx +62 -0
- package/starters/lokatech/themes/starter/components/text-with-image/schema.yaml +30 -0
- package/starters/lokatech/themes/starter/components/text-with-image/text-with-image.tsx +86 -0
- package/starters/lokatech/themes/starter/components/video/schema.yaml +19 -0
- package/starters/lokatech/themes/starter/components/video/video.tsx +98 -0
- package/starters/lokatech/themes/starter/layouts/article.tsx +42 -0
- package/starters/lokatech/themes/starter/layouts/base.tsx +92 -0
- package/starters/lokatech/themes/starter/layouts/landing-page.tsx +14 -0
- package/starters/lokatech/themes/starter/layouts/page.tsx +29 -0
- package/starters/lokatech/themes/starter/partials/footer.tsx +22 -0
- package/starters/lokatech/themes/starter/partials/header.tsx +32 -0
- package/starters/lokatech/themes/starter/static/style.css +125 -0
- package/starters/lokatech/themes/starter/theme.yaml +16 -0
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
/** @jsxImportSource hono/jsx */
|
|
2
|
+
import type { FC } from 'hono/jsx';
|
|
3
|
+
import type { SectionProps } from '../../_types.js';
|
|
4
|
+
|
|
5
|
+
const spacingMap: Record<string, string> = {
|
|
6
|
+
none: 'py-0',
|
|
7
|
+
small: 'py-8',
|
|
8
|
+
medium: 'py-16',
|
|
9
|
+
large: 'py-24',
|
|
10
|
+
xlarge: 'py-32',
|
|
11
|
+
};
|
|
12
|
+
|
|
13
|
+
const widthMap: Record<string, string> = {
|
|
14
|
+
contained: 'max-w-4xl mx-auto px-6',
|
|
15
|
+
wide: 'max-w-6xl mx-auto px-6',
|
|
16
|
+
full: 'w-full px-6',
|
|
17
|
+
};
|
|
18
|
+
|
|
19
|
+
const Cta: FC<SectionProps> = ({ data, settings, themeSettings }) => {
|
|
20
|
+
const spacing = spacingMap[settings.spacing] ?? spacingMap.large;
|
|
21
|
+
const width = widthMap[settings.width] ?? widthMap.contained;
|
|
22
|
+
const primaryColor = themeSettings.primary_color ?? '#2563eb';
|
|
23
|
+
|
|
24
|
+
return (
|
|
25
|
+
<section
|
|
26
|
+
class={`${spacing} text-white ${settings.css_class ?? ''}`}
|
|
27
|
+
id={settings.anchor_id}
|
|
28
|
+
style={{ backgroundColor: primaryColor }}
|
|
29
|
+
>
|
|
30
|
+
<div class={`${width} text-center`}>
|
|
31
|
+
{data.heading && (
|
|
32
|
+
<h2 class="text-3xl font-bold tracking-tight sm:text-4xl">
|
|
33
|
+
{data.heading}
|
|
34
|
+
</h2>
|
|
35
|
+
)}
|
|
36
|
+
{data.description && (
|
|
37
|
+
<p class="mt-4 text-lg opacity-90">
|
|
38
|
+
{data.description}
|
|
39
|
+
</p>
|
|
40
|
+
)}
|
|
41
|
+
{data.button_text && (
|
|
42
|
+
<div class="mt-8">
|
|
43
|
+
<a
|
|
44
|
+
href={data.button_url ?? '#'}
|
|
45
|
+
class="inline-block rounded-lg bg-white px-8 py-3 text-sm font-semibold shadow-lg transition-transform hover:scale-105"
|
|
46
|
+
style={{ color: primaryColor }}
|
|
47
|
+
>
|
|
48
|
+
{data.button_text}
|
|
49
|
+
</a>
|
|
50
|
+
</div>
|
|
51
|
+
)}
|
|
52
|
+
</div>
|
|
53
|
+
</section>
|
|
54
|
+
);
|
|
55
|
+
};
|
|
56
|
+
|
|
57
|
+
export default Cta;
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
label: Call to Action
|
|
2
|
+
icon: megaphone
|
|
3
|
+
description: "Prominent call-to-action with optional eyebrow, primary and secondary buttons."
|
|
4
|
+
status: stable
|
|
5
|
+
fields:
|
|
6
|
+
eyebrow:
|
|
7
|
+
type: text
|
|
8
|
+
label: Eyebrow
|
|
9
|
+
heading:
|
|
10
|
+
type: text
|
|
11
|
+
label: Heading
|
|
12
|
+
required: true
|
|
13
|
+
body:
|
|
14
|
+
type: textarea
|
|
15
|
+
label: Body Text
|
|
16
|
+
description:
|
|
17
|
+
type: textarea
|
|
18
|
+
label: Description
|
|
19
|
+
button_text:
|
|
20
|
+
type: text
|
|
21
|
+
label: Button Text
|
|
22
|
+
button_url:
|
|
23
|
+
type: text
|
|
24
|
+
label: Button URL
|
|
25
|
+
secondary_text:
|
|
26
|
+
type: text
|
|
27
|
+
label: Secondary Button Text
|
|
28
|
+
secondary_url:
|
|
29
|
+
type: text
|
|
30
|
+
label: Secondary Button URL
|
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
/** @jsxImportSource hono/jsx */
|
|
2
|
+
import type { FC } from 'hono/jsx';
|
|
3
|
+
import type { SectionProps } from '../../_types.js';
|
|
4
|
+
|
|
5
|
+
const spacingMap: Record<string, string> = {
|
|
6
|
+
none: 'py-0',
|
|
7
|
+
small: 'py-8',
|
|
8
|
+
medium: 'py-16',
|
|
9
|
+
large: 'py-24',
|
|
10
|
+
xlarge: 'py-32',
|
|
11
|
+
};
|
|
12
|
+
|
|
13
|
+
const widthMap: Record<string, string> = {
|
|
14
|
+
contained: 'max-w-3xl mx-auto px-6',
|
|
15
|
+
wide: 'max-w-5xl mx-auto px-6',
|
|
16
|
+
full: 'w-full px-6',
|
|
17
|
+
};
|
|
18
|
+
|
|
19
|
+
const bgMap: Record<string, string> = {
|
|
20
|
+
light: 'bg-white text-gray-900',
|
|
21
|
+
dark: 'bg-gray-900 text-white',
|
|
22
|
+
primary: 'text-white',
|
|
23
|
+
custom: '',
|
|
24
|
+
};
|
|
25
|
+
|
|
26
|
+
const Faq: FC<SectionProps> = ({ data, settings, themeSettings }) => {
|
|
27
|
+
if (settings.hidden) return null;
|
|
28
|
+
|
|
29
|
+
const spacing = spacingMap[settings.spacing] ?? spacingMap.large;
|
|
30
|
+
const width = widthMap[settings.width] ?? widthMap.contained;
|
|
31
|
+
const bg = bgMap[settings.background] ?? bgMap.light;
|
|
32
|
+
const primaryColor = themeSettings.primary_color ?? '#2563eb';
|
|
33
|
+
const items: Array<{ question: string; answer: string }> = data.items ?? [];
|
|
34
|
+
|
|
35
|
+
const bgStyle: Record<string, string> = {};
|
|
36
|
+
if (settings.background === 'primary') {
|
|
37
|
+
bgStyle.backgroundColor = primaryColor;
|
|
38
|
+
} else if (settings.background === 'custom' && settings.background_color) {
|
|
39
|
+
bgStyle.backgroundColor = settings.background_color;
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
const isDark = settings.background === 'dark' || settings.background === 'primary';
|
|
43
|
+
|
|
44
|
+
return (
|
|
45
|
+
<section
|
|
46
|
+
class={`${spacing} ${bg} ${settings.css_class ?? ''}`}
|
|
47
|
+
id={settings.anchor_id}
|
|
48
|
+
style={Object.keys(bgStyle).length > 0 ? bgStyle : undefined}
|
|
49
|
+
>
|
|
50
|
+
<div class={width}>
|
|
51
|
+
{data.heading && (
|
|
52
|
+
<h2 class="mb-12 text-center text-3xl font-bold tracking-tight sm:text-4xl">
|
|
53
|
+
{data.heading}
|
|
54
|
+
</h2>
|
|
55
|
+
)}
|
|
56
|
+
|
|
57
|
+
<div class="divide-y divide-gray-200">
|
|
58
|
+
{items.map((item) => (
|
|
59
|
+
<details class="group">
|
|
60
|
+
<summary
|
|
61
|
+
class={`flex cursor-pointer items-center justify-between py-5 text-left text-lg font-medium transition-colors ${isDark ? 'hover:opacity-80' : 'hover:text-gray-600'}`}
|
|
62
|
+
>
|
|
63
|
+
{item.question}
|
|
64
|
+
<span class="ml-4 flex-shrink-0 text-xl transition-transform group-open:rotate-45">+</span>
|
|
65
|
+
</summary>
|
|
66
|
+
<div class={`pb-5 leading-relaxed ${isDark ? 'opacity-80' : 'text-gray-600'}`}>
|
|
67
|
+
{item.answer}
|
|
68
|
+
</div>
|
|
69
|
+
</details>
|
|
70
|
+
))}
|
|
71
|
+
</div>
|
|
72
|
+
</div>
|
|
73
|
+
</section>
|
|
74
|
+
);
|
|
75
|
+
};
|
|
76
|
+
|
|
77
|
+
export default Faq;
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
label: FAQ
|
|
2
|
+
icon: help-circle
|
|
3
|
+
description: "Question and answer list."
|
|
4
|
+
status: stable
|
|
5
|
+
fields:
|
|
6
|
+
heading:
|
|
7
|
+
type: text
|
|
8
|
+
label: Heading
|
|
9
|
+
items:
|
|
10
|
+
type: repeater
|
|
11
|
+
label: Questions
|
|
12
|
+
fields:
|
|
13
|
+
question:
|
|
14
|
+
type: text
|
|
15
|
+
label: Question
|
|
16
|
+
required: true
|
|
17
|
+
answer:
|
|
18
|
+
type: textarea
|
|
19
|
+
label: Answer
|
|
20
|
+
required: true
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
/** @jsxImportSource hono/jsx */
|
|
2
|
+
import type { FC } from 'hono/jsx';
|
|
3
|
+
import type { SectionProps } from '../../_types.js';
|
|
4
|
+
|
|
5
|
+
const spacingMap: Record<string, string> = {
|
|
6
|
+
none: 'py-0',
|
|
7
|
+
small: 'py-8',
|
|
8
|
+
medium: 'py-16',
|
|
9
|
+
large: 'py-24',
|
|
10
|
+
xlarge: 'py-32',
|
|
11
|
+
};
|
|
12
|
+
|
|
13
|
+
const widthMap: Record<string, string> = {
|
|
14
|
+
contained: 'max-w-6xl mx-auto px-6',
|
|
15
|
+
wide: 'max-w-7xl mx-auto px-6',
|
|
16
|
+
full: 'w-full px-6',
|
|
17
|
+
};
|
|
18
|
+
|
|
19
|
+
const bgMap: Record<string, string> = {
|
|
20
|
+
light: 'bg-white text-gray-900',
|
|
21
|
+
dark: 'bg-gray-900 text-white',
|
|
22
|
+
primary: 'text-white',
|
|
23
|
+
custom: '',
|
|
24
|
+
};
|
|
25
|
+
|
|
26
|
+
const Features: FC<SectionProps> = ({ data, settings, themeSettings }) => {
|
|
27
|
+
const spacing = spacingMap[settings.spacing] ?? spacingMap.large;
|
|
28
|
+
const width = widthMap[settings.width] ?? widthMap.contained;
|
|
29
|
+
const bg = bgMap[settings.background] ?? bgMap.light;
|
|
30
|
+
const primaryColor = themeSettings.primary_color ?? '#2563eb';
|
|
31
|
+
const items: Array<{ icon?: string; title: string; description?: string }> =
|
|
32
|
+
data.items ?? [];
|
|
33
|
+
|
|
34
|
+
const bgStyle: Record<string, string> = {};
|
|
35
|
+
if (settings.background === 'primary') {
|
|
36
|
+
bgStyle.backgroundColor = primaryColor;
|
|
37
|
+
} else if (settings.background === 'custom' && settings.background_color) {
|
|
38
|
+
bgStyle.backgroundColor = settings.background_color;
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
return (
|
|
42
|
+
<section
|
|
43
|
+
class={`${spacing} ${bg} ${settings.css_class ?? ''}`}
|
|
44
|
+
id={settings.anchor_id}
|
|
45
|
+
style={Object.keys(bgStyle).length > 0 ? bgStyle : undefined}
|
|
46
|
+
>
|
|
47
|
+
<div class={width}>
|
|
48
|
+
{data.heading && (
|
|
49
|
+
<h2 class="mb-4 text-center text-3xl font-bold tracking-tight sm:text-4xl">
|
|
50
|
+
{data.heading}
|
|
51
|
+
</h2>
|
|
52
|
+
)}
|
|
53
|
+
{data.subheading && (
|
|
54
|
+
<p class="mb-12 text-center text-lg opacity-70">
|
|
55
|
+
{data.subheading}
|
|
56
|
+
</p>
|
|
57
|
+
)}
|
|
58
|
+
|
|
59
|
+
<div class="grid gap-8 sm:grid-cols-2 lg:grid-cols-3">
|
|
60
|
+
{items.map((item) => (
|
|
61
|
+
<div class="rounded-xl border border-gray-100 bg-white p-6 shadow-sm transition-shadow hover:shadow-md">
|
|
62
|
+
{item.icon && (
|
|
63
|
+
<div
|
|
64
|
+
class="mb-4 flex h-12 w-12 items-center justify-center rounded-lg text-2xl text-white"
|
|
65
|
+
style={{ backgroundColor: primaryColor }}
|
|
66
|
+
>
|
|
67
|
+
{item.icon}
|
|
68
|
+
</div>
|
|
69
|
+
)}
|
|
70
|
+
<h3 class="mb-2 text-lg font-semibold text-gray-900">{item.title}</h3>
|
|
71
|
+
{item.description && (
|
|
72
|
+
<p class="text-sm leading-relaxed text-gray-600">{item.description}</p>
|
|
73
|
+
)}
|
|
74
|
+
</div>
|
|
75
|
+
))}
|
|
76
|
+
</div>
|
|
77
|
+
</div>
|
|
78
|
+
</section>
|
|
79
|
+
);
|
|
80
|
+
};
|
|
81
|
+
|
|
82
|
+
export default Features;
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
label: Features
|
|
2
|
+
icon: grid
|
|
3
|
+
description: "Grid of feature cards with icons, titles, and descriptions."
|
|
4
|
+
status: stable
|
|
5
|
+
fields:
|
|
6
|
+
heading:
|
|
7
|
+
type: text
|
|
8
|
+
label: Heading
|
|
9
|
+
subheading:
|
|
10
|
+
type: textarea
|
|
11
|
+
label: Subheading
|
|
12
|
+
columns:
|
|
13
|
+
type: select
|
|
14
|
+
label: Columns
|
|
15
|
+
options: ["2", "3", "4"]
|
|
16
|
+
default: "3"
|
|
17
|
+
items:
|
|
18
|
+
type: textarea
|
|
19
|
+
label: Feature Items (YAML)
|
|
@@ -0,0 +1,126 @@
|
|
|
1
|
+
/** @jsxImportSource hono/jsx */
|
|
2
|
+
import type { FC } from 'hono/jsx';
|
|
3
|
+
import type { SectionProps } from '../../_types.js';
|
|
4
|
+
|
|
5
|
+
const spacingMap: Record<string, string> = {
|
|
6
|
+
none: 'py-0',
|
|
7
|
+
small: 'py-8',
|
|
8
|
+
medium: 'py-16',
|
|
9
|
+
large: 'py-24',
|
|
10
|
+
xlarge: 'py-32',
|
|
11
|
+
};
|
|
12
|
+
|
|
13
|
+
const widthMap: Record<string, string> = {
|
|
14
|
+
contained: 'max-w-2xl mx-auto px-6',
|
|
15
|
+
wide: 'max-w-4xl mx-auto px-6',
|
|
16
|
+
full: 'w-full px-6',
|
|
17
|
+
};
|
|
18
|
+
|
|
19
|
+
const bgMap: Record<string, string> = {
|
|
20
|
+
light: 'bg-white text-gray-900',
|
|
21
|
+
dark: 'bg-gray-900 text-white',
|
|
22
|
+
primary: 'text-white',
|
|
23
|
+
custom: '',
|
|
24
|
+
};
|
|
25
|
+
|
|
26
|
+
const Form: FC<SectionProps> = ({ data, settings, themeSettings }) => {
|
|
27
|
+
if (settings.hidden) return null;
|
|
28
|
+
|
|
29
|
+
const spacing = spacingMap[settings.spacing] ?? spacingMap.large;
|
|
30
|
+
const width = widthMap[settings.width] ?? widthMap.contained;
|
|
31
|
+
const bg = bgMap[settings.background] ?? bgMap.light;
|
|
32
|
+
const primaryColor = themeSettings.primary_color ?? '#2563eb';
|
|
33
|
+
|
|
34
|
+
const bgStyle: Record<string, string> = {};
|
|
35
|
+
if (settings.background === 'primary') {
|
|
36
|
+
bgStyle.backgroundColor = primaryColor;
|
|
37
|
+
} else if (settings.background === 'custom' && settings.background_color) {
|
|
38
|
+
bgStyle.backgroundColor = settings.background_color;
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
const isDark = settings.background === 'dark' || settings.background === 'primary';
|
|
42
|
+
const inputClasses = isDark
|
|
43
|
+
? 'w-full rounded-lg border border-white/20 bg-white/10 px-4 py-3 text-white placeholder-white/50 focus:border-white/40 focus:outline-none focus:ring-1 focus:ring-white/40'
|
|
44
|
+
: 'w-full rounded-lg border border-gray-300 bg-white px-4 py-3 text-gray-900 placeholder-gray-400 focus:border-blue-500 focus:outline-none focus:ring-1 focus:ring-blue-500';
|
|
45
|
+
|
|
46
|
+
return (
|
|
47
|
+
<section
|
|
48
|
+
class={`${spacing} ${bg} ${settings.css_class ?? ''}`}
|
|
49
|
+
id={settings.anchor_id}
|
|
50
|
+
style={Object.keys(bgStyle).length > 0 ? bgStyle : undefined}
|
|
51
|
+
>
|
|
52
|
+
<div class={width}>
|
|
53
|
+
{data.heading && (
|
|
54
|
+
<h2 class="mb-4 text-center text-3xl font-bold tracking-tight sm:text-4xl">
|
|
55
|
+
{data.heading}
|
|
56
|
+
</h2>
|
|
57
|
+
)}
|
|
58
|
+
{data.description && (
|
|
59
|
+
<p class={`mb-10 text-center text-lg ${isDark ? 'opacity-80' : 'text-gray-600'}`}>
|
|
60
|
+
{data.description}
|
|
61
|
+
</p>
|
|
62
|
+
)}
|
|
63
|
+
|
|
64
|
+
<form
|
|
65
|
+
action={data.action_url ?? '#'}
|
|
66
|
+
method="post"
|
|
67
|
+
class="space-y-6"
|
|
68
|
+
>
|
|
69
|
+
<div>
|
|
70
|
+
<label for="form-name" class="mb-1 block text-sm font-medium">Name</label>
|
|
71
|
+
<input
|
|
72
|
+
id="form-name"
|
|
73
|
+
name="name"
|
|
74
|
+
type="text"
|
|
75
|
+
required
|
|
76
|
+
placeholder="Your name"
|
|
77
|
+
class={inputClasses}
|
|
78
|
+
/>
|
|
79
|
+
</div>
|
|
80
|
+
|
|
81
|
+
<div>
|
|
82
|
+
<label for="form-email" class="mb-1 block text-sm font-medium">Email</label>
|
|
83
|
+
<input
|
|
84
|
+
id="form-email"
|
|
85
|
+
name="email"
|
|
86
|
+
type="email"
|
|
87
|
+
required
|
|
88
|
+
placeholder="you@example.com"
|
|
89
|
+
class={inputClasses}
|
|
90
|
+
/>
|
|
91
|
+
</div>
|
|
92
|
+
|
|
93
|
+
<div>
|
|
94
|
+
<label for="form-message" class="mb-1 block text-sm font-medium">Message</label>
|
|
95
|
+
<textarea
|
|
96
|
+
id="form-message"
|
|
97
|
+
name="message"
|
|
98
|
+
rows={5}
|
|
99
|
+
required
|
|
100
|
+
placeholder="How can we help?"
|
|
101
|
+
class={inputClasses}
|
|
102
|
+
/>
|
|
103
|
+
</div>
|
|
104
|
+
|
|
105
|
+
<div class="text-center">
|
|
106
|
+
<button
|
|
107
|
+
type="submit"
|
|
108
|
+
class="inline-block rounded-lg px-8 py-3 text-sm font-semibold text-white shadow-lg transition-transform hover:scale-105"
|
|
109
|
+
style={{ backgroundColor: primaryColor }}
|
|
110
|
+
>
|
|
111
|
+
{data.button_text ?? 'Send message'}
|
|
112
|
+
</button>
|
|
113
|
+
</div>
|
|
114
|
+
</form>
|
|
115
|
+
|
|
116
|
+
{data.success_message && (
|
|
117
|
+
<div class="mt-4 hidden text-center text-sm text-green-600" data-form-success>
|
|
118
|
+
{data.success_message}
|
|
119
|
+
</div>
|
|
120
|
+
)}
|
|
121
|
+
</div>
|
|
122
|
+
</section>
|
|
123
|
+
);
|
|
124
|
+
};
|
|
125
|
+
|
|
126
|
+
export default Form;
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
label: Contact Form
|
|
2
|
+
icon: mail
|
|
3
|
+
description: "Contact form with name, email, company, and message fields."
|
|
4
|
+
status: stable
|
|
5
|
+
fields:
|
|
6
|
+
heading:
|
|
7
|
+
type: text
|
|
8
|
+
label: Heading
|
|
9
|
+
description:
|
|
10
|
+
type: textarea
|
|
11
|
+
label: Description
|
|
12
|
+
action_url:
|
|
13
|
+
type: text
|
|
14
|
+
label: Form Action URL
|
|
15
|
+
success_message:
|
|
16
|
+
type: text
|
|
17
|
+
label: Success Message
|
|
18
|
+
default: "Thank you! We'll be in touch."
|
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
/** @jsxImportSource hono/jsx */
|
|
2
|
+
import type { FC } from 'hono/jsx';
|
|
3
|
+
import type { SectionProps } from '../../_types.js';
|
|
4
|
+
|
|
5
|
+
const spacingMap: Record<string, string> = {
|
|
6
|
+
none: 'py-0',
|
|
7
|
+
small: 'py-8',
|
|
8
|
+
medium: 'py-16',
|
|
9
|
+
large: 'py-24',
|
|
10
|
+
xlarge: 'py-32',
|
|
11
|
+
};
|
|
12
|
+
|
|
13
|
+
const widthMap: Record<string, string> = {
|
|
14
|
+
contained: 'max-w-6xl mx-auto px-6',
|
|
15
|
+
wide: 'max-w-7xl mx-auto px-6',
|
|
16
|
+
full: 'w-full px-6',
|
|
17
|
+
};
|
|
18
|
+
|
|
19
|
+
const bgMap: Record<string, string> = {
|
|
20
|
+
light: 'bg-white text-gray-900',
|
|
21
|
+
dark: 'bg-gray-900 text-white',
|
|
22
|
+
primary: 'text-white',
|
|
23
|
+
custom: '',
|
|
24
|
+
};
|
|
25
|
+
|
|
26
|
+
const colsMap: Record<string, string> = {
|
|
27
|
+
'2': 'sm:grid-cols-2',
|
|
28
|
+
'3': 'sm:grid-cols-2 lg:grid-cols-3',
|
|
29
|
+
'4': 'sm:grid-cols-2 lg:grid-cols-4',
|
|
30
|
+
};
|
|
31
|
+
|
|
32
|
+
const Gallery: FC<SectionProps> = ({ data, settings, themeSettings }) => {
|
|
33
|
+
if (settings.hidden) return null;
|
|
34
|
+
|
|
35
|
+
const spacing = spacingMap[settings.spacing] ?? spacingMap.large;
|
|
36
|
+
const width = widthMap[settings.width] ?? widthMap.contained;
|
|
37
|
+
const bg = bgMap[settings.background] ?? bgMap.light;
|
|
38
|
+
const primaryColor = themeSettings.primary_color ?? '#2563eb';
|
|
39
|
+
const items: Array<{ src: string; alt?: string; caption?: string }> =
|
|
40
|
+
data.items ?? [];
|
|
41
|
+
const columns = String(data.columns ?? '3');
|
|
42
|
+
|
|
43
|
+
const bgStyle: Record<string, string> = {};
|
|
44
|
+
if (settings.background === 'primary') {
|
|
45
|
+
bgStyle.backgroundColor = primaryColor;
|
|
46
|
+
} else if (settings.background === 'custom' && settings.background_color) {
|
|
47
|
+
bgStyle.backgroundColor = settings.background_color;
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
return (
|
|
51
|
+
<section
|
|
52
|
+
class={`${spacing} ${bg} ${settings.css_class ?? ''}`}
|
|
53
|
+
id={settings.anchor_id}
|
|
54
|
+
style={Object.keys(bgStyle).length > 0 ? bgStyle : undefined}
|
|
55
|
+
>
|
|
56
|
+
<div class={width}>
|
|
57
|
+
{data.heading && (
|
|
58
|
+
<h2 class="mb-12 text-center text-3xl font-bold tracking-tight sm:text-4xl">
|
|
59
|
+
{data.heading}
|
|
60
|
+
</h2>
|
|
61
|
+
)}
|
|
62
|
+
|
|
63
|
+
<div class={`grid gap-4 ${colsMap[columns] ?? colsMap['3']}`}>
|
|
64
|
+
{items.map((item) => (
|
|
65
|
+
<figure class="group overflow-hidden rounded-lg">
|
|
66
|
+
<img
|
|
67
|
+
src={item.src}
|
|
68
|
+
alt={item.alt ?? ''}
|
|
69
|
+
class="aspect-square w-full object-cover transition-transform duration-300 group-hover:scale-105"
|
|
70
|
+
loading="lazy"
|
|
71
|
+
/>
|
|
72
|
+
{item.caption && (
|
|
73
|
+
<figcaption class="mt-2 text-center text-sm opacity-60">
|
|
74
|
+
{item.caption}
|
|
75
|
+
</figcaption>
|
|
76
|
+
)}
|
|
77
|
+
</figure>
|
|
78
|
+
))}
|
|
79
|
+
</div>
|
|
80
|
+
</div>
|
|
81
|
+
</section>
|
|
82
|
+
);
|
|
83
|
+
};
|
|
84
|
+
|
|
85
|
+
export default Gallery;
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
label: Gallery
|
|
2
|
+
icon: grid
|
|
3
|
+
description: "Responsive image grid with captions and alt text."
|
|
4
|
+
status: stable
|
|
5
|
+
fields:
|
|
6
|
+
heading:
|
|
7
|
+
type: text
|
|
8
|
+
label: Heading
|
|
9
|
+
columns:
|
|
10
|
+
type: select
|
|
11
|
+
label: Columns
|
|
12
|
+
options: ["2", "3", "4"]
|
|
13
|
+
default: "3"
|
|
14
|
+
items:
|
|
15
|
+
type: repeater
|
|
16
|
+
label: Images
|
|
17
|
+
fields:
|
|
18
|
+
image:
|
|
19
|
+
type: media
|
|
20
|
+
label: Image
|
|
21
|
+
required: true
|
|
22
|
+
caption:
|
|
23
|
+
type: text
|
|
24
|
+
label: Caption
|
|
25
|
+
alt:
|
|
26
|
+
type: text
|
|
27
|
+
label: Alt Text
|
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
/** @jsxImportSource hono/jsx */
|
|
2
|
+
import type { FC } from 'hono/jsx';
|
|
3
|
+
import type { SectionProps } from '../../_types.js';
|
|
4
|
+
|
|
5
|
+
const spacingMap: Record<string, string> = {
|
|
6
|
+
none: 'py-0',
|
|
7
|
+
small: 'py-8',
|
|
8
|
+
medium: 'py-16',
|
|
9
|
+
large: 'py-24',
|
|
10
|
+
xlarge: 'py-32',
|
|
11
|
+
};
|
|
12
|
+
|
|
13
|
+
const widthMap: Record<string, string> = {
|
|
14
|
+
contained: 'max-w-5xl mx-auto px-6',
|
|
15
|
+
wide: 'max-w-7xl mx-auto px-6',
|
|
16
|
+
full: 'w-full px-6',
|
|
17
|
+
};
|
|
18
|
+
|
|
19
|
+
const bgMap: Record<string, string> = {
|
|
20
|
+
light: 'bg-white text-gray-900',
|
|
21
|
+
dark: 'bg-gray-900 text-white',
|
|
22
|
+
primary: 'text-white',
|
|
23
|
+
custom: '',
|
|
24
|
+
};
|
|
25
|
+
|
|
26
|
+
const Hero: FC<SectionProps> = ({ data, settings, themeSettings }) => {
|
|
27
|
+
const spacing = spacingMap[settings.spacing] ?? spacingMap.large;
|
|
28
|
+
const width = widthMap[settings.width] ?? widthMap.contained;
|
|
29
|
+
const bg = bgMap[settings.background] ?? bgMap.light;
|
|
30
|
+
const primaryColor = themeSettings.primary_color ?? '#2563eb';
|
|
31
|
+
|
|
32
|
+
const bgStyle: Record<string, string> = {};
|
|
33
|
+
if (settings.background === 'primary') {
|
|
34
|
+
bgStyle.backgroundColor = primaryColor;
|
|
35
|
+
} else if (settings.background === 'custom' && settings.background_color) {
|
|
36
|
+
bgStyle.backgroundColor = settings.background_color;
|
|
37
|
+
}
|
|
38
|
+
if (settings.background_image) {
|
|
39
|
+
bgStyle.backgroundImage = `url(${settings.background_image})`;
|
|
40
|
+
bgStyle.backgroundSize = 'cover';
|
|
41
|
+
bgStyle.backgroundPosition = 'center';
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
return (
|
|
45
|
+
<section
|
|
46
|
+
class={`${spacing} ${bg} ${settings.css_class ?? ''}`}
|
|
47
|
+
id={settings.anchor_id}
|
|
48
|
+
style={Object.keys(bgStyle).length > 0 ? bgStyle : undefined}
|
|
49
|
+
>
|
|
50
|
+
<div class={`${width} text-center`}>
|
|
51
|
+
{data.heading && (
|
|
52
|
+
<h1 class="text-4xl font-bold tracking-tight sm:text-6xl">
|
|
53
|
+
{data.heading}
|
|
54
|
+
</h1>
|
|
55
|
+
)}
|
|
56
|
+
{data.subheading && (
|
|
57
|
+
<p class="mt-6 text-lg leading-relaxed opacity-80 sm:text-xl">
|
|
58
|
+
{data.subheading}
|
|
59
|
+
</p>
|
|
60
|
+
)}
|
|
61
|
+
{data.cta_text && (
|
|
62
|
+
<div class="mt-10">
|
|
63
|
+
<a
|
|
64
|
+
href={data.cta_url ?? '#'}
|
|
65
|
+
class="inline-block rounded-lg px-8 py-3 text-sm font-semibold text-white shadow-lg transition-transform hover:scale-105"
|
|
66
|
+
style={{ backgroundColor: primaryColor }}
|
|
67
|
+
>
|
|
68
|
+
{data.cta_text}
|
|
69
|
+
</a>
|
|
70
|
+
</div>
|
|
71
|
+
)}
|
|
72
|
+
</div>
|
|
73
|
+
</section>
|
|
74
|
+
);
|
|
75
|
+
};
|
|
76
|
+
|
|
77
|
+
export default Hero;
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
label: Hero
|
|
2
|
+
icon: star
|
|
3
|
+
description: "Full-width hero banner with heading, subheading, CTA buttons."
|
|
4
|
+
status: stable
|
|
5
|
+
fields:
|
|
6
|
+
heading:
|
|
7
|
+
type: text
|
|
8
|
+
label: Heading
|
|
9
|
+
required: true
|
|
10
|
+
subheading:
|
|
11
|
+
type: textarea
|
|
12
|
+
label: Subheading
|
|
13
|
+
image:
|
|
14
|
+
type: media
|
|
15
|
+
label: Background Image
|
|
16
|
+
cta_text:
|
|
17
|
+
type: text
|
|
18
|
+
label: CTA Button Text
|
|
19
|
+
cta_url:
|
|
20
|
+
type: text
|
|
21
|
+
label: CTA Button URL
|
|
22
|
+
alignment:
|
|
23
|
+
type: select
|
|
24
|
+
label: Alignment
|
|
25
|
+
options: [left, center, right]
|
|
26
|
+
default: center
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
.logo-marquee-wrap {
|
|
2
|
+
overflow: hidden;
|
|
3
|
+
mask-image: linear-gradient(to right, transparent, black 10%, black 90%, transparent);
|
|
4
|
+
-webkit-mask-image: linear-gradient(to right, transparent, black 10%, black 90%, transparent);
|
|
5
|
+
}
|
|
6
|
+
|
|
7
|
+
.logo-marquee {
|
|
8
|
+
display: flex;
|
|
9
|
+
align-items: center;
|
|
10
|
+
width: max-content;
|
|
11
|
+
animation: marquee 30s linear infinite;
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
.logo-marquee:hover {
|
|
15
|
+
animation-play-state: paused;
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
@keyframes marquee {
|
|
19
|
+
0% { transform: translateX(0); }
|
|
20
|
+
100% { transform: translateX(-50%); }
|
|
21
|
+
}
|