@cimplify/sdk 0.44.34 → 0.45.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/README.md +21 -16
- package/dist/styles.css +1 -1
- package/package.json +5 -9
- package/dist/cli/commands/deploy.mjs +0 -717
- package/dist/cli/commands/dev.mjs +0 -479
- package/dist/cli/commands/domains.mjs +0 -769
- package/dist/cli/commands/env.mjs +0 -705
- package/dist/cli/commands/link.mjs +0 -378
- package/dist/cli/commands/login.mjs +0 -584
- package/dist/cli/commands/logout.mjs +0 -75
- package/dist/cli/commands/logs.mjs +0 -432
- package/dist/cli/commands/projects.mjs +0 -473
- package/dist/cli/commands/repo.mjs +0 -584
- package/dist/cli/commands/rollback.mjs +0 -553
- package/dist/cli/commands/status.mjs +0 -450
- package/dist/cli/commands/unlink.mjs +0 -79
- package/dist/cli/commands/whoami.mjs +0 -285
- package/dist/cli.js +0 -184
- package/dist/dispatcher.mjs +0 -360
- package/registry/booking-page.json +0 -18
- package/registry/bookings-page.json +0 -17
- package/registry/service-card.json +0 -16
- package/registry/service-grid.json +0 -16
- package/templates/storefront-bakery/.claude/skills/cimplify-storefront/SKILL.md +0 -145
- package/templates/storefront-bakery/.cursor/rules/cimplify-storefront.mdc +0 -25
- package/templates/storefront-bakery/.env.example +0 -16
- package/templates/storefront-bakery/AGENTS.md +0 -120
- package/templates/storefront-bakery/CLAUDE.md +0 -22
- package/templates/storefront-bakery/README.md +0 -73
- package/templates/storefront-bakery/__tests__/brand.test.ts +0 -4
- package/templates/storefront-bakery/__tests__/cart-flow.test.ts +0 -4
- package/templates/storefront-bakery/__tests__/contract.test.ts +0 -4
- package/templates/storefront-bakery/app/about/page.tsx +0 -38
- package/templates/storefront-bakery/app/accessibility/page.tsx +0 -11
- package/templates/storefront-bakery/app/account/addresses/page.tsx +0 -21
- package/templates/storefront-bakery/app/account/orders/page.tsx +0 -21
- package/templates/storefront-bakery/app/account/page.tsx +0 -22
- package/templates/storefront-bakery/app/account/settings/page.tsx +0 -21
- package/templates/storefront-bakery/app/cart/page.tsx +0 -9
- package/templates/storefront-bakery/app/categories/[slug]/listing-client.tsx +0 -19
- package/templates/storefront-bakery/app/categories/[slug]/page.tsx +0 -118
- package/templates/storefront-bakery/app/checkout/page.tsx +0 -17
- package/templates/storefront-bakery/app/collections/[slug]/listing-client.tsx +0 -20
- package/templates/storefront-bakery/app/collections/[slug]/page.tsx +0 -118
- package/templates/storefront-bakery/app/contact/contact-form.tsx +0 -109
- package/templates/storefront-bakery/app/contact/page.tsx +0 -54
- package/templates/storefront-bakery/app/error.tsx +0 -60
- package/templates/storefront-bakery/app/faq/page.tsx +0 -46
- package/templates/storefront-bakery/app/globals.css +0 -47
- package/templates/storefront-bakery/app/layout.tsx +0 -82
- package/templates/storefront-bakery/app/llms.txt/route.ts +0 -94
- package/templates/storefront-bakery/app/login/page.tsx +0 -17
- package/templates/storefront-bakery/app/not-found.tsx +0 -39
- package/templates/storefront-bakery/app/opensearch.xml/route.ts +0 -37
- package/templates/storefront-bakery/app/orders/[id]/page.tsx +0 -21
- package/templates/storefront-bakery/app/page.tsx +0 -97
- package/templates/storefront-bakery/app/privacy/page.tsx +0 -44
- package/templates/storefront-bakery/app/returns/page.tsx +0 -11
- package/templates/storefront-bakery/app/robots.ts +0 -18
- package/templates/storefront-bakery/app/search/page.tsx +0 -38
- package/templates/storefront-bakery/app/search/search-client.tsx +0 -7
- package/templates/storefront-bakery/app/shipping/page.tsx +0 -16
- package/templates/storefront-bakery/app/shop/page.tsx +0 -31
- package/templates/storefront-bakery/app/shop/shop-client.tsx +0 -27
- package/templates/storefront-bakery/app/signup/page.tsx +0 -17
- package/templates/storefront-bakery/app/sitemap-page/page.tsx +0 -167
- package/templates/storefront-bakery/app/sitemap.ts +0 -62
- package/templates/storefront-bakery/app/terms/page.tsx +0 -44
- package/templates/storefront-bakery/app/track-order/page.tsx +0 -24
- package/templates/storefront-bakery/app/track-order/track-order-form.tsx +0 -69
- package/templates/storefront-bakery/components/account-iframe.tsx +0 -13
- package/templates/storefront-bakery/components/cart-drawer.tsx +0 -14
- package/templates/storefront-bakery/components/cart-pill.tsx +0 -36
- package/templates/storefront-bakery/components/category-grid.tsx +0 -28
- package/templates/storefront-bakery/components/collection-strip.tsx +0 -45
- package/templates/storefront-bakery/components/footer.tsx +0 -148
- package/templates/storefront-bakery/components/header.tsx +0 -43
- package/templates/storefront-bakery/components/hero.tsx +0 -25
- package/templates/storefront-bakery/components/nav-link.tsx +0 -20
- package/templates/storefront-bakery/components/policy-page.tsx +0 -49
- package/templates/storefront-bakery/components/product-modal.tsx +0 -104
- package/templates/storefront-bakery/components/providers.tsx +0 -35
- package/templates/storefront-bakery/components/store-product-card.tsx +0 -87
- package/templates/storefront-bakery/lib/brand.ts +0 -570
- package/templates/storefront-bakery/lib/cart.ts +0 -12
- package/templates/storefront-bakery/next.config.ts +0 -42
- package/templates/storefront-bakery/package.json +0 -35
- package/templates/storefront-bakery/postcss.config.mjs +0 -7
- package/templates/storefront-bakery/tsconfig.json +0 -23
- package/templates/storefront-bakery/vitest.config.ts +0 -9
- package/templates/storefront-fashion/.claude/skills/cimplify-storefront/SKILL.md +0 -145
- package/templates/storefront-fashion/.cursor/rules/cimplify-storefront.mdc +0 -25
- package/templates/storefront-fashion/.env.example +0 -16
- package/templates/storefront-fashion/AGENTS.md +0 -126
- package/templates/storefront-fashion/CLAUDE.md +0 -22
- package/templates/storefront-fashion/README.md +0 -77
- package/templates/storefront-fashion/__tests__/brand.test.ts +0 -4
- package/templates/storefront-fashion/__tests__/cart-flow.test.ts +0 -55
- package/templates/storefront-fashion/__tests__/contract.test.ts +0 -4
- package/templates/storefront-fashion/app/about/page.tsx +0 -41
- package/templates/storefront-fashion/app/accessibility/page.tsx +0 -11
- package/templates/storefront-fashion/app/account/addresses/page.tsx +0 -21
- package/templates/storefront-fashion/app/account/orders/page.tsx +0 -21
- package/templates/storefront-fashion/app/account/page.tsx +0 -22
- package/templates/storefront-fashion/app/account/settings/page.tsx +0 -21
- package/templates/storefront-fashion/app/cart/page.tsx +0 -9
- package/templates/storefront-fashion/app/categories/[slug]/listing-client.tsx +0 -19
- package/templates/storefront-fashion/app/categories/[slug]/page.tsx +0 -130
- package/templates/storefront-fashion/app/checkout/page.tsx +0 -17
- package/templates/storefront-fashion/app/collections/[slug]/listing-client.tsx +0 -20
- package/templates/storefront-fashion/app/collections/[slug]/page.tsx +0 -130
- package/templates/storefront-fashion/app/contact/contact-form.tsx +0 -109
- package/templates/storefront-fashion/app/contact/page.tsx +0 -54
- package/templates/storefront-fashion/app/error.tsx +0 -61
- package/templates/storefront-fashion/app/faq/page.tsx +0 -46
- package/templates/storefront-fashion/app/globals.css +0 -46
- package/templates/storefront-fashion/app/layout.tsx +0 -78
- package/templates/storefront-fashion/app/llms.txt/route.ts +0 -94
- package/templates/storefront-fashion/app/login/page.tsx +0 -17
- package/templates/storefront-fashion/app/lookbook/page.tsx +0 -132
- package/templates/storefront-fashion/app/not-found.tsx +0 -39
- package/templates/storefront-fashion/app/opensearch.xml/route.ts +0 -37
- package/templates/storefront-fashion/app/orders/[id]/page.tsx +0 -24
- package/templates/storefront-fashion/app/page.tsx +0 -183
- package/templates/storefront-fashion/app/privacy/page.tsx +0 -44
- package/templates/storefront-fashion/app/products/[slug]/page.tsx +0 -165
- package/templates/storefront-fashion/app/products/[slug]/product-detail.tsx +0 -70
- package/templates/storefront-fashion/app/returns/page.tsx +0 -11
- package/templates/storefront-fashion/app/robots.ts +0 -18
- package/templates/storefront-fashion/app/search/page.tsx +0 -38
- package/templates/storefront-fashion/app/search/search-client.tsx +0 -7
- package/templates/storefront-fashion/app/shipping/page.tsx +0 -16
- package/templates/storefront-fashion/app/shop/page.tsx +0 -63
- package/templates/storefront-fashion/app/shop/shop-client.tsx +0 -32
- package/templates/storefront-fashion/app/signup/page.tsx +0 -17
- package/templates/storefront-fashion/app/sitemap-page/page.tsx +0 -167
- package/templates/storefront-fashion/app/sitemap.ts +0 -59
- package/templates/storefront-fashion/app/size-guide/page.tsx +0 -155
- package/templates/storefront-fashion/app/terms/page.tsx +0 -44
- package/templates/storefront-fashion/app/track-order/page.tsx +0 -24
- package/templates/storefront-fashion/app/track-order/track-order-form.tsx +0 -69
- package/templates/storefront-fashion/components/account-iframe.tsx +0 -13
- package/templates/storefront-fashion/components/brand-marquee.tsx +0 -27
- package/templates/storefront-fashion/components/cart-drawer.tsx +0 -14
- package/templates/storefront-fashion/components/cart-pill.tsx +0 -36
- package/templates/storefront-fashion/components/category-grid.tsx +0 -28
- package/templates/storefront-fashion/components/category-tiles.tsx +0 -104
- package/templates/storefront-fashion/components/collection-strip.tsx +0 -45
- package/templates/storefront-fashion/components/feature-hero.tsx +0 -82
- package/templates/storefront-fashion/components/footer.tsx +0 -153
- package/templates/storefront-fashion/components/header.tsx +0 -43
- package/templates/storefront-fashion/components/hero.tsx +0 -28
- package/templates/storefront-fashion/components/nav-link.tsx +0 -20
- package/templates/storefront-fashion/components/newsletter.tsx +0 -50
- package/templates/storefront-fashion/components/policy-page.tsx +0 -49
- package/templates/storefront-fashion/components/promo-banner.tsx +0 -41
- package/templates/storefront-fashion/components/providers.tsx +0 -35
- package/templates/storefront-fashion/components/section-heading.tsx +0 -37
- package/templates/storefront-fashion/components/store-product-card.tsx +0 -87
- package/templates/storefront-fashion/components/trade-in-cta.tsx +0 -54
- package/templates/storefront-fashion/components/trust-bar.tsx +0 -66
- package/templates/storefront-fashion/e2e/visual.spec.ts +0 -52
- package/templates/storefront-fashion/lib/brand.ts +0 -518
- package/templates/storefront-fashion/lib/cart.ts +0 -12
- package/templates/storefront-fashion/next.config.ts +0 -42
- package/templates/storefront-fashion/package.json +0 -38
- package/templates/storefront-fashion/playwright.config.ts +0 -48
- package/templates/storefront-fashion/postcss.config.mjs +0 -7
- package/templates/storefront-fashion/tsconfig.json +0 -23
- package/templates/storefront-fashion/vitest.config.ts +0 -9
- package/templates/storefront-grocery/.claude/skills/cimplify-storefront/SKILL.md +0 -145
- package/templates/storefront-grocery/.cursor/rules/cimplify-storefront.mdc +0 -25
- package/templates/storefront-grocery/.env.example +0 -16
- package/templates/storefront-grocery/AGENTS.md +0 -96
- package/templates/storefront-grocery/CLAUDE.md +0 -22
- package/templates/storefront-grocery/README.md +0 -73
- package/templates/storefront-grocery/__tests__/brand.test.ts +0 -4
- package/templates/storefront-grocery/__tests__/cart-flow.test.ts +0 -4
- package/templates/storefront-grocery/__tests__/contract.test.ts +0 -4
- package/templates/storefront-grocery/app/about/page.tsx +0 -38
- package/templates/storefront-grocery/app/accessibility/page.tsx +0 -11
- package/templates/storefront-grocery/app/account/addresses/page.tsx +0 -21
- package/templates/storefront-grocery/app/account/orders/page.tsx +0 -21
- package/templates/storefront-grocery/app/account/page.tsx +0 -22
- package/templates/storefront-grocery/app/account/settings/page.tsx +0 -21
- package/templates/storefront-grocery/app/cart/page.tsx +0 -9
- package/templates/storefront-grocery/app/categories/[slug]/listing-client.tsx +0 -19
- package/templates/storefront-grocery/app/categories/[slug]/page.tsx +0 -118
- package/templates/storefront-grocery/app/checkout/page.tsx +0 -17
- package/templates/storefront-grocery/app/collections/[slug]/listing-client.tsx +0 -20
- package/templates/storefront-grocery/app/collections/[slug]/page.tsx +0 -118
- package/templates/storefront-grocery/app/contact/contact-form.tsx +0 -109
- package/templates/storefront-grocery/app/contact/page.tsx +0 -54
- package/templates/storefront-grocery/app/error.tsx +0 -60
- package/templates/storefront-grocery/app/faq/page.tsx +0 -46
- package/templates/storefront-grocery/app/globals.css +0 -45
- package/templates/storefront-grocery/app/layout.tsx +0 -77
- package/templates/storefront-grocery/app/llms.txt/route.ts +0 -94
- package/templates/storefront-grocery/app/login/page.tsx +0 -17
- package/templates/storefront-grocery/app/not-found.tsx +0 -39
- package/templates/storefront-grocery/app/opensearch.xml/route.ts +0 -37
- package/templates/storefront-grocery/app/orders/[id]/page.tsx +0 -21
- package/templates/storefront-grocery/app/page.tsx +0 -97
- package/templates/storefront-grocery/app/privacy/page.tsx +0 -44
- package/templates/storefront-grocery/app/returns/page.tsx +0 -11
- package/templates/storefront-grocery/app/robots.ts +0 -18
- package/templates/storefront-grocery/app/search/page.tsx +0 -38
- package/templates/storefront-grocery/app/search/search-client.tsx +0 -7
- package/templates/storefront-grocery/app/shipping/page.tsx +0 -16
- package/templates/storefront-grocery/app/shop/page.tsx +0 -31
- package/templates/storefront-grocery/app/shop/shop-client.tsx +0 -27
- package/templates/storefront-grocery/app/signup/page.tsx +0 -17
- package/templates/storefront-grocery/app/sitemap-page/page.tsx +0 -167
- package/templates/storefront-grocery/app/sitemap.ts +0 -62
- package/templates/storefront-grocery/app/terms/page.tsx +0 -44
- package/templates/storefront-grocery/app/track-order/page.tsx +0 -24
- package/templates/storefront-grocery/app/track-order/track-order-form.tsx +0 -69
- package/templates/storefront-grocery/components/account-iframe.tsx +0 -13
- package/templates/storefront-grocery/components/cart-drawer.tsx +0 -14
- package/templates/storefront-grocery/components/cart-pill.tsx +0 -36
- package/templates/storefront-grocery/components/category-grid.tsx +0 -28
- package/templates/storefront-grocery/components/collection-strip.tsx +0 -45
- package/templates/storefront-grocery/components/footer.tsx +0 -148
- package/templates/storefront-grocery/components/header.tsx +0 -43
- package/templates/storefront-grocery/components/hero.tsx +0 -25
- package/templates/storefront-grocery/components/nav-link.tsx +0 -20
- package/templates/storefront-grocery/components/policy-page.tsx +0 -49
- package/templates/storefront-grocery/components/product-modal.tsx +0 -104
- package/templates/storefront-grocery/components/providers.tsx +0 -35
- package/templates/storefront-grocery/components/store-product-card.tsx +0 -87
- package/templates/storefront-grocery/lib/brand.ts +0 -375
- package/templates/storefront-grocery/lib/cart.ts +0 -12
- package/templates/storefront-grocery/next.config.ts +0 -42
- package/templates/storefront-grocery/package.json +0 -35
- package/templates/storefront-grocery/postcss.config.mjs +0 -7
- package/templates/storefront-grocery/tsconfig.json +0 -23
- package/templates/storefront-grocery/vitest.config.ts +0 -9
- package/templates/storefront-restaurant/.claude/skills/cimplify-storefront/SKILL.md +0 -145
- package/templates/storefront-restaurant/.cursor/rules/cimplify-storefront.mdc +0 -25
- package/templates/storefront-restaurant/.env.example +0 -16
- package/templates/storefront-restaurant/AGENTS.md +0 -102
- package/templates/storefront-restaurant/CLAUDE.md +0 -22
- package/templates/storefront-restaurant/README.md +0 -73
- package/templates/storefront-restaurant/__tests__/brand.test.ts +0 -4
- package/templates/storefront-restaurant/__tests__/cart-flow.test.ts +0 -4
- package/templates/storefront-restaurant/__tests__/contract.test.ts +0 -4
- package/templates/storefront-restaurant/app/about/page.tsx +0 -38
- package/templates/storefront-restaurant/app/accessibility/page.tsx +0 -11
- package/templates/storefront-restaurant/app/account/addresses/page.tsx +0 -21
- package/templates/storefront-restaurant/app/account/orders/page.tsx +0 -21
- package/templates/storefront-restaurant/app/account/page.tsx +0 -22
- package/templates/storefront-restaurant/app/account/settings/page.tsx +0 -21
- package/templates/storefront-restaurant/app/cart/page.tsx +0 -9
- package/templates/storefront-restaurant/app/categories/[slug]/listing-client.tsx +0 -19
- package/templates/storefront-restaurant/app/categories/[slug]/page.tsx +0 -118
- package/templates/storefront-restaurant/app/checkout/page.tsx +0 -17
- package/templates/storefront-restaurant/app/collections/[slug]/listing-client.tsx +0 -20
- package/templates/storefront-restaurant/app/collections/[slug]/page.tsx +0 -118
- package/templates/storefront-restaurant/app/contact/contact-form.tsx +0 -109
- package/templates/storefront-restaurant/app/contact/page.tsx +0 -54
- package/templates/storefront-restaurant/app/error.tsx +0 -60
- package/templates/storefront-restaurant/app/faq/page.tsx +0 -46
- package/templates/storefront-restaurant/app/globals.css +0 -44
- package/templates/storefront-restaurant/app/layout.tsx +0 -82
- package/templates/storefront-restaurant/app/llms.txt/route.ts +0 -94
- package/templates/storefront-restaurant/app/login/page.tsx +0 -17
- package/templates/storefront-restaurant/app/not-found.tsx +0 -39
- package/templates/storefront-restaurant/app/opensearch.xml/route.ts +0 -37
- package/templates/storefront-restaurant/app/orders/[id]/page.tsx +0 -21
- package/templates/storefront-restaurant/app/page.tsx +0 -97
- package/templates/storefront-restaurant/app/privacy/page.tsx +0 -44
- package/templates/storefront-restaurant/app/reservations/page.tsx +0 -66
- package/templates/storefront-restaurant/app/reservations/reservations-client.tsx +0 -234
- package/templates/storefront-restaurant/app/returns/page.tsx +0 -11
- package/templates/storefront-restaurant/app/robots.ts +0 -18
- package/templates/storefront-restaurant/app/search/page.tsx +0 -38
- package/templates/storefront-restaurant/app/search/search-client.tsx +0 -7
- package/templates/storefront-restaurant/app/shipping/page.tsx +0 -16
- package/templates/storefront-restaurant/app/shop/page.tsx +0 -31
- package/templates/storefront-restaurant/app/shop/shop-client.tsx +0 -27
- package/templates/storefront-restaurant/app/signup/page.tsx +0 -17
- package/templates/storefront-restaurant/app/sitemap-page/page.tsx +0 -167
- package/templates/storefront-restaurant/app/sitemap.ts +0 -62
- package/templates/storefront-restaurant/app/terms/page.tsx +0 -44
- package/templates/storefront-restaurant/app/track-order/page.tsx +0 -24
- package/templates/storefront-restaurant/app/track-order/track-order-form.tsx +0 -69
- package/templates/storefront-restaurant/components/account-iframe.tsx +0 -13
- package/templates/storefront-restaurant/components/cart-drawer.tsx +0 -14
- package/templates/storefront-restaurant/components/cart-pill.tsx +0 -36
- package/templates/storefront-restaurant/components/category-grid.tsx +0 -28
- package/templates/storefront-restaurant/components/collection-strip.tsx +0 -45
- package/templates/storefront-restaurant/components/footer.tsx +0 -148
- package/templates/storefront-restaurant/components/header.tsx +0 -43
- package/templates/storefront-restaurant/components/hero.tsx +0 -25
- package/templates/storefront-restaurant/components/nav-link.tsx +0 -20
- package/templates/storefront-restaurant/components/policy-page.tsx +0 -49
- package/templates/storefront-restaurant/components/product-modal.tsx +0 -104
- package/templates/storefront-restaurant/components/providers.tsx +0 -35
- package/templates/storefront-restaurant/components/store-product-card.tsx +0 -87
- package/templates/storefront-restaurant/lib/brand.ts +0 -377
- package/templates/storefront-restaurant/lib/cart.ts +0 -12
- package/templates/storefront-restaurant/next.config.ts +0 -42
- package/templates/storefront-restaurant/package.json +0 -35
- package/templates/storefront-restaurant/postcss.config.mjs +0 -7
- package/templates/storefront-restaurant/tsconfig.json +0 -23
- package/templates/storefront-restaurant/vitest.config.ts +0 -9
- package/templates/storefront-retail/.claude/skills/cimplify-storefront/SKILL.md +0 -145
- package/templates/storefront-retail/.cursor/rules/cimplify-storefront.mdc +0 -25
- package/templates/storefront-retail/.env.example +0 -16
- package/templates/storefront-retail/AGENTS.md +0 -117
- package/templates/storefront-retail/CLAUDE.md +0 -22
- package/templates/storefront-retail/README.md +0 -77
- package/templates/storefront-retail/__tests__/brand.test.ts +0 -4
- package/templates/storefront-retail/__tests__/cart-flow.test.ts +0 -4
- package/templates/storefront-retail/__tests__/contract.test.ts +0 -4
- package/templates/storefront-retail/app/about/page.tsx +0 -41
- package/templates/storefront-retail/app/accessibility/page.tsx +0 -11
- package/templates/storefront-retail/app/account/addresses/page.tsx +0 -21
- package/templates/storefront-retail/app/account/orders/page.tsx +0 -21
- package/templates/storefront-retail/app/account/page.tsx +0 -22
- package/templates/storefront-retail/app/account/settings/page.tsx +0 -21
- package/templates/storefront-retail/app/cart/page.tsx +0 -9
- package/templates/storefront-retail/app/categories/[slug]/listing-client.tsx +0 -19
- package/templates/storefront-retail/app/categories/[slug]/page.tsx +0 -130
- package/templates/storefront-retail/app/checkout/page.tsx +0 -17
- package/templates/storefront-retail/app/collections/[slug]/listing-client.tsx +0 -20
- package/templates/storefront-retail/app/collections/[slug]/page.tsx +0 -130
- package/templates/storefront-retail/app/contact/contact-form.tsx +0 -109
- package/templates/storefront-retail/app/contact/page.tsx +0 -54
- package/templates/storefront-retail/app/error.tsx +0 -61
- package/templates/storefront-retail/app/faq/page.tsx +0 -46
- package/templates/storefront-retail/app/globals.css +0 -47
- package/templates/storefront-retail/app/layout.tsx +0 -77
- package/templates/storefront-retail/app/llms.txt/route.ts +0 -94
- package/templates/storefront-retail/app/login/page.tsx +0 -17
- package/templates/storefront-retail/app/not-found.tsx +0 -39
- package/templates/storefront-retail/app/opensearch.xml/route.ts +0 -37
- package/templates/storefront-retail/app/orders/[id]/page.tsx +0 -24
- package/templates/storefront-retail/app/page.tsx +0 -182
- package/templates/storefront-retail/app/privacy/page.tsx +0 -44
- package/templates/storefront-retail/app/products/[slug]/page.tsx +0 -165
- package/templates/storefront-retail/app/products/[slug]/product-detail.tsx +0 -70
- package/templates/storefront-retail/app/returns/page.tsx +0 -11
- package/templates/storefront-retail/app/robots.ts +0 -18
- package/templates/storefront-retail/app/search/page.tsx +0 -38
- package/templates/storefront-retail/app/search/search-client.tsx +0 -7
- package/templates/storefront-retail/app/shipping/page.tsx +0 -16
- package/templates/storefront-retail/app/shop/page.tsx +0 -63
- package/templates/storefront-retail/app/shop/shop-client.tsx +0 -32
- package/templates/storefront-retail/app/signup/page.tsx +0 -17
- package/templates/storefront-retail/app/sitemap-page/page.tsx +0 -167
- package/templates/storefront-retail/app/sitemap.ts +0 -59
- package/templates/storefront-retail/app/terms/page.tsx +0 -44
- package/templates/storefront-retail/app/track-order/page.tsx +0 -24
- package/templates/storefront-retail/app/track-order/track-order-form.tsx +0 -69
- package/templates/storefront-retail/components/account-iframe.tsx +0 -13
- package/templates/storefront-retail/components/brand-marquee.tsx +0 -27
- package/templates/storefront-retail/components/cart-drawer.tsx +0 -14
- package/templates/storefront-retail/components/cart-pill.tsx +0 -36
- package/templates/storefront-retail/components/category-grid.tsx +0 -28
- package/templates/storefront-retail/components/category-tiles.tsx +0 -104
- package/templates/storefront-retail/components/collection-strip.tsx +0 -45
- package/templates/storefront-retail/components/feature-hero.tsx +0 -84
- package/templates/storefront-retail/components/footer.tsx +0 -153
- package/templates/storefront-retail/components/header.tsx +0 -45
- package/templates/storefront-retail/components/hero.tsx +0 -28
- package/templates/storefront-retail/components/nav-link.tsx +0 -20
- package/templates/storefront-retail/components/newsletter.tsx +0 -50
- package/templates/storefront-retail/components/policy-page.tsx +0 -49
- package/templates/storefront-retail/components/promo-banner.tsx +0 -41
- package/templates/storefront-retail/components/providers.tsx +0 -35
- package/templates/storefront-retail/components/section-heading.tsx +0 -37
- package/templates/storefront-retail/components/store-product-card.tsx +0 -87
- package/templates/storefront-retail/components/trade-in-cta.tsx +0 -54
- package/templates/storefront-retail/components/trust-bar.tsx +0 -66
- package/templates/storefront-retail/lib/brand.ts +0 -664
- package/templates/storefront-retail/lib/cart.ts +0 -12
- package/templates/storefront-retail/next.config.ts +0 -42
- package/templates/storefront-retail/package.json +0 -35
- package/templates/storefront-retail/postcss.config.mjs +0 -7
- package/templates/storefront-retail/tsconfig.json +0 -23
- package/templates/storefront-retail/vitest.config.ts +0 -9
- package/templates/storefront-services/.claude/skills/cimplify-storefront/SKILL.md +0 -145
- package/templates/storefront-services/.cursor/rules/cimplify-storefront.mdc +0 -25
- package/templates/storefront-services/.env.example +0 -16
- package/templates/storefront-services/AGENTS.md +0 -101
- package/templates/storefront-services/CLAUDE.md +0 -22
- package/templates/storefront-services/README.md +0 -73
- package/templates/storefront-services/__tests__/brand.test.ts +0 -4
- package/templates/storefront-services/__tests__/cart-flow.test.ts +0 -4
- package/templates/storefront-services/__tests__/contract.test.ts +0 -4
- package/templates/storefront-services/app/about/page.tsx +0 -38
- package/templates/storefront-services/app/accessibility/page.tsx +0 -11
- package/templates/storefront-services/app/account/addresses/page.tsx +0 -21
- package/templates/storefront-services/app/account/orders/page.tsx +0 -21
- package/templates/storefront-services/app/account/page.tsx +0 -22
- package/templates/storefront-services/app/account/settings/page.tsx +0 -21
- package/templates/storefront-services/app/book/book-client.tsx +0 -195
- package/templates/storefront-services/app/book/page.tsx +0 -65
- package/templates/storefront-services/app/cart/page.tsx +0 -9
- package/templates/storefront-services/app/categories/[slug]/listing-client.tsx +0 -19
- package/templates/storefront-services/app/categories/[slug]/page.tsx +0 -118
- package/templates/storefront-services/app/checkout/page.tsx +0 -17
- package/templates/storefront-services/app/collections/[slug]/listing-client.tsx +0 -20
- package/templates/storefront-services/app/collections/[slug]/page.tsx +0 -118
- package/templates/storefront-services/app/contact/contact-form.tsx +0 -109
- package/templates/storefront-services/app/contact/page.tsx +0 -54
- package/templates/storefront-services/app/error.tsx +0 -60
- package/templates/storefront-services/app/faq/page.tsx +0 -46
- package/templates/storefront-services/app/globals.css +0 -45
- package/templates/storefront-services/app/layout.tsx +0 -82
- package/templates/storefront-services/app/llms.txt/route.ts +0 -94
- package/templates/storefront-services/app/login/page.tsx +0 -17
- package/templates/storefront-services/app/not-found.tsx +0 -39
- package/templates/storefront-services/app/opensearch.xml/route.ts +0 -37
- package/templates/storefront-services/app/orders/[id]/page.tsx +0 -21
- package/templates/storefront-services/app/page.tsx +0 -97
- package/templates/storefront-services/app/privacy/page.tsx +0 -44
- package/templates/storefront-services/app/returns/page.tsx +0 -11
- package/templates/storefront-services/app/robots.ts +0 -18
- package/templates/storefront-services/app/search/page.tsx +0 -38
- package/templates/storefront-services/app/search/search-client.tsx +0 -7
- package/templates/storefront-services/app/shipping/page.tsx +0 -16
- package/templates/storefront-services/app/shop/page.tsx +0 -31
- package/templates/storefront-services/app/shop/shop-client.tsx +0 -27
- package/templates/storefront-services/app/signup/page.tsx +0 -17
- package/templates/storefront-services/app/sitemap-page/page.tsx +0 -167
- package/templates/storefront-services/app/sitemap.ts +0 -62
- package/templates/storefront-services/app/terms/page.tsx +0 -44
- package/templates/storefront-services/app/track-order/page.tsx +0 -24
- package/templates/storefront-services/app/track-order/track-order-form.tsx +0 -69
- package/templates/storefront-services/components/account-iframe.tsx +0 -13
- package/templates/storefront-services/components/cart-drawer.tsx +0 -14
- package/templates/storefront-services/components/cart-pill.tsx +0 -36
- package/templates/storefront-services/components/category-grid.tsx +0 -28
- package/templates/storefront-services/components/collection-strip.tsx +0 -45
- package/templates/storefront-services/components/footer.tsx +0 -148
- package/templates/storefront-services/components/header.tsx +0 -43
- package/templates/storefront-services/components/hero.tsx +0 -25
- package/templates/storefront-services/components/nav-link.tsx +0 -20
- package/templates/storefront-services/components/policy-page.tsx +0 -49
- package/templates/storefront-services/components/product-modal.tsx +0 -104
- package/templates/storefront-services/components/providers.tsx +0 -35
- package/templates/storefront-services/components/store-product-card.tsx +0 -87
- package/templates/storefront-services/lib/brand.ts +0 -396
- package/templates/storefront-services/lib/cart.ts +0 -12
- package/templates/storefront-services/next.config.ts +0 -42
- package/templates/storefront-services/package.json +0 -35
- package/templates/storefront-services/postcss.config.mjs +0 -7
- package/templates/storefront-services/tsconfig.json +0 -23
- package/templates/storefront-services/vitest.config.ts +0 -9
|
@@ -1,45 +0,0 @@
|
|
|
1
|
-
import Link from "next/link";
|
|
2
|
-
import type { Collection, Product } from "@cimplify/sdk";
|
|
3
|
-
import { StoreProductCard } from "./store-product-card";
|
|
4
|
-
|
|
5
|
-
interface CollectionStripProps {
|
|
6
|
-
collection: Collection;
|
|
7
|
-
products: Product[];
|
|
8
|
-
collectionHref?: string;
|
|
9
|
-
}
|
|
10
|
-
|
|
11
|
-
/**
|
|
12
|
-
* Horizontal strip of products under a collection title. Cards come from the
|
|
13
|
-
* SDK so every variant (Food, Bundle, Composite, Service, …) renders
|
|
14
|
-
* correctly; clicks open the shared URL-driven product modal.
|
|
15
|
-
*/
|
|
16
|
-
export function CollectionStrip({ collection, products, collectionHref }: CollectionStripProps) {
|
|
17
|
-
if (products.length === 0) return null;
|
|
18
|
-
return (
|
|
19
|
-
<section className="max-w-7xl mx-auto px-8 pt-12">
|
|
20
|
-
<header className="grid grid-cols-[1fr_auto] items-end gap-4 mb-5">
|
|
21
|
-
<h2 className="font-serif text-[28px] font-semibold m-0">{collection.name}</h2>
|
|
22
|
-
{collectionHref && (
|
|
23
|
-
<Link
|
|
24
|
-
href={collectionHref}
|
|
25
|
-
className="text-[13px] font-semibold text-primary hover:underline"
|
|
26
|
-
>
|
|
27
|
-
See all →
|
|
28
|
-
</Link>
|
|
29
|
-
)}
|
|
30
|
-
{collection.description && (
|
|
31
|
-
<p className="col-span-full m-0 mt-1 text-sm text-muted-foreground">
|
|
32
|
-
{collection.description}
|
|
33
|
-
</p>
|
|
34
|
-
)}
|
|
35
|
-
</header>
|
|
36
|
-
<div className="grid grid-flow-col auto-cols-[minmax(220px,1fr)] gap-4 overflow-x-auto snap-x snap-mandatory pb-2">
|
|
37
|
-
{products.slice(0, 8).map((p) => (
|
|
38
|
-
<div key={p.id} className="snap-start">
|
|
39
|
-
<StoreProductCard product={p} />
|
|
40
|
-
</div>
|
|
41
|
-
))}
|
|
42
|
-
</div>
|
|
43
|
-
</section>
|
|
44
|
-
);
|
|
45
|
-
}
|
|
@@ -1,84 +0,0 @@
|
|
|
1
|
-
import Link from "next/link";
|
|
2
|
-
import Image from "next/image";
|
|
3
|
-
|
|
4
|
-
interface FeatureHeroProps {
|
|
5
|
-
eyebrow: string;
|
|
6
|
-
title: React.ReactNode;
|
|
7
|
-
description: string;
|
|
8
|
-
primaryCta: { label: string; href: string };
|
|
9
|
-
secondaryCta?: { label: string; href: string };
|
|
10
|
-
imageUrl: string;
|
|
11
|
-
imageAlt: string;
|
|
12
|
-
badge?: string;
|
|
13
|
-
}
|
|
14
|
-
|
|
15
|
-
/**
|
|
16
|
-
* Apple-style split hero. Left: copy + CTAs. Right: large product image.
|
|
17
|
-
* Stacks to image-on-top on mobile. Strings come from `brand.hero` at the
|
|
18
|
-
* call site — this component is otherwise design-only.
|
|
19
|
-
*/
|
|
20
|
-
export function FeatureHero({
|
|
21
|
-
eyebrow,
|
|
22
|
-
title,
|
|
23
|
-
description,
|
|
24
|
-
primaryCta,
|
|
25
|
-
secondaryCta,
|
|
26
|
-
imageUrl,
|
|
27
|
-
imageAlt,
|
|
28
|
-
badge,
|
|
29
|
-
}: FeatureHeroProps) {
|
|
30
|
-
return (
|
|
31
|
-
<section className="relative overflow-hidden bg-foreground text-background">
|
|
32
|
-
<div className="absolute inset-0 opacity-[0.04] pointer-events-none [background-image:radial-gradient(circle_at_2px_2px,white_1px,transparent_0)] [background-size:40px_40px]" />
|
|
33
|
-
<div className="relative max-w-7xl mx-auto px-6 sm:px-8 py-16 sm:py-20 lg:py-24 grid grid-cols-1 lg:grid-cols-[1.1fr_1fr] gap-10 lg:gap-16 items-center">
|
|
34
|
-
<div>
|
|
35
|
-
{badge && (
|
|
36
|
-
<span className="inline-flex items-center gap-2 mb-5 px-3 py-1.5 rounded-full bg-primary/15 border border-primary/40 text-primary-foreground/95 text-[11px] font-mono uppercase tracking-[0.16em]">
|
|
37
|
-
<span className="grid place-items-center w-1.5 h-1.5 rounded-full bg-primary animate-pulse" />
|
|
38
|
-
{badge}
|
|
39
|
-
</span>
|
|
40
|
-
)}
|
|
41
|
-
<p className="text-[12px] font-mono uppercase tracking-[0.2em] text-background/60 mb-3">
|
|
42
|
-
{eyebrow}
|
|
43
|
-
</p>
|
|
44
|
-
<h1 className="text-[clamp(2.5rem,6vw,4.75rem)] font-bold m-0 mb-5 -tracking-[0.035em] leading-[1.02]">
|
|
45
|
-
{title}
|
|
46
|
-
</h1>
|
|
47
|
-
<p className="text-base sm:text-lg text-background/75 leading-relaxed max-w-xl">
|
|
48
|
-
{description}
|
|
49
|
-
</p>
|
|
50
|
-
<div className="flex flex-wrap items-center gap-3 mt-7">
|
|
51
|
-
<Link
|
|
52
|
-
href={primaryCta.href}
|
|
53
|
-
className="inline-flex items-center gap-2 px-5 py-2.5 rounded-md bg-primary text-primary-foreground font-semibold text-sm hover:bg-primary/90 transition-colors"
|
|
54
|
-
>
|
|
55
|
-
{primaryCta.label}
|
|
56
|
-
<svg viewBox="0 0 12 12" className="w-3 h-3" fill="none" stroke="currentColor" strokeWidth="2" aria-hidden>
|
|
57
|
-
<path d="M3 6h7m0 0L7 3m3 3L7 9" strokeLinecap="round" strokeLinejoin="round" />
|
|
58
|
-
</svg>
|
|
59
|
-
</Link>
|
|
60
|
-
{secondaryCta && (
|
|
61
|
-
<Link
|
|
62
|
-
href={secondaryCta.href}
|
|
63
|
-
className="inline-flex items-center gap-2 px-5 py-2.5 rounded-md border border-background/25 text-background hover:bg-background/10 transition-colors text-sm font-medium"
|
|
64
|
-
>
|
|
65
|
-
{secondaryCta.label}
|
|
66
|
-
</Link>
|
|
67
|
-
)}
|
|
68
|
-
</div>
|
|
69
|
-
</div>
|
|
70
|
-
<div className="relative aspect-[4/3] lg:aspect-square w-full rounded-2xl overflow-hidden bg-background/5 ring-1 ring-background/10">
|
|
71
|
-
<Image
|
|
72
|
-
src={imageUrl}
|
|
73
|
-
alt={imageAlt}
|
|
74
|
-
fill
|
|
75
|
-
sizes="(min-width: 1024px) 50vw, 100vw"
|
|
76
|
-
className="object-cover"
|
|
77
|
-
priority
|
|
78
|
-
/>
|
|
79
|
-
<div className="absolute inset-0 bg-gradient-to-tr from-foreground/40 via-transparent to-transparent pointer-events-none" />
|
|
80
|
-
</div>
|
|
81
|
-
</div>
|
|
82
|
-
</section>
|
|
83
|
-
);
|
|
84
|
-
}
|
|
@@ -1,153 +0,0 @@
|
|
|
1
|
-
import Link from "next/link";
|
|
2
|
-
import { brand } from "@/lib/brand";
|
|
3
|
-
|
|
4
|
-
const ICONS: Record<string, React.ReactNode> = {
|
|
5
|
-
instagram: (
|
|
6
|
-
<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" strokeWidth="1.5" aria-hidden className="w-5 h-5">
|
|
7
|
-
<rect x="3" y="3" width="18" height="18" rx="5" />
|
|
8
|
-
<circle cx="12" cy="12" r="4" />
|
|
9
|
-
<circle cx="17.5" cy="6.5" r="0.75" fill="currentColor" />
|
|
10
|
-
</svg>
|
|
11
|
-
),
|
|
12
|
-
x: (
|
|
13
|
-
<svg viewBox="0 0 24 24" fill="currentColor" aria-hidden className="w-5 h-5">
|
|
14
|
-
<path d="M18 2h3l-7.5 8.6L22 22h-6.6l-5-6.5L4 22H1l8-9.2L1.4 2H8l4.6 6 5.4-6z" />
|
|
15
|
-
</svg>
|
|
16
|
-
),
|
|
17
|
-
tiktok: (
|
|
18
|
-
<svg viewBox="0 0 24 24" fill="currentColor" aria-hidden className="w-5 h-5">
|
|
19
|
-
<path d="M16 3v3.5a4.5 4.5 0 0 0 4.5 4.5V14a7.5 7.5 0 0 1-4.5-1.5V16a5 5 0 1 1-5-5v3a2 2 0 1 0 2 2V3z" />
|
|
20
|
-
</svg>
|
|
21
|
-
),
|
|
22
|
-
facebook: (
|
|
23
|
-
<svg viewBox="0 0 24 24" fill="currentColor" aria-hidden className="w-5 h-5">
|
|
24
|
-
<path d="M14 9V7a1 1 0 0 1 1-1h2V3h-3a4 4 0 0 0-4 4v2H8v3h2v9h3v-9h2.5l.5-3H13z" />
|
|
25
|
-
</svg>
|
|
26
|
-
),
|
|
27
|
-
youtube: (
|
|
28
|
-
<svg viewBox="0 0 24 24" fill="currentColor" aria-hidden className="w-5 h-5">
|
|
29
|
-
<path d="M22.5 6.5a2.6 2.6 0 0 0-1.8-1.8C19 4.2 12 4.2 12 4.2s-7 0-8.7.5A2.6 2.6 0 0 0 1.5 6.5C1 8.2 1 12 1 12s0 3.8.5 5.5a2.6 2.6 0 0 0 1.8 1.8C5 19.8 12 19.8 12 19.8s7 0 8.7-.5a2.6 2.6 0 0 0 1.8-1.8c.5-1.7.5-5.5.5-5.5s0-3.8-.5-5.5zM10 15.5v-7l6 3.5-6 3.5z" />
|
|
30
|
-
</svg>
|
|
31
|
-
),
|
|
32
|
-
linkedin: (
|
|
33
|
-
<svg viewBox="0 0 24 24" fill="currentColor" aria-hidden className="w-5 h-5">
|
|
34
|
-
<path d="M4 4h4v16H4zM6 2.5a2 2 0 1 0 0 4 2 2 0 0 0 0-4zM10 8h4v2.5h.1c.6-1.1 2-2.5 4-2.5 4 0 4.9 2.6 4.9 6V20h-4v-5c0-1.5-.5-3-2.3-3-1.7 0-2.5 1.3-2.5 3v5h-4z" />
|
|
35
|
-
</svg>
|
|
36
|
-
),
|
|
37
|
-
whatsapp: (
|
|
38
|
-
<svg viewBox="0 0 24 24" fill="currentColor" aria-hidden className="w-5 h-5">
|
|
39
|
-
<path d="M12 2a10 10 0 0 0-8.6 15l-1.4 5 5.2-1.4A10 10 0 1 0 12 2zm5 14.2c-.2.6-1.2 1.2-1.7 1.2-.5.1-1.1.1-1.7-.1-.4-.1-.9-.3-1.5-.6a8.4 8.4 0 0 1-3.7-3.4c-.7-1-1-1.8-1-2.5 0-.7.4-1.1.6-1.3.2-.2.4-.2.5-.2h.4c.1 0 .3 0 .4.3l.6 1.4c.1.2 0 .3 0 .4l-.3.4-.3.3c-.1.1-.2.2-.1.4.2.4.7 1.1 1.4 1.8.9.8 1.7 1.1 1.9 1.2.2.1.3.1.5-.1l.6-.7c.2-.2.3-.2.5-.1l1.4.7c.2.1.3.2.4.3.1.2.1.6 0 1z" />
|
|
40
|
-
</svg>
|
|
41
|
-
),
|
|
42
|
-
};
|
|
43
|
-
|
|
44
|
-
const FALLBACK_ICON = (
|
|
45
|
-
<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" strokeWidth="1.5" aria-hidden className="w-5 h-5">
|
|
46
|
-
<circle cx="12" cy="12" r="9" />
|
|
47
|
-
</svg>
|
|
48
|
-
);
|
|
49
|
-
|
|
50
|
-
export async function Footer() {
|
|
51
|
-
"use cache";
|
|
52
|
-
const year = new Date().getFullYear();
|
|
53
|
-
return (
|
|
54
|
-
<footer className="mt-16 border-t border-border bg-foreground text-background/80 text-sm">
|
|
55
|
-
<div className="max-w-7xl mx-auto px-6 sm:px-8 pt-12 pb-8">
|
|
56
|
-
<div className="grid gap-10 md:grid-cols-[1.4fr_repeat(4,1fr)]">
|
|
57
|
-
<div>
|
|
58
|
-
<div className="flex items-center gap-2.5 mb-4">
|
|
59
|
-
<span className="grid place-items-center w-8 h-8 rounded-md bg-primary text-primary-foreground text-[13px] font-bold font-mono">
|
|
60
|
-
{brand.shortName.charAt(0).toUpperCase()}
|
|
61
|
-
</span>
|
|
62
|
-
<span className="text-background text-lg font-bold -tracking-[0.025em]">
|
|
63
|
-
{brand.name}
|
|
64
|
-
</span>
|
|
65
|
-
</div>
|
|
66
|
-
<p className="leading-relaxed mb-4 max-w-sm">{brand.footer.blurb}</p>
|
|
67
|
-
<address className="not-italic space-y-1">
|
|
68
|
-
<p className="m-0">{brand.contact.address}</p>
|
|
69
|
-
<p className="m-0">
|
|
70
|
-
<a
|
|
71
|
-
href={`tel:${brand.contact.phoneTel}`}
|
|
72
|
-
className="hover:text-background transition-colors"
|
|
73
|
-
>
|
|
74
|
-
{brand.contact.phone}
|
|
75
|
-
</a>
|
|
76
|
-
</p>
|
|
77
|
-
<p className="m-0">
|
|
78
|
-
<a
|
|
79
|
-
href={`mailto:${brand.contact.email}`}
|
|
80
|
-
className="hover:text-background transition-colors"
|
|
81
|
-
>
|
|
82
|
-
{brand.contact.email}
|
|
83
|
-
</a>
|
|
84
|
-
</p>
|
|
85
|
-
<p className="m-0 text-xs">{brand.contact.hours}</p>
|
|
86
|
-
</address>
|
|
87
|
-
<div className="flex items-center gap-3 mt-5">
|
|
88
|
-
{brand.socials.map((s) => (
|
|
89
|
-
<a
|
|
90
|
-
key={s.label}
|
|
91
|
-
href={s.href}
|
|
92
|
-
aria-label={s.label}
|
|
93
|
-
target="_blank"
|
|
94
|
-
rel="noopener noreferrer"
|
|
95
|
-
className="inline-flex items-center justify-center w-9 h-9 rounded-md border border-background/20 hover:bg-primary hover:border-primary transition-colors"
|
|
96
|
-
>
|
|
97
|
-
{(s.icon && ICONS[s.icon]) ?? FALLBACK_ICON}
|
|
98
|
-
</a>
|
|
99
|
-
))}
|
|
100
|
-
</div>
|
|
101
|
-
</div>
|
|
102
|
-
{brand.footer.sitemap.map((section) => (
|
|
103
|
-
<nav key={section.title} aria-labelledby={`footer-${section.title}`}>
|
|
104
|
-
<p
|
|
105
|
-
id={`footer-${section.title}`}
|
|
106
|
-
className="text-background font-mono mb-3 text-[11px] uppercase tracking-[0.12em]"
|
|
107
|
-
>
|
|
108
|
-
{section.title}
|
|
109
|
-
</p>
|
|
110
|
-
<ul className="space-y-2 m-0 p-0 list-none">
|
|
111
|
-
{section.links.map((link) => (
|
|
112
|
-
<li key={link.label}>
|
|
113
|
-
<Link href={link.href} className="hover:text-background transition-colors">
|
|
114
|
-
{link.label}
|
|
115
|
-
</Link>
|
|
116
|
-
</li>
|
|
117
|
-
))}
|
|
118
|
-
</ul>
|
|
119
|
-
</nav>
|
|
120
|
-
))}
|
|
121
|
-
</div>
|
|
122
|
-
|
|
123
|
-
<div className="mt-12 pt-6 border-t border-background/15 flex flex-col sm:flex-row items-center justify-between gap-3 text-xs">
|
|
124
|
-
<p className="m-0">© {year} {brand.name}. All rights reserved.</p>
|
|
125
|
-
{brand.footer.poweredBy && (
|
|
126
|
-
<p className="m-0 inline-flex items-center gap-1.5">
|
|
127
|
-
<span className="opacity-70">Powered by</span>
|
|
128
|
-
<a
|
|
129
|
-
href={brand.footer.poweredBy.href}
|
|
130
|
-
target="_blank"
|
|
131
|
-
rel="noopener noreferrer"
|
|
132
|
-
aria-label={brand.footer.poweredBy.label}
|
|
133
|
-
className="inline-flex items-center gap-1 text-background hover:text-primary transition-colors"
|
|
134
|
-
>
|
|
135
|
-
<span className="font-semibold tracking-tight">{brand.footer.poweredBy.label}</span>
|
|
136
|
-
<svg
|
|
137
|
-
viewBox="0 0 12 12"
|
|
138
|
-
aria-hidden
|
|
139
|
-
className="w-3 h-3 opacity-70"
|
|
140
|
-
fill="none"
|
|
141
|
-
stroke="currentColor"
|
|
142
|
-
strokeWidth="1.5"
|
|
143
|
-
>
|
|
144
|
-
<path d="M3 9L9 3M9 3H4M9 3v5" strokeLinecap="round" strokeLinejoin="round" />
|
|
145
|
-
</svg>
|
|
146
|
-
</a>
|
|
147
|
-
</p>
|
|
148
|
-
)}
|
|
149
|
-
</div>
|
|
150
|
-
</div>
|
|
151
|
-
</footer>
|
|
152
|
-
);
|
|
153
|
-
}
|
|
@@ -1,45 +0,0 @@
|
|
|
1
|
-
import Link from "next/link";
|
|
2
|
-
import { Suspense } from "react";
|
|
3
|
-
import { NavLink } from "./nav-link";
|
|
4
|
-
import { CartPill, CartPillSkeleton } from "./cart-pill";
|
|
5
|
-
import { brand } from "@/lib/brand";
|
|
6
|
-
|
|
7
|
-
/**
|
|
8
|
-
* Server-rendered header chrome. Brand mark + nav layout streams from the
|
|
9
|
-
* cache; the active-link styling and live cart count are dynamic islands
|
|
10
|
-
* mounted in their own Suspense boundaries so the chrome never blocks.
|
|
11
|
-
*/
|
|
12
|
-
export function Header() {
|
|
13
|
-
const initial = brand.shortName.charAt(0).toUpperCase();
|
|
14
|
-
return (
|
|
15
|
-
<header className="sticky top-0 z-30 flex items-center justify-between px-6 sm:px-8 py-3.5 border-b border-border bg-background/90 backdrop-blur-md">
|
|
16
|
-
<Link href="/" className="flex items-center gap-2.5 group">
|
|
17
|
-
<span className="grid place-items-center w-8 h-8 rounded-md bg-foreground text-background text-[13px] font-bold font-mono group-hover:bg-primary transition-colors">
|
|
18
|
-
{initial}
|
|
19
|
-
</span>
|
|
20
|
-
<span className="text-[18px] font-bold -tracking-[0.025em]">{brand.shortName}</span>
|
|
21
|
-
<span className="hidden sm:inline text-[10px] font-mono uppercase tracking-[0.16em] text-muted-foreground border border-border rounded px-1.5 py-0.5">
|
|
22
|
-
{brand.microTag}
|
|
23
|
-
</span>
|
|
24
|
-
</Link>
|
|
25
|
-
<nav className="flex items-center gap-5 sm:gap-6">
|
|
26
|
-
{brand.header.nav.map((link) => (
|
|
27
|
-
<Suspense key={link.href} fallback={<NavLinkFallback>{link.label}</NavLinkFallback>}>
|
|
28
|
-
<NavLink href={link.href}>{link.label}</NavLink>
|
|
29
|
-
</Suspense>
|
|
30
|
-
))}
|
|
31
|
-
<Suspense fallback={<CartPillSkeleton />}>
|
|
32
|
-
<CartPill />
|
|
33
|
-
</Suspense>
|
|
34
|
-
</nav>
|
|
35
|
-
</header>
|
|
36
|
-
);
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
function NavLinkFallback({ children }: { children: React.ReactNode }) {
|
|
40
|
-
return (
|
|
41
|
-
<span className="text-[13px] font-medium tracking-wide text-muted-foreground">
|
|
42
|
-
{children}
|
|
43
|
-
</span>
|
|
44
|
-
);
|
|
45
|
-
}
|
|
@@ -1,28 +0,0 @@
|
|
|
1
|
-
interface HeroProps {
|
|
2
|
-
badge?: string;
|
|
3
|
-
title: string;
|
|
4
|
-
subtitle?: string;
|
|
5
|
-
}
|
|
6
|
-
|
|
7
|
-
export function Hero({ badge, title, subtitle }: HeroProps) {
|
|
8
|
-
return (
|
|
9
|
-
<section className="relative px-8 py-20 text-center overflow-hidden bg-gradient-to-br from-foreground via-foreground to-primary text-background">
|
|
10
|
-
<div className="absolute inset-0 opacity-[0.06] pointer-events-none [background-image:radial-gradient(circle_at_2px_2px,white_1px,transparent_0)] [background-size:32px_32px]" />
|
|
11
|
-
<div className="relative max-w-3xl mx-auto">
|
|
12
|
-
{badge && (
|
|
13
|
-
<span className="inline-block mb-5 px-3.5 py-1.5 rounded-full bg-primary/15 border border-primary/30 text-primary-foreground/90 text-[11px] font-semibold uppercase tracking-[0.16em] font-mono">
|
|
14
|
-
{badge}
|
|
15
|
-
</span>
|
|
16
|
-
)}
|
|
17
|
-
<h1 className="text-[clamp(2.5rem,6vw,4rem)] font-bold m-0 -tracking-[0.03em] leading-[1.05]">
|
|
18
|
-
{title}
|
|
19
|
-
</h1>
|
|
20
|
-
{subtitle && (
|
|
21
|
-
<p className="mx-auto mt-5 max-w-2xl text-base sm:text-lg text-background/80 leading-relaxed">
|
|
22
|
-
{subtitle}
|
|
23
|
-
</p>
|
|
24
|
-
)}
|
|
25
|
-
</div>
|
|
26
|
-
</section>
|
|
27
|
-
);
|
|
28
|
-
}
|
|
@@ -1,20 +0,0 @@
|
|
|
1
|
-
"use client";
|
|
2
|
-
|
|
3
|
-
import Link from "next/link";
|
|
4
|
-
import { usePathname } from "next/navigation";
|
|
5
|
-
|
|
6
|
-
export function NavLink({ href, children }: { href: string; children: React.ReactNode }) {
|
|
7
|
-
const pathname = usePathname();
|
|
8
|
-
const active = pathname === href;
|
|
9
|
-
return (
|
|
10
|
-
<Link
|
|
11
|
-
href={href}
|
|
12
|
-
className={[
|
|
13
|
-
"text-[13px] font-medium tracking-wide transition-colors",
|
|
14
|
-
active ? "text-primary" : "text-muted-foreground hover:text-foreground",
|
|
15
|
-
].join(" ")}
|
|
16
|
-
>
|
|
17
|
-
{children}
|
|
18
|
-
</Link>
|
|
19
|
-
);
|
|
20
|
-
}
|
|
@@ -1,50 +0,0 @@
|
|
|
1
|
-
"use client";
|
|
2
|
-
|
|
3
|
-
import { useState } from "react";
|
|
4
|
-
import { brand } from "@/lib/brand";
|
|
5
|
-
|
|
6
|
-
export function Newsletter() {
|
|
7
|
-
const n = brand.newsletter;
|
|
8
|
-
const [email, setEmail] = useState("");
|
|
9
|
-
const [submitted, setSubmitted] = useState(false);
|
|
10
|
-
|
|
11
|
-
return (
|
|
12
|
-
<section className="max-w-7xl mx-auto px-6 sm:px-8 py-14 sm:py-20">
|
|
13
|
-
<div className="rounded-3xl border border-border bg-card p-8 sm:p-12 grid grid-cols-1 lg:grid-cols-2 gap-8 items-center">
|
|
14
|
-
<div>
|
|
15
|
-
<p className="text-[11px] font-mono uppercase tracking-[0.16em] text-primary mb-2">
|
|
16
|
-
{n.eyebrow}
|
|
17
|
-
</p>
|
|
18
|
-
<h2 className="text-[clamp(1.5rem,3vw,2rem)] font-bold m-0 mb-3 -tracking-[0.025em]">
|
|
19
|
-
{n.title}
|
|
20
|
-
</h2>
|
|
21
|
-
<p className="text-muted-foreground leading-relaxed">{n.body}</p>
|
|
22
|
-
</div>
|
|
23
|
-
<form
|
|
24
|
-
onSubmit={(e) => {
|
|
25
|
-
e.preventDefault();
|
|
26
|
-
setSubmitted(true);
|
|
27
|
-
}}
|
|
28
|
-
className="flex flex-col sm:flex-row gap-2"
|
|
29
|
-
>
|
|
30
|
-
<input
|
|
31
|
-
type="email"
|
|
32
|
-
required
|
|
33
|
-
value={email}
|
|
34
|
-
onChange={(e) => setEmail(e.target.value)}
|
|
35
|
-
placeholder={n.placeholder}
|
|
36
|
-
disabled={submitted}
|
|
37
|
-
className="flex-1 px-4 py-3 rounded-md bg-background border border-border focus:border-primary focus:ring-2 focus:ring-primary/20 outline-none transition-shadow text-sm disabled:opacity-50"
|
|
38
|
-
/>
|
|
39
|
-
<button
|
|
40
|
-
type="submit"
|
|
41
|
-
disabled={submitted}
|
|
42
|
-
className="inline-flex items-center justify-center gap-2 px-5 py-3 rounded-md bg-foreground text-background font-semibold text-sm hover:bg-primary transition-colors disabled:opacity-50"
|
|
43
|
-
>
|
|
44
|
-
{submitted ? n.successLabel : n.submitLabel}
|
|
45
|
-
</button>
|
|
46
|
-
</form>
|
|
47
|
-
</div>
|
|
48
|
-
</section>
|
|
49
|
-
);
|
|
50
|
-
}
|
|
@@ -1,49 +0,0 @@
|
|
|
1
|
-
import type { BrandPolicySection } from "@/lib/brand";
|
|
2
|
-
|
|
3
|
-
interface PolicyShape {
|
|
4
|
-
eyebrow: string;
|
|
5
|
-
title: string;
|
|
6
|
-
lastUpdated?: string;
|
|
7
|
-
sections: BrandPolicySection[];
|
|
8
|
-
}
|
|
9
|
-
|
|
10
|
-
/**
|
|
11
|
-
* Shared layout for shipping / returns / accessibility / terms / privacy.
|
|
12
|
-
* Reads a `{ eyebrow, title, lastUpdated, sections[] }` block from brand.
|
|
13
|
-
*/
|
|
14
|
-
export function PolicyPage({ policy }: { policy: PolicyShape }) {
|
|
15
|
-
return (
|
|
16
|
-
<article className="max-w-3xl mx-auto px-8 py-16 prose prose-lg max-w-none">
|
|
17
|
-
<p className="text-[11px] font-semibold uppercase tracking-[0.16em] text-primary mb-2 not-prose">
|
|
18
|
-
{policy.eyebrow}
|
|
19
|
-
</p>
|
|
20
|
-
<h1 className="text-[clamp(2.25rem,5vw,3.5rem)] font-semibold mb-2 -tracking-[0.02em]">
|
|
21
|
-
{policy.title}
|
|
22
|
-
</h1>
|
|
23
|
-
{policy.lastUpdated && (
|
|
24
|
-
<p className="text-sm text-muted-foreground not-prose mb-10">
|
|
25
|
-
Last updated: {policy.lastUpdated}
|
|
26
|
-
</p>
|
|
27
|
-
)}
|
|
28
|
-
<section className="space-y-5 leading-relaxed text-foreground/90">
|
|
29
|
-
{policy.sections.map((s) => (
|
|
30
|
-
<div key={s.heading}>
|
|
31
|
-
<h2 className="text-2xl font-semibold mt-0">{s.heading}</h2>
|
|
32
|
-
{typeof s.body === "string" ? (
|
|
33
|
-
<p>{s.body}</p>
|
|
34
|
-
) : (
|
|
35
|
-
<>
|
|
36
|
-
<p>{s.body.intro}</p>
|
|
37
|
-
<ul className="list-disc pl-6 space-y-2">
|
|
38
|
-
{s.body.bullets.map((b) => (
|
|
39
|
-
<li key={b}>{b}</li>
|
|
40
|
-
))}
|
|
41
|
-
</ul>
|
|
42
|
-
</>
|
|
43
|
-
)}
|
|
44
|
-
</div>
|
|
45
|
-
))}
|
|
46
|
-
</section>
|
|
47
|
-
</article>
|
|
48
|
-
);
|
|
49
|
-
}
|
|
@@ -1,41 +0,0 @@
|
|
|
1
|
-
import Link from "next/link";
|
|
2
|
-
import { brand } from "@/lib/brand";
|
|
3
|
-
|
|
4
|
-
/**
|
|
5
|
-
* Full-width promo banner — reads brand.promo. Renders nothing if the
|
|
6
|
-
* brand doesn't define a promo, so this component is safe to drop in
|
|
7
|
-
* across templates that may or may not run a campaign.
|
|
8
|
-
*/
|
|
9
|
-
export function PromoBanner() {
|
|
10
|
-
const promo = brand.promo;
|
|
11
|
-
if (!promo) return null;
|
|
12
|
-
return (
|
|
13
|
-
<section className="max-w-7xl mx-auto px-6 sm:px-8 py-6">
|
|
14
|
-
<div className="relative overflow-hidden rounded-3xl bg-gradient-to-br from-primary via-primary to-foreground text-primary-foreground p-8 sm:p-12 lg:p-16">
|
|
15
|
-
<div className="absolute -top-20 -right-20 w-72 h-72 rounded-full bg-background/10 blur-3xl pointer-events-none" />
|
|
16
|
-
<div className="absolute -bottom-32 -left-20 w-96 h-96 rounded-full bg-foreground/30 blur-3xl pointer-events-none" />
|
|
17
|
-
<div className="relative grid grid-cols-1 lg:grid-cols-[1fr_auto] gap-8 items-center">
|
|
18
|
-
<div className="max-w-2xl">
|
|
19
|
-
<span className="inline-flex items-center gap-2 mb-4 px-3 py-1 rounded-full bg-background/15 border border-background/25 text-[11px] font-mono uppercase tracking-[0.16em]">
|
|
20
|
-
<span className="w-1.5 h-1.5 rounded-full bg-background animate-pulse" />
|
|
21
|
-
{promo.badge}
|
|
22
|
-
</span>
|
|
23
|
-
<h2 className="text-[clamp(1.75rem,3.5vw,2.75rem)] font-bold m-0 mb-3 -tracking-[0.025em] leading-[1.1]">
|
|
24
|
-
{promo.title}
|
|
25
|
-
</h2>
|
|
26
|
-
<p className="text-base sm:text-lg opacity-90 leading-relaxed">{promo.body}</p>
|
|
27
|
-
</div>
|
|
28
|
-
<Link
|
|
29
|
-
href={promo.ctaHref}
|
|
30
|
-
className="inline-flex items-center gap-2 px-5 py-3 rounded-md bg-background text-foreground font-semibold text-sm hover:bg-background/90 transition-colors whitespace-nowrap"
|
|
31
|
-
>
|
|
32
|
-
{promo.ctaLabel}
|
|
33
|
-
<svg viewBox="0 0 12 12" className="w-3 h-3" fill="none" stroke="currentColor" strokeWidth="2" aria-hidden>
|
|
34
|
-
<path d="M3 6h7m0 0L7 3m3 3L7 9" strokeLinecap="round" strokeLinejoin="round" />
|
|
35
|
-
</svg>
|
|
36
|
-
</Link>
|
|
37
|
-
</div>
|
|
38
|
-
</div>
|
|
39
|
-
</section>
|
|
40
|
-
);
|
|
41
|
-
}
|
|
@@ -1,35 +0,0 @@
|
|
|
1
|
-
"use client";
|
|
2
|
-
|
|
3
|
-
import { useMemo, type ReactNode } from "react";
|
|
4
|
-
import { createCimplifyClient } from "@cimplify/sdk";
|
|
5
|
-
import { CimplifyProvider, CartDrawerProvider } from "@cimplify/sdk/react";
|
|
6
|
-
|
|
7
|
-
/**
|
|
8
|
-
* Boots the Cimplify SDK client once on the client-side and exposes it via
|
|
9
|
-
* <CimplifyProvider/>.
|
|
10
|
-
*
|
|
11
|
-
* Base-URL resolution:
|
|
12
|
-
* 1) If NEXT_PUBLIC_CIMPLIFY_API_URL is set, use it verbatim.
|
|
13
|
-
* 2) Otherwise use the current origin so requests flow through the
|
|
14
|
-
* Next.js rewrite in `next.config.ts` to the mock at :8787 (no CORS).
|
|
15
|
-
* 3) Fall back to 127.0.0.1:8787 only during SSR, when there's no window.
|
|
16
|
-
*/
|
|
17
|
-
export function Providers({ children }: { children: ReactNode }) {
|
|
18
|
-
const client = useMemo(() => {
|
|
19
|
-
const baseUrl =
|
|
20
|
-
process.env.NEXT_PUBLIC_CIMPLIFY_API_URL?.trim() ||
|
|
21
|
-
(typeof window !== "undefined" ? window.location.origin : "http://127.0.0.1:8787");
|
|
22
|
-
const publicKey = process.env.NEXT_PUBLIC_CIMPLIFY_PUBLIC_KEY ?? "mock-dev";
|
|
23
|
-
return createCimplifyClient({
|
|
24
|
-
baseUrl,
|
|
25
|
-
publicKey,
|
|
26
|
-
suppressPublicKeyWarning: true,
|
|
27
|
-
});
|
|
28
|
-
}, []);
|
|
29
|
-
|
|
30
|
-
return (
|
|
31
|
-
<CimplifyProvider client={client}>
|
|
32
|
-
<CartDrawerProvider>{children}</CartDrawerProvider>
|
|
33
|
-
</CimplifyProvider>
|
|
34
|
-
);
|
|
35
|
-
}
|
|
@@ -1,37 +0,0 @@
|
|
|
1
|
-
import Link from "next/link";
|
|
2
|
-
|
|
3
|
-
interface SectionHeadingProps {
|
|
4
|
-
eyebrow: string;
|
|
5
|
-
title: string;
|
|
6
|
-
description?: string;
|
|
7
|
-
link?: { label: string; href: string };
|
|
8
|
-
}
|
|
9
|
-
|
|
10
|
-
export function SectionHeading({ eyebrow, title, description, link }: SectionHeadingProps) {
|
|
11
|
-
return (
|
|
12
|
-
<div className="flex items-end justify-between gap-6 mb-8">
|
|
13
|
-
<div className="max-w-2xl">
|
|
14
|
-
<p className="text-[11px] font-mono uppercase tracking-[0.16em] text-primary mb-2">
|
|
15
|
-
{eyebrow}
|
|
16
|
-
</p>
|
|
17
|
-
<h2 className="text-[clamp(1.75rem,3vw,2.25rem)] font-bold m-0 -tracking-[0.025em]">
|
|
18
|
-
{title}
|
|
19
|
-
</h2>
|
|
20
|
-
{description && (
|
|
21
|
-
<p className="mt-2 text-muted-foreground">{description}</p>
|
|
22
|
-
)}
|
|
23
|
-
</div>
|
|
24
|
-
{link && (
|
|
25
|
-
<Link
|
|
26
|
-
href={link.href}
|
|
27
|
-
className="text-sm font-semibold text-primary hover:underline whitespace-nowrap hidden sm:inline-flex items-center gap-1"
|
|
28
|
-
>
|
|
29
|
-
{link.label}
|
|
30
|
-
<svg viewBox="0 0 12 12" className="w-3 h-3" fill="none" stroke="currentColor" strokeWidth="2" aria-hidden>
|
|
31
|
-
<path d="M3 6h7m0 0L7 3m3 3L7 9" strokeLinecap="round" strokeLinejoin="round" />
|
|
32
|
-
</svg>
|
|
33
|
-
</Link>
|
|
34
|
-
)}
|
|
35
|
-
</div>
|
|
36
|
-
);
|
|
37
|
-
}
|