@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,672 @@
|
|
|
1
|
+
/** @jsxImportSource hono/jsx */
|
|
2
|
+
import type { FC } from 'hono/jsx';
|
|
3
|
+
import type { LayoutProps } from '../_types.js';
|
|
4
|
+
|
|
5
|
+
const megaServices = [
|
|
6
|
+
{ labelKey: 'mega.services.custom_software', descKey: 'mega.services.custom_software_desc', href: '/services/custom-software-development', icon: 'code' },
|
|
7
|
+
{ labelKey: 'mega.services.cloud', descKey: 'mega.services.cloud_desc', href: '/services/cloud-infrastructure', icon: 'cloud' },
|
|
8
|
+
{ labelKey: 'mega.services.data_ai', descKey: 'mega.services.data_ai_desc', href: '/services/data-ai', icon: 'brain' },
|
|
9
|
+
{ labelKey: 'mega.services.cybersecurity', descKey: 'mega.services.cybersecurity_desc', href: '/services/cybersecurity', icon: 'shield' },
|
|
10
|
+
{ labelKey: 'mega.services.devops', descKey: 'mega.services.devops_desc', href: '/services/digital-transformation', icon: 'rocket' },
|
|
11
|
+
{ labelKey: 'mega.services.ai_ml', descKey: 'mega.services.ai_ml_desc', href: '/services/it-outsourcing', icon: 'zap' },
|
|
12
|
+
];
|
|
13
|
+
|
|
14
|
+
const megaIndustries = [
|
|
15
|
+
{ labelKey: 'mega.industries.financial', descKey: 'mega.industries.financial_desc', href: '/industries/financial-services', icon: 'landmark' },
|
|
16
|
+
{ labelKey: 'mega.industries.healthcare', descKey: 'mega.industries.healthcare_desc', href: '/industries/healthcare', icon: 'heart' },
|
|
17
|
+
{ labelKey: 'mega.industries.manufacturing', descKey: 'mega.industries.manufacturing_desc', href: '/industries/manufacturing', icon: 'factory' },
|
|
18
|
+
{ labelKey: 'mega.industries.retail', descKey: 'mega.industries.retail_desc', href: '/industries/retail', icon: 'store' },
|
|
19
|
+
{ labelKey: 'mega.industries.telecom', descKey: 'mega.industries.telecom_desc', href: '/industries/telecom', icon: 'signal' },
|
|
20
|
+
{ labelKey: 'mega.industries.energy', descKey: 'mega.industries.energy_desc', href: '/industries/energy', icon: 'zap' },
|
|
21
|
+
];
|
|
22
|
+
|
|
23
|
+
const iconSvg: Record<string, string> = {
|
|
24
|
+
code: '<svg width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><polyline points="16 18 22 12 16 6"/><polyline points="8 6 2 12 8 18"/></svg>',
|
|
25
|
+
cloud: '<svg width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M18 10h-1.26A8 8 0 1 0 9 20h9a5 5 0 0 0 0-10z"/></svg>',
|
|
26
|
+
brain: '<svg width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M12 2a4 4 0 0 1 4 4c0 1.1-.9 2-2 2h-4c-1.1 0-2-.9-2-2a4 4 0 0 1 4-4z"/><path d="M8 8v2c0 2.2 1.8 4 4 4s4-1.8 4-4V8"/><path d="M6 14c-1.7 1-3 3-3 5v1h18v-1c0-2-1.3-4-3-5"/></svg>',
|
|
27
|
+
shield: '<svg width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M12 22s8-4 8-10V5l-8-3-8 3v7c0 6 8 10 8 10z"/><path d="m9 12 2 2 4-4"/></svg>',
|
|
28
|
+
rocket: '<svg width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M4.5 16.5c-1.5 1.26-2 5-2 5s3.74-.5 5-2c.71-.84.7-2.13-.09-2.91a2.18 2.18 0 0 0-2.91-.09z"/><path d="M12 15l-3-3a22 22 0 0 1 2-3.95A12.88 12.88 0 0 1 22 2c0 2.72-.78 7.5-6 11a22.35 22.35 0 0 1-4 2z"/></svg>',
|
|
29
|
+
zap: '<svg width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><polygon points="13 2 3 14 12 14 11 22 21 10 12 10 13 2"/></svg>',
|
|
30
|
+
landmark: '<svg width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><line x1="3" y1="22" x2="21" y2="22"/><line x1="6" y1="18" x2="6" y2="11"/><line x1="10" y1="18" x2="10" y2="11"/><line x1="14" y1="18" x2="14" y2="11"/><line x1="18" y1="18" x2="18" y2="11"/><polygon points="12 2 20 7 4 7"/></svg>',
|
|
31
|
+
heart: '<svg width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M20.84 4.61a5.5 5.5 0 0 0-7.78 0L12 5.67l-1.06-1.06a5.5 5.5 0 0 0-7.78 7.78l1.06 1.06L12 21.23l7.78-7.78 1.06-1.06a5.5 5.5 0 0 0 0-7.78z"/></svg>',
|
|
32
|
+
factory: '<svg width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M2 20a2 2 0 0 0 2 2h16a2 2 0 0 0 2-2V8l-7 5V8l-7 5V4a2 2 0 0 0-2-2H4a2 2 0 0 0-2 2Z"/></svg>',
|
|
33
|
+
store: '<svg width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="m2 7 4.41-4.41A2 2 0 0 1 7.83 2h8.34a2 2 0 0 1 1.42.59L22 7"/><path d="M4 12v8a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2v-8"/><path d="M2 7h20"/></svg>',
|
|
34
|
+
signal: '<svg width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M2 20h.01"/><path d="M7 20v-4"/><path d="M12 20v-8"/><path d="M17 20V8"/><path d="M22 4v16"/></svg>',
|
|
35
|
+
edit: '<svg width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M11 4H4a2 2 0 0 0-2 2v14a2 2 0 0 0 2 2h14a2 2 0 0 0 2-2v-7"/><path d="M18.5 2.5a2.121 2.121 0 0 1 3 3L12 15l-4 1 1-4 9.5-9.5z"/></svg>',
|
|
36
|
+
book: '<svg width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M4 19.5A2.5 2.5 0 0 1 6.5 17H20"/><path d="M6.5 2H20v20H6.5A2.5 2.5 0 0 1 4 19.5v-15A2.5 2.5 0 0 1 6.5 2z"/></svg>',
|
|
37
|
+
video: '<svg width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><polygon points="23 7 16 12 23 17 23 7"/><rect x="1" y="5" width="15" height="14" rx="2" ry="2"/></svg>',
|
|
38
|
+
check: '<svg width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M9 11l3 3L22 4"/><path d="M21 12v7a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2h11"/></svg>',
|
|
39
|
+
play: '<svg width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><circle cx="12" cy="12" r="10"/><polygon points="10 8 16 12 10 16 10 8"/></svg>',
|
|
40
|
+
mic: '<svg width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M12 1a3 3 0 0 0-3 3v8a3 3 0 0 0 6 0V4a3 3 0 0 0-3-3z"/><path d="M19 10v2a7 7 0 0 1-14 0v-2"/><line x1="12" y1="19" x2="12" y2="23"/><line x1="8" y1="23" x2="16" y2="23"/></svg>',
|
|
41
|
+
github: '<svg width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M9 19c-5 1.5-5-2.5-7-3m14 6v-3.87a3.37 3.37 0 0 0-.94-2.61c3.14-.35 6.44-1.54 6.44-7A5.44 5.44 0 0 0 20 4.77 5.07 5.07 0 0 0 19.91 1S18.73.65 16 2.48a13.38 13.38 0 0 0-7 0C6.27.65 5.09 1 5.09 1A5.07 5.07 0 0 0 5 4.77a5.44 5.44 0 0 0-1.5 3.78c0 5.42 3.3 6.61 6.44 7A3.37 3.37 0 0 0 9 18.13V22"/></svg>',
|
|
42
|
+
};
|
|
43
|
+
|
|
44
|
+
const megaInsights = [
|
|
45
|
+
{ labelKey: 'mega.insights.blog', href: '/articles', icon: 'edit' },
|
|
46
|
+
{ labelKey: 'mega.insights.ebooks', href: '/resources/ebooks', icon: 'book' },
|
|
47
|
+
{ labelKey: 'mega.insights.webinars', href: '/resources/webinars', icon: 'video' },
|
|
48
|
+
{ labelKey: 'mega.insights.tools', href: '/resources/tools', icon: 'check' },
|
|
49
|
+
{ labelKey: 'mega.insights.demo', href: '/resources/demo', icon: 'play' },
|
|
50
|
+
{ labelKey: 'mega.insights.talks', href: '/resources/talks', icon: 'mic' },
|
|
51
|
+
{ labelKey: 'mega.insights.opensource', href: '/open-source', icon: 'github' },
|
|
52
|
+
];
|
|
53
|
+
|
|
54
|
+
const footerServices = [
|
|
55
|
+
{ labelKey: 'footer.cloud_infrastructure', href: '/services/cloud-infrastructure' },
|
|
56
|
+
{ labelKey: 'footer.data_engineering', href: '/services/data-ai' },
|
|
57
|
+
{ labelKey: 'footer.custom_software', href: '/services/custom-software-development' },
|
|
58
|
+
{ labelKey: 'footer.devops_sre', href: '/services/digital-transformation' },
|
|
59
|
+
{ labelKey: 'footer.ai_ml', href: '/services/it-outsourcing' },
|
|
60
|
+
];
|
|
61
|
+
|
|
62
|
+
const footerCompany = [
|
|
63
|
+
{ labelKey: 'footer.about_us', href: '/about' },
|
|
64
|
+
{ labelKey: 'footer.leadership', href: '/about/leadership' },
|
|
65
|
+
{ labelKey: 'footer.careers', href: '/careers' },
|
|
66
|
+
{ labelKey: 'footer.partners', href: '/partners' },
|
|
67
|
+
{ labelKey: 'footer.contact', href: '/contact' },
|
|
68
|
+
];
|
|
69
|
+
|
|
70
|
+
const footerResources = [
|
|
71
|
+
{ labelKey: 'footer.blog', href: '/articles' },
|
|
72
|
+
{ labelKey: 'footer.case_studies', href: '/case-studies' },
|
|
73
|
+
{ labelKey: 'footer.ebooks', href: '/resources/ebooks' },
|
|
74
|
+
{ labelKey: 'footer.webinars', href: '/resources/webinars' },
|
|
75
|
+
{ labelKey: 'footer.opensource', href: '/open-source' },
|
|
76
|
+
];
|
|
77
|
+
|
|
78
|
+
const MegaPanel: FC<{ items: typeof megaServices; primaryColor: string; viewAllLabel: string; viewAllHref: string; urlFn?: (p: string) => string; t?: (k: string) => string }> = ({ items, primaryColor, viewAllLabel, viewAllHref, urlFn = (p) => p, t: tFn = (k) => k }) => (
|
|
79
|
+
<div class="mega-dropdown pointer-events-none invisible absolute left-1/2 top-full z-50 w-[640px] -translate-x-1/2 pt-3 opacity-0 transition-all duration-200">
|
|
80
|
+
<div class="pointer-events-auto rounded-2xl border border-gray-100 bg-white p-6 shadow-xl shadow-slate-200/50">
|
|
81
|
+
<div class="grid gap-2 sm:grid-cols-2">
|
|
82
|
+
{items.map((item) => (
|
|
83
|
+
<a
|
|
84
|
+
href={urlFn(item.href)}
|
|
85
|
+
class="group/item flex items-start gap-3 rounded-xl p-3 transition-colors duration-150 hover:bg-slate-50 hover:no-underline"
|
|
86
|
+
>
|
|
87
|
+
<div
|
|
88
|
+
class="mt-0.5 flex h-9 w-9 shrink-0 items-center justify-center rounded-lg text-white"
|
|
89
|
+
style={{ backgroundColor: primaryColor }}
|
|
90
|
+
dangerouslySetInnerHTML={{ __html: iconSvg[item.icon] ?? '' }}
|
|
91
|
+
/>
|
|
92
|
+
<div>
|
|
93
|
+
<div class="text-sm font-semibold text-slate-900 group-hover/item:text-emerald-600">
|
|
94
|
+
{tFn(item.labelKey)}
|
|
95
|
+
</div>
|
|
96
|
+
{'descKey' in item && (
|
|
97
|
+
<div class="mt-0.5 text-xs leading-relaxed text-slate-400">
|
|
98
|
+
{tFn((item as any).descKey)}
|
|
99
|
+
</div>
|
|
100
|
+
)}
|
|
101
|
+
</div>
|
|
102
|
+
</a>
|
|
103
|
+
))}
|
|
104
|
+
</div>
|
|
105
|
+
<div class="mt-4 border-t border-gray-100 pt-4">
|
|
106
|
+
<a
|
|
107
|
+
href={urlFn(viewAllHref)}
|
|
108
|
+
class="flex items-center gap-1 text-xs font-semibold uppercase tracking-widest hover:no-underline"
|
|
109
|
+
style={{ color: primaryColor }}
|
|
110
|
+
>
|
|
111
|
+
{viewAllLabel}
|
|
112
|
+
<span>→</span>
|
|
113
|
+
</a>
|
|
114
|
+
</div>
|
|
115
|
+
</div>
|
|
116
|
+
</div>
|
|
117
|
+
);
|
|
118
|
+
|
|
119
|
+
const Base: FC<LayoutProps> = ({ content, site, theme, themeSettings, children }) => {
|
|
120
|
+
const seo = content.seo ?? {};
|
|
121
|
+
const separator = site.seo?.title_separator ?? ' | ';
|
|
122
|
+
const pageTitle = seo.title ?? content.title;
|
|
123
|
+
const fullTitle = `${pageTitle}${separator}${site.site_name}`;
|
|
124
|
+
const description = seo.description ?? site.seo?.default_description ?? '';
|
|
125
|
+
const ogImage = seo.image ?? site.seo?.default_image ?? '';
|
|
126
|
+
const canonical = seo.canonical ?? `${site.base_url}/${content.slug}`;
|
|
127
|
+
const primaryColor = themeSettings.primary_color ?? '#10B981';
|
|
128
|
+
const navColor = themeSettings.nav_color ?? '#0B1222';
|
|
129
|
+
const langcode = content.langcode ?? themeSettings._lang ?? 'en';
|
|
130
|
+
|
|
131
|
+
const currentLang = themeSettings._lang ?? langcode;
|
|
132
|
+
const defaultLang = themeSettings._defaultLang ?? 'en';
|
|
133
|
+
const languages: Record<string, { code: string; label: string }> = themeSettings._languages ?? {};
|
|
134
|
+
const currentPath = themeSettings._currentPath ?? '/';
|
|
135
|
+
const hasMultipleLangs = Object.keys(languages).length > 1;
|
|
136
|
+
const basePath: string = themeSettings._basePath ?? (currentLang === defaultLang ? '' : `/${currentLang}`);
|
|
137
|
+
const url = themeSettings._url ?? ((path: string) => `${basePath}${path}`);
|
|
138
|
+
const homeUrl = basePath || '/';
|
|
139
|
+
const t = themeSettings._t ?? ((key: string) => key);
|
|
140
|
+
|
|
141
|
+
function langSwitchUrl(targetLang: string): string {
|
|
142
|
+
if (targetLang === defaultLang) {
|
|
143
|
+
if (currentLang === defaultLang) return currentPath;
|
|
144
|
+
return currentPath.replace(new RegExp(`^/${currentLang}`), '') || '/';
|
|
145
|
+
}
|
|
146
|
+
if (currentLang === defaultLang) {
|
|
147
|
+
return `/${targetLang}${currentPath === '/' ? '' : currentPath}`;
|
|
148
|
+
}
|
|
149
|
+
return currentPath.replace(new RegExp(`^/${currentLang}`), `/${targetLang}`);
|
|
150
|
+
}
|
|
151
|
+
|
|
152
|
+
const jsonLd = {
|
|
153
|
+
'@context': 'https://schema.org',
|
|
154
|
+
'@type': content.type === 'article' ? 'Article' : 'WebPage',
|
|
155
|
+
name: pageTitle,
|
|
156
|
+
description,
|
|
157
|
+
url: canonical,
|
|
158
|
+
...(content.publishedAt && { datePublished: content.publishedAt.toISOString() }),
|
|
159
|
+
...(content.updatedAt && { dateModified: content.updatedAt.toISOString() }),
|
|
160
|
+
};
|
|
161
|
+
|
|
162
|
+
return (
|
|
163
|
+
<html lang={langcode}>
|
|
164
|
+
<head>
|
|
165
|
+
<meta charset="utf-8" />
|
|
166
|
+
<meta name="viewport" content="width=device-width, initial-scale=1, viewport-fit=cover" />
|
|
167
|
+
<title>{fullTitle}</title>
|
|
168
|
+
<meta name="description" content={description} />
|
|
169
|
+
{seo.noindex && <meta name="robots" content="noindex, nofollow" />}
|
|
170
|
+
<link rel="canonical" href={canonical} />
|
|
171
|
+
|
|
172
|
+
<meta property="og:type" content={content.type === 'article' ? 'article' : 'website'} />
|
|
173
|
+
<meta property="og:title" content={pageTitle} />
|
|
174
|
+
<meta property="og:description" content={description} />
|
|
175
|
+
<meta property="og:url" content={canonical} />
|
|
176
|
+
{ogImage && <meta property="og:image" content={ogImage} />}
|
|
177
|
+
|
|
178
|
+
<meta name="twitter:card" content="summary_large_image" />
|
|
179
|
+
<meta name="twitter:title" content={pageTitle} />
|
|
180
|
+
<meta name="twitter:description" content={description} />
|
|
181
|
+
{ogImage && <meta name="twitter:image" content={ogImage} />}
|
|
182
|
+
|
|
183
|
+
<script src="https://cdn.tailwindcss.com"></script>
|
|
184
|
+
<link rel="stylesheet" href="/static/style.css" />
|
|
185
|
+
<link rel="stylesheet" href="/static/components.css" />
|
|
186
|
+
|
|
187
|
+
<script
|
|
188
|
+
type="application/ld+json"
|
|
189
|
+
dangerouslySetInnerHTML={{ __html: JSON.stringify(jsonLd) }}
|
|
190
|
+
/>
|
|
191
|
+
|
|
192
|
+
<style>{`
|
|
193
|
+
:root {
|
|
194
|
+
--color-primary: ${primaryColor};
|
|
195
|
+
--color-navy: ${navColor};
|
|
196
|
+
}
|
|
197
|
+
`}</style>
|
|
198
|
+
</head>
|
|
199
|
+
<body class="min-h-screen flex flex-col bg-white text-slate-800 antialiased">
|
|
200
|
+
|
|
201
|
+
{/* ═══ Desktop Header with Mega Menu ═══ */}
|
|
202
|
+
<header class="sticky top-0 z-50 hidden border-b border-gray-100 md:block" style={{ backdropFilter: 'blur(12px)', backgroundColor: 'rgba(255,255,255,0.95)' }}>
|
|
203
|
+
<nav class="mx-auto flex max-w-7xl items-center justify-between px-6 py-4">
|
|
204
|
+
<a href={homeUrl} class="flex items-center gap-2 hover:no-underline">
|
|
205
|
+
{themeSettings.logo
|
|
206
|
+
? <img src={themeSettings.logo} alt={site.site_name} class="h-14" />
|
|
207
|
+
: <span class="text-xl font-bold tracking-tight text-slate-900">{site.site_name}</span>}
|
|
208
|
+
</a>
|
|
209
|
+
|
|
210
|
+
<ul class="flex items-center gap-1 text-sm font-medium text-slate-500">
|
|
211
|
+
{/* Services — mega dropdown */}
|
|
212
|
+
<li class="mega-trigger relative">
|
|
213
|
+
<a
|
|
214
|
+
href={url('/services')}
|
|
215
|
+
class="flex items-center gap-1 rounded-lg px-3 py-2 transition-colors duration-200 hover:bg-slate-50 hover:text-slate-900 hover:no-underline"
|
|
216
|
+
>
|
|
217
|
+
{t('nav.services')}
|
|
218
|
+
<svg class="h-3.5 w-3.5 opacity-50" viewBox="0 0 20 20" fill="currentColor"><path fill-rule="evenodd" d="M5.293 7.293a1 1 0 011.414 0L10 10.586l3.293-3.293a1 1 0 111.414 1.414l-4 4a1 1 0 01-1.414 0l-4-4a1 1 0 010-1.414z" clip-rule="evenodd"/></svg>
|
|
219
|
+
</a>
|
|
220
|
+
<MegaPanel items={megaServices} primaryColor={primaryColor} viewAllLabel={t('nav.view_all_services')} viewAllHref="/services" urlFn={url} t={t} />
|
|
221
|
+
</li>
|
|
222
|
+
|
|
223
|
+
{/* Industries — mega dropdown */}
|
|
224
|
+
<li class="mega-trigger relative">
|
|
225
|
+
<a
|
|
226
|
+
href={url('/industries')}
|
|
227
|
+
class="flex items-center gap-1 rounded-lg px-3 py-2 transition-colors duration-200 hover:bg-slate-50 hover:text-slate-900 hover:no-underline"
|
|
228
|
+
>
|
|
229
|
+
{t('nav.industries')}
|
|
230
|
+
<svg class="h-3.5 w-3.5 opacity-50" viewBox="0 0 20 20" fill="currentColor"><path fill-rule="evenodd" d="M5.293 7.293a1 1 0 011.414 0L10 10.586l3.293-3.293a1 1 0 111.414 1.414l-4 4a1 1 0 01-1.414 0l-4-4a1 1 0 010-1.414z" clip-rule="evenodd"/></svg>
|
|
231
|
+
</a>
|
|
232
|
+
<MegaPanel items={megaIndustries} primaryColor={primaryColor} viewAllLabel={t('nav.view_all_industries')} viewAllHref="/industries" urlFn={url} t={t} />
|
|
233
|
+
</li>
|
|
234
|
+
|
|
235
|
+
<li>
|
|
236
|
+
<a href={url('/case-studies')} class="rounded-lg px-3 py-2 transition-colors duration-200 hover:bg-slate-50 hover:text-slate-900 hover:no-underline">
|
|
237
|
+
{t('nav.case_studies')}
|
|
238
|
+
</a>
|
|
239
|
+
</li>
|
|
240
|
+
{/* Insights — mega dropdown */}
|
|
241
|
+
<li class="mega-trigger relative">
|
|
242
|
+
<a
|
|
243
|
+
href={url('/articles')}
|
|
244
|
+
class="flex items-center gap-1 rounded-lg px-3 py-2 transition-colors duration-200 hover:bg-slate-50 hover:text-slate-900 hover:no-underline"
|
|
245
|
+
>
|
|
246
|
+
{t('nav.insights')}
|
|
247
|
+
<svg class="h-3.5 w-3.5 opacity-50" viewBox="0 0 20 20" fill="currentColor"><path fill-rule="evenodd" d="M5.293 7.293a1 1 0 011.414 0L10 10.586l3.293-3.293a1 1 0 111.414 1.414l-4 4a1 1 0 01-1.414 0l-4-4a1 1 0 010-1.414z" clip-rule="evenodd"/></svg>
|
|
248
|
+
</a>
|
|
249
|
+
<div class="mega-dropdown pointer-events-none invisible absolute left-1/2 top-full z-50 w-[280px] -translate-x-1/2 pt-3 opacity-0 transition-all duration-200">
|
|
250
|
+
<div class="pointer-events-auto rounded-2xl border border-gray-100 bg-white p-4 shadow-xl shadow-slate-200/50">
|
|
251
|
+
<div class="space-y-1">
|
|
252
|
+
{megaInsights.map((item) => (
|
|
253
|
+
<a
|
|
254
|
+
href={url(item.href)}
|
|
255
|
+
class="group/item flex items-center gap-3 rounded-xl px-3 py-2.5 transition-colors duration-150 hover:bg-slate-50 hover:no-underline"
|
|
256
|
+
>
|
|
257
|
+
<div
|
|
258
|
+
class="flex h-8 w-8 shrink-0 items-center justify-center rounded-lg text-white"
|
|
259
|
+
style={{ backgroundColor: primaryColor }}
|
|
260
|
+
dangerouslySetInnerHTML={{ __html: iconSvg[item.icon] ?? '' }}
|
|
261
|
+
/>
|
|
262
|
+
<span class="text-sm font-medium text-slate-700 group-hover/item:text-emerald-600">
|
|
263
|
+
{t(item.labelKey)}
|
|
264
|
+
</span>
|
|
265
|
+
</a>
|
|
266
|
+
))}
|
|
267
|
+
</div>
|
|
268
|
+
</div>
|
|
269
|
+
</div>
|
|
270
|
+
</li>
|
|
271
|
+
<li>
|
|
272
|
+
<a href={url('/about')} class="rounded-lg px-3 py-2 transition-colors duration-200 hover:bg-slate-50 hover:text-slate-900 hover:no-underline">
|
|
273
|
+
{t('nav.about')}
|
|
274
|
+
</a>
|
|
275
|
+
</li>
|
|
276
|
+
<li>
|
|
277
|
+
<a href={url('/careers')} class="rounded-lg px-3 py-2 transition-colors duration-200 hover:bg-slate-50 hover:text-slate-900 hover:no-underline">
|
|
278
|
+
{t('nav.careers')}
|
|
279
|
+
</a>
|
|
280
|
+
</li>
|
|
281
|
+
</ul>
|
|
282
|
+
|
|
283
|
+
<div class="flex items-center gap-3">
|
|
284
|
+
{hasMultipleLangs && (
|
|
285
|
+
<div class="lang-switcher relative">
|
|
286
|
+
<button class="lang-switcher-trigger flex items-center gap-1.5 rounded-lg border border-gray-200 px-2.5 py-2 text-xs font-semibold uppercase tracking-wide text-slate-600 transition-colors hover:border-gray-300 hover:text-slate-900">
|
|
287
|
+
<svg class="h-4 w-4 opacity-60" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><circle cx="12" cy="12" r="10"/><line x1="2" y1="12" x2="22" y2="12"/><path d="M12 2a15.3 15.3 0 0 1 4 10 15.3 15.3 0 0 1-4 10 15.3 15.3 0 0 1-4-10 15.3 15.3 0 0 1 4-10z"/></svg>
|
|
288
|
+
{currentLang.toUpperCase()}
|
|
289
|
+
<svg class="h-3 w-3 opacity-40" viewBox="0 0 20 20" fill="currentColor"><path fill-rule="evenodd" d="M5.293 7.293a1 1 0 011.414 0L10 10.586l3.293-3.293a1 1 0 111.414 1.414l-4 4a1 1 0 01-1.414 0l-4-4a1 1 0 010-1.414z" clip-rule="evenodd"/></svg>
|
|
290
|
+
</button>
|
|
291
|
+
<div class="lang-switcher-dropdown pointer-events-none invisible absolute right-0 top-full z-50 min-w-[160px] pt-2 opacity-0 transition-all duration-200">
|
|
292
|
+
<div class="pointer-events-auto max-h-64 overflow-y-auto rounded-xl border border-gray-100 bg-white py-1.5 shadow-xl shadow-slate-200/50">
|
|
293
|
+
{Object.entries(languages).map(([code, lang]) => (
|
|
294
|
+
<a
|
|
295
|
+
href={langSwitchUrl(code)}
|
|
296
|
+
class={`flex items-center gap-2.5 px-3.5 py-2 text-sm transition-colors hover:bg-slate-50 hover:no-underline ${
|
|
297
|
+
code === currentLang
|
|
298
|
+
? 'font-semibold text-slate-900'
|
|
299
|
+
: 'text-slate-500 hover:text-slate-800'
|
|
300
|
+
}`}
|
|
301
|
+
>
|
|
302
|
+
<span class="w-7 text-[11px] font-bold uppercase tracking-wider text-slate-400">{code}</span>
|
|
303
|
+
<span>{(lang as any).label}</span>
|
|
304
|
+
{code === currentLang && (
|
|
305
|
+
<svg class="ml-auto h-4 w-4" viewBox="0 0 20 20" fill="currentColor" style={{ color: primaryColor }}><path fill-rule="evenodd" d="M16.707 5.293a1 1 0 010 1.414l-8 8a1 1 0 01-1.414 0l-4-4a1 1 0 011.414-1.414L8 12.586l7.293-7.293a1 1 0 011.414 0z" clip-rule="evenodd"/></svg>
|
|
306
|
+
)}
|
|
307
|
+
</a>
|
|
308
|
+
))}
|
|
309
|
+
</div>
|
|
310
|
+
</div>
|
|
311
|
+
</div>
|
|
312
|
+
)}
|
|
313
|
+
<a
|
|
314
|
+
href={url('/contact')}
|
|
315
|
+
class="rounded-lg px-5 py-2.5 text-sm font-semibold text-white transition-all duration-200 hover:shadow-lg hover:no-underline"
|
|
316
|
+
style={{ backgroundColor: primaryColor }}
|
|
317
|
+
>
|
|
318
|
+
{t('nav.contact')}
|
|
319
|
+
</a>
|
|
320
|
+
</div>
|
|
321
|
+
</nav>
|
|
322
|
+
</header>
|
|
323
|
+
|
|
324
|
+
{/* ═══ Mobile Top Bar ═══ */}
|
|
325
|
+
<header class="sticky top-0 z-50 border-b border-gray-100 md:hidden" style={{ backdropFilter: 'blur(12px)', backgroundColor: 'rgba(255,255,255,0.95)' }}>
|
|
326
|
+
<div class="flex items-center justify-between px-5 py-3">
|
|
327
|
+
<a href={homeUrl} class="flex items-center gap-2 hover:no-underline">
|
|
328
|
+
{themeSettings.logo
|
|
329
|
+
? <img src={themeSettings.logo} alt={site.site_name} class="h-10" />
|
|
330
|
+
: <span class="text-lg font-bold tracking-tight text-slate-900">{site.site_name}</span>}
|
|
331
|
+
</a>
|
|
332
|
+
<button
|
|
333
|
+
id="mobile-menu-toggle"
|
|
334
|
+
class="flex h-10 w-10 items-center justify-center rounded-lg text-slate-600 transition-colors hover:bg-slate-100"
|
|
335
|
+
aria-label="Open menu"
|
|
336
|
+
>
|
|
337
|
+
<svg class="h-6 w-6" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round">
|
|
338
|
+
<line x1="3" y1="6" x2="21" y2="6" />
|
|
339
|
+
<line x1="3" y1="12" x2="21" y2="12" />
|
|
340
|
+
<line x1="3" y1="18" x2="21" y2="18" />
|
|
341
|
+
</svg>
|
|
342
|
+
</button>
|
|
343
|
+
</div>
|
|
344
|
+
</header>
|
|
345
|
+
|
|
346
|
+
{/* ═══ Mobile Full-screen Menu ═══ */}
|
|
347
|
+
<div id="mobile-menu" class="fixed inset-0 z-[60] hidden md:hidden" style={{ backgroundColor: 'rgba(0,0,0,0.4)' }}>
|
|
348
|
+
<div class="mobile-menu-panel ml-auto flex h-full w-[85vw] max-w-sm flex-col bg-white shadow-2xl" style={{ transform: 'translateX(100%)', transition: 'transform 0.3s cubic-bezier(0.32,0.72,0,1)' }}>
|
|
349
|
+
{/* Menu header */}
|
|
350
|
+
<div class="flex items-center justify-between border-b border-gray-100 px-5 py-3">
|
|
351
|
+
<a href={homeUrl} class="flex items-center gap-2 hover:no-underline">
|
|
352
|
+
{themeSettings.logo
|
|
353
|
+
? <img src={themeSettings.logo} alt={site.site_name} class="h-10" />
|
|
354
|
+
: <span class="text-lg font-bold tracking-tight text-slate-900">{site.site_name}</span>}
|
|
355
|
+
</a>
|
|
356
|
+
<button
|
|
357
|
+
id="mobile-menu-close"
|
|
358
|
+
class="flex h-10 w-10 items-center justify-center rounded-lg text-slate-400 transition-colors hover:bg-slate-100 hover:text-slate-600"
|
|
359
|
+
aria-label="Close menu"
|
|
360
|
+
>
|
|
361
|
+
<svg class="h-5 w-5" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round">
|
|
362
|
+
<line x1="18" y1="6" x2="6" y2="18" />
|
|
363
|
+
<line x1="6" y1="6" x2="18" y2="18" />
|
|
364
|
+
</svg>
|
|
365
|
+
</button>
|
|
366
|
+
</div>
|
|
367
|
+
|
|
368
|
+
{/* Scrollable nav */}
|
|
369
|
+
<nav class="flex-1 overflow-y-auto px-4 py-4">
|
|
370
|
+
{/* Services — accordion */}
|
|
371
|
+
<div class="mobile-accordion border-b border-gray-100">
|
|
372
|
+
<button class="mobile-accordion-trigger flex w-full items-center justify-between py-3.5 text-left text-[15px] font-semibold text-slate-800">
|
|
373
|
+
{t('nav.services')}
|
|
374
|
+
<svg class="mobile-accordion-arrow h-4 w-4 text-slate-400 transition-transform duration-200" viewBox="0 0 20 20" fill="currentColor"><path fill-rule="evenodd" d="M5.293 7.293a1 1 0 011.414 0L10 10.586l3.293-3.293a1 1 0 111.414 1.414l-4 4a1 1 0 01-1.414 0l-4-4a1 1 0 010-1.414z" clip-rule="evenodd"/></svg>
|
|
375
|
+
</button>
|
|
376
|
+
<div class="mobile-accordion-body hidden pb-3">
|
|
377
|
+
{megaServices.map((item) => (
|
|
378
|
+
<a href={url(item.href)} class="flex items-center gap-3 rounded-lg px-3 py-2.5 text-sm text-slate-600 transition-colors hover:bg-slate-50 hover:text-slate-900 hover:no-underline">
|
|
379
|
+
<div
|
|
380
|
+
class="flex h-8 w-8 shrink-0 items-center justify-center rounded-lg text-white"
|
|
381
|
+
style={{ backgroundColor: primaryColor }}
|
|
382
|
+
dangerouslySetInnerHTML={{ __html: iconSvg[item.icon] ?? '' }}
|
|
383
|
+
/>
|
|
384
|
+
<div>
|
|
385
|
+
<div class="font-medium">{t(item.labelKey)}</div>
|
|
386
|
+
<div class="text-xs text-slate-400">{t(item.descKey)}</div>
|
|
387
|
+
</div>
|
|
388
|
+
</a>
|
|
389
|
+
))}
|
|
390
|
+
<a href={url('/services')} class="mt-1 flex items-center gap-1 px-3 py-2 text-xs font-semibold uppercase tracking-wider hover:no-underline" style={{ color: primaryColor }}>
|
|
391
|
+
{t('nav.view_all_services')} <span>→</span>
|
|
392
|
+
</a>
|
|
393
|
+
</div>
|
|
394
|
+
</div>
|
|
395
|
+
|
|
396
|
+
{/* Industries — accordion */}
|
|
397
|
+
<div class="mobile-accordion border-b border-gray-100">
|
|
398
|
+
<button class="mobile-accordion-trigger flex w-full items-center justify-between py-3.5 text-left text-[15px] font-semibold text-slate-800">
|
|
399
|
+
{t('nav.industries')}
|
|
400
|
+
<svg class="mobile-accordion-arrow h-4 w-4 text-slate-400 transition-transform duration-200" viewBox="0 0 20 20" fill="currentColor"><path fill-rule="evenodd" d="M5.293 7.293a1 1 0 011.414 0L10 10.586l3.293-3.293a1 1 0 111.414 1.414l-4 4a1 1 0 01-1.414 0l-4-4a1 1 0 010-1.414z" clip-rule="evenodd"/></svg>
|
|
401
|
+
</button>
|
|
402
|
+
<div class="mobile-accordion-body hidden pb-3">
|
|
403
|
+
{megaIndustries.map((item) => (
|
|
404
|
+
<a href={url(item.href)} class="flex items-center gap-3 rounded-lg px-3 py-2.5 text-sm text-slate-600 transition-colors hover:bg-slate-50 hover:text-slate-900 hover:no-underline">
|
|
405
|
+
<div
|
|
406
|
+
class="flex h-8 w-8 shrink-0 items-center justify-center rounded-lg text-white"
|
|
407
|
+
style={{ backgroundColor: primaryColor }}
|
|
408
|
+
dangerouslySetInnerHTML={{ __html: iconSvg[item.icon] ?? '' }}
|
|
409
|
+
/>
|
|
410
|
+
<div>
|
|
411
|
+
<div class="font-medium">{t(item.labelKey)}</div>
|
|
412
|
+
<div class="text-xs text-slate-400">{t(item.descKey)}</div>
|
|
413
|
+
</div>
|
|
414
|
+
</a>
|
|
415
|
+
))}
|
|
416
|
+
<a href={url('/industries')} class="mt-1 flex items-center gap-1 px-3 py-2 text-xs font-semibold uppercase tracking-wider hover:no-underline" style={{ color: primaryColor }}>
|
|
417
|
+
{t('nav.view_all_industries')} <span>→</span>
|
|
418
|
+
</a>
|
|
419
|
+
</div>
|
|
420
|
+
</div>
|
|
421
|
+
|
|
422
|
+
{/* Case Studies — direct link */}
|
|
423
|
+
<a href={url('/case-studies')} class="flex items-center border-b border-gray-100 py-3.5 text-[15px] font-semibold text-slate-800 hover:text-slate-900 hover:no-underline">
|
|
424
|
+
{t('nav.case_studies')}
|
|
425
|
+
</a>
|
|
426
|
+
|
|
427
|
+
{/* Insights — accordion */}
|
|
428
|
+
<div class="mobile-accordion border-b border-gray-100">
|
|
429
|
+
<button class="mobile-accordion-trigger flex w-full items-center justify-between py-3.5 text-left text-[15px] font-semibold text-slate-800">
|
|
430
|
+
{t('nav.insights')}
|
|
431
|
+
<svg class="mobile-accordion-arrow h-4 w-4 text-slate-400 transition-transform duration-200" viewBox="0 0 20 20" fill="currentColor"><path fill-rule="evenodd" d="M5.293 7.293a1 1 0 011.414 0L10 10.586l3.293-3.293a1 1 0 111.414 1.414l-4 4a1 1 0 01-1.414 0l-4-4a1 1 0 010-1.414z" clip-rule="evenodd"/></svg>
|
|
432
|
+
</button>
|
|
433
|
+
<div class="mobile-accordion-body hidden pb-3">
|
|
434
|
+
{megaInsights.map((item) => (
|
|
435
|
+
<a href={url(item.href)} class="flex items-center gap-3 rounded-lg px-3 py-2.5 text-sm text-slate-600 transition-colors hover:bg-slate-50 hover:text-slate-900 hover:no-underline">
|
|
436
|
+
<div
|
|
437
|
+
class="flex h-8 w-8 shrink-0 items-center justify-center rounded-lg text-white"
|
|
438
|
+
style={{ backgroundColor: primaryColor }}
|
|
439
|
+
dangerouslySetInnerHTML={{ __html: iconSvg[item.icon] ?? '' }}
|
|
440
|
+
/>
|
|
441
|
+
<span class="font-medium">{t(item.labelKey)}</span>
|
|
442
|
+
</a>
|
|
443
|
+
))}
|
|
444
|
+
</div>
|
|
445
|
+
</div>
|
|
446
|
+
|
|
447
|
+
{/* About — direct link */}
|
|
448
|
+
<a href={url('/about')} class="flex items-center border-b border-gray-100 py-3.5 text-[15px] font-semibold text-slate-800 hover:text-slate-900 hover:no-underline">
|
|
449
|
+
{t('nav.about')}
|
|
450
|
+
</a>
|
|
451
|
+
|
|
452
|
+
{/* Careers — direct link */}
|
|
453
|
+
<a href={url('/careers')} class="flex items-center py-3.5 text-[15px] font-semibold text-slate-800 hover:text-slate-900 hover:no-underline">
|
|
454
|
+
{t('nav.careers')}
|
|
455
|
+
</a>
|
|
456
|
+
|
|
457
|
+
{/* Language switcher */}
|
|
458
|
+
{hasMultipleLangs && (
|
|
459
|
+
<div class="border-t border-gray-100 pt-4 mt-2">
|
|
460
|
+
<span class="mb-2 block text-xs font-semibold uppercase tracking-wider text-slate-400">
|
|
461
|
+
{t('lang.label')}
|
|
462
|
+
</span>
|
|
463
|
+
<div class="space-y-0.5">
|
|
464
|
+
{Object.entries(languages).map(([code, lang]) => (
|
|
465
|
+
<a
|
|
466
|
+
href={langSwitchUrl(code)}
|
|
467
|
+
class={`flex items-center gap-2.5 rounded-lg px-3 py-2.5 text-sm transition-colors hover:no-underline ${
|
|
468
|
+
code === currentLang
|
|
469
|
+
? 'bg-slate-100 font-semibold text-slate-900'
|
|
470
|
+
: 'text-slate-500 hover:bg-slate-50 hover:text-slate-800'
|
|
471
|
+
}`}
|
|
472
|
+
>
|
|
473
|
+
<span class="w-7 text-[11px] font-bold uppercase tracking-wider text-slate-400">{code}</span>
|
|
474
|
+
<span>{(lang as any).label}</span>
|
|
475
|
+
{code === currentLang && (
|
|
476
|
+
<svg class="ml-auto h-4 w-4" viewBox="0 0 20 20" fill="currentColor" style={{ color: primaryColor }}><path fill-rule="evenodd" d="M16.707 5.293a1 1 0 010 1.414l-8 8a1 1 0 01-1.414 0l-4-4a1 1 0 011.414-1.414L8 12.586l7.293-7.293a1 1 0 011.414 0z" clip-rule="evenodd"/></svg>
|
|
477
|
+
)}
|
|
478
|
+
</a>
|
|
479
|
+
))}
|
|
480
|
+
</div>
|
|
481
|
+
</div>
|
|
482
|
+
)}
|
|
483
|
+
</nav>
|
|
484
|
+
|
|
485
|
+
{/* CTA at bottom */}
|
|
486
|
+
<div class="border-t border-gray-100 px-5 py-5">
|
|
487
|
+
<a
|
|
488
|
+
href={url('/contact')}
|
|
489
|
+
class="flex w-full items-center justify-center rounded-xl px-5 py-3.5 text-sm font-semibold text-white hover:no-underline"
|
|
490
|
+
style={{ backgroundColor: primaryColor }}
|
|
491
|
+
>
|
|
492
|
+
{t('nav.contact')}
|
|
493
|
+
</a>
|
|
494
|
+
</div>
|
|
495
|
+
</div>
|
|
496
|
+
</div>
|
|
497
|
+
|
|
498
|
+
{/* Mobile menu script */}
|
|
499
|
+
<script dangerouslySetInnerHTML={{ __html: `
|
|
500
|
+
(function(){
|
|
501
|
+
var menu = document.getElementById('mobile-menu');
|
|
502
|
+
var panel = menu && menu.querySelector('.mobile-menu-panel');
|
|
503
|
+
var openBtn = document.getElementById('mobile-menu-toggle');
|
|
504
|
+
var closeBtn = document.getElementById('mobile-menu-close');
|
|
505
|
+
|
|
506
|
+
function openMenu() {
|
|
507
|
+
menu.classList.remove('hidden');
|
|
508
|
+
requestAnimationFrame(function(){
|
|
509
|
+
requestAnimationFrame(function(){
|
|
510
|
+
panel.style.transform = 'translateX(0)';
|
|
511
|
+
menu.style.backgroundColor = 'rgba(0,0,0,0.4)';
|
|
512
|
+
});
|
|
513
|
+
});
|
|
514
|
+
document.body.style.overflow = 'hidden';
|
|
515
|
+
}
|
|
516
|
+
|
|
517
|
+
function closeMenu() {
|
|
518
|
+
panel.style.transform = 'translateX(100%)';
|
|
519
|
+
menu.style.backgroundColor = 'rgba(0,0,0,0)';
|
|
520
|
+
setTimeout(function(){ menu.classList.add('hidden'); }, 300);
|
|
521
|
+
document.body.style.overflow = '';
|
|
522
|
+
}
|
|
523
|
+
|
|
524
|
+
if (openBtn) openBtn.addEventListener('click', openMenu);
|
|
525
|
+
if (closeBtn) closeBtn.addEventListener('click', closeMenu);
|
|
526
|
+
if (menu) menu.addEventListener('click', function(e) {
|
|
527
|
+
if (e.target === menu) closeMenu();
|
|
528
|
+
});
|
|
529
|
+
|
|
530
|
+
// Desktop lang switcher dropdown
|
|
531
|
+
var langSwitcher = document.querySelector('.lang-switcher');
|
|
532
|
+
var langTrigger = langSwitcher && langSwitcher.querySelector('.lang-switcher-trigger');
|
|
533
|
+
var langDropdown = langSwitcher && langSwitcher.querySelector('.lang-switcher-dropdown');
|
|
534
|
+
if (langTrigger && langDropdown) {
|
|
535
|
+
langTrigger.addEventListener('click', function(e) {
|
|
536
|
+
e.stopPropagation();
|
|
537
|
+
var isOpen = !langDropdown.classList.contains('invisible');
|
|
538
|
+
if (isOpen) {
|
|
539
|
+
langDropdown.classList.add('invisible','opacity-0','pointer-events-none');
|
|
540
|
+
} else {
|
|
541
|
+
langDropdown.classList.remove('invisible','opacity-0','pointer-events-none');
|
|
542
|
+
}
|
|
543
|
+
});
|
|
544
|
+
document.addEventListener('click', function() {
|
|
545
|
+
langDropdown.classList.add('invisible','opacity-0','pointer-events-none');
|
|
546
|
+
});
|
|
547
|
+
langSwitcher.addEventListener('click', function(e) { e.stopPropagation(); });
|
|
548
|
+
}
|
|
549
|
+
|
|
550
|
+
document.querySelectorAll('.mobile-accordion-trigger').forEach(function(btn) {
|
|
551
|
+
btn.addEventListener('click', function() {
|
|
552
|
+
var body = btn.nextElementSibling;
|
|
553
|
+
var arrow = btn.querySelector('.mobile-accordion-arrow');
|
|
554
|
+
var isOpen = !body.classList.contains('hidden');
|
|
555
|
+
document.querySelectorAll('.mobile-accordion-body').forEach(function(b) { b.classList.add('hidden'); });
|
|
556
|
+
document.querySelectorAll('.mobile-accordion-arrow').forEach(function(a) { a.style.transform = ''; });
|
|
557
|
+
if (!isOpen) {
|
|
558
|
+
body.classList.remove('hidden');
|
|
559
|
+
arrow.style.transform = 'rotate(180deg)';
|
|
560
|
+
}
|
|
561
|
+
});
|
|
562
|
+
});
|
|
563
|
+
})();
|
|
564
|
+
` }} />
|
|
565
|
+
|
|
566
|
+
<main class="flex-1 pb-20 md:pb-0">
|
|
567
|
+
{children}
|
|
568
|
+
</main>
|
|
569
|
+
|
|
570
|
+
{/* ═══ Mobile Bottom Navigation (app-style) ═══ */}
|
|
571
|
+
<nav class="mobile-bottom-nav fixed bottom-0 left-0 right-0 z-50 border-t border-gray-200 bg-white md:hidden" style={{ paddingBottom: 'env(safe-area-inset-bottom, 0px)' }}>
|
|
572
|
+
<div class="mx-auto flex max-w-lg items-center justify-around px-1 py-1.5">
|
|
573
|
+
<a href={homeUrl} class="mobile-nav-item flex flex-col items-center gap-0.5 rounded-xl px-2 py-1.5 text-slate-400 transition-colors duration-200 hover:no-underline" data-active="home">
|
|
574
|
+
<svg class="h-5 w-5" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="m3 9 9-7 9 7v11a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2z"/><polyline points="9 22 9 12 15 12 15 22"/></svg>
|
|
575
|
+
<span class="text-[10px] font-medium">{t('mobile.home')}</span>
|
|
576
|
+
</a>
|
|
577
|
+
<a href={url('/services')} class="mobile-nav-item flex flex-col items-center gap-0.5 rounded-xl px-2 py-1.5 text-slate-400 transition-colors duration-200 hover:no-underline">
|
|
578
|
+
<svg class="h-5 w-5" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><rect x="3" y="3" width="7" height="7"/><rect x="14" y="3" width="7" height="7"/><rect x="14" y="14" width="7" height="7"/><rect x="3" y="14" width="7" height="7"/></svg>
|
|
579
|
+
<span class="text-[10px] font-medium">{t('mobile.services')}</span>
|
|
580
|
+
</a>
|
|
581
|
+
<a href={url('/case-studies')} class="mobile-nav-item flex flex-col items-center gap-0.5 rounded-xl px-2 py-1.5 text-slate-400 transition-colors duration-200 hover:no-underline">
|
|
582
|
+
<svg class="h-5 w-5" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M2 3h6a4 4 0 0 1 4 4v14a3 3 0 0 0-3-3H2z"/><path d="M22 3h-6a4 4 0 0 0-4 4v14a3 3 0 0 1 3-3h7z"/></svg>
|
|
583
|
+
<span class="text-[10px] font-medium">{t('mobile.case_studies')}</span>
|
|
584
|
+
</a>
|
|
585
|
+
<a href={url('/articles')} class="mobile-nav-item flex flex-col items-center gap-0.5 rounded-xl px-2 py-1.5 text-slate-400 transition-colors duration-200 hover:no-underline">
|
|
586
|
+
<svg class="h-5 w-5" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><polygon points="12 2 15.09 8.26 22 9.27 17 14.14 18.18 21.02 12 17.77 5.82 21.02 7 14.14 2 9.27 8.91 8.26 12 2"/></svg>
|
|
587
|
+
<span class="text-[10px] font-medium">{t('mobile.articles')}</span>
|
|
588
|
+
</a>
|
|
589
|
+
<a href={url('/about')} class="mobile-nav-item flex flex-col items-center gap-0.5 rounded-xl px-2 py-1.5 text-slate-400 transition-colors duration-200 hover:no-underline">
|
|
590
|
+
<svg class="h-5 w-5" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><circle cx="12" cy="12" r="10"/><line x1="12" y1="16" x2="12" y2="12"/><line x1="12" y1="8" x2="12.01" y2="8"/></svg>
|
|
591
|
+
<span class="text-[10px] font-medium">{t('mobile.about')}</span>
|
|
592
|
+
</a>
|
|
593
|
+
<a
|
|
594
|
+
href={url('/contact')}
|
|
595
|
+
class="mobile-nav-item flex flex-col items-center gap-0.5 rounded-xl px-2 py-1.5 transition-colors duration-200 hover:no-underline"
|
|
596
|
+
style={{ color: primaryColor }}
|
|
597
|
+
>
|
|
598
|
+
<svg class="h-5 w-5" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2.5" stroke-linecap="round" stroke-linejoin="round"><path d="M22 16.92v3a2 2 0 0 1-2.18 2 19.79 19.79 0 0 1-8.63-3.07 19.5 19.5 0 0 1-6-6 19.79 19.79 0 0 1-3.07-8.67A2 2 0 0 1 4.11 2h3a2 2 0 0 1 2 1.72 12.84 12.84 0 0 0 .7 2.81 2 2 0 0 1-.45 2.11L8.09 9.91a16 16 0 0 0 6 6l1.27-1.27a2 2 0 0 1 2.11-.45 12.84 12.84 0 0 0 2.81.7A2 2 0 0 1 22 16.92z"/></svg>
|
|
599
|
+
<span class="text-[10px] font-bold">{t('mobile.contact')}</span>
|
|
600
|
+
</a>
|
|
601
|
+
</div>
|
|
602
|
+
</nav>
|
|
603
|
+
|
|
604
|
+
{/* ═══ Footer ═══ */}
|
|
605
|
+
<footer class="md:block" style={{ backgroundColor: navColor }}>
|
|
606
|
+
<div class="h-px" style={{ background: `linear-gradient(to right, transparent, ${primaryColor}, transparent)` }} />
|
|
607
|
+
<div class="mx-auto max-w-7xl px-6 py-20">
|
|
608
|
+
<div class="grid gap-12 sm:grid-cols-2 lg:grid-cols-4">
|
|
609
|
+
<div>
|
|
610
|
+
<div class="mb-5 text-lg font-bold text-white">{site.site_name}</div>
|
|
611
|
+
<p class="mb-6 text-sm leading-relaxed text-gray-400">
|
|
612
|
+
{themeSettings.footer_text ?? 'Engineering technology that moves enterprises forward.'}
|
|
613
|
+
</p>
|
|
614
|
+
<div class="flex gap-5 text-sm text-gray-500">
|
|
615
|
+
<a href="#" class="transition-colors duration-200 hover:text-white hover:no-underline">LinkedIn</a>
|
|
616
|
+
<a href="#" class="transition-colors duration-200 hover:text-white hover:no-underline">X</a>
|
|
617
|
+
<a href="#" class="transition-colors duration-200 hover:text-white hover:no-underline">GitHub</a>
|
|
618
|
+
</div>
|
|
619
|
+
</div>
|
|
620
|
+
|
|
621
|
+
<div>
|
|
622
|
+
<h4 class="mb-5 text-xs font-semibold uppercase tracking-[0.15em] text-gray-400">{t('footer.services')}</h4>
|
|
623
|
+
<ul class="space-y-3">
|
|
624
|
+
{footerServices.map((link) => (
|
|
625
|
+
<li>
|
|
626
|
+
<a href={url(link.href)} class="text-sm text-gray-500 transition-colors duration-200 hover:text-white hover:no-underline">
|
|
627
|
+
{t(link.labelKey)}
|
|
628
|
+
</a>
|
|
629
|
+
</li>
|
|
630
|
+
))}
|
|
631
|
+
</ul>
|
|
632
|
+
</div>
|
|
633
|
+
|
|
634
|
+
<div>
|
|
635
|
+
<h4 class="mb-5 text-xs font-semibold uppercase tracking-[0.15em] text-gray-400">{t('footer.company')}</h4>
|
|
636
|
+
<ul class="space-y-3">
|
|
637
|
+
{footerCompany.map((link) => (
|
|
638
|
+
<li>
|
|
639
|
+
<a href={url(link.href)} class="text-sm text-gray-500 transition-colors duration-200 hover:text-white hover:no-underline">
|
|
640
|
+
{t(link.labelKey)}
|
|
641
|
+
</a>
|
|
642
|
+
</li>
|
|
643
|
+
))}
|
|
644
|
+
</ul>
|
|
645
|
+
</div>
|
|
646
|
+
|
|
647
|
+
<div>
|
|
648
|
+
<h4 class="mb-5 text-xs font-semibold uppercase tracking-[0.15em] text-gray-400">{t('footer.resources')}</h4>
|
|
649
|
+
<ul class="space-y-3">
|
|
650
|
+
{footerResources.map((link) => (
|
|
651
|
+
<li>
|
|
652
|
+
<a href={url(link.href)} class="text-sm text-gray-500 transition-colors duration-200 hover:text-white hover:no-underline">
|
|
653
|
+
{t(link.labelKey)}
|
|
654
|
+
</a>
|
|
655
|
+
</li>
|
|
656
|
+
))}
|
|
657
|
+
</ul>
|
|
658
|
+
</div>
|
|
659
|
+
</div>
|
|
660
|
+
|
|
661
|
+
<div class="mt-16 border-t border-gray-800/50 pt-8 text-center text-xs text-gray-600">
|
|
662
|
+
<p>© {new Date().getFullYear()} {site.site_name}. {t('footer.rights')}</p>
|
|
663
|
+
<p class="mt-3 text-gray-700/40">{t('footer.crafted_with')} <a href="https://barkajs.dev" class="hover:text-gray-500 hover:no-underline" style="color: inherit">Barka</a></p>
|
|
664
|
+
</div>
|
|
665
|
+
</div>
|
|
666
|
+
</footer>
|
|
667
|
+
</body>
|
|
668
|
+
</html>
|
|
669
|
+
);
|
|
670
|
+
};
|
|
671
|
+
|
|
672
|
+
export default Base;
|