@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,44 +0,0 @@
|
|
|
1
|
-
@import "tailwindcss";
|
|
2
|
-
|
|
3
|
-
@source "../node_modules/@cimplify/sdk/dist";
|
|
4
|
-
|
|
5
|
-
/* Mama's Kitchen — forest green + cream palette, Sweetgreen / boutique
|
|
6
|
-
restaurant feel. Warm, appetizing, refined. */
|
|
7
|
-
@theme {
|
|
8
|
-
--color-background: oklch(0.985 0.013 90);
|
|
9
|
-
--color-foreground: oklch(0.18 0.04 145);
|
|
10
|
-
--color-card: oklch(1 0 0);
|
|
11
|
-
--color-card-foreground: oklch(0.18 0.04 145);
|
|
12
|
-
--color-popover: oklch(1 0 0);
|
|
13
|
-
--color-popover-foreground: oklch(0.18 0.04 145);
|
|
14
|
-
--color-primary: oklch(0.36 0.09 150);
|
|
15
|
-
--color-primary-foreground: oklch(0.98 0.012 90);
|
|
16
|
-
--color-secondary: oklch(0.95 0.025 90);
|
|
17
|
-
--color-secondary-foreground: oklch(0.25 0.05 140);
|
|
18
|
-
--color-muted: oklch(0.94 0.018 85);
|
|
19
|
-
--color-muted-foreground: oklch(0.45 0.03 140);
|
|
20
|
-
--color-accent: oklch(0.85 0.06 80);
|
|
21
|
-
--color-accent-foreground: oklch(0.25 0.06 140);
|
|
22
|
-
--color-destructive: oklch(0.58 0.24 27);
|
|
23
|
-
--color-destructive-foreground: oklch(0.99 0 0);
|
|
24
|
-
--color-border: oklch(0.9 0.018 85);
|
|
25
|
-
--color-input: oklch(0.92 0.018 85);
|
|
26
|
-
--color-ring: oklch(0.36 0.09 150);
|
|
27
|
-
--radius: 0.625rem;
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
@layer base {
|
|
31
|
-
html, body {
|
|
32
|
-
margin: 0;
|
|
33
|
-
padding: 0;
|
|
34
|
-
background: var(--color-background);
|
|
35
|
-
color: var(--color-foreground);
|
|
36
|
-
-webkit-font-smoothing: antialiased;
|
|
37
|
-
-moz-osx-font-smoothing: grayscale;
|
|
38
|
-
}
|
|
39
|
-
a { color: inherit; text-decoration: none; }
|
|
40
|
-
h1, h2, h3, h4 {
|
|
41
|
-
font-family: var(--font-serif);
|
|
42
|
-
letter-spacing: -0.012em;
|
|
43
|
-
}
|
|
44
|
-
}
|
|
@@ -1,82 +0,0 @@
|
|
|
1
|
-
import type { Metadata } from "next";
|
|
2
|
-
import { Inter, Lora } 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 lora = Lora({
|
|
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} ${lora.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
|
-
}
|