@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,161 @@
|
|
|
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-slate-50 text-slate-900',
|
|
21
|
+
dark: 'text-white',
|
|
22
|
+
primary: 'text-white',
|
|
23
|
+
custom: '',
|
|
24
|
+
};
|
|
25
|
+
|
|
26
|
+
const Pricing: 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 ?? '#10B981';
|
|
33
|
+
const navColor = themeSettings.nav_color ?? '#0B1222';
|
|
34
|
+
const plans: Array<{
|
|
35
|
+
name: string;
|
|
36
|
+
price: string;
|
|
37
|
+
period?: string;
|
|
38
|
+
description?: string;
|
|
39
|
+
features?: string;
|
|
40
|
+
cta_text?: string;
|
|
41
|
+
cta_url?: string;
|
|
42
|
+
highlighted?: boolean;
|
|
43
|
+
}> = data.plans ?? [];
|
|
44
|
+
|
|
45
|
+
const bgStyle: Record<string, string> = {};
|
|
46
|
+
if (settings.background === 'dark') {
|
|
47
|
+
bgStyle.backgroundColor = navColor;
|
|
48
|
+
} else if (settings.background === 'primary') {
|
|
49
|
+
bgStyle.backgroundColor = primaryColor;
|
|
50
|
+
} else if (settings.background === 'custom' && settings.background_color) {
|
|
51
|
+
bgStyle.backgroundColor = settings.background_color;
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
const isDark = settings.background === 'dark' || settings.background === 'primary';
|
|
55
|
+
const cols = plans.length <= 2 ? 'sm:grid-cols-2' : 'sm:grid-cols-2 lg:grid-cols-3';
|
|
56
|
+
|
|
57
|
+
return (
|
|
58
|
+
<section
|
|
59
|
+
class={`${spacing} ${bg} ${settings.css_class ?? ''}`}
|
|
60
|
+
id={settings.anchor_id}
|
|
61
|
+
style={Object.keys(bgStyle).length > 0 ? bgStyle : undefined}
|
|
62
|
+
>
|
|
63
|
+
<div class={width}>
|
|
64
|
+
{data.heading && (
|
|
65
|
+
<h2 class="mb-4 text-center text-3xl font-bold tracking-tight sm:text-4xl">
|
|
66
|
+
{data.heading}
|
|
67
|
+
</h2>
|
|
68
|
+
)}
|
|
69
|
+
{data.subheading && (
|
|
70
|
+
<p class={`mx-auto mb-12 max-w-2xl text-center text-lg ${isDark ? 'text-gray-300' : 'text-slate-500'}`}>
|
|
71
|
+
{data.subheading}
|
|
72
|
+
</p>
|
|
73
|
+
)}
|
|
74
|
+
|
|
75
|
+
<div class={`grid gap-8 ${cols}`}>
|
|
76
|
+
{plans.map((plan) => {
|
|
77
|
+
const featureList = (plan.features ?? '')
|
|
78
|
+
.split('\n')
|
|
79
|
+
.map((f) => f.trim())
|
|
80
|
+
.filter(Boolean);
|
|
81
|
+
const isHighlighted = plan.highlighted;
|
|
82
|
+
|
|
83
|
+
return (
|
|
84
|
+
<div
|
|
85
|
+
class={`relative flex flex-col rounded-2xl border p-8 shadow-sm transition-shadow hover:shadow-md ${
|
|
86
|
+
isHighlighted
|
|
87
|
+
? 'border-2 scale-105'
|
|
88
|
+
: isDark
|
|
89
|
+
? 'border-gray-700 bg-white/5'
|
|
90
|
+
: 'border-gray-200 bg-white'
|
|
91
|
+
}`}
|
|
92
|
+
style={isHighlighted ? { borderColor: primaryColor, backgroundColor: isDark ? 'rgba(16,185,129,0.08)' : '#fff' } : undefined}
|
|
93
|
+
>
|
|
94
|
+
{isHighlighted && (
|
|
95
|
+
<div
|
|
96
|
+
class="absolute -top-3 left-1/2 -translate-x-1/2 rounded-full px-4 py-1 text-xs font-semibold text-white"
|
|
97
|
+
style={{ backgroundColor: primaryColor }}
|
|
98
|
+
>
|
|
99
|
+
{data.highlighted_label ?? 'Popular'}
|
|
100
|
+
</div>
|
|
101
|
+
)}
|
|
102
|
+
|
|
103
|
+
<h3 class={`text-lg font-semibold ${isDark ? 'text-white' : 'text-slate-900'}`}>
|
|
104
|
+
{plan.name}
|
|
105
|
+
</h3>
|
|
106
|
+
|
|
107
|
+
<div class="mt-4 flex items-baseline">
|
|
108
|
+
<span class={`text-4xl font-extrabold ${isDark ? 'text-white' : 'text-slate-900'}`}>
|
|
109
|
+
{plan.price}
|
|
110
|
+
</span>
|
|
111
|
+
{plan.period && (
|
|
112
|
+
<span class={`ml-1 text-sm ${isDark ? 'text-gray-400' : 'text-slate-500'}`}>
|
|
113
|
+
/{plan.period}
|
|
114
|
+
</span>
|
|
115
|
+
)}
|
|
116
|
+
</div>
|
|
117
|
+
|
|
118
|
+
{plan.description && (
|
|
119
|
+
<p class={`mt-3 text-sm ${isDark ? 'text-gray-400' : 'text-slate-500'}`}>
|
|
120
|
+
{plan.description}
|
|
121
|
+
</p>
|
|
122
|
+
)}
|
|
123
|
+
|
|
124
|
+
{featureList.length > 0 && (
|
|
125
|
+
<ul class="mt-6 flex-1 space-y-3">
|
|
126
|
+
{featureList.map((feature) => (
|
|
127
|
+
<li class={`flex items-start gap-2 text-sm ${isDark ? 'text-gray-300' : 'text-slate-600'}`}>
|
|
128
|
+
<svg class="mt-0.5 h-4 w-4 flex-shrink-0" style={{ color: primaryColor }} fill="none" viewBox="0 0 24 24" stroke="currentColor" stroke-width="2">
|
|
129
|
+
<path stroke-linecap="round" stroke-linejoin="round" d="M5 13l4 4L19 7" />
|
|
130
|
+
</svg>
|
|
131
|
+
{feature}
|
|
132
|
+
</li>
|
|
133
|
+
))}
|
|
134
|
+
</ul>
|
|
135
|
+
)}
|
|
136
|
+
|
|
137
|
+
{plan.cta_text && (
|
|
138
|
+
<a
|
|
139
|
+
href={plan.cta_url ?? '#'}
|
|
140
|
+
class={`mt-8 block rounded-lg py-3 text-center text-sm font-semibold transition-all hover:no-underline ${
|
|
141
|
+
isHighlighted
|
|
142
|
+
? 'text-white shadow-lg hover:brightness-110'
|
|
143
|
+
: isDark
|
|
144
|
+
? 'border border-gray-600 text-white hover:border-gray-400'
|
|
145
|
+
: 'border border-gray-300 text-slate-900 hover:border-gray-400'
|
|
146
|
+
}`}
|
|
147
|
+
style={isHighlighted ? { backgroundColor: primaryColor } : undefined}
|
|
148
|
+
>
|
|
149
|
+
{plan.cta_text}
|
|
150
|
+
</a>
|
|
151
|
+
)}
|
|
152
|
+
</div>
|
|
153
|
+
);
|
|
154
|
+
})}
|
|
155
|
+
</div>
|
|
156
|
+
</div>
|
|
157
|
+
</section>
|
|
158
|
+
);
|
|
159
|
+
};
|
|
160
|
+
|
|
161
|
+
export default Pricing;
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
label: Pricing
|
|
2
|
+
icon: credit-card
|
|
3
|
+
description: "Pricing plans grid with features, highlighted plan, and CTAs."
|
|
4
|
+
status: stable
|
|
5
|
+
fields:
|
|
6
|
+
heading:
|
|
7
|
+
type: text
|
|
8
|
+
label: Heading
|
|
9
|
+
subheading:
|
|
10
|
+
type: text
|
|
11
|
+
label: Subheading
|
|
12
|
+
plans:
|
|
13
|
+
type: repeater
|
|
14
|
+
label: Plans
|
|
15
|
+
fields:
|
|
16
|
+
name:
|
|
17
|
+
type: text
|
|
18
|
+
label: Plan Name
|
|
19
|
+
required: true
|
|
20
|
+
price:
|
|
21
|
+
type: text
|
|
22
|
+
label: Price
|
|
23
|
+
required: true
|
|
24
|
+
period:
|
|
25
|
+
type: text
|
|
26
|
+
label: Period
|
|
27
|
+
default: "/month"
|
|
28
|
+
description:
|
|
29
|
+
type: text
|
|
30
|
+
label: Description
|
|
31
|
+
features:
|
|
32
|
+
type: textarea
|
|
33
|
+
label: "Features (one per line)"
|
|
34
|
+
highlighted:
|
|
35
|
+
type: boolean
|
|
36
|
+
label: Highlighted
|
|
37
|
+
default: false
|
|
38
|
+
cta_text:
|
|
39
|
+
type: text
|
|
40
|
+
label: Button Text
|
|
41
|
+
default: "Choose Plan"
|
|
42
|
+
cta_url:
|
|
43
|
+
type: text
|
|
44
|
+
label: Button URL
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
label: Testimonials
|
|
2
|
+
icon: quote
|
|
3
|
+
description: "Featured testimonial with side quotes and author details."
|
|
4
|
+
status: stable
|
|
5
|
+
fields:
|
|
6
|
+
heading:
|
|
7
|
+
type: text
|
|
8
|
+
label: Heading
|
|
9
|
+
items:
|
|
10
|
+
type: repeater
|
|
11
|
+
label: Testimonials
|
|
12
|
+
fields:
|
|
13
|
+
quote:
|
|
14
|
+
type: textarea
|
|
15
|
+
label: Quote
|
|
16
|
+
required: true
|
|
17
|
+
author:
|
|
18
|
+
type: text
|
|
19
|
+
label: Author Name
|
|
20
|
+
required: true
|
|
21
|
+
role:
|
|
22
|
+
type: text
|
|
23
|
+
label: Author Role
|
|
24
|
+
avatar:
|
|
25
|
+
type: media
|
|
26
|
+
label: Avatar
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
.testimonial-featured {
|
|
2
|
+
opacity: 0;
|
|
3
|
+
animation: fadeInLeft 0.8s cubic-bezier(0.16, 1, 0.3, 1) 0.1s both;
|
|
4
|
+
}
|
|
5
|
+
|
|
6
|
+
.testimonial-side > *:nth-child(1) {
|
|
7
|
+
opacity: 0;
|
|
8
|
+
animation: fadeInRight 0.7s cubic-bezier(0.16, 1, 0.3, 1) 0.25s both;
|
|
9
|
+
}
|
|
10
|
+
.testimonial-side > *:nth-child(2) {
|
|
11
|
+
opacity: 0;
|
|
12
|
+
animation: fadeInRight 0.7s cubic-bezier(0.16, 1, 0.3, 1) 0.45s both;
|
|
13
|
+
}
|
|
@@ -0,0 +1,150 @@
|
|
|
1
|
+
/** @jsxImportSource hono/jsx */
|
|
2
|
+
import { raw } from 'hono/html';
|
|
3
|
+
import type { FC } from 'hono/jsx';
|
|
4
|
+
import type { SectionProps } from '../../_types.js';
|
|
5
|
+
|
|
6
|
+
function renderGradient(text: string, color: string): any {
|
|
7
|
+
const parts = text.split(/(\*[^*]+\*)/g);
|
|
8
|
+
const html = parts
|
|
9
|
+
.map((p) =>
|
|
10
|
+
p.startsWith('*') && p.endsWith('*')
|
|
11
|
+
? `<em class="not-italic" style="background:linear-gradient(135deg,${color},${color}99,#60a5fa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text">${p.slice(1, -1)}</em>`
|
|
12
|
+
: p,
|
|
13
|
+
)
|
|
14
|
+
.join('');
|
|
15
|
+
return raw(html);
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
const spacingMap: Record<string, string> = {
|
|
19
|
+
none: 'py-0',
|
|
20
|
+
small: 'py-10',
|
|
21
|
+
medium: 'py-20',
|
|
22
|
+
large: 'py-28',
|
|
23
|
+
xlarge: 'py-36',
|
|
24
|
+
};
|
|
25
|
+
|
|
26
|
+
const widthMap: Record<string, string> = {
|
|
27
|
+
contained: 'max-w-6xl mx-auto px-6',
|
|
28
|
+
wide: 'max-w-7xl mx-auto px-6',
|
|
29
|
+
full: 'w-full px-6',
|
|
30
|
+
};
|
|
31
|
+
|
|
32
|
+
const bgMap: Record<string, string> = {
|
|
33
|
+
light: 'bg-slate-50 text-slate-900',
|
|
34
|
+
dark: 'text-white',
|
|
35
|
+
primary: 'text-white',
|
|
36
|
+
custom: '',
|
|
37
|
+
};
|
|
38
|
+
|
|
39
|
+
const Testimonials: FC<SectionProps> = ({ data, settings, themeSettings }) => {
|
|
40
|
+
if (settings.hidden) return null;
|
|
41
|
+
|
|
42
|
+
const spacing = spacingMap[settings.spacing] ?? spacingMap.large;
|
|
43
|
+
const width = widthMap[settings.width] ?? widthMap.contained;
|
|
44
|
+
const bg = bgMap[settings.background] ?? bgMap.light;
|
|
45
|
+
const primaryColor = themeSettings.primary_color ?? '#10B981';
|
|
46
|
+
const navColor = themeSettings.nav_color ?? '#0B1222';
|
|
47
|
+
const items: Array<{
|
|
48
|
+
quote: string;
|
|
49
|
+
author: string;
|
|
50
|
+
role?: string;
|
|
51
|
+
avatar?: string;
|
|
52
|
+
}> = data.items ?? [];
|
|
53
|
+
|
|
54
|
+
const bgStyle: Record<string, string> = {};
|
|
55
|
+
if (settings.background === 'dark') {
|
|
56
|
+
bgStyle.backgroundColor = navColor;
|
|
57
|
+
} else if (settings.background === 'primary') {
|
|
58
|
+
bgStyle.backgroundColor = primaryColor;
|
|
59
|
+
} else if (settings.background === 'custom' && settings.background_color) {
|
|
60
|
+
bgStyle.backgroundColor = settings.background_color;
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
const isDark = settings.background === 'dark' || settings.background === 'primary';
|
|
64
|
+
|
|
65
|
+
const featured = items[0];
|
|
66
|
+
const rest = items.slice(1);
|
|
67
|
+
|
|
68
|
+
return (
|
|
69
|
+
<section
|
|
70
|
+
class={`${spacing} ${bg} relative overflow-hidden ${settings.css_class ?? ''}`}
|
|
71
|
+
id={settings.anchor_id}
|
|
72
|
+
style={Object.keys(bgStyle).length > 0 ? bgStyle : undefined}
|
|
73
|
+
>
|
|
74
|
+
<div class={width}>
|
|
75
|
+
{data.heading && (
|
|
76
|
+
<h2 class="reveal-heading mb-16 max-w-2xl text-3xl font-bold tracking-[-0.03em] sm:text-4xl lg:text-5xl">
|
|
77
|
+
{data.heading.includes('*') ? renderGradient(data.heading, primaryColor) : data.heading}
|
|
78
|
+
</h2>
|
|
79
|
+
)}
|
|
80
|
+
|
|
81
|
+
{/* Asymmetric layout: 1 large left, 2 stacked right */}
|
|
82
|
+
<div class="grid gap-6 lg:grid-cols-5">
|
|
83
|
+
{/* Featured testimonial — spans 3 cols */}
|
|
84
|
+
{featured && (
|
|
85
|
+
<div
|
|
86
|
+
class={`testimonial-featured lg:col-span-3 group relative rounded-2xl border p-10 transition-all duration-400 ${
|
|
87
|
+
isDark
|
|
88
|
+
? 'border-gray-700/50 bg-white/[0.04] hover:border-gray-600'
|
|
89
|
+
: 'border-gray-100 bg-white shadow-sm hover:shadow-xl hover:shadow-slate-200/50'
|
|
90
|
+
}`}
|
|
91
|
+
>
|
|
92
|
+
<div class="mb-6 text-7xl font-serif leading-none" style={{ color: `${primaryColor}30` }}>"</div>
|
|
93
|
+
<blockquote class={`mb-8 text-xl leading-relaxed ${isDark ? 'text-gray-200' : 'text-slate-700'}`}>
|
|
94
|
+
{featured.quote}
|
|
95
|
+
</blockquote>
|
|
96
|
+
<div class="flex items-center gap-4">
|
|
97
|
+
{featured.avatar ? (
|
|
98
|
+
<img src={featured.avatar} alt={featured.author} class="h-14 w-14 rounded-full object-cover ring-2 ring-gray-100" loading="lazy" />
|
|
99
|
+
) : (
|
|
100
|
+
<div class="flex h-14 w-14 items-center justify-center rounded-full text-lg font-bold text-white" style={{ backgroundColor: primaryColor }}>
|
|
101
|
+
{featured.author.charAt(0).toUpperCase()}
|
|
102
|
+
</div>
|
|
103
|
+
)}
|
|
104
|
+
<div>
|
|
105
|
+
<div class={`text-base font-semibold ${isDark ? 'text-white' : 'text-slate-900'}`}>{featured.author}</div>
|
|
106
|
+
{featured.role && <div class={`text-sm ${isDark ? 'text-gray-500' : 'text-slate-400'}`}>{featured.role}</div>}
|
|
107
|
+
</div>
|
|
108
|
+
</div>
|
|
109
|
+
{/* Accent corner */}
|
|
110
|
+
<div class="absolute bottom-0 right-0 h-1 w-24 rounded-tl-full" style={{ backgroundColor: primaryColor }} />
|
|
111
|
+
</div>
|
|
112
|
+
)}
|
|
113
|
+
|
|
114
|
+
{/* Side testimonials — offset with top margin */}
|
|
115
|
+
<div class="testimonial-side flex flex-col gap-6 lg:col-span-2 lg:mt-8">
|
|
116
|
+
{rest.map((item) => (
|
|
117
|
+
<div
|
|
118
|
+
class={`group relative rounded-2xl border p-7 transition-all duration-400 ${
|
|
119
|
+
isDark
|
|
120
|
+
? 'border-gray-700/50 bg-white/[0.03] hover:border-gray-600'
|
|
121
|
+
: 'border-gray-100 bg-white shadow-sm hover:shadow-lg hover:shadow-slate-200/50'
|
|
122
|
+
}`}
|
|
123
|
+
>
|
|
124
|
+
<div class="mb-4 text-4xl font-serif leading-none" style={{ color: `${primaryColor}25` }}>"</div>
|
|
125
|
+
<blockquote class={`mb-6 text-sm leading-relaxed ${isDark ? 'text-gray-300' : 'text-slate-600'}`}>
|
|
126
|
+
{item.quote}
|
|
127
|
+
</blockquote>
|
|
128
|
+
<div class="flex items-center gap-3">
|
|
129
|
+
{item.avatar ? (
|
|
130
|
+
<img src={item.avatar} alt={item.author} class="h-10 w-10 rounded-full object-cover ring-2 ring-gray-100" loading="lazy" />
|
|
131
|
+
) : (
|
|
132
|
+
<div class="flex h-10 w-10 items-center justify-center rounded-full text-sm font-bold text-white" style={{ backgroundColor: primaryColor }}>
|
|
133
|
+
{item.author.charAt(0).toUpperCase()}
|
|
134
|
+
</div>
|
|
135
|
+
)}
|
|
136
|
+
<div>
|
|
137
|
+
<div class={`text-sm font-semibold ${isDark ? 'text-white' : 'text-slate-900'}`}>{item.author}</div>
|
|
138
|
+
{item.role && <div class={`text-xs ${isDark ? 'text-gray-500' : 'text-slate-400'}`}>{item.role}</div>}
|
|
139
|
+
</div>
|
|
140
|
+
</div>
|
|
141
|
+
</div>
|
|
142
|
+
))}
|
|
143
|
+
</div>
|
|
144
|
+
</div>
|
|
145
|
+
</div>
|
|
146
|
+
</section>
|
|
147
|
+
);
|
|
148
|
+
};
|
|
149
|
+
|
|
150
|
+
export default Testimonials;
|
|
@@ -0,0 +1,67 @@
|
|
|
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-slate-900',
|
|
21
|
+
dark: 'text-white',
|
|
22
|
+
primary: 'text-white',
|
|
23
|
+
custom: '',
|
|
24
|
+
};
|
|
25
|
+
|
|
26
|
+
const Text: FC<SectionProps> = ({ data, settings, themeSettings }) => {
|
|
27
|
+
const spacing = spacingMap[settings.spacing] ?? spacingMap.medium;
|
|
28
|
+
const width = widthMap[settings.width] ?? widthMap.contained;
|
|
29
|
+
const bg = bgMap[settings.background] ?? bgMap.light;
|
|
30
|
+
const primaryColor = themeSettings.primary_color ?? '#10B981';
|
|
31
|
+
const navColor = themeSettings.nav_color ?? '#0B1222';
|
|
32
|
+
|
|
33
|
+
const bgStyle: Record<string, string> = {};
|
|
34
|
+
if (settings.background === 'dark') {
|
|
35
|
+
bgStyle.backgroundColor = navColor;
|
|
36
|
+
} else 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-6 text-3xl font-bold tracking-tight">
|
|
53
|
+
{data.heading}
|
|
54
|
+
</h2>
|
|
55
|
+
)}
|
|
56
|
+
{data.body && (
|
|
57
|
+
<div
|
|
58
|
+
class={`prose prose-lg max-w-none ${isDark ? 'prose-invert' : 'prose-slate'}`}
|
|
59
|
+
dangerouslySetInnerHTML={{ __html: data.body }}
|
|
60
|
+
/>
|
|
61
|
+
)}
|
|
62
|
+
</div>
|
|
63
|
+
</section>
|
|
64
|
+
);
|
|
65
|
+
};
|
|
66
|
+
|
|
67
|
+
export default Text;
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
label: Text with Image
|
|
2
|
+
icon: image
|
|
3
|
+
description: "Two-column text and image with optional CTA."
|
|
4
|
+
status: stable
|
|
5
|
+
fields:
|
|
6
|
+
heading:
|
|
7
|
+
type: text
|
|
8
|
+
label: Heading
|
|
9
|
+
body:
|
|
10
|
+
type: textarea
|
|
11
|
+
label: Body
|
|
12
|
+
required: true
|
|
13
|
+
image:
|
|
14
|
+
type: media
|
|
15
|
+
label: Image
|
|
16
|
+
required: true
|
|
17
|
+
image_position:
|
|
18
|
+
type: select
|
|
19
|
+
label: Image Position
|
|
20
|
+
options: [left, right]
|
|
21
|
+
default: right
|
|
22
|
+
image_alt:
|
|
23
|
+
type: text
|
|
24
|
+
label: Image Alt Text
|
|
25
|
+
cta_text:
|
|
26
|
+
type: text
|
|
27
|
+
label: Button Text
|
|
28
|
+
cta_url:
|
|
29
|
+
type: text
|
|
30
|
+
label: Button URL
|
|
@@ -0,0 +1,92 @@
|
|
|
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-10',
|
|
8
|
+
medium: 'py-20',
|
|
9
|
+
large: 'py-28',
|
|
10
|
+
xlarge: 'py-36',
|
|
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-slate-900',
|
|
21
|
+
dark: 'text-white',
|
|
22
|
+
primary: 'text-white',
|
|
23
|
+
custom: '',
|
|
24
|
+
};
|
|
25
|
+
|
|
26
|
+
const TextWithImage: FC<SectionProps> = ({ data, settings, themeSettings }) => {
|
|
27
|
+
const urlFn = (p: string) => themeSettings._url?.(p) ?? p;
|
|
28
|
+
const spacing = spacingMap[settings.spacing] ?? spacingMap.large;
|
|
29
|
+
const width = widthMap[settings.width] ?? widthMap.contained;
|
|
30
|
+
const bg = bgMap[settings.background] ?? bgMap.light;
|
|
31
|
+
const primaryColor = themeSettings.primary_color ?? '#10B981';
|
|
32
|
+
const navColor = themeSettings.nav_color ?? '#0B1222';
|
|
33
|
+
const reversed = data.image_position === 'left';
|
|
34
|
+
|
|
35
|
+
const bgStyle: Record<string, string> = {};
|
|
36
|
+
if (settings.background === 'dark') {
|
|
37
|
+
bgStyle.backgroundColor = navColor;
|
|
38
|
+
} else if (settings.background === 'primary') {
|
|
39
|
+
bgStyle.backgroundColor = primaryColor;
|
|
40
|
+
} else if (settings.background === 'custom' && settings.background_color) {
|
|
41
|
+
bgStyle.backgroundColor = settings.background_color;
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
const isDark = settings.background === 'dark' || settings.background === 'primary';
|
|
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} grid items-center gap-16 md:grid-cols-2`}>
|
|
53
|
+
<div class={reversed ? 'order-2' : ''}>
|
|
54
|
+
{data.heading && (
|
|
55
|
+
<h2 class="mb-5 text-3xl font-bold tracking-[-0.02em]">
|
|
56
|
+
{data.heading}
|
|
57
|
+
</h2>
|
|
58
|
+
)}
|
|
59
|
+
{data.body && (
|
|
60
|
+
<div
|
|
61
|
+
class={`prose prose-lg max-w-none ${isDark ? 'prose-invert' : 'prose-slate'}`}
|
|
62
|
+
dangerouslySetInnerHTML={{ __html: data.body }}
|
|
63
|
+
/>
|
|
64
|
+
)}
|
|
65
|
+
{data.cta_text && (
|
|
66
|
+
<div class="mt-8">
|
|
67
|
+
<a
|
|
68
|
+
href={urlFn(data.cta_url ?? '#')}
|
|
69
|
+
class="inline-block rounded-lg px-6 py-2.5 text-sm font-semibold text-white transition-all duration-200 hover:shadow-lg hover:no-underline"
|
|
70
|
+
style={{ backgroundColor: primaryColor }}
|
|
71
|
+
>
|
|
72
|
+
{data.cta_text}
|
|
73
|
+
</a>
|
|
74
|
+
</div>
|
|
75
|
+
)}
|
|
76
|
+
</div>
|
|
77
|
+
<div class={reversed ? 'order-1' : ''}>
|
|
78
|
+
{data.image && (
|
|
79
|
+
<img
|
|
80
|
+
src={data.image}
|
|
81
|
+
alt={data.image_alt ?? ''}
|
|
82
|
+
class="rounded-2xl shadow-xl ring-1 ring-gray-100"
|
|
83
|
+
loading="lazy"
|
|
84
|
+
/>
|
|
85
|
+
)}
|
|
86
|
+
</div>
|
|
87
|
+
</div>
|
|
88
|
+
</section>
|
|
89
|
+
);
|
|
90
|
+
};
|
|
91
|
+
|
|
92
|
+
export default TextWithImage;
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
label: Video Embed
|
|
2
|
+
icon: play-circle
|
|
3
|
+
description: "YouTube or Vimeo video embed with optional heading and caption."
|
|
4
|
+
status: stable
|
|
5
|
+
fields:
|
|
6
|
+
heading:
|
|
7
|
+
type: text
|
|
8
|
+
label: Heading
|
|
9
|
+
video_url:
|
|
10
|
+
type: text
|
|
11
|
+
label: "Video URL (YouTube/Vimeo)"
|
|
12
|
+
required: true
|
|
13
|
+
caption:
|
|
14
|
+
type: text
|
|
15
|
+
label: Caption
|
|
16
|
+
autoplay:
|
|
17
|
+
type: boolean
|
|
18
|
+
label: Autoplay
|
|
19
|
+
default: false
|