@cimplify/sdk 0.44.34 → 0.45.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +21 -16
- package/dist/advanced.d.mts +1 -1
- package/dist/advanced.d.ts +1 -1
- package/dist/{client-5B9IPDmf.d.ts → client-Bsd4Vi_y.d.ts} +1 -0
- package/dist/{client-CpVMRI8V.d.mts → client-C5LcbNxL.d.mts} +1 -0
- package/dist/{client-DMhRxuzm.d.ts → client-DjzIoewX.d.ts} +1 -1
- package/dist/{client-Cwb1sMr3.d.mts → client-EM8xKCPO.d.mts} +1 -1
- package/dist/index.d.mts +1 -1
- package/dist/index.d.ts +1 -1
- package/dist/react.d.mts +120 -45
- package/dist/react.d.ts +120 -45
- package/dist/react.js +453 -97
- package/dist/react.mjs +452 -98
- package/dist/server.d.mts +2 -2
- package/dist/server.d.ts +2 -2
- package/dist/styles.css +2 -2
- package/dist/testing/suite.d.mts +2 -2
- package/dist/testing/suite.d.ts +2 -2
- package/dist/testing.d.mts +2 -2
- package/dist/testing.d.ts +2 -2
- package/package.json +5 -9
- package/registry/booking-page.json +2 -1
- package/registry/bookings-page.json +1 -1
- package/registry/index.json +24 -0
- 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/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,118 +0,0 @@
|
|
|
1
|
-
import type { Metadata } from "next";
|
|
2
|
-
import { Suspense } from "react";
|
|
3
|
-
import Link from "next/link";
|
|
4
|
-
import { notFound } from "next/navigation";
|
|
5
|
-
import { cacheTag, cacheLife } from "next/cache";
|
|
6
|
-
import {
|
|
7
|
-
getServerClient,
|
|
8
|
-
tags,
|
|
9
|
-
type Collection,
|
|
10
|
-
type Product,
|
|
11
|
-
} from "@cimplify/sdk/server";
|
|
12
|
-
import { ListingClient } from "./listing-client";
|
|
13
|
-
import { brand } from "@/lib/brand";
|
|
14
|
-
|
|
15
|
-
interface CollectionData {
|
|
16
|
-
collection: Collection;
|
|
17
|
-
products: Product[];
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
async function getCollection(slug: string): Promise<CollectionData | null> {
|
|
21
|
-
"use cache";
|
|
22
|
-
cacheTag(tags.collections());
|
|
23
|
-
cacheLife("hours");
|
|
24
|
-
|
|
25
|
-
const client = getServerClient();
|
|
26
|
-
const colRes = await client.catalogue.getCollectionBySlug(slug);
|
|
27
|
-
if (!colRes.ok) return null;
|
|
28
|
-
|
|
29
|
-
cacheTag(tags.collection(colRes.value.id), tags.collectionProducts(colRes.value.id));
|
|
30
|
-
const r = await client.catalogue.getCollectionProducts(colRes.value.id);
|
|
31
|
-
const products = r.ok
|
|
32
|
-
? ((r.value as { items?: Product[] }).items ?? (r.value as Product[]))
|
|
33
|
-
: [];
|
|
34
|
-
return { collection: colRes.value, products };
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
export async function generateMetadata({
|
|
38
|
-
params,
|
|
39
|
-
}: {
|
|
40
|
-
params: Promise<{ slug: string }>;
|
|
41
|
-
}): Promise<Metadata> {
|
|
42
|
-
const { slug } = await params;
|
|
43
|
-
const data = await getCollection(slug);
|
|
44
|
-
if (!data) return {};
|
|
45
|
-
return {
|
|
46
|
-
title: `${data.collection.name} — ${brand.name}`,
|
|
47
|
-
description: data.collection.description ?? undefined,
|
|
48
|
-
};
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
export default async function CollectionPage({
|
|
52
|
-
params,
|
|
53
|
-
}: {
|
|
54
|
-
params: Promise<{ slug: string }>;
|
|
55
|
-
}) {
|
|
56
|
-
return (
|
|
57
|
-
<Suspense fallback={<CollectionSkeleton />}>
|
|
58
|
-
<CollectionContent params={params} />
|
|
59
|
-
</Suspense>
|
|
60
|
-
);
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
async function CollectionContent({
|
|
64
|
-
params,
|
|
65
|
-
}: {
|
|
66
|
-
params: Promise<{ slug: string }>;
|
|
67
|
-
}) {
|
|
68
|
-
const { slug } = await params;
|
|
69
|
-
const data = await getCollection(slug);
|
|
70
|
-
if (!data) notFound();
|
|
71
|
-
|
|
72
|
-
const { collection, products } = data;
|
|
73
|
-
return (
|
|
74
|
-
<section className="max-w-7xl mx-auto px-8 pt-12">
|
|
75
|
-
<header className="mb-8 text-center">
|
|
76
|
-
<p className="text-[11px] font-semibold uppercase tracking-[0.16em] text-primary mb-2">
|
|
77
|
-
Collection
|
|
78
|
-
</p>
|
|
79
|
-
<h1 className="font-serif text-[clamp(2rem,4vw,2.75rem)] font-semibold mb-2">
|
|
80
|
-
{collection.name}
|
|
81
|
-
</h1>
|
|
82
|
-
{collection.description && (
|
|
83
|
-
<p className="mx-auto mb-2 max-w-xl text-muted-foreground">
|
|
84
|
-
{collection.description}
|
|
85
|
-
</p>
|
|
86
|
-
)}
|
|
87
|
-
<p className="text-sm text-muted-foreground">
|
|
88
|
-
{products.length} item{products.length === 1 ? "" : "s"}
|
|
89
|
-
</p>
|
|
90
|
-
</header>
|
|
91
|
-
<ListingClient products={products} />
|
|
92
|
-
{products.length === 0 && (
|
|
93
|
-
<p className="text-center mt-8">
|
|
94
|
-
<Link href="/" className="text-primary font-semibold">
|
|
95
|
-
← Back home
|
|
96
|
-
</Link>
|
|
97
|
-
</p>
|
|
98
|
-
)}
|
|
99
|
-
</section>
|
|
100
|
-
);
|
|
101
|
-
}
|
|
102
|
-
|
|
103
|
-
function CollectionSkeleton() {
|
|
104
|
-
return (
|
|
105
|
-
<section className="max-w-7xl mx-auto px-8 pt-12">
|
|
106
|
-
<header className="mb-8 text-center">
|
|
107
|
-
<div className="mx-auto h-3 w-20 bg-muted rounded mb-2 animate-pulse" />
|
|
108
|
-
<div className="mx-auto h-10 w-64 bg-muted rounded mb-2 animate-pulse" />
|
|
109
|
-
<div className="mx-auto h-4 w-80 bg-muted rounded animate-pulse" />
|
|
110
|
-
</header>
|
|
111
|
-
<div className="grid grid-cols-2 md:grid-cols-3 gap-4">
|
|
112
|
-
{Array.from({ length: 6 }).map((_, i) => (
|
|
113
|
-
<div key={i} className="aspect-square bg-muted rounded-2xl animate-pulse" />
|
|
114
|
-
))}
|
|
115
|
-
</div>
|
|
116
|
-
</section>
|
|
117
|
-
);
|
|
118
|
-
}
|
|
@@ -1,109 +0,0 @@
|
|
|
1
|
-
"use client";
|
|
2
|
-
|
|
3
|
-
import { useState } from "react";
|
|
4
|
-
|
|
5
|
-
/**
|
|
6
|
-
* Local-only contact form. On submit, fakes a successful response so the
|
|
7
|
-
* template ships a usable interaction. Wire to a real handler (Server
|
|
8
|
-
* Action posting to your CRM, support inbox, or Cimplify Support API)
|
|
9
|
-
* before going to production.
|
|
10
|
-
*/
|
|
11
|
-
export function ContactForm({ reasons }: { reasons: string[] }) {
|
|
12
|
-
const [submitted, setSubmitted] = useState(false);
|
|
13
|
-
const [reason, setReason] = useState(reasons[0] ?? "");
|
|
14
|
-
|
|
15
|
-
if (submitted) {
|
|
16
|
-
return (
|
|
17
|
-
<div className="rounded-2xl border border-border bg-card p-8">
|
|
18
|
-
<p className="text-[11px] font-semibold uppercase tracking-[0.16em] text-primary mb-2">
|
|
19
|
-
✓ Sent
|
|
20
|
-
</p>
|
|
21
|
-
<h2 className="font-serif text-2xl font-semibold mb-2">Thanks — we'll be in touch.</h2>
|
|
22
|
-
<p className="text-muted-foreground">
|
|
23
|
-
We respond within one business day. Check your spam folder if you don't see a
|
|
24
|
-
reply by tomorrow.
|
|
25
|
-
</p>
|
|
26
|
-
</div>
|
|
27
|
-
);
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
return (
|
|
31
|
-
<form
|
|
32
|
-
onSubmit={(e) => {
|
|
33
|
-
e.preventDefault();
|
|
34
|
-
setSubmitted(true);
|
|
35
|
-
}}
|
|
36
|
-
className="space-y-5"
|
|
37
|
-
>
|
|
38
|
-
<div className="grid grid-cols-1 sm:grid-cols-2 gap-4">
|
|
39
|
-
<Field label="Your name" name="name" required />
|
|
40
|
-
<Field label="Email" name="email" type="email" required />
|
|
41
|
-
</div>
|
|
42
|
-
<div>
|
|
43
|
-
<label className="text-xs font-semibold uppercase tracking-wider text-muted-foreground block mb-1.5">
|
|
44
|
-
What's it about?
|
|
45
|
-
</label>
|
|
46
|
-
<select
|
|
47
|
-
name="reason"
|
|
48
|
-
value={reason}
|
|
49
|
-
onChange={(e) => setReason(e.target.value)}
|
|
50
|
-
className="w-full px-4 py-2.5 rounded-md bg-background border border-border focus:border-primary focus:ring-2 focus:ring-primary/20 outline-none text-sm"
|
|
51
|
-
>
|
|
52
|
-
{reasons.map((r) => (
|
|
53
|
-
<option key={r} value={r}>
|
|
54
|
-
{r}
|
|
55
|
-
</option>
|
|
56
|
-
))}
|
|
57
|
-
</select>
|
|
58
|
-
</div>
|
|
59
|
-
<Field label="Order number (optional)" name="order" />
|
|
60
|
-
<div>
|
|
61
|
-
<label className="text-xs font-semibold uppercase tracking-wider text-muted-foreground block mb-1.5">
|
|
62
|
-
Message
|
|
63
|
-
</label>
|
|
64
|
-
<textarea
|
|
65
|
-
name="message"
|
|
66
|
-
required
|
|
67
|
-
rows={6}
|
|
68
|
-
className="w-full px-4 py-2.5 rounded-md bg-background border border-border focus:border-primary focus:ring-2 focus:ring-primary/20 outline-none text-sm resize-y"
|
|
69
|
-
/>
|
|
70
|
-
</div>
|
|
71
|
-
<button
|
|
72
|
-
type="submit"
|
|
73
|
-
className="inline-flex items-center justify-center px-5 py-3 rounded-md bg-primary text-primary-foreground font-semibold text-sm hover:bg-primary/90 transition-colors"
|
|
74
|
-
>
|
|
75
|
-
Send message
|
|
76
|
-
</button>
|
|
77
|
-
</form>
|
|
78
|
-
);
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
function Field({
|
|
82
|
-
label,
|
|
83
|
-
name,
|
|
84
|
-
type = "text",
|
|
85
|
-
required,
|
|
86
|
-
}: {
|
|
87
|
-
label: string;
|
|
88
|
-
name: string;
|
|
89
|
-
type?: string;
|
|
90
|
-
required?: boolean;
|
|
91
|
-
}) {
|
|
92
|
-
return (
|
|
93
|
-
<div>
|
|
94
|
-
<label
|
|
95
|
-
htmlFor={name}
|
|
96
|
-
className="text-xs font-semibold uppercase tracking-wider text-muted-foreground block mb-1.5"
|
|
97
|
-
>
|
|
98
|
-
{label}
|
|
99
|
-
</label>
|
|
100
|
-
<input
|
|
101
|
-
id={name}
|
|
102
|
-
name={name}
|
|
103
|
-
type={type}
|
|
104
|
-
required={required}
|
|
105
|
-
className="w-full px-4 py-2.5 rounded-md bg-background border border-border focus:border-primary focus:ring-2 focus:ring-primary/20 outline-none text-sm"
|
|
106
|
-
/>
|
|
107
|
-
</div>
|
|
108
|
-
);
|
|
109
|
-
}
|
|
@@ -1,54 +0,0 @@
|
|
|
1
|
-
import type { Metadata } from "next";
|
|
2
|
-
import { ContactForm } from "./contact-form";
|
|
3
|
-
import { brand } from "@/lib/brand";
|
|
4
|
-
|
|
5
|
-
export const metadata: Metadata = {
|
|
6
|
-
title: `Contact — ${brand.name}`,
|
|
7
|
-
description: brand.contactPage.body,
|
|
8
|
-
};
|
|
9
|
-
|
|
10
|
-
export default function ContactPage() {
|
|
11
|
-
const c = brand.contactPage;
|
|
12
|
-
return (
|
|
13
|
-
<article className="max-w-5xl mx-auto px-6 sm:px-8 py-16">
|
|
14
|
-
<p className="text-[11px] font-semibold uppercase tracking-[0.16em] text-primary mb-2">
|
|
15
|
-
{c.eyebrow}
|
|
16
|
-
</p>
|
|
17
|
-
<h1 className="font-serif text-[clamp(2.25rem,5vw,3.5rem)] font-semibold mb-4 -tracking-[0.02em]">
|
|
18
|
-
{c.title}
|
|
19
|
-
</h1>
|
|
20
|
-
<p className="text-lg text-muted-foreground max-w-2xl mb-12 leading-relaxed">{c.body}</p>
|
|
21
|
-
|
|
22
|
-
<div className="grid grid-cols-1 lg:grid-cols-[1.5fr_1fr] gap-10 items-start">
|
|
23
|
-
<ContactForm reasons={c.reasons} />
|
|
24
|
-
<aside className="space-y-5 lg:pl-10 lg:border-l border-border">
|
|
25
|
-
<div>
|
|
26
|
-
<p className="text-[11px] font-semibold uppercase tracking-[0.16em] text-muted-foreground mb-3">
|
|
27
|
-
Direct lines
|
|
28
|
-
</p>
|
|
29
|
-
<ul className="space-y-3 list-none p-0 m-0">
|
|
30
|
-
{c.directLines.map((line) => (
|
|
31
|
-
<li key={line.label}>
|
|
32
|
-
<p className="text-xs text-muted-foreground m-0">{line.label}</p>
|
|
33
|
-
<a
|
|
34
|
-
href={line.href}
|
|
35
|
-
className="text-foreground hover:text-primary transition-colors"
|
|
36
|
-
>
|
|
37
|
-
{line.value}
|
|
38
|
-
</a>
|
|
39
|
-
</li>
|
|
40
|
-
))}
|
|
41
|
-
</ul>
|
|
42
|
-
</div>
|
|
43
|
-
<div>
|
|
44
|
-
<p className="text-[11px] font-semibold uppercase tracking-[0.16em] text-muted-foreground mb-3">
|
|
45
|
-
Visit
|
|
46
|
-
</p>
|
|
47
|
-
<p className="text-foreground m-0">{brand.contact.address}</p>
|
|
48
|
-
<p className="text-xs text-muted-foreground mt-1">{brand.contact.hours}</p>
|
|
49
|
-
</div>
|
|
50
|
-
</aside>
|
|
51
|
-
</div>
|
|
52
|
-
</article>
|
|
53
|
-
);
|
|
54
|
-
}
|
|
@@ -1,60 +0,0 @@
|
|
|
1
|
-
"use client";
|
|
2
|
-
|
|
3
|
-
import { useEffect } from "react";
|
|
4
|
-
import Link from "next/link";
|
|
5
|
-
|
|
6
|
-
/**
|
|
7
|
-
* Root error boundary. Next.js calls this whenever a thrown error escapes
|
|
8
|
-
* a Server Component without being caught by a closer `error.tsx`.
|
|
9
|
-
*
|
|
10
|
-
* Wire `reportError` (Sentry, Datadog, etc.) here so production failures
|
|
11
|
-
* surface — silently recovering hides real bugs.
|
|
12
|
-
*/
|
|
13
|
-
export default function GlobalError({
|
|
14
|
-
error,
|
|
15
|
-
reset,
|
|
16
|
-
}: {
|
|
17
|
-
error: Error & { digest?: string };
|
|
18
|
-
reset: () => void;
|
|
19
|
-
}) {
|
|
20
|
-
useEffect(() => {
|
|
21
|
-
// TODO: replace with your error reporter
|
|
22
|
-
// eslint-disable-next-line no-console
|
|
23
|
-
console.error("Storefront error:", error);
|
|
24
|
-
}, [error]);
|
|
25
|
-
|
|
26
|
-
return (
|
|
27
|
-
<section className="max-w-2xl mx-auto px-8 py-20 text-center">
|
|
28
|
-
<p className="text-[11px] font-semibold uppercase tracking-[0.16em] text-primary mb-3">
|
|
29
|
-
Something broke
|
|
30
|
-
</p>
|
|
31
|
-
<h1 className="font-serif text-[clamp(2rem,4vw,2.75rem)] font-semibold mb-4">
|
|
32
|
-
That wasn't supposed to happen.
|
|
33
|
-
</h1>
|
|
34
|
-
<p className="text-muted-foreground leading-relaxed mb-8">
|
|
35
|
-
We've been notified. Refresh the page, or head back home —
|
|
36
|
-
most of the time the second try just works.
|
|
37
|
-
</p>
|
|
38
|
-
{error.digest && (
|
|
39
|
-
<p className="text-xs font-mono text-muted-foreground mb-6">
|
|
40
|
-
Reference: <code className="text-foreground">{error.digest}</code>
|
|
41
|
-
</p>
|
|
42
|
-
)}
|
|
43
|
-
<div className="flex flex-wrap items-center justify-center gap-3">
|
|
44
|
-
<button
|
|
45
|
-
type="button"
|
|
46
|
-
onClick={reset}
|
|
47
|
-
className="inline-block px-6 py-3 rounded-full bg-primary text-primary-foreground font-semibold text-sm transition-colors hover:bg-primary/90"
|
|
48
|
-
>
|
|
49
|
-
Try again
|
|
50
|
-
</button>
|
|
51
|
-
<Link
|
|
52
|
-
href="/"
|
|
53
|
-
className="inline-block px-6 py-3 rounded-full border border-border hover:bg-muted transition-colors text-sm font-medium"
|
|
54
|
-
>
|
|
55
|
-
Back home
|
|
56
|
-
</Link>
|
|
57
|
-
</div>
|
|
58
|
-
</section>
|
|
59
|
-
);
|
|
60
|
-
}
|
|
@@ -1,46 +0,0 @@
|
|
|
1
|
-
import type { Metadata } from "next";
|
|
2
|
-
import { brand } from "@/lib/brand";
|
|
3
|
-
|
|
4
|
-
export const metadata: Metadata = {
|
|
5
|
-
title: `FAQ — ${brand.name}`,
|
|
6
|
-
description: "Delivery, pickup, custom cakes, allergens, payment — answers to the questions we hear most often.",
|
|
7
|
-
};
|
|
8
|
-
|
|
9
|
-
export default function FaqPage() {
|
|
10
|
-
const f = brand.faq;
|
|
11
|
-
return (
|
|
12
|
-
<article className="max-w-3xl mx-auto px-8 py-16">
|
|
13
|
-
<p className="text-[11px] font-semibold uppercase tracking-[0.16em] text-primary mb-2">
|
|
14
|
-
{f.eyebrow}
|
|
15
|
-
</p>
|
|
16
|
-
<h1 className="font-serif text-[clamp(2.25rem,5vw,3.5rem)] font-semibold mb-10 -tracking-[0.02em]">
|
|
17
|
-
{f.title}
|
|
18
|
-
</h1>
|
|
19
|
-
<div className="space-y-12">
|
|
20
|
-
{f.sections.map((section) => (
|
|
21
|
-
<section key={section.title}>
|
|
22
|
-
<h2 className="font-serif text-2xl font-semibold mb-5">{section.title}</h2>
|
|
23
|
-
<dl className="space-y-6">
|
|
24
|
-
{section.items.map((item) => (
|
|
25
|
-
<div key={item.q}>
|
|
26
|
-
<dt className="font-medium text-foreground mb-1.5">{item.q}</dt>
|
|
27
|
-
<dd className="text-muted-foreground leading-relaxed">{item.a}</dd>
|
|
28
|
-
</div>
|
|
29
|
-
))}
|
|
30
|
-
</dl>
|
|
31
|
-
</section>
|
|
32
|
-
))}
|
|
33
|
-
</div>
|
|
34
|
-
<p className="mt-12 pt-8 border-t border-border text-sm text-muted-foreground">
|
|
35
|
-
{f.contactPrompt}{" "}
|
|
36
|
-
<a
|
|
37
|
-
href={`mailto:${f.contactEmail}`}
|
|
38
|
-
className="text-primary font-semibold hover:underline"
|
|
39
|
-
>
|
|
40
|
-
{f.contactEmail}
|
|
41
|
-
</a>{" "}
|
|
42
|
-
and a real human will reply within 24 hours.
|
|
43
|
-
</p>
|
|
44
|
-
</article>
|
|
45
|
-
);
|
|
46
|
-
}
|
|
@@ -1,47 +0,0 @@
|
|
|
1
|
-
@import "tailwindcss";
|
|
2
|
-
|
|
3
|
-
/* Scan the SDK's bundled JS so utility classes used inside its components
|
|
4
|
-
land in the compiled stylesheet alongside our own. */
|
|
5
|
-
@source "../node_modules/@cimplify/sdk/dist";
|
|
6
|
-
|
|
7
|
-
/* The SDK declares its design tokens with `@theme reference`, meaning the
|
|
8
|
-
consumer must supply the actual values. Warm bakery palette below — swap
|
|
9
|
-
these to retheme the entire SDK + storefront in one place. */
|
|
10
|
-
@theme {
|
|
11
|
-
--color-background: oklch(0.985 0.007 80);
|
|
12
|
-
--color-foreground: oklch(0.18 0.01 60);
|
|
13
|
-
--color-card: oklch(1 0 0);
|
|
14
|
-
--color-card-foreground: oklch(0.18 0.01 60);
|
|
15
|
-
--color-popover: oklch(1 0 0);
|
|
16
|
-
--color-popover-foreground: oklch(0.18 0.01 60);
|
|
17
|
-
--color-primary: oklch(0.45 0.16 40);
|
|
18
|
-
--color-primary-foreground: oklch(0.99 0 0);
|
|
19
|
-
--color-secondary: oklch(0.95 0.02 80);
|
|
20
|
-
--color-secondary-foreground: oklch(0.25 0.04 50);
|
|
21
|
-
--color-muted: oklch(0.96 0.01 80);
|
|
22
|
-
--color-muted-foreground: oklch(0.5 0.02 60);
|
|
23
|
-
--color-accent: oklch(0.92 0.05 70);
|
|
24
|
-
--color-accent-foreground: oklch(0.3 0.06 40);
|
|
25
|
-
--color-destructive: oklch(0.58 0.24 27);
|
|
26
|
-
--color-destructive-foreground: oklch(0.99 0 0);
|
|
27
|
-
--color-border: oklch(0.9 0.02 80);
|
|
28
|
-
--color-input: oklch(0.92 0.02 80);
|
|
29
|
-
--color-ring: oklch(0.6 0.1 40);
|
|
30
|
-
--radius: 0.75rem;
|
|
31
|
-
}
|
|
32
|
-
|
|
33
|
-
@layer base {
|
|
34
|
-
html, body {
|
|
35
|
-
margin: 0;
|
|
36
|
-
padding: 0;
|
|
37
|
-
background: var(--color-background);
|
|
38
|
-
color: var(--color-foreground);
|
|
39
|
-
-webkit-font-smoothing: antialiased;
|
|
40
|
-
-moz-osx-font-smoothing: grayscale;
|
|
41
|
-
}
|
|
42
|
-
a { color: inherit; text-decoration: none; }
|
|
43
|
-
h1, h2, h3, h4 {
|
|
44
|
-
font-family: var(--font-serif);
|
|
45
|
-
letter-spacing: -0.01em;
|
|
46
|
-
}
|
|
47
|
-
}
|
|
@@ -1,82 +0,0 @@
|
|
|
1
|
-
import type { Metadata } from "next";
|
|
2
|
-
import { Inter, Playfair_Display } from "next/font/google";
|
|
3
|
-
import "./globals.css";
|
|
4
|
-
import { Providers } from "@/components/providers";
|
|
5
|
-
import { Header } from "@/components/header";
|
|
6
|
-
import { Footer } from "@/components/footer";
|
|
7
|
-
import { ProductModal } from "@/components/product-modal";
|
|
8
|
-
import { CartDrawer } from "@/components/cart-drawer";
|
|
9
|
-
import { Suspense } from "react";
|
|
10
|
-
import { brand } from "@/lib/brand";
|
|
11
|
-
|
|
12
|
-
const inter = Inter({
|
|
13
|
-
subsets: ["latin"],
|
|
14
|
-
variable: "--font-sans",
|
|
15
|
-
display: "swap",
|
|
16
|
-
});
|
|
17
|
-
|
|
18
|
-
const playfair = Playfair_Display({
|
|
19
|
-
subsets: ["latin"],
|
|
20
|
-
variable: "--font-serif",
|
|
21
|
-
display: "swap",
|
|
22
|
-
});
|
|
23
|
-
|
|
24
|
-
const SITE_URL =
|
|
25
|
-
process.env.NEXT_PUBLIC_SITE_URL?.trim() || "https://example.com";
|
|
26
|
-
|
|
27
|
-
export const metadata: Metadata = {
|
|
28
|
-
metadataBase: new URL(SITE_URL),
|
|
29
|
-
title: {
|
|
30
|
-
default: brand.name,
|
|
31
|
-
template: `%s — ${brand.name}`,
|
|
32
|
-
},
|
|
33
|
-
description: brand.description,
|
|
34
|
-
openGraph: {
|
|
35
|
-
type: "website",
|
|
36
|
-
siteName: brand.name,
|
|
37
|
-
locale: brand.locale,
|
|
38
|
-
},
|
|
39
|
-
twitter: { card: "summary_large_image" },
|
|
40
|
-
};
|
|
41
|
-
|
|
42
|
-
const ORGANIZATION_LD = {
|
|
43
|
-
"@context": "https://schema.org",
|
|
44
|
-
"@type": brand.schemaType,
|
|
45
|
-
name: brand.name,
|
|
46
|
-
url: SITE_URL,
|
|
47
|
-
description: brand.description,
|
|
48
|
-
email: brand.contact.email,
|
|
49
|
-
telephone: brand.contact.phoneTel,
|
|
50
|
-
address: {
|
|
51
|
-
"@type": "PostalAddress",
|
|
52
|
-
streetAddress: brand.contact.streetAddress,
|
|
53
|
-
addressLocality: brand.contact.city,
|
|
54
|
-
addressCountry: brand.contact.countryCode,
|
|
55
|
-
},
|
|
56
|
-
sameAs: brand.socials.map((s) => s.href),
|
|
57
|
-
};
|
|
58
|
-
|
|
59
|
-
export default function RootLayout({ children }: { children: React.ReactNode }) {
|
|
60
|
-
return (
|
|
61
|
-
<html lang="en" suppressHydrationWarning className={`${inter.variable} ${playfair.variable}`}>
|
|
62
|
-
<body
|
|
63
|
-
suppressHydrationWarning
|
|
64
|
-
className="min-h-screen flex flex-col bg-background text-foreground font-sans"
|
|
65
|
-
>
|
|
66
|
-
<script
|
|
67
|
-
type="application/ld+json"
|
|
68
|
-
dangerouslySetInnerHTML={{ __html: JSON.stringify(ORGANIZATION_LD) }}
|
|
69
|
-
/>
|
|
70
|
-
<Providers>
|
|
71
|
-
<Header />
|
|
72
|
-
<main className="flex-1 pb-12 w-full">{children}</main>
|
|
73
|
-
<Footer />
|
|
74
|
-
<Suspense fallback={null}>
|
|
75
|
-
<ProductModal />
|
|
76
|
-
</Suspense>
|
|
77
|
-
<CartDrawer />
|
|
78
|
-
</Providers>
|
|
79
|
-
</body>
|
|
80
|
-
</html>
|
|
81
|
-
);
|
|
82
|
-
}
|
|
@@ -1,94 +0,0 @@
|
|
|
1
|
-
import { cacheTag, cacheLife } from "next/cache";
|
|
2
|
-
import { getServerClient, tags, type Product } from "@cimplify/sdk/server";
|
|
3
|
-
import { brand } from "@/lib/brand";
|
|
4
|
-
|
|
5
|
-
const SITE_URL =
|
|
6
|
-
process.env.NEXT_PUBLIC_SITE_URL?.trim() || "https://example.com";
|
|
7
|
-
|
|
8
|
-
async function buildLlmsTxt(): Promise<string> {
|
|
9
|
-
"use cache";
|
|
10
|
-
cacheTag(tags.products(), tags.categories(), tags.collections());
|
|
11
|
-
cacheLife("hours");
|
|
12
|
-
|
|
13
|
-
const client = getServerClient();
|
|
14
|
-
const [productsRes, categoriesRes, collectionsRes] = await Promise.all([
|
|
15
|
-
client.catalogue.getProducts({ limit: 500 }),
|
|
16
|
-
client.catalogue.getCategories(),
|
|
17
|
-
client.catalogue.getCollections(),
|
|
18
|
-
]);
|
|
19
|
-
|
|
20
|
-
const products: Product[] = productsRes.ok ? productsRes.value.items : [];
|
|
21
|
-
const categories = categoriesRes.ok ? categoriesRes.value : [];
|
|
22
|
-
const collections = collectionsRes.ok ? collectionsRes.value : [];
|
|
23
|
-
|
|
24
|
-
const lines: string[] = [];
|
|
25
|
-
lines.push(`# ${brand.name}`);
|
|
26
|
-
lines.push("");
|
|
27
|
-
lines.push(`> ${brand.llms.summary}`);
|
|
28
|
-
lines.push("");
|
|
29
|
-
lines.push("## Browse");
|
|
30
|
-
lines.push(`- [Home](${SITE_URL}/)`);
|
|
31
|
-
lines.push(`- [Shop](${SITE_URL}/shop): Full menu with filter and sort.`);
|
|
32
|
-
|
|
33
|
-
if (categories.length > 0) {
|
|
34
|
-
lines.push("");
|
|
35
|
-
lines.push("## Categories");
|
|
36
|
-
for (const c of categories) {
|
|
37
|
-
lines.push(
|
|
38
|
-
`- [${c.name}](${SITE_URL}/categories/${c.slug})${c.description ? `: ${c.description}` : ""}`,
|
|
39
|
-
);
|
|
40
|
-
}
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
if (collections.length > 0) {
|
|
44
|
-
lines.push("");
|
|
45
|
-
lines.push("## Collections");
|
|
46
|
-
for (const c of collections) {
|
|
47
|
-
lines.push(
|
|
48
|
-
`- [${c.name}](${SITE_URL}/collections/${c.slug})${c.description ? `: ${c.description}` : ""}`,
|
|
49
|
-
);
|
|
50
|
-
}
|
|
51
|
-
}
|
|
52
|
-
|
|
53
|
-
if (products.length > 0) {
|
|
54
|
-
lines.push("");
|
|
55
|
-
lines.push("## Products");
|
|
56
|
-
for (const p of products) {
|
|
57
|
-
const slug = p.slug ?? p.id;
|
|
58
|
-
const price = `${brand.currency} ${p.default_price}`;
|
|
59
|
-
const desc = p.description ? ` — ${p.description.replace(/\s+/g, " ").slice(0, 200)}` : "";
|
|
60
|
-
lines.push(`- [${p.name}](${SITE_URL}/shop?product=${slug}) (${price})${desc}`);
|
|
61
|
-
}
|
|
62
|
-
}
|
|
63
|
-
|
|
64
|
-
lines.push("");
|
|
65
|
-
lines.push("## Information");
|
|
66
|
-
lines.push(`- [About](${SITE_URL}/about)`);
|
|
67
|
-
lines.push(`- [FAQ](${SITE_URL}/faq)`);
|
|
68
|
-
lines.push(`- [Terms of Service](${SITE_URL}/terms)`);
|
|
69
|
-
lines.push(`- [Privacy Policy](${SITE_URL}/privacy)`);
|
|
70
|
-
lines.push(`- [Sitemap (XML)](${SITE_URL}/sitemap.xml)`);
|
|
71
|
-
lines.push("");
|
|
72
|
-
lines.push("## Contact");
|
|
73
|
-
lines.push(`- Email: ${brand.contact.email}`);
|
|
74
|
-
lines.push(`- Phone: ${brand.contact.phone}`);
|
|
75
|
-
lines.push(`- Address: ${brand.contact.address}`);
|
|
76
|
-
|
|
77
|
-
return lines.join("\n") + "\n";
|
|
78
|
-
}
|
|
79
|
-
|
|
80
|
-
/**
|
|
81
|
-
* `/llms.txt` — machine-readable site index for LLMs (per llmstxt.org).
|
|
82
|
-
* Lets coding agents and chat assistants find products, categories, and
|
|
83
|
-
* support pages without scraping HTML. Plain Markdown so it streams cheaply
|
|
84
|
-
* into context windows.
|
|
85
|
-
*/
|
|
86
|
-
export async function GET(): Promise<Response> {
|
|
87
|
-
const body = await buildLlmsTxt();
|
|
88
|
-
return new Response(body, {
|
|
89
|
-
headers: {
|
|
90
|
-
"Content-Type": "text/plain; charset=utf-8",
|
|
91
|
-
"Cache-Control": "public, max-age=0, s-maxage=3600, stale-while-revalidate=86400",
|
|
92
|
-
},
|
|
93
|
-
});
|
|
94
|
-
}
|
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
import type { Metadata } from "next";
|
|
2
|
-
import { redirect } from "next/navigation";
|
|
3
|
-
import { brand } from "@/lib/brand";
|
|
4
|
-
|
|
5
|
-
export const metadata: Metadata = {
|
|
6
|
-
title: `Sign in — ${brand.name}`,
|
|
7
|
-
description: brand.account.loginSubtitle,
|
|
8
|
-
};
|
|
9
|
-
|
|
10
|
-
/**
|
|
11
|
-
* Cimplify Link (the iframe in `<CimplifyAccount>`) handles sign-in
|
|
12
|
-
* automatically when no session exists. We just bounce /login to /account
|
|
13
|
-
* so consumers landing here get the right UI without a duplicate form.
|
|
14
|
-
*/
|
|
15
|
-
export default function LoginPage(): never {
|
|
16
|
-
redirect("/account");
|
|
17
|
-
}
|
|
@@ -1,39 +0,0 @@
|
|
|
1
|
-
import type { Metadata } from "next";
|
|
2
|
-
import Link from "next/link";
|
|
3
|
-
import { brand } from "@/lib/brand";
|
|
4
|
-
|
|
5
|
-
export const metadata: Metadata = {
|
|
6
|
-
title: `Page not found — ${brand.name}`,
|
|
7
|
-
description: "We couldn't find that page.",
|
|
8
|
-
};
|
|
9
|
-
|
|
10
|
-
export default function NotFound() {
|
|
11
|
-
return (
|
|
12
|
-
<section className="max-w-2xl mx-auto px-8 py-20 text-center">
|
|
13
|
-
<p className="text-[11px] font-semibold uppercase tracking-[0.16em] text-primary mb-3">
|
|
14
|
-
404
|
|
15
|
-
</p>
|
|
16
|
-
<h1 className="font-serif text-[clamp(2.5rem,5vw,3.5rem)] font-semibold mb-4">
|
|
17
|
-
Page not found.
|
|
18
|
-
</h1>
|
|
19
|
-
<p className="text-muted-foreground leading-relaxed mb-8">
|
|
20
|
-
The URL you followed might be old, a typo, or pointing at a product
|
|
21
|
-
that's sold out for the day. Try the menu or head back home.
|
|
22
|
-
</p>
|
|
23
|
-
<div className="flex flex-wrap items-center justify-center gap-3">
|
|
24
|
-
<Link
|
|
25
|
-
href="/shop"
|
|
26
|
-
className="inline-block px-6 py-3 rounded-full bg-primary text-primary-foreground font-semibold text-sm transition-colors hover:bg-primary/90"
|
|
27
|
-
>
|
|
28
|
-
Browse the menu
|
|
29
|
-
</Link>
|
|
30
|
-
<Link
|
|
31
|
-
href="/"
|
|
32
|
-
className="inline-block px-6 py-3 rounded-full border border-border hover:bg-muted transition-colors text-sm font-medium"
|
|
33
|
-
>
|
|
34
|
-
Back home
|
|
35
|
-
</Link>
|
|
36
|
-
</div>
|
|
37
|
-
</section>
|
|
38
|
-
);
|
|
39
|
-
}
|