@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,42 +0,0 @@
|
|
|
1
|
-
import type { NextConfig } from "next";
|
|
2
|
-
|
|
3
|
-
const MOCK_URL = process.env.NEXT_PUBLIC_CIMPLIFY_API_URL?.trim() || "http://127.0.0.1:8787";
|
|
4
|
-
|
|
5
|
-
/**
|
|
6
|
-
* Same-origin proxy to the Cimplify mock so the browser never makes a
|
|
7
|
-
* cross-origin request in dev (no CORS preflights, no flaky `Origin`
|
|
8
|
-
* mismatches). The SDK's base URL stays empty/relative — requests go to
|
|
9
|
-
* `/api/v1/...` on the Next origin, then this rewrite forwards them to
|
|
10
|
-
* the mock at `127.0.0.1:8787`.
|
|
11
|
-
*
|
|
12
|
-
* In production, point `NEXT_PUBLIC_CIMPLIFY_API_URL` at your Cimplify
|
|
13
|
-
* host and the rewrite continues to work the same way (or remove it and
|
|
14
|
-
* pass the absolute URL through `<CimplifyProvider/>`).
|
|
15
|
-
*/
|
|
16
|
-
const nextConfig: NextConfig = {
|
|
17
|
-
// Enable Next 16's `cacheComponents` mode so we can use `'use cache'` +
|
|
18
|
-
// `cacheTag` / `cacheLife` for SSR caching. Cached chrome streams first,
|
|
19
|
-
// dynamic Suspense boundaries fill in when ready.
|
|
20
|
-
cacheComponents: true,
|
|
21
|
-
async rewrites() {
|
|
22
|
-
return [
|
|
23
|
-
{ source: "/api/v1/:path*", destination: `${MOCK_URL}/api/v1/:path*` },
|
|
24
|
-
{ source: "/img/:path*", destination: `${MOCK_URL}/img/:path*` },
|
|
25
|
-
{ source: "/elements/:path*", destination: `${MOCK_URL}/elements/:path*` },
|
|
26
|
-
{ source: "/_mock/:path*", destination: `${MOCK_URL}/_mock/:path*` },
|
|
27
|
-
];
|
|
28
|
-
},
|
|
29
|
-
images: {
|
|
30
|
-
remotePatterns: [
|
|
31
|
-
{ protocol: "http", hostname: "127.0.0.1", port: "8787", pathname: "/img/**" },
|
|
32
|
-
{ protocol: "http", hostname: "localhost", port: "8787", pathname: "/img/**" },
|
|
33
|
-
{ protocol: "http", hostname: "localhost", port: "3000", pathname: "/img/**" },
|
|
34
|
-
{ protocol: "https", hostname: "loremflickr.com", pathname: "/**" },
|
|
35
|
-
{ protocol: "https", hostname: "images.unsplash.com", pathname: "/**" },
|
|
36
|
-
{ protocol: "https", hostname: "static-tmp.cimplify.io", pathname: "/**" },
|
|
37
|
-
{ protocol: "https", hostname: "cdn.cimplify.io", pathname: "/**" },
|
|
38
|
-
],
|
|
39
|
-
},
|
|
40
|
-
};
|
|
41
|
-
|
|
42
|
-
export default nextConfig;
|
|
@@ -1,35 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"name": "__STOREFRONT_NAME__",
|
|
3
|
-
"private": true,
|
|
4
|
-
"version": "0.0.0",
|
|
5
|
-
"scripts": {
|
|
6
|
-
"dev": "concurrently -k -n mock,next -c blue,magenta \"bunx @cimplify/sdk --seed default --quiet\" \"next dev\"",
|
|
7
|
-
"dev:storefront": "next dev",
|
|
8
|
-
"dev:mock": "bunx @cimplify/sdk --seed default",
|
|
9
|
-
"build": "next build",
|
|
10
|
-
"start": "next start",
|
|
11
|
-
"typecheck": "tsc --noEmit",
|
|
12
|
-
"test": "vitest",
|
|
13
|
-
"test:run": "vitest run",
|
|
14
|
-
"check:brand": "vitest run __tests__/brand.test.ts",
|
|
15
|
-
"check:cart": "vitest run __tests__/cart-flow.test.ts",
|
|
16
|
-
"check:contract": "vitest run __tests__/contract.test.ts",
|
|
17
|
-
"check": "bun run typecheck && bun run test:run"
|
|
18
|
-
},
|
|
19
|
-
"dependencies": {
|
|
20
|
-
"@cimplify/sdk": "^0.44.34",
|
|
21
|
-
"next": "^16.2.4",
|
|
22
|
-
"react": "^19.0.0",
|
|
23
|
-
"react-dom": "^19.0.0"
|
|
24
|
-
},
|
|
25
|
-
"devDependencies": {
|
|
26
|
-
"@tailwindcss/postcss": "^4.2.4",
|
|
27
|
-
"@types/node": "^22.10.0",
|
|
28
|
-
"@types/react": "^19.0.0",
|
|
29
|
-
"@types/react-dom": "^19.0.0",
|
|
30
|
-
"concurrently": "^9.0.0",
|
|
31
|
-
"tailwindcss": "^4.2.4",
|
|
32
|
-
"typescript": "^5.9.3",
|
|
33
|
-
"vitest": "^4.1.5"
|
|
34
|
-
}
|
|
35
|
-
}
|
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"compilerOptions": {
|
|
3
|
-
"target": "ES2022",
|
|
4
|
-
"lib": ["dom", "dom.iterable", "esnext"],
|
|
5
|
-
"allowJs": false,
|
|
6
|
-
"skipLibCheck": true,
|
|
7
|
-
"strict": true,
|
|
8
|
-
"noEmit": true,
|
|
9
|
-
"esModuleInterop": true,
|
|
10
|
-
"module": "esnext",
|
|
11
|
-
"moduleResolution": "bundler",
|
|
12
|
-
"resolveJsonModule": true,
|
|
13
|
-
"isolatedModules": true,
|
|
14
|
-
"jsx": "preserve",
|
|
15
|
-
"incremental": true,
|
|
16
|
-
"plugins": [{ "name": "next" }],
|
|
17
|
-
"paths": {
|
|
18
|
-
"@/*": ["./*"]
|
|
19
|
-
}
|
|
20
|
-
},
|
|
21
|
-
"include": ["next-env.d.ts", "**/*.ts", "**/*.tsx", ".next/types/**/*.ts", ".next/dev/types/**/*.ts"],
|
|
22
|
-
"exclude": ["node_modules"]
|
|
23
|
-
}
|
|
@@ -1,145 +0,0 @@
|
|
|
1
|
-
---
|
|
2
|
-
name: cimplify-storefront
|
|
3
|
-
description: Build, customize, rebrand, or deploy a Cimplify-scaffolded storefront. Triggers when the user asks to create a storefront, rebrand a Cimplify template, change the palette, add a page, deploy to Cimplify, or works in a project containing `lib/brand.ts` and `next.config.ts` with `cacheComponents`.
|
|
4
|
-
---
|
|
5
|
-
|
|
6
|
-
# Cimplify Storefront skill
|
|
7
|
-
|
|
8
|
-
You're working on a project scaffolded from `bunx @cimplify/sdk init`. The architecture is opinionated and the rebrand surface is intentionally small. Read `AGENTS.md` at the project root for the file ↔ brand-field map for *this template's* industry; this skill gives you the playbook that's the same across all six.
|
|
9
|
-
|
|
10
|
-
## The contract — never break
|
|
11
|
-
|
|
12
|
-
1. **`lib/brand.ts` is the only place for content edits.** Every visible string reads from this file. If a string isn't in `brand`, *add a field* to the `Brand` interface — don't hardcode it in a page or component.
|
|
13
|
-
2. **`app/globals.css` `@theme { … }`** holds palette + radius + font references. To re-skin the entire site, edit only this block.
|
|
14
|
-
3. **Server Components are cached** via `'use cache'` + `cacheTag(tags.X())` + `cacheLife("hours")`. Don't downgrade them to `"use client"` to avoid an issue — fix the issue.
|
|
15
|
-
4. **Client islands** (anything reading `useSearchParams`, `usePathname`, `useRouter`, `useState`) live behind `<Suspense>`.
|
|
16
|
-
5. **`cacheComponents: true`** in `next.config.ts` is non-negotiable. Don't turn it off.
|
|
17
|
-
6. **`bun run test:run` (vitest)** is the canonical test runner. `bun test` will show false failures because Bun's `vi` shim is incomplete.
|
|
18
|
-
7. **Cart, checkout, orders stay client.** They're session-bound. Don't try to SSR them.
|
|
19
|
-
|
|
20
|
-
## The brand-field schema (in `lib/brand.ts`)
|
|
21
|
-
|
|
22
|
-
```
|
|
23
|
-
identity: name, shortName, microTag, description, schemaType, currency, locale
|
|
24
|
-
contact: address, streetAddress, city, countryCode, phone, phoneTel, email, privacyEmail, hours
|
|
25
|
-
socials: [{ label, href, icon }] // icon ∈ instagram|x|tiktok|facebook|youtube|linkedin|whatsapp
|
|
26
|
-
header: { nav: [{ label, href }] }
|
|
27
|
-
hero: { badge, title, subtitle, primaryCtaLabel, secondaryCtaLabel?, secondaryCtaHref? }
|
|
28
|
-
optional: trustItems[]?, brandStrip?, promo?, tradeIn? // render conditionally
|
|
29
|
-
newsletter: { eyebrow, title, body, placeholder, submitLabel, successLabel }
|
|
30
|
-
about: { eyebrow, title, paragraphs[], sections[{ heading, body }] }
|
|
31
|
-
faq: { eyebrow, title, sections[{ title, items[{ q, a }] }], contactPrompt, contactEmail }
|
|
32
|
-
terms,
|
|
33
|
-
privacy,
|
|
34
|
-
shipping,
|
|
35
|
-
returns,
|
|
36
|
-
accessibility: { eyebrow, title, lastUpdated, sections[{ heading, body | { intro, bullets[] } }] }
|
|
37
|
-
account: eyebrows + titles for /account, /login, /signup
|
|
38
|
-
contactPage: { eyebrow, title, body, reasons[], directLines[{ label, value, href }] }
|
|
39
|
-
trackOrder: { eyebrow, title, body }
|
|
40
|
-
footer: { blurb, sitemap[{ title, links[] }], poweredBy? }
|
|
41
|
-
llms: { summary } // opens /llms.txt
|
|
42
|
-
mock: { seed, businessId }
|
|
43
|
-
```
|
|
44
|
-
|
|
45
|
-
## Playbook — common tasks
|
|
46
|
-
|
|
47
|
-
### Rebrand a storefront for a new merchant
|
|
48
|
-
|
|
49
|
-
1. Edit `lib/brand.ts`. Replace every field with the merchant's content. Use the brief / context the user gave you.
|
|
50
|
-
2. Edit `app/globals.css` `@theme { … }`. Change `--color-primary`, `--color-background`, `--color-foreground`, optionally `--radius`. Use OKLCH; if the brand only gave hex, convert.
|
|
51
|
-
3. (Optional) Swap fonts in `app/layout.tsx` — `next/font/google` import + the variable wired into the `<html>` className.
|
|
52
|
-
4. Set `.env.local`: `NEXT_PUBLIC_CIMPLIFY_API_URL`, `NEXT_PUBLIC_CIMPLIFY_PUBLIC_KEY`, `NEXT_PUBLIC_CIMPLIFY_BUSINESS_ID`, `NEXT_PUBLIC_SITE_URL`.
|
|
53
|
-
|
|
54
|
-
Don't touch any other file. If the rebrand needs content not in the schema, add the field to `Brand` first, populate it, then read it from the page.
|
|
55
|
-
|
|
56
|
-
### Add a new section / component
|
|
57
|
-
|
|
58
|
-
1. Build it as a Server Component in `components/` (or a client island in `*-client.tsx` if interactive).
|
|
59
|
-
2. Read merchant copy from `brand`. Add new fields to the `Brand` interface if needed.
|
|
60
|
-
3. Wrap interactive bits in `<Suspense fallback={…}>` so the cached chrome streams.
|
|
61
|
-
4. Compose into the page.
|
|
62
|
-
|
|
63
|
-
### Wire a Server Action that mutates data
|
|
64
|
-
|
|
65
|
-
```ts
|
|
66
|
-
"use server";
|
|
67
|
-
import { getServerClient, revalidateProducts } from "@cimplify/sdk/server";
|
|
68
|
-
|
|
69
|
-
export async function createProduct(input: ProductInput) {
|
|
70
|
-
await getServerClient().catalogue.createProduct(input);
|
|
71
|
-
revalidateProducts();
|
|
72
|
-
}
|
|
73
|
-
```
|
|
74
|
-
|
|
75
|
-
After every mutation, call the matching `revalidate*` helper from `@cimplify/sdk/server`: `revalidateProducts`, `revalidateProduct(id)`, `revalidateCategories`, `revalidateCategory(id)`, `revalidateCollections`, `revalidateCollection(id)`, `revalidateBusiness`.
|
|
76
|
-
|
|
77
|
-
### Add a Server Component data fetch
|
|
78
|
-
|
|
79
|
-
```ts
|
|
80
|
-
import { cacheTag, cacheLife } from "next/cache";
|
|
81
|
-
import { getServerClient, tags } from "@cimplify/sdk/server";
|
|
82
|
-
|
|
83
|
-
async function getX() {
|
|
84
|
-
"use cache";
|
|
85
|
-
cacheTag(tags.products());
|
|
86
|
-
cacheLife("hours");
|
|
87
|
-
const r = await getServerClient().catalogue.getProducts({ limit: 24 });
|
|
88
|
-
if (!r.ok) throw new Error(r.error.message);
|
|
89
|
-
return r.value.items;
|
|
90
|
-
}
|
|
91
|
-
```
|
|
92
|
-
|
|
93
|
-
### Eject an SDK component for deeper customization
|
|
94
|
-
|
|
95
|
-
Try `classNames`, `renderImage`, `renderLink`, slot props first. If those run out:
|
|
96
|
-
|
|
97
|
-
```bash
|
|
98
|
-
bunx @cimplify/sdk eject --list
|
|
99
|
-
bunx @cimplify/sdk eject product-card --dir src/components/cimplify
|
|
100
|
-
```
|
|
101
|
-
|
|
102
|
-
Once ejected, the file is yours. Hooks/types still come from `@cimplify/sdk`.
|
|
103
|
-
|
|
104
|
-
### Deploy
|
|
105
|
-
|
|
106
|
-
```bash
|
|
107
|
-
bunx @cimplify/sdk login
|
|
108
|
-
bunx @cimplify/sdk projects create my-store
|
|
109
|
-
bunx @cimplify/sdk link <project-id>
|
|
110
|
-
bunx @cimplify/sdk env push
|
|
111
|
-
bunx @cimplify/sdk deploy --prod
|
|
112
|
-
bunx @cimplify/sdk logs --follow
|
|
113
|
-
bunx @cimplify/sdk domains add my-store.com
|
|
114
|
-
```
|
|
115
|
-
|
|
116
|
-
## Pitfalls — explicit ❌ list
|
|
117
|
-
|
|
118
|
-
- ❌ Hardcoding any visible string in a page or component. Always `brand.X`.
|
|
119
|
-
- ❌ Disabling `cacheComponents: true` to silence a warning. Fix the warning by wrapping the dynamic call in `<Suspense>`.
|
|
120
|
-
- ❌ Using `unstable_cache` — Next 16's canonical primitive is `'use cache'` + `cacheTag` + `cacheLife`.
|
|
121
|
-
- ❌ Bypassing `getServerClient()` and calling `createCimplifyClient` directly in a Server Component — loses per-request memoization.
|
|
122
|
-
- ❌ Mutating data without calling the matching `revalidate*` helper.
|
|
123
|
-
- ❌ Adding an `app/error.tsx` handler that calls `reset()` without logging — silently swallowed errors hide bugs.
|
|
124
|
-
- ❌ Running `bun test` and reporting failures. Use `bun run test:run` (vitest).
|
|
125
|
-
- ❌ Editing the per-template `AGENTS.md` to remove notes about TODOs (contact form, newsletter fake submits) — they're real.
|
|
126
|
-
|
|
127
|
-
## Where things live
|
|
128
|
-
|
|
129
|
-
| Need | Look here |
|
|
130
|
-
|---|---|
|
|
131
|
-
| Which page reads which `brand.X` field | `AGENTS.md` at project root |
|
|
132
|
-
| Architectural rules | `AGENTS.md` at project root + this skill |
|
|
133
|
-
| Running locally | `bun dev` (boots mock + Next together) |
|
|
134
|
-
| Switching mock seed | edit `dev:mock` in `package.json` and `NEXT_PUBLIC_CIMPLIFY_BUSINESS_ID` in `.env.local` |
|
|
135
|
-
| Full SDK reference | `docs/sdk/storefronts.md` in the Cimplify repo |
|
|
136
|
-
|
|
137
|
-
## What to do when the user asks something out-of-scope
|
|
138
|
-
|
|
139
|
-
If the user asks for something the template doesn't support out of the box:
|
|
140
|
-
|
|
141
|
-
1. **Check first** — is there an SDK component or hook that does it? `@cimplify/sdk/react` has 50+ components, 30+ hooks. Search `node_modules/@cimplify/sdk/dist/react.d.mts` if needed.
|
|
142
|
-
2. **Compose from existing parts** before authoring new ones.
|
|
143
|
-
3. **If genuinely missing** — build the new component, hoist its strings into `brand.ts`, document in `AGENTS.md`.
|
|
144
|
-
|
|
145
|
-
Don't introduce competing patterns (a new caching strategy, a new auth flow, a new theming system). The template's opinions are intentional.
|
|
@@ -1,25 +0,0 @@
|
|
|
1
|
-
---
|
|
2
|
-
description: Cimplify storefront — architectural rules and rebrand contract for a project scaffolded from `bunx @cimplify/sdk init`. Triggers when files like lib/brand.ts, app/globals.css, components/header.tsx, or .cimplify/project.json are in the workspace.
|
|
3
|
-
globs: ["lib/brand.ts", "app/**", "components/**", ".env.local", "next.config.ts"]
|
|
4
|
-
alwaysApply: true
|
|
5
|
-
---
|
|
6
|
-
|
|
7
|
-
# Cimplify storefront
|
|
8
|
-
|
|
9
|
-
This project was scaffolded from a Cimplify template. Read `AGENTS.md` at the project root for the file ↔ `brand.X` field map and `.claude/skills/cimplify-storefront/SKILL.md` for the full playbook.
|
|
10
|
-
|
|
11
|
-
## The contract
|
|
12
|
-
|
|
13
|
-
1. **`lib/brand.ts`** — every visible string. If something isn't there, add a field to the `Brand` interface; don't hardcode.
|
|
14
|
-
2. **`app/globals.css` `@theme` block** — palette, radius, font references.
|
|
15
|
-
3. **Server Components are cached** via `'use cache'` + `cacheTag(tags.X())` + `cacheLife("hours")`. Don't downgrade to client to silence a warning.
|
|
16
|
-
4. **Client islands** behind `<Suspense>`.
|
|
17
|
-
5. **`cacheComponents: true`** in `next.config.ts` is non-negotiable.
|
|
18
|
-
6. Use **`bun run test:run`** (vitest), not `bun test`.
|
|
19
|
-
|
|
20
|
-
## Don't
|
|
21
|
-
|
|
22
|
-
- Hardcode visible strings in pages/components.
|
|
23
|
-
- Use `unstable_cache` (Next 16 uses `'use cache'`).
|
|
24
|
-
- Bypass `getServerClient()` (loses per-request memoization).
|
|
25
|
-
- Mutate without calling the matching `revalidate*` helper from `@cimplify/sdk/server`.
|
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
# Cimplify API base URL.
|
|
2
|
-
# Dev: leave empty so the SDK uses the current origin (localhost:3000),
|
|
3
|
-
# which Next.js rewrites to the mock at 127.0.0.1:8787 (see next.config.ts).
|
|
4
|
-
# Production: set to your Cimplify host (e.g. https://api.cimplify.io).
|
|
5
|
-
NEXT_PUBLIC_CIMPLIFY_API_URL=
|
|
6
|
-
|
|
7
|
-
# Tenant public key. The mock accepts any value.
|
|
8
|
-
NEXT_PUBLIC_CIMPLIFY_PUBLIC_KEY=mock-dev
|
|
9
|
-
|
|
10
|
-
# Business id used by the mock seed (fashion: Studio FRX).
|
|
11
|
-
NEXT_PUBLIC_CIMPLIFY_BUSINESS_ID=bus_studio_frx
|
|
12
|
-
|
|
13
|
-
# Canonical public site URL — used by sitemap.xml, robots.txt, llms.txt,
|
|
14
|
-
# and OpenGraph metadata. Set this on production deploys (Vercel auto-injects
|
|
15
|
-
# via VERCEL_URL but Next prefers an explicit value).
|
|
16
|
-
NEXT_PUBLIC_SITE_URL=https://example.com
|
|
@@ -1,126 +0,0 @@
|
|
|
1
|
-
# AGENTS.md — Fashion / streetwear storefront template
|
|
2
|
-
|
|
3
|
-
If you are an AI agent (Claude, Cursor, Aider, devin, …) working on this storefront, **start here.**
|
|
4
|
-
|
|
5
|
-
## TL;DR for rebranding
|
|
6
|
-
|
|
7
|
-
1. **Edit `lib/brand.ts`** — every visible string lives here.
|
|
8
|
-
2. **Edit `app/globals.css`** — `@theme { … }` for palette + radius + font references.
|
|
9
|
-
3. **Edit `.env.local`** — `NEXT_PUBLIC_CIMPLIFY_API_URL`, `NEXT_PUBLIC_CIMPLIFY_PUBLIC_KEY`, `NEXT_PUBLIC_CIMPLIFY_BUSINESS_ID`, `NEXT_PUBLIC_SITE_URL`.
|
|
10
|
-
|
|
11
|
-
## Aesthetic
|
|
12
|
-
|
|
13
|
-
Streetwear / lookbook-led brands (Nike, Aritzia, Highsnobiety, drop culture):
|
|
14
|
-
|
|
15
|
-
- **Anton display + Inter** — uppercase condensed display, clean body sans.
|
|
16
|
-
- **High-contrast palette** — near-black foreground on near-white background, electric primary (default coral, `oklch(0.7 0.24 30)`).
|
|
17
|
-
- **Sharp corners**: `0.125rem` — minimal rounding.
|
|
18
|
-
- **Editorial full-bleed hero** with image gradient overlay.
|
|
19
|
-
- **Block-letter header** — no logo mark, just the shortName in display type.
|
|
20
|
-
- Schema.org `@type` is `Store`.
|
|
21
|
-
|
|
22
|
-
## Page surface
|
|
23
|
-
|
|
24
|
-
```
|
|
25
|
-
app/
|
|
26
|
-
page.tsx Multi-section home — full-bleed editorial hero,
|
|
27
|
-
trust bar, category tiles, promo banner,
|
|
28
|
-
"Just dropped" grid, brand strip, collections,
|
|
29
|
-
studio-collective CTA, best sellers, newsletter
|
|
30
|
-
shop/page.tsx SDK <CataloguePage/> with custom hero
|
|
31
|
-
search/page.tsx Search
|
|
32
|
-
collections/[slug]/page.tsx Collection landing (drops)
|
|
33
|
-
categories/[slug]/page.tsx Category landing
|
|
34
|
-
products/[slug]/page.tsx Full product detail page (Product JSON-LD)
|
|
35
|
-
|
|
36
|
-
size-guide/page.tsx ⭐ Fashion-specific: chest/length/shoulder + waist/hip/inseam
|
|
37
|
-
tables, "how to measure" callout
|
|
38
|
-
lookbook/page.tsx ⭐ Fashion-specific: editorial multi-drop lookbook —
|
|
39
|
-
hero + 3-up tile galleries per drop, "Shop Drop X" CTAs
|
|
40
|
-
|
|
41
|
-
cart/page.tsx, checkout/page.tsx, orders/[id]/page.tsx
|
|
42
|
-
|
|
43
|
-
account/page.tsx <CimplifyAccount /> (iframe)
|
|
44
|
-
account/orders/page.tsx <CimplifyAccount section="orders" />
|
|
45
|
-
account/addresses/page.tsx <CimplifyAccount section="addresses" />
|
|
46
|
-
account/settings/page.tsx <CimplifyAccount section="settings" />
|
|
47
|
-
login/page.tsx, signup/page.tsx redirects → /account
|
|
48
|
-
|
|
49
|
-
contact/page.tsx, track-order/page.tsx
|
|
50
|
-
|
|
51
|
-
about/page.tsx, faq/page.tsx
|
|
52
|
-
shipping/page.tsx (DHL Express worldwide), returns/page.tsx (30 days),
|
|
53
|
-
accessibility/page.tsx, terms/page.tsx, privacy/page.tsx
|
|
54
|
-
|
|
55
|
-
sitemap-page/page.tsx, sitemap.ts, robots.ts, llms.txt/route.ts, opensearch.xml/route.ts
|
|
56
|
-
error.tsx, not-found.tsx
|
|
57
|
-
```
|
|
58
|
-
|
|
59
|
-
## File ↔ brand-field map
|
|
60
|
-
|
|
61
|
-
| File | Reads from `brand` |
|
|
62
|
-
|---|---|
|
|
63
|
-
| `app/layout.tsx` | identity, contact, socials, Store JSON-LD |
|
|
64
|
-
| `app/page.tsx` | `brand.hero`, `brand.trustItems`, `brand.brandStrip`, `brand.promo`, `brand.tradeIn` (= studio-collective copy), `brand.newsletter` |
|
|
65
|
-
| `app/about/page.tsx` | `brand.about` |
|
|
66
|
-
| `app/faq/page.tsx` | `brand.faq` (sizing, drops, returns, customs) |
|
|
67
|
-
| `app/shipping/page.tsx` | `brand.shipping` (worldwide DHL, customs) |
|
|
68
|
-
| `app/returns/page.tsx` | `brand.returns` (30 days, free US/UK/EU) |
|
|
69
|
-
| `app/accessibility/page.tsx` | `brand.accessibility` |
|
|
70
|
-
| `app/terms/page.tsx`, `app/privacy/page.tsx` | `brand.terms`, `brand.privacy` |
|
|
71
|
-
| `app/contact/page.tsx` | `brand.contactPage`, `brand.contact` |
|
|
72
|
-
| `app/track-order/page.tsx` | `brand.trackOrder` |
|
|
73
|
-
| `app/account/*/page.tsx` | `brand.account` (iframe owns UI) |
|
|
74
|
-
| `app/products/[slug]/page.tsx` | `brand.name`, `brand.currency` (Product JSON-LD) |
|
|
75
|
-
| `app/size-guide/page.tsx` | currently has its size charts inlined — hoist to `brand.sizeGuide` if you want agents to edit them |
|
|
76
|
-
| `app/lookbook/page.tsx` | currently has the lookbook entries inlined (image URLs + drop names) — hoist to `brand.lookbook` for agent editing |
|
|
77
|
-
| `app/llms.txt/route.ts` | `brand.llms`, contact, currency |
|
|
78
|
-
| `components/header.tsx`, `footer.tsx` | `brand.header`, `brand.footer`, `brand.contact`, `brand.socials` |
|
|
79
|
-
| `components/promo-banner.tsx`, `trade-in-cta.tsx`, `brand-marquee.tsx`, `trust-bar.tsx`, `newsletter.tsx` | corresponding optional sections in `brand` |
|
|
80
|
-
|
|
81
|
-
## Fashion-specific notes
|
|
82
|
-
|
|
83
|
-
- **Hero is full-bleed editorial.** Replace `HERO_FALLBACK_IMAGE` in `app/page.tsx` with the merchant's drop campaign shot for maximum impact.
|
|
84
|
-
- **Drop badges and "limited run" copy** drive urgency. Keep `brand.hero.badge` and `brand.promo.badge` short and time-bounded.
|
|
85
|
-
- **`brand.tradeIn`** is repurposed as the "Studio collective" / membership programme — three-step access flow.
|
|
86
|
-
- **Product detail uses the page-driven model** (`/products/[slug]`) — fashion is a consideration purchase (sizing, fit, fabric details), not impulse.
|
|
87
|
-
- **`brandStrip.headline` is `"Stocked at"`** with editorial publication wordmarks (Vogue, Highsnobiety, etc.) — typography-led, no logo licensing required.
|
|
88
|
-
|
|
89
|
-
## Known TODOs
|
|
90
|
-
|
|
91
|
-
- `app/size-guide/page.tsx` has its size charts inlined as constants. Move them to `brand.sizeGuide` (typed) so agents can edit per-merchant size charts in one file.
|
|
92
|
-
- `app/lookbook/page.tsx` has its drop entries inlined. Move to `brand.lookbook` for agent editing — each drop becomes `{ drop, title, date, byline, hero, tiles[] }`.
|
|
93
|
-
- Contact form + newsletter fake submits.
|
|
94
|
-
|
|
95
|
-
## Mock seed
|
|
96
|
-
|
|
97
|
-
Wired to `--seed fashion` (Studio FRX apparel catalogue — 14 products with size variants XS–2XL, Drop 04 + Best Sellers collections, full-bleed product imagery served from `static-tmp.cimplify.io`).
|
|
98
|
-
|
|
99
|
-
## Customizing SDK components
|
|
100
|
-
|
|
101
|
-
For anything beyond `lib/brand.ts` + `app/globals.css`, you'll likely want to lean on the SDK's prebuilt components rather than reinvent. Particularly for **product customization** (variants, add-ons, bundles, composites, services with scheduling), the SDK already gets the price math, variant axis matching, and cart payload contracts right. Default to ejecting and restyling:
|
|
102
|
-
|
|
103
|
-
```bash
|
|
104
|
-
bunx @cimplify/sdk add variant-selector # copies into ./components/
|
|
105
|
-
bunx @cimplify/sdk add cart-drawer
|
|
106
|
-
bunx @cimplify/sdk add product-page
|
|
107
|
-
```
|
|
108
|
-
|
|
109
|
-
Then edit the local copy. **Don't change the cart payload shape** unless you're also touching the SDK's mock and the backend lens.
|
|
110
|
-
|
|
111
|
-
If you're considering a from-scratch rebuild of the customizer, read these SDK source files first to understand the contract you must reproduce:
|
|
112
|
-
- `src/react/product-customizer.tsx` — top-level state machine + final `onAddToCart` payload assembly
|
|
113
|
-
- `src/react/variant-selector.tsx` — multi-axis matching via `display_attributes`; default-variant init runs in a `useEffect` and is easy to break
|
|
114
|
-
- `src/react/{add-on,bundle,composite}-selector.tsx` — group constraints, exclusivity rules, per-component variants
|
|
115
|
-
- `src/mock/domain/cart/{index,pricing}.ts` — the contract: `computeUnitPrice`, `computeBundlePrice`, `computeCompositePrice` (4 modes), `computeLineKey`
|
|
116
|
-
|
|
117
|
-
Full ejection + customization rules are in the SDK-level [`AGENTS.md`](../../AGENTS.md) under "Don't reinvent product customization".
|
|
118
|
-
|
|
119
|
-
## Quick start
|
|
120
|
-
|
|
121
|
-
```bash
|
|
122
|
-
bun install
|
|
123
|
-
bun dev
|
|
124
|
-
```
|
|
125
|
-
|
|
126
|
-
Open <http://localhost:3000>.
|
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
# CLAUDE.md
|
|
2
|
-
|
|
3
|
-
This project was scaffolded from a Cimplify storefront template (`bunx @cimplify/sdk init`).
|
|
4
|
-
|
|
5
|
-
## Read these first
|
|
6
|
-
|
|
7
|
-
- **`AGENTS.md`** at the project root — the file ↔ `brand.X` field map for *this template's* industry, plus the architectural rules.
|
|
8
|
-
- **`.claude/skills/cimplify-storefront/SKILL.md`** — the playbook for common tasks (rebrand, add a section, wire a Server Action, deploy, eject a component). Invoke it whenever you're asked to change content, palette, copy, or routing.
|
|
9
|
-
|
|
10
|
-
## The two-line summary
|
|
11
|
-
|
|
12
|
-
1. **Edit `lib/brand.ts`** for any visible string.
|
|
13
|
-
2. **Edit `app/globals.css` `@theme` block** for any palette / radius / font change.
|
|
14
|
-
|
|
15
|
-
That covers ~95% of what merchants ask for. For anything else, follow the `cimplify-storefront` skill.
|
|
16
|
-
|
|
17
|
-
## Don't do
|
|
18
|
-
|
|
19
|
-
- Hardcode strings in pages or components.
|
|
20
|
-
- Disable `cacheComponents: true` in `next.config.ts`.
|
|
21
|
-
- Use `unstable_cache` — Next 16's canonical primitive is `'use cache'`.
|
|
22
|
-
- Run `bun test` (Bun's `vi` shim is incomplete) — use `bun run test:run`.
|
|
@@ -1,77 +0,0 @@
|
|
|
1
|
-
# __STOREFRONT_NAME__
|
|
2
|
-
|
|
3
|
-
A Cimplify storefront scaffolded from the **retail** template — Next.js 16 (App Router), React 19, Tailwind v4. Cool navy + electric blue palette, Inter + JetBrains Mono typography, modern electronics-store aesthetic.
|
|
4
|
-
|
|
5
|
-
## Run
|
|
6
|
-
|
|
7
|
-
```bash
|
|
8
|
-
bun install
|
|
9
|
-
bun dev
|
|
10
|
-
```
|
|
11
|
-
|
|
12
|
-
Two things start in parallel:
|
|
13
|
-
|
|
14
|
-
- `bunx @cimplify/sdk --seed retail` — the Cimplify mock API on `http://127.0.0.1:8787`, seeded with Currents Electronics.
|
|
15
|
-
- `next dev` — this storefront on `http://localhost:3000`.
|
|
16
|
-
|
|
17
|
-
Open the storefront in your browser. Edit `app/page.tsx` to start customising.
|
|
18
|
-
|
|
19
|
-
## Structure
|
|
20
|
-
|
|
21
|
-
```
|
|
22
|
-
app/
|
|
23
|
-
layout.tsx # root layout, fonts, providers, header/footer/modal
|
|
24
|
-
page.tsx # home
|
|
25
|
-
shop/page.tsx # full catalogue (SDK <CataloguePage/>)
|
|
26
|
-
collections/[slug]/ # collection landing
|
|
27
|
-
categories/[slug]/ # category landing
|
|
28
|
-
cart/page.tsx # SDK <CartPage/>
|
|
29
|
-
checkout/page.tsx # SDK <CheckoutPage/>
|
|
30
|
-
orders/[id]/page.tsx # post-checkout thank-you
|
|
31
|
-
about, faq, terms, privacy
|
|
32
|
-
globals.css # Tailwind import + theme tokens
|
|
33
|
-
components/
|
|
34
|
-
providers.tsx # CimplifyProvider client wrapper
|
|
35
|
-
header.tsx, footer.tsx, hero.tsx
|
|
36
|
-
store-product-card.tsx # SDK <ProductCard/> wired to URL-driven modal
|
|
37
|
-
product-modal.tsx # ?product=<slug> deep-linkable modal
|
|
38
|
-
collection-strip.tsx # horizontal product strip
|
|
39
|
-
category-grid.tsx # SDK <CategoryGrid/> with router navigation
|
|
40
|
-
lib/
|
|
41
|
-
cart.ts # useCartCount() for the header pill
|
|
42
|
-
```
|
|
43
|
-
|
|
44
|
-
## Switch the seed
|
|
45
|
-
|
|
46
|
-
This template is wired to the `retail` seed. To preview a different industry without re-scaffolding:
|
|
47
|
-
|
|
48
|
-
```bash
|
|
49
|
-
bunx @cimplify/sdk --seed restaurant # Mama's Kitchen
|
|
50
|
-
bunx @cimplify/sdk --seed services # Serene Spa
|
|
51
|
-
bunx @cimplify/sdk --seed grocery # FreshMart
|
|
52
|
-
```
|
|
53
|
-
|
|
54
|
-
Update `NEXT_PUBLIC_CIMPLIFY_BUSINESS_ID` in `.env.local` to match the seeded business.
|
|
55
|
-
|
|
56
|
-
For a fresh scaffold with another design altogether:
|
|
57
|
-
|
|
58
|
-
```bash
|
|
59
|
-
bunx @cimplify/sdk init my-store --template bakery # warm food/pastry
|
|
60
|
-
bunx @cimplify/sdk init my-store --template restaurant # coming soon
|
|
61
|
-
bunx @cimplify/sdk init my-store --template services # coming soon
|
|
62
|
-
bunx @cimplify/sdk init my-store --template grocery # coming soon
|
|
63
|
-
```
|
|
64
|
-
|
|
65
|
-
## Go live
|
|
66
|
-
|
|
67
|
-
```diff
|
|
68
|
-
# .env.local
|
|
69
|
-
- NEXT_PUBLIC_CIMPLIFY_API_URL=http://127.0.0.1:8787
|
|
70
|
-
+ NEXT_PUBLIC_CIMPLIFY_API_URL=https://api.cimplify.io
|
|
71
|
-
- NEXT_PUBLIC_CIMPLIFY_PUBLIC_KEY=mock-dev
|
|
72
|
-
+ NEXT_PUBLIC_CIMPLIFY_PUBLIC_KEY=<your tenant key>
|
|
73
|
-
- NEXT_PUBLIC_CIMPLIFY_BUSINESS_ID=bus_currents_electronics
|
|
74
|
-
+ NEXT_PUBLIC_CIMPLIFY_BUSINESS_ID=<your business id>
|
|
75
|
-
```
|
|
76
|
-
|
|
77
|
-
Deploy to Vercel with one click — `next.config.ts` already whitelists the SDK image hosts under `images.remotePatterns`.
|
|
@@ -1,55 +0,0 @@
|
|
|
1
|
-
import { createCartFlowSuite } from "@cimplify/sdk/testing/suite";
|
|
2
|
-
import { expect } from "vitest";
|
|
3
|
-
import { brand } from "../lib/brand";
|
|
4
|
-
|
|
5
|
-
/**
|
|
6
|
-
* Cart flow suite — base + per-merchant assertions.
|
|
7
|
-
*
|
|
8
|
-
* The base suite (from `@cimplify/sdk/testing/suite`) exercises the
|
|
9
|
-
* universal contract: empty cart, add, dedupe, remove, businessId
|
|
10
|
-
* round-trip. The `extend` hook below adds Studio FRX-specific
|
|
11
|
-
* invariants — copy this pattern when a merchant has unique business
|
|
12
|
-
* rules that need their own coverage.
|
|
13
|
-
*
|
|
14
|
-
* • `getHandle()` returns the suite's current `TestClientHandle`
|
|
15
|
-
* (per `it`) so the seed and session are already wired.
|
|
16
|
-
* • `it` is the vitest API; cases land inside the suite's `describe`
|
|
17
|
-
* so its `beforeEach`/`afterEach` hooks apply automatically.
|
|
18
|
-
*/
|
|
19
|
-
createCartFlowSuite({
|
|
20
|
-
seed: brand.mock.seed,
|
|
21
|
-
businessId: brand.mock.businessId,
|
|
22
|
-
extend: ({ getHandle, it }) => {
|
|
23
|
-
it("Studio FRX prices everything in GHS", async () => {
|
|
24
|
-
// Currency is brand-level (not per-product) — Product carries the price
|
|
25
|
-
// string only. Catalog completeness here is just a sanity check.
|
|
26
|
-
expect(brand.currency).toBe("GHS");
|
|
27
|
-
const h = getHandle();
|
|
28
|
-
const list = await h.client.catalogue.getProducts();
|
|
29
|
-
if (!list.ok) throw list.error;
|
|
30
|
-
const items = (list.value as unknown as { items?: unknown[] }).items ?? [];
|
|
31
|
-
expect(items.length).toBeGreaterThan(0);
|
|
32
|
-
});
|
|
33
|
-
|
|
34
|
-
it("every apparel product covers the studio's core size run (S/M/L)", async () => {
|
|
35
|
-
const h = getHandle();
|
|
36
|
-
const list = await h.client.catalogue.getProducts();
|
|
37
|
-
if (!list.ok) throw list.error;
|
|
38
|
-
const items = (list.value as unknown as { items?: { id: string; name: string }[] }).items ?? [];
|
|
39
|
-
|
|
40
|
-
// Apparel only — caps/socks/totes intentionally lack size variants.
|
|
41
|
-
const apparel = items.filter((p) => /tee|hoodie|jacket|trouser|pant/i.test(p.name));
|
|
42
|
-
expect(apparel.length).toBeGreaterThan(0);
|
|
43
|
-
|
|
44
|
-
const required = new Set(["S", "M", "L"]);
|
|
45
|
-
for (const product of apparel) {
|
|
46
|
-
const variants = await h.client.catalogue.getVariants(product.id);
|
|
47
|
-
if (!variants.ok) throw variants.error;
|
|
48
|
-
const sizes = new Set(variants.value.map((v) => v.name).filter(Boolean));
|
|
49
|
-
for (const size of required) {
|
|
50
|
-
expect(sizes, `${product.name} missing size ${size}`).toContain(size);
|
|
51
|
-
}
|
|
52
|
-
}
|
|
53
|
-
});
|
|
54
|
-
},
|
|
55
|
-
});
|
|
@@ -1,41 +0,0 @@
|
|
|
1
|
-
import type { Metadata } from "next";
|
|
2
|
-
import { brand } from "@/lib/brand";
|
|
3
|
-
|
|
4
|
-
export const metadata: Metadata = {
|
|
5
|
-
title: `About — ${brand.name}`,
|
|
6
|
-
description: brand.description,
|
|
7
|
-
};
|
|
8
|
-
|
|
9
|
-
export default function AboutPage() {
|
|
10
|
-
const a = brand.about;
|
|
11
|
-
// Title supports a single \n for a hard line break.
|
|
12
|
-
const titleParts = a.title.split("\n");
|
|
13
|
-
return (
|
|
14
|
-
<article className="max-w-3xl mx-auto px-8 py-16">
|
|
15
|
-
<p className="text-[11px] font-mono uppercase tracking-[0.16em] text-primary mb-2">
|
|
16
|
-
{a.eyebrow}
|
|
17
|
-
</p>
|
|
18
|
-
<h1 className="text-[clamp(2.25rem,5vw,3.5rem)] font-bold mb-6 -tracking-[0.025em] leading-tight">
|
|
19
|
-
{titleParts.map((line, i) => (
|
|
20
|
-
<span key={i}>
|
|
21
|
-
{line}
|
|
22
|
-
{i < titleParts.length - 1 && <br />}
|
|
23
|
-
</span>
|
|
24
|
-
))}
|
|
25
|
-
</h1>
|
|
26
|
-
<div className="prose prose-lg max-w-none space-y-5 text-foreground/90 leading-relaxed">
|
|
27
|
-
{a.paragraphs.map((p, i) => (
|
|
28
|
-
<p key={i}>{p}</p>
|
|
29
|
-
))}
|
|
30
|
-
{a.sections.map((s) => (
|
|
31
|
-
<div key={s.heading}>
|
|
32
|
-
<h2 className="text-2xl font-semibold mt-10 mb-3 -tracking-[0.02em]">
|
|
33
|
-
{s.heading}
|
|
34
|
-
</h2>
|
|
35
|
-
<p>{s.body}</p>
|
|
36
|
-
</div>
|
|
37
|
-
))}
|
|
38
|
-
</div>
|
|
39
|
-
</article>
|
|
40
|
-
);
|
|
41
|
-
}
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
import type { Metadata } from "next";
|
|
2
|
-
import { brand } from "@/lib/brand";
|
|
3
|
-
import { PolicyPage } from "@/components/policy-page";
|
|
4
|
-
|
|
5
|
-
export const metadata: Metadata = {
|
|
6
|
-
title: `${brand.accessibility.title} — ${brand.name}`,
|
|
7
|
-
};
|
|
8
|
-
|
|
9
|
-
export default function AccessibilityPage() {
|
|
10
|
-
return <PolicyPage policy={brand.accessibility} />;
|
|
11
|
-
}
|