@cimplify/sdk 0.44.33 → 0.45.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +21 -16
- package/dist/styles.css +1 -1
- package/package.json +5 -9
- package/dist/cli/commands/deploy.mjs +0 -569
- package/dist/cli/commands/dev.mjs +0 -434
- package/dist/cli/commands/domains.mjs +0 -653
- package/dist/cli/commands/env.mjs +0 -610
- package/dist/cli/commands/link.mjs +0 -325
- package/dist/cli/commands/login.mjs +0 -515
- package/dist/cli/commands/logout.mjs +0 -54
- package/dist/cli/commands/logs.mjs +0 -358
- package/dist/cli/commands/projects.mjs +0 -327
- package/dist/cli/commands/rollback.mjs +0 -477
- package/dist/cli/commands/status.mjs +0 -380
- package/dist/cli/commands/unlink.mjs +0 -58
- package/dist/cli/commands/whoami.mjs +0 -234
- package/dist/cli.js +0 -184
- package/dist/dispatcher.mjs +0 -286
- package/registry/booking-page.json +0 -18
- package/registry/bookings-page.json +0 -17
- package/registry/service-card.json +0 -16
- package/registry/service-grid.json +0 -16
- package/templates/storefront-bakery/.claude/skills/cimplify-storefront/SKILL.md +0 -145
- package/templates/storefront-bakery/.cursor/rules/cimplify-storefront.mdc +0 -25
- package/templates/storefront-bakery/.env.example +0 -16
- package/templates/storefront-bakery/AGENTS.md +0 -120
- package/templates/storefront-bakery/CLAUDE.md +0 -22
- package/templates/storefront-bakery/README.md +0 -73
- package/templates/storefront-bakery/__tests__/brand.test.ts +0 -4
- package/templates/storefront-bakery/__tests__/cart-flow.test.ts +0 -4
- package/templates/storefront-bakery/__tests__/contract.test.ts +0 -4
- package/templates/storefront-bakery/app/about/page.tsx +0 -38
- package/templates/storefront-bakery/app/accessibility/page.tsx +0 -11
- package/templates/storefront-bakery/app/account/addresses/page.tsx +0 -21
- package/templates/storefront-bakery/app/account/orders/page.tsx +0 -21
- package/templates/storefront-bakery/app/account/page.tsx +0 -22
- package/templates/storefront-bakery/app/account/settings/page.tsx +0 -21
- package/templates/storefront-bakery/app/cart/page.tsx +0 -9
- package/templates/storefront-bakery/app/categories/[slug]/listing-client.tsx +0 -19
- package/templates/storefront-bakery/app/categories/[slug]/page.tsx +0 -118
- package/templates/storefront-bakery/app/checkout/page.tsx +0 -17
- package/templates/storefront-bakery/app/collections/[slug]/listing-client.tsx +0 -20
- package/templates/storefront-bakery/app/collections/[slug]/page.tsx +0 -118
- package/templates/storefront-bakery/app/contact/contact-form.tsx +0 -109
- package/templates/storefront-bakery/app/contact/page.tsx +0 -54
- package/templates/storefront-bakery/app/error.tsx +0 -60
- package/templates/storefront-bakery/app/faq/page.tsx +0 -46
- package/templates/storefront-bakery/app/globals.css +0 -47
- package/templates/storefront-bakery/app/layout.tsx +0 -82
- package/templates/storefront-bakery/app/llms.txt/route.ts +0 -94
- package/templates/storefront-bakery/app/login/page.tsx +0 -17
- package/templates/storefront-bakery/app/not-found.tsx +0 -39
- package/templates/storefront-bakery/app/opensearch.xml/route.ts +0 -37
- package/templates/storefront-bakery/app/orders/[id]/page.tsx +0 -21
- package/templates/storefront-bakery/app/page.tsx +0 -97
- package/templates/storefront-bakery/app/privacy/page.tsx +0 -44
- package/templates/storefront-bakery/app/returns/page.tsx +0 -11
- package/templates/storefront-bakery/app/robots.ts +0 -18
- package/templates/storefront-bakery/app/search/page.tsx +0 -38
- package/templates/storefront-bakery/app/search/search-client.tsx +0 -7
- package/templates/storefront-bakery/app/shipping/page.tsx +0 -16
- package/templates/storefront-bakery/app/shop/page.tsx +0 -31
- package/templates/storefront-bakery/app/shop/shop-client.tsx +0 -27
- package/templates/storefront-bakery/app/signup/page.tsx +0 -17
- package/templates/storefront-bakery/app/sitemap-page/page.tsx +0 -167
- package/templates/storefront-bakery/app/sitemap.ts +0 -62
- package/templates/storefront-bakery/app/terms/page.tsx +0 -44
- package/templates/storefront-bakery/app/track-order/page.tsx +0 -24
- package/templates/storefront-bakery/app/track-order/track-order-form.tsx +0 -69
- package/templates/storefront-bakery/components/account-iframe.tsx +0 -13
- package/templates/storefront-bakery/components/cart-drawer.tsx +0 -14
- package/templates/storefront-bakery/components/cart-pill.tsx +0 -36
- package/templates/storefront-bakery/components/category-grid.tsx +0 -28
- package/templates/storefront-bakery/components/collection-strip.tsx +0 -45
- package/templates/storefront-bakery/components/footer.tsx +0 -148
- package/templates/storefront-bakery/components/header.tsx +0 -43
- package/templates/storefront-bakery/components/hero.tsx +0 -25
- package/templates/storefront-bakery/components/nav-link.tsx +0 -20
- package/templates/storefront-bakery/components/policy-page.tsx +0 -49
- package/templates/storefront-bakery/components/product-modal.tsx +0 -104
- package/templates/storefront-bakery/components/providers.tsx +0 -35
- package/templates/storefront-bakery/components/store-product-card.tsx +0 -87
- package/templates/storefront-bakery/lib/brand.ts +0 -570
- package/templates/storefront-bakery/lib/cart.ts +0 -12
- package/templates/storefront-bakery/next.config.ts +0 -42
- package/templates/storefront-bakery/package.json +0 -35
- package/templates/storefront-bakery/postcss.config.mjs +0 -7
- package/templates/storefront-bakery/tsconfig.json +0 -23
- package/templates/storefront-bakery/vitest.config.ts +0 -9
- package/templates/storefront-fashion/.claude/skills/cimplify-storefront/SKILL.md +0 -145
- package/templates/storefront-fashion/.cursor/rules/cimplify-storefront.mdc +0 -25
- package/templates/storefront-fashion/.env.example +0 -16
- package/templates/storefront-fashion/AGENTS.md +0 -126
- package/templates/storefront-fashion/CLAUDE.md +0 -22
- package/templates/storefront-fashion/README.md +0 -77
- package/templates/storefront-fashion/__tests__/brand.test.ts +0 -4
- package/templates/storefront-fashion/__tests__/cart-flow.test.ts +0 -55
- package/templates/storefront-fashion/__tests__/contract.test.ts +0 -4
- package/templates/storefront-fashion/app/about/page.tsx +0 -41
- package/templates/storefront-fashion/app/accessibility/page.tsx +0 -11
- package/templates/storefront-fashion/app/account/addresses/page.tsx +0 -21
- package/templates/storefront-fashion/app/account/orders/page.tsx +0 -21
- package/templates/storefront-fashion/app/account/page.tsx +0 -22
- package/templates/storefront-fashion/app/account/settings/page.tsx +0 -21
- package/templates/storefront-fashion/app/cart/page.tsx +0 -9
- package/templates/storefront-fashion/app/categories/[slug]/listing-client.tsx +0 -19
- package/templates/storefront-fashion/app/categories/[slug]/page.tsx +0 -130
- package/templates/storefront-fashion/app/checkout/page.tsx +0 -17
- package/templates/storefront-fashion/app/collections/[slug]/listing-client.tsx +0 -20
- package/templates/storefront-fashion/app/collections/[slug]/page.tsx +0 -130
- package/templates/storefront-fashion/app/contact/contact-form.tsx +0 -109
- package/templates/storefront-fashion/app/contact/page.tsx +0 -54
- package/templates/storefront-fashion/app/error.tsx +0 -61
- package/templates/storefront-fashion/app/faq/page.tsx +0 -46
- package/templates/storefront-fashion/app/globals.css +0 -46
- package/templates/storefront-fashion/app/layout.tsx +0 -78
- package/templates/storefront-fashion/app/llms.txt/route.ts +0 -94
- package/templates/storefront-fashion/app/login/page.tsx +0 -17
- package/templates/storefront-fashion/app/lookbook/page.tsx +0 -132
- package/templates/storefront-fashion/app/not-found.tsx +0 -39
- package/templates/storefront-fashion/app/opensearch.xml/route.ts +0 -37
- package/templates/storefront-fashion/app/orders/[id]/page.tsx +0 -24
- package/templates/storefront-fashion/app/page.tsx +0 -183
- package/templates/storefront-fashion/app/privacy/page.tsx +0 -44
- package/templates/storefront-fashion/app/products/[slug]/page.tsx +0 -165
- package/templates/storefront-fashion/app/products/[slug]/product-detail.tsx +0 -70
- package/templates/storefront-fashion/app/returns/page.tsx +0 -11
- package/templates/storefront-fashion/app/robots.ts +0 -18
- package/templates/storefront-fashion/app/search/page.tsx +0 -38
- package/templates/storefront-fashion/app/search/search-client.tsx +0 -7
- package/templates/storefront-fashion/app/shipping/page.tsx +0 -16
- package/templates/storefront-fashion/app/shop/page.tsx +0 -63
- package/templates/storefront-fashion/app/shop/shop-client.tsx +0 -32
- package/templates/storefront-fashion/app/signup/page.tsx +0 -17
- package/templates/storefront-fashion/app/sitemap-page/page.tsx +0 -167
- package/templates/storefront-fashion/app/sitemap.ts +0 -59
- package/templates/storefront-fashion/app/size-guide/page.tsx +0 -155
- package/templates/storefront-fashion/app/terms/page.tsx +0 -44
- package/templates/storefront-fashion/app/track-order/page.tsx +0 -24
- package/templates/storefront-fashion/app/track-order/track-order-form.tsx +0 -69
- package/templates/storefront-fashion/components/account-iframe.tsx +0 -13
- package/templates/storefront-fashion/components/brand-marquee.tsx +0 -27
- package/templates/storefront-fashion/components/cart-drawer.tsx +0 -14
- package/templates/storefront-fashion/components/cart-pill.tsx +0 -36
- package/templates/storefront-fashion/components/category-grid.tsx +0 -28
- package/templates/storefront-fashion/components/category-tiles.tsx +0 -104
- package/templates/storefront-fashion/components/collection-strip.tsx +0 -45
- package/templates/storefront-fashion/components/feature-hero.tsx +0 -82
- package/templates/storefront-fashion/components/footer.tsx +0 -153
- package/templates/storefront-fashion/components/header.tsx +0 -43
- package/templates/storefront-fashion/components/hero.tsx +0 -28
- package/templates/storefront-fashion/components/nav-link.tsx +0 -20
- package/templates/storefront-fashion/components/newsletter.tsx +0 -50
- package/templates/storefront-fashion/components/policy-page.tsx +0 -49
- package/templates/storefront-fashion/components/promo-banner.tsx +0 -41
- package/templates/storefront-fashion/components/providers.tsx +0 -35
- package/templates/storefront-fashion/components/section-heading.tsx +0 -37
- package/templates/storefront-fashion/components/store-product-card.tsx +0 -87
- package/templates/storefront-fashion/components/trade-in-cta.tsx +0 -54
- package/templates/storefront-fashion/components/trust-bar.tsx +0 -66
- package/templates/storefront-fashion/e2e/visual.spec.ts +0 -52
- package/templates/storefront-fashion/lib/brand.ts +0 -518
- package/templates/storefront-fashion/lib/cart.ts +0 -12
- package/templates/storefront-fashion/next.config.ts +0 -42
- package/templates/storefront-fashion/package.json +0 -38
- package/templates/storefront-fashion/playwright.config.ts +0 -48
- package/templates/storefront-fashion/postcss.config.mjs +0 -7
- package/templates/storefront-fashion/tsconfig.json +0 -23
- package/templates/storefront-fashion/vitest.config.ts +0 -9
- package/templates/storefront-grocery/.claude/skills/cimplify-storefront/SKILL.md +0 -145
- package/templates/storefront-grocery/.cursor/rules/cimplify-storefront.mdc +0 -25
- package/templates/storefront-grocery/.env.example +0 -16
- package/templates/storefront-grocery/AGENTS.md +0 -96
- package/templates/storefront-grocery/CLAUDE.md +0 -22
- package/templates/storefront-grocery/README.md +0 -73
- package/templates/storefront-grocery/__tests__/brand.test.ts +0 -4
- package/templates/storefront-grocery/__tests__/cart-flow.test.ts +0 -4
- package/templates/storefront-grocery/__tests__/contract.test.ts +0 -4
- package/templates/storefront-grocery/app/about/page.tsx +0 -38
- package/templates/storefront-grocery/app/accessibility/page.tsx +0 -11
- package/templates/storefront-grocery/app/account/addresses/page.tsx +0 -21
- package/templates/storefront-grocery/app/account/orders/page.tsx +0 -21
- package/templates/storefront-grocery/app/account/page.tsx +0 -22
- package/templates/storefront-grocery/app/account/settings/page.tsx +0 -21
- package/templates/storefront-grocery/app/cart/page.tsx +0 -9
- package/templates/storefront-grocery/app/categories/[slug]/listing-client.tsx +0 -19
- package/templates/storefront-grocery/app/categories/[slug]/page.tsx +0 -118
- package/templates/storefront-grocery/app/checkout/page.tsx +0 -17
- package/templates/storefront-grocery/app/collections/[slug]/listing-client.tsx +0 -20
- package/templates/storefront-grocery/app/collections/[slug]/page.tsx +0 -118
- package/templates/storefront-grocery/app/contact/contact-form.tsx +0 -109
- package/templates/storefront-grocery/app/contact/page.tsx +0 -54
- package/templates/storefront-grocery/app/error.tsx +0 -60
- package/templates/storefront-grocery/app/faq/page.tsx +0 -46
- package/templates/storefront-grocery/app/globals.css +0 -45
- package/templates/storefront-grocery/app/layout.tsx +0 -77
- package/templates/storefront-grocery/app/llms.txt/route.ts +0 -94
- package/templates/storefront-grocery/app/login/page.tsx +0 -17
- package/templates/storefront-grocery/app/not-found.tsx +0 -39
- package/templates/storefront-grocery/app/opensearch.xml/route.ts +0 -37
- package/templates/storefront-grocery/app/orders/[id]/page.tsx +0 -21
- package/templates/storefront-grocery/app/page.tsx +0 -97
- package/templates/storefront-grocery/app/privacy/page.tsx +0 -44
- package/templates/storefront-grocery/app/returns/page.tsx +0 -11
- package/templates/storefront-grocery/app/robots.ts +0 -18
- package/templates/storefront-grocery/app/search/page.tsx +0 -38
- package/templates/storefront-grocery/app/search/search-client.tsx +0 -7
- package/templates/storefront-grocery/app/shipping/page.tsx +0 -16
- package/templates/storefront-grocery/app/shop/page.tsx +0 -31
- package/templates/storefront-grocery/app/shop/shop-client.tsx +0 -27
- package/templates/storefront-grocery/app/signup/page.tsx +0 -17
- package/templates/storefront-grocery/app/sitemap-page/page.tsx +0 -167
- package/templates/storefront-grocery/app/sitemap.ts +0 -62
- package/templates/storefront-grocery/app/terms/page.tsx +0 -44
- package/templates/storefront-grocery/app/track-order/page.tsx +0 -24
- package/templates/storefront-grocery/app/track-order/track-order-form.tsx +0 -69
- package/templates/storefront-grocery/components/account-iframe.tsx +0 -13
- package/templates/storefront-grocery/components/cart-drawer.tsx +0 -14
- package/templates/storefront-grocery/components/cart-pill.tsx +0 -36
- package/templates/storefront-grocery/components/category-grid.tsx +0 -28
- package/templates/storefront-grocery/components/collection-strip.tsx +0 -45
- package/templates/storefront-grocery/components/footer.tsx +0 -148
- package/templates/storefront-grocery/components/header.tsx +0 -43
- package/templates/storefront-grocery/components/hero.tsx +0 -25
- package/templates/storefront-grocery/components/nav-link.tsx +0 -20
- package/templates/storefront-grocery/components/policy-page.tsx +0 -49
- package/templates/storefront-grocery/components/product-modal.tsx +0 -104
- package/templates/storefront-grocery/components/providers.tsx +0 -35
- package/templates/storefront-grocery/components/store-product-card.tsx +0 -87
- package/templates/storefront-grocery/lib/brand.ts +0 -375
- package/templates/storefront-grocery/lib/cart.ts +0 -12
- package/templates/storefront-grocery/next.config.ts +0 -42
- package/templates/storefront-grocery/package.json +0 -35
- package/templates/storefront-grocery/postcss.config.mjs +0 -7
- package/templates/storefront-grocery/tsconfig.json +0 -23
- package/templates/storefront-grocery/vitest.config.ts +0 -9
- package/templates/storefront-restaurant/.claude/skills/cimplify-storefront/SKILL.md +0 -145
- package/templates/storefront-restaurant/.cursor/rules/cimplify-storefront.mdc +0 -25
- package/templates/storefront-restaurant/.env.example +0 -16
- package/templates/storefront-restaurant/AGENTS.md +0 -102
- package/templates/storefront-restaurant/CLAUDE.md +0 -22
- package/templates/storefront-restaurant/README.md +0 -73
- package/templates/storefront-restaurant/__tests__/brand.test.ts +0 -4
- package/templates/storefront-restaurant/__tests__/cart-flow.test.ts +0 -4
- package/templates/storefront-restaurant/__tests__/contract.test.ts +0 -4
- package/templates/storefront-restaurant/app/about/page.tsx +0 -38
- package/templates/storefront-restaurant/app/accessibility/page.tsx +0 -11
- package/templates/storefront-restaurant/app/account/addresses/page.tsx +0 -21
- package/templates/storefront-restaurant/app/account/orders/page.tsx +0 -21
- package/templates/storefront-restaurant/app/account/page.tsx +0 -22
- package/templates/storefront-restaurant/app/account/settings/page.tsx +0 -21
- package/templates/storefront-restaurant/app/cart/page.tsx +0 -9
- package/templates/storefront-restaurant/app/categories/[slug]/listing-client.tsx +0 -19
- package/templates/storefront-restaurant/app/categories/[slug]/page.tsx +0 -118
- package/templates/storefront-restaurant/app/checkout/page.tsx +0 -17
- package/templates/storefront-restaurant/app/collections/[slug]/listing-client.tsx +0 -20
- package/templates/storefront-restaurant/app/collections/[slug]/page.tsx +0 -118
- package/templates/storefront-restaurant/app/contact/contact-form.tsx +0 -109
- package/templates/storefront-restaurant/app/contact/page.tsx +0 -54
- package/templates/storefront-restaurant/app/error.tsx +0 -60
- package/templates/storefront-restaurant/app/faq/page.tsx +0 -46
- package/templates/storefront-restaurant/app/globals.css +0 -44
- package/templates/storefront-restaurant/app/layout.tsx +0 -82
- package/templates/storefront-restaurant/app/llms.txt/route.ts +0 -94
- package/templates/storefront-restaurant/app/login/page.tsx +0 -17
- package/templates/storefront-restaurant/app/not-found.tsx +0 -39
- package/templates/storefront-restaurant/app/opensearch.xml/route.ts +0 -37
- package/templates/storefront-restaurant/app/orders/[id]/page.tsx +0 -21
- package/templates/storefront-restaurant/app/page.tsx +0 -97
- package/templates/storefront-restaurant/app/privacy/page.tsx +0 -44
- package/templates/storefront-restaurant/app/reservations/page.tsx +0 -66
- package/templates/storefront-restaurant/app/reservations/reservations-client.tsx +0 -234
- package/templates/storefront-restaurant/app/returns/page.tsx +0 -11
- package/templates/storefront-restaurant/app/robots.ts +0 -18
- package/templates/storefront-restaurant/app/search/page.tsx +0 -38
- package/templates/storefront-restaurant/app/search/search-client.tsx +0 -7
- package/templates/storefront-restaurant/app/shipping/page.tsx +0 -16
- package/templates/storefront-restaurant/app/shop/page.tsx +0 -31
- package/templates/storefront-restaurant/app/shop/shop-client.tsx +0 -27
- package/templates/storefront-restaurant/app/signup/page.tsx +0 -17
- package/templates/storefront-restaurant/app/sitemap-page/page.tsx +0 -167
- package/templates/storefront-restaurant/app/sitemap.ts +0 -62
- package/templates/storefront-restaurant/app/terms/page.tsx +0 -44
- package/templates/storefront-restaurant/app/track-order/page.tsx +0 -24
- package/templates/storefront-restaurant/app/track-order/track-order-form.tsx +0 -69
- package/templates/storefront-restaurant/components/account-iframe.tsx +0 -13
- package/templates/storefront-restaurant/components/cart-drawer.tsx +0 -14
- package/templates/storefront-restaurant/components/cart-pill.tsx +0 -36
- package/templates/storefront-restaurant/components/category-grid.tsx +0 -28
- package/templates/storefront-restaurant/components/collection-strip.tsx +0 -45
- package/templates/storefront-restaurant/components/footer.tsx +0 -148
- package/templates/storefront-restaurant/components/header.tsx +0 -43
- package/templates/storefront-restaurant/components/hero.tsx +0 -25
- package/templates/storefront-restaurant/components/nav-link.tsx +0 -20
- package/templates/storefront-restaurant/components/policy-page.tsx +0 -49
- package/templates/storefront-restaurant/components/product-modal.tsx +0 -104
- package/templates/storefront-restaurant/components/providers.tsx +0 -35
- package/templates/storefront-restaurant/components/store-product-card.tsx +0 -87
- package/templates/storefront-restaurant/lib/brand.ts +0 -377
- package/templates/storefront-restaurant/lib/cart.ts +0 -12
- package/templates/storefront-restaurant/next.config.ts +0 -42
- package/templates/storefront-restaurant/package.json +0 -35
- package/templates/storefront-restaurant/postcss.config.mjs +0 -7
- package/templates/storefront-restaurant/tsconfig.json +0 -23
- package/templates/storefront-restaurant/vitest.config.ts +0 -9
- package/templates/storefront-retail/.claude/skills/cimplify-storefront/SKILL.md +0 -145
- package/templates/storefront-retail/.cursor/rules/cimplify-storefront.mdc +0 -25
- package/templates/storefront-retail/.env.example +0 -16
- package/templates/storefront-retail/AGENTS.md +0 -117
- package/templates/storefront-retail/CLAUDE.md +0 -22
- package/templates/storefront-retail/README.md +0 -77
- package/templates/storefront-retail/__tests__/brand.test.ts +0 -4
- package/templates/storefront-retail/__tests__/cart-flow.test.ts +0 -4
- package/templates/storefront-retail/__tests__/contract.test.ts +0 -4
- package/templates/storefront-retail/app/about/page.tsx +0 -41
- package/templates/storefront-retail/app/accessibility/page.tsx +0 -11
- package/templates/storefront-retail/app/account/addresses/page.tsx +0 -21
- package/templates/storefront-retail/app/account/orders/page.tsx +0 -21
- package/templates/storefront-retail/app/account/page.tsx +0 -22
- package/templates/storefront-retail/app/account/settings/page.tsx +0 -21
- package/templates/storefront-retail/app/cart/page.tsx +0 -9
- package/templates/storefront-retail/app/categories/[slug]/listing-client.tsx +0 -19
- package/templates/storefront-retail/app/categories/[slug]/page.tsx +0 -130
- package/templates/storefront-retail/app/checkout/page.tsx +0 -17
- package/templates/storefront-retail/app/collections/[slug]/listing-client.tsx +0 -20
- package/templates/storefront-retail/app/collections/[slug]/page.tsx +0 -130
- package/templates/storefront-retail/app/contact/contact-form.tsx +0 -109
- package/templates/storefront-retail/app/contact/page.tsx +0 -54
- package/templates/storefront-retail/app/error.tsx +0 -61
- package/templates/storefront-retail/app/faq/page.tsx +0 -46
- package/templates/storefront-retail/app/globals.css +0 -47
- package/templates/storefront-retail/app/layout.tsx +0 -77
- package/templates/storefront-retail/app/llms.txt/route.ts +0 -94
- package/templates/storefront-retail/app/login/page.tsx +0 -17
- package/templates/storefront-retail/app/not-found.tsx +0 -39
- package/templates/storefront-retail/app/opensearch.xml/route.ts +0 -37
- package/templates/storefront-retail/app/orders/[id]/page.tsx +0 -24
- package/templates/storefront-retail/app/page.tsx +0 -182
- package/templates/storefront-retail/app/privacy/page.tsx +0 -44
- package/templates/storefront-retail/app/products/[slug]/page.tsx +0 -165
- package/templates/storefront-retail/app/products/[slug]/product-detail.tsx +0 -70
- package/templates/storefront-retail/app/returns/page.tsx +0 -11
- package/templates/storefront-retail/app/robots.ts +0 -18
- package/templates/storefront-retail/app/search/page.tsx +0 -38
- package/templates/storefront-retail/app/search/search-client.tsx +0 -7
- package/templates/storefront-retail/app/shipping/page.tsx +0 -16
- package/templates/storefront-retail/app/shop/page.tsx +0 -63
- package/templates/storefront-retail/app/shop/shop-client.tsx +0 -32
- package/templates/storefront-retail/app/signup/page.tsx +0 -17
- package/templates/storefront-retail/app/sitemap-page/page.tsx +0 -167
- package/templates/storefront-retail/app/sitemap.ts +0 -59
- package/templates/storefront-retail/app/terms/page.tsx +0 -44
- package/templates/storefront-retail/app/track-order/page.tsx +0 -24
- package/templates/storefront-retail/app/track-order/track-order-form.tsx +0 -69
- package/templates/storefront-retail/components/account-iframe.tsx +0 -13
- package/templates/storefront-retail/components/brand-marquee.tsx +0 -27
- package/templates/storefront-retail/components/cart-drawer.tsx +0 -14
- package/templates/storefront-retail/components/cart-pill.tsx +0 -36
- package/templates/storefront-retail/components/category-grid.tsx +0 -28
- package/templates/storefront-retail/components/category-tiles.tsx +0 -104
- package/templates/storefront-retail/components/collection-strip.tsx +0 -45
- package/templates/storefront-retail/components/feature-hero.tsx +0 -84
- package/templates/storefront-retail/components/footer.tsx +0 -153
- package/templates/storefront-retail/components/header.tsx +0 -45
- package/templates/storefront-retail/components/hero.tsx +0 -28
- package/templates/storefront-retail/components/nav-link.tsx +0 -20
- package/templates/storefront-retail/components/newsletter.tsx +0 -50
- package/templates/storefront-retail/components/policy-page.tsx +0 -49
- package/templates/storefront-retail/components/promo-banner.tsx +0 -41
- package/templates/storefront-retail/components/providers.tsx +0 -35
- package/templates/storefront-retail/components/section-heading.tsx +0 -37
- package/templates/storefront-retail/components/store-product-card.tsx +0 -87
- package/templates/storefront-retail/components/trade-in-cta.tsx +0 -54
- package/templates/storefront-retail/components/trust-bar.tsx +0 -66
- package/templates/storefront-retail/lib/brand.ts +0 -664
- package/templates/storefront-retail/lib/cart.ts +0 -12
- package/templates/storefront-retail/next.config.ts +0 -42
- package/templates/storefront-retail/package.json +0 -35
- package/templates/storefront-retail/postcss.config.mjs +0 -7
- package/templates/storefront-retail/tsconfig.json +0 -23
- package/templates/storefront-retail/vitest.config.ts +0 -9
- package/templates/storefront-services/.claude/skills/cimplify-storefront/SKILL.md +0 -145
- package/templates/storefront-services/.cursor/rules/cimplify-storefront.mdc +0 -25
- package/templates/storefront-services/.env.example +0 -16
- package/templates/storefront-services/AGENTS.md +0 -101
- package/templates/storefront-services/CLAUDE.md +0 -22
- package/templates/storefront-services/README.md +0 -73
- package/templates/storefront-services/__tests__/brand.test.ts +0 -4
- package/templates/storefront-services/__tests__/cart-flow.test.ts +0 -4
- package/templates/storefront-services/__tests__/contract.test.ts +0 -4
- package/templates/storefront-services/app/about/page.tsx +0 -38
- package/templates/storefront-services/app/accessibility/page.tsx +0 -11
- package/templates/storefront-services/app/account/addresses/page.tsx +0 -21
- package/templates/storefront-services/app/account/orders/page.tsx +0 -21
- package/templates/storefront-services/app/account/page.tsx +0 -22
- package/templates/storefront-services/app/account/settings/page.tsx +0 -21
- package/templates/storefront-services/app/book/book-client.tsx +0 -195
- package/templates/storefront-services/app/book/page.tsx +0 -65
- package/templates/storefront-services/app/cart/page.tsx +0 -9
- package/templates/storefront-services/app/categories/[slug]/listing-client.tsx +0 -19
- package/templates/storefront-services/app/categories/[slug]/page.tsx +0 -118
- package/templates/storefront-services/app/checkout/page.tsx +0 -17
- package/templates/storefront-services/app/collections/[slug]/listing-client.tsx +0 -20
- package/templates/storefront-services/app/collections/[slug]/page.tsx +0 -118
- package/templates/storefront-services/app/contact/contact-form.tsx +0 -109
- package/templates/storefront-services/app/contact/page.tsx +0 -54
- package/templates/storefront-services/app/error.tsx +0 -60
- package/templates/storefront-services/app/faq/page.tsx +0 -46
- package/templates/storefront-services/app/globals.css +0 -45
- package/templates/storefront-services/app/layout.tsx +0 -82
- package/templates/storefront-services/app/llms.txt/route.ts +0 -94
- package/templates/storefront-services/app/login/page.tsx +0 -17
- package/templates/storefront-services/app/not-found.tsx +0 -39
- package/templates/storefront-services/app/opensearch.xml/route.ts +0 -37
- package/templates/storefront-services/app/orders/[id]/page.tsx +0 -21
- package/templates/storefront-services/app/page.tsx +0 -97
- package/templates/storefront-services/app/privacy/page.tsx +0 -44
- package/templates/storefront-services/app/returns/page.tsx +0 -11
- package/templates/storefront-services/app/robots.ts +0 -18
- package/templates/storefront-services/app/search/page.tsx +0 -38
- package/templates/storefront-services/app/search/search-client.tsx +0 -7
- package/templates/storefront-services/app/shipping/page.tsx +0 -16
- package/templates/storefront-services/app/shop/page.tsx +0 -31
- package/templates/storefront-services/app/shop/shop-client.tsx +0 -27
- package/templates/storefront-services/app/signup/page.tsx +0 -17
- package/templates/storefront-services/app/sitemap-page/page.tsx +0 -167
- package/templates/storefront-services/app/sitemap.ts +0 -62
- package/templates/storefront-services/app/terms/page.tsx +0 -44
- package/templates/storefront-services/app/track-order/page.tsx +0 -24
- package/templates/storefront-services/app/track-order/track-order-form.tsx +0 -69
- package/templates/storefront-services/components/account-iframe.tsx +0 -13
- package/templates/storefront-services/components/cart-drawer.tsx +0 -14
- package/templates/storefront-services/components/cart-pill.tsx +0 -36
- package/templates/storefront-services/components/category-grid.tsx +0 -28
- package/templates/storefront-services/components/collection-strip.tsx +0 -45
- package/templates/storefront-services/components/footer.tsx +0 -148
- package/templates/storefront-services/components/header.tsx +0 -43
- package/templates/storefront-services/components/hero.tsx +0 -25
- package/templates/storefront-services/components/nav-link.tsx +0 -20
- package/templates/storefront-services/components/policy-page.tsx +0 -49
- package/templates/storefront-services/components/product-modal.tsx +0 -104
- package/templates/storefront-services/components/providers.tsx +0 -35
- package/templates/storefront-services/components/store-product-card.tsx +0 -87
- package/templates/storefront-services/lib/brand.ts +0 -396
- package/templates/storefront-services/lib/cart.ts +0 -12
- package/templates/storefront-services/next.config.ts +0 -42
- package/templates/storefront-services/package.json +0 -35
- package/templates/storefront-services/postcss.config.mjs +0 -7
- package/templates/storefront-services/tsconfig.json +0 -23
- package/templates/storefront-services/vitest.config.ts +0 -9
|
@@ -1,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 retail --quiet\" \"next dev\"",
|
|
7
|
-
"dev:storefront": "next dev",
|
|
8
|
-
"dev:mock": "bunx @cimplify/sdk --seed retail",
|
|
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.33",
|
|
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 (services: Serene Spa).
|
|
11
|
-
NEXT_PUBLIC_CIMPLIFY_BUSINESS_ID=bus_serene_spa
|
|
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,101 +0,0 @@
|
|
|
1
|
-
# AGENTS.md — Services / spa / wellness 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.
|
|
9
|
-
3. **Edit `.env.local`** — `NEXT_PUBLIC_CIMPLIFY_BUSINESS_ID=bus_serene_spa` for the bundled seed.
|
|
10
|
-
|
|
11
|
-
## Aesthetic
|
|
12
|
-
|
|
13
|
-
- **Fraunces serif + Inter** — warm, slightly editorial headings.
|
|
14
|
-
- **Sand + sage palette** — warm cream background, deep sage primary.
|
|
15
|
-
- **Generous radius**: `1rem` — calm, soft.
|
|
16
|
-
- Lower-contrast than retail / fashion.
|
|
17
|
-
- Schema.org `@type` is `BeautySalon`.
|
|
18
|
-
|
|
19
|
-
## Page surface
|
|
20
|
-
|
|
21
|
-
```
|
|
22
|
-
app/
|
|
23
|
-
page.tsx Home — hero ("Now booking"), service strips,
|
|
24
|
-
category grid, newsletter
|
|
25
|
-
shop/page.tsx Treatment menu (SDK <CataloguePage/>)
|
|
26
|
-
search/page.tsx Search
|
|
27
|
-
collections/[slug]/page.tsx Collection landing
|
|
28
|
-
categories/[slug]/page.tsx Category landing (e.g. memberships, packages)
|
|
29
|
-
|
|
30
|
-
book/page.tsx ⭐ Services-specific: full booking widget
|
|
31
|
-
(treatment + 14-day date + 30-min slot grid)
|
|
32
|
-
→ adds to cart with slot as note → /checkout
|
|
33
|
-
|
|
34
|
-
cart/page.tsx, checkout/page.tsx, orders/[id]/page.tsx
|
|
35
|
-
|
|
36
|
-
account/page.tsx <CimplifyAccount /> (iframe)
|
|
37
|
-
account/orders/page.tsx <CimplifyAccount section="orders" />
|
|
38
|
-
account/addresses/page.tsx <CimplifyAccount section="addresses" />
|
|
39
|
-
account/settings/page.tsx <CimplifyAccount section="settings" />
|
|
40
|
-
login/page.tsx, signup/page.tsx redirects → /account
|
|
41
|
-
|
|
42
|
-
contact/page.tsx, track-order/page.tsx (find a booking)
|
|
43
|
-
|
|
44
|
-
about/page.tsx, faq/page.tsx
|
|
45
|
-
shipping/page.tsx (what to expect at the studio), returns/page.tsx (cancellations),
|
|
46
|
-
accessibility/page.tsx, terms/page.tsx, privacy/page.tsx
|
|
47
|
-
|
|
48
|
-
sitemap-page/page.tsx, sitemap.ts, robots.ts, llms.txt/route.ts, opensearch.xml/route.ts
|
|
49
|
-
error.tsx, not-found.tsx
|
|
50
|
-
```
|
|
51
|
-
|
|
52
|
-
## File ↔ brand-field map
|
|
53
|
-
|
|
54
|
-
| File | Reads from `brand` |
|
|
55
|
-
|---|---|
|
|
56
|
-
| `app/layout.tsx` | identity, contact, socials, BeautySalon JSON-LD |
|
|
57
|
-
| `app/page.tsx` | `brand.hero` ("Now booking") |
|
|
58
|
-
| `app/about/page.tsx` | `brand.about` |
|
|
59
|
-
| `app/faq/page.tsx` | `brand.faq` (booking, contraindications, memberships) |
|
|
60
|
-
| `app/shipping/page.tsx` | `brand.shipping` (what to expect at the studio) |
|
|
61
|
-
| `app/returns/page.tsx` | `brand.returns` (cancellation policy) |
|
|
62
|
-
| `app/accessibility/page.tsx` | `brand.accessibility` |
|
|
63
|
-
| `app/terms/page.tsx`, `app/privacy/page.tsx` | `brand.terms`, `brand.privacy` |
|
|
64
|
-
| `app/contact/page.tsx` | `brand.contactPage`, `brand.contact` |
|
|
65
|
-
| `app/track-order/page.tsx` | `brand.trackOrder` ("find a booking") |
|
|
66
|
-
| `app/account/*/page.tsx` | `brand.account` (iframe owns UI) |
|
|
67
|
-
| `app/book/*` | derives bookable services from product list (`type: "service"`) |
|
|
68
|
-
| `app/llms.txt/route.ts` | `brand.llms`, contact, currency |
|
|
69
|
-
| `components/header.tsx`, `footer.tsx` | `brand.header`, `brand.footer`, `brand.contact`, `brand.socials` |
|
|
70
|
-
|
|
71
|
-
## Services-specific notes
|
|
72
|
-
|
|
73
|
-
- **Bookable services are `type: "service"` products.** The `/book` page filters the product list to type=service and treats them as treatments. Their `duration_minutes` is shown on the chip.
|
|
74
|
-
- Cart-item notes carry the booked time slot — checkout sends them through Cimplify's order pipeline. The merchant's downstream system reads the note to schedule the appointment.
|
|
75
|
-
- Mock seed: `--seed services` (Serene Spa).
|
|
76
|
-
|
|
77
|
-
## Known TODOs
|
|
78
|
-
|
|
79
|
-
- `/book` widget shows every slot as available. For production, wire `useAvailableSlots({ serviceId, date })` from `@cimplify/sdk/react` to filter to genuinely-free windows.
|
|
80
|
-
- Contact + newsletter fake submits.
|
|
81
|
-
|
|
82
|
-
## Customizing SDK components
|
|
83
|
-
|
|
84
|
-
For anything beyond `lib/brand.ts` + `app/globals.css`, lean on the SDK's prebuilt components rather than reinvent. **Especially for service scheduling, booking widgets, and add-on selectors** — the SDK already gets price math, slot matching, and cart payload contracts right. Default to ejecting and restyling:
|
|
85
|
-
|
|
86
|
-
```bash
|
|
87
|
-
bunx @cimplify/sdk add cart-drawer
|
|
88
|
-
bunx @cimplify/sdk add product-page
|
|
89
|
-
bunx @cimplify/sdk add booking-card
|
|
90
|
-
```
|
|
91
|
-
|
|
92
|
-
Then edit the local copy. **Don't change the cart payload shape** (`scheduled_start`, `scheduled_end`, `staff_id`, `customer_inputs`, etc.) unless you're also touching the SDK mock + backend lens. Full ejection rules and the customizer contract are in the SDK-level [`AGENTS.md`](../../AGENTS.md) → "Don't reinvent product customization".
|
|
93
|
-
|
|
94
|
-
## Quick start
|
|
95
|
-
|
|
96
|
-
```bash
|
|
97
|
-
bun install
|
|
98
|
-
bun dev
|
|
99
|
-
```
|
|
100
|
-
|
|
101
|
-
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,73 +0,0 @@
|
|
|
1
|
-
# __STOREFRONT_NAME__
|
|
2
|
-
|
|
3
|
-
A Cimplify storefront scaffolded from the **bakery** template — Next.js 16 (App Router), React 19, Tailwind v4. Warm food-styled palette, Playfair Display + Inter typography, designed for bakeries, pâtisseries, and food businesses.
|
|
4
|
-
|
|
5
|
-
For a different industry, scaffold with `--template`:
|
|
6
|
-
|
|
7
|
-
```bash
|
|
8
|
-
bunx @cimplify/sdk init my-store --template retail # electronics / consumer goods
|
|
9
|
-
bunx @cimplify/sdk init my-store --template bakery # default — food / pâtisserie
|
|
10
|
-
```
|
|
11
|
-
|
|
12
|
-
## Run
|
|
13
|
-
|
|
14
|
-
```bash
|
|
15
|
-
bun install
|
|
16
|
-
bun dev
|
|
17
|
-
```
|
|
18
|
-
|
|
19
|
-
Two things start in parallel:
|
|
20
|
-
|
|
21
|
-
- `bunx @cimplify/sdk` — the Cimplify mock API on `http://127.0.0.1:8787` (Akua's Bakery seeded by default).
|
|
22
|
-
- `next dev` — this storefront on `http://localhost:3000`.
|
|
23
|
-
|
|
24
|
-
Open the storefront in your browser. Edit `app/page.tsx` to start customising. The SDK ships full pages (`<CataloguePage>`, `<ProductPage>`, `<CartPage>`, `<CheckoutPage>`) and layouts (`<DefaultProductLayout>`, `<FoodProductLayout>`, etc.) that you can swap in.
|
|
25
|
-
|
|
26
|
-
## Structure
|
|
27
|
-
|
|
28
|
-
```
|
|
29
|
-
app/
|
|
30
|
-
layout.tsx # root layout, fonts, providers, header/footer/modal
|
|
31
|
-
page.tsx # home
|
|
32
|
-
shop/page.tsx # full catalogue (SDK <CataloguePage/>)
|
|
33
|
-
collections/[slug]/ # collection landing
|
|
34
|
-
categories/[slug]/ # category landing
|
|
35
|
-
cart/page.tsx # SDK <CartPage/>
|
|
36
|
-
checkout/page.tsx # SDK <CheckoutPage/>
|
|
37
|
-
orders/[id]/page.tsx # post-checkout thank-you
|
|
38
|
-
globals.css # Tailwind import + theme tokens
|
|
39
|
-
components/
|
|
40
|
-
providers.tsx # CimplifyProvider client wrapper
|
|
41
|
-
header.tsx, footer.tsx, hero.tsx
|
|
42
|
-
store-product-card.tsx # SDK <ProductCard/> wired to URL-driven modal
|
|
43
|
-
product-modal.tsx # ?product=<slug> deep-linkable modal
|
|
44
|
-
collection-strip.tsx # horizontal product strip
|
|
45
|
-
category-grid.tsx # SDK <CategoryGrid/> with router navigation
|
|
46
|
-
lib/
|
|
47
|
-
cart.ts # useCartCount() for the header pill
|
|
48
|
-
```
|
|
49
|
-
|
|
50
|
-
## Switch seed
|
|
51
|
-
|
|
52
|
-
```bash
|
|
53
|
-
bunx @cimplify/sdk --seed restaurant # Mama's Kitchen
|
|
54
|
-
bunx @cimplify/sdk --seed retail # Currents Electronics
|
|
55
|
-
bunx @cimplify/sdk --seed services # Serene Spa
|
|
56
|
-
bunx @cimplify/sdk --seed grocery # FreshMart
|
|
57
|
-
```
|
|
58
|
-
|
|
59
|
-
Update `NEXT_PUBLIC_CIMPLIFY_BUSINESS_ID` in `.env.local` to match the seeded business.
|
|
60
|
-
|
|
61
|
-
## Go live
|
|
62
|
-
|
|
63
|
-
```diff
|
|
64
|
-
# .env.local
|
|
65
|
-
- NEXT_PUBLIC_CIMPLIFY_API_URL=http://127.0.0.1:8787
|
|
66
|
-
+ NEXT_PUBLIC_CIMPLIFY_API_URL=https://api.cimplify.io
|
|
67
|
-
- NEXT_PUBLIC_CIMPLIFY_PUBLIC_KEY=mock-dev
|
|
68
|
-
+ NEXT_PUBLIC_CIMPLIFY_PUBLIC_KEY=<your tenant key>
|
|
69
|
-
- NEXT_PUBLIC_CIMPLIFY_BUSINESS_ID=bus_default_akua_bakery
|
|
70
|
-
+ NEXT_PUBLIC_CIMPLIFY_BUSINESS_ID=<your business id>
|
|
71
|
-
```
|
|
72
|
-
|
|
73
|
-
Deploy to Vercel with one click — `next.config.ts` already whitelists the SDK image hosts under `images.remotePatterns`.
|
|
@@ -1,38 +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
|
-
const titleParts = a.title.split("\n");
|
|
12
|
-
return (
|
|
13
|
-
<article className="max-w-3xl mx-auto px-8 py-16">
|
|
14
|
-
<p className="text-[11px] font-semibold uppercase tracking-[0.16em] text-primary mb-2">
|
|
15
|
-
{a.eyebrow}
|
|
16
|
-
</p>
|
|
17
|
-
<h1 className="font-serif text-[clamp(2.25rem,5vw,3.5rem)] font-semibold mb-6 -tracking-[0.02em]">
|
|
18
|
-
{titleParts.map((line, i) => (
|
|
19
|
-
<span key={i}>
|
|
20
|
-
{line}
|
|
21
|
-
{i < titleParts.length - 1 && <br />}
|
|
22
|
-
</span>
|
|
23
|
-
))}
|
|
24
|
-
</h1>
|
|
25
|
-
<div className="prose prose-lg max-w-none space-y-5 text-foreground/90 leading-relaxed">
|
|
26
|
-
{a.paragraphs.map((p, i) => (
|
|
27
|
-
<p key={i}>{p}</p>
|
|
28
|
-
))}
|
|
29
|
-
{a.sections.map((s) => (
|
|
30
|
-
<div key={s.heading}>
|
|
31
|
-
<h2 className="font-serif text-3xl font-semibold mt-10 mb-3">{s.heading}</h2>
|
|
32
|
-
<p>{s.body}</p>
|
|
33
|
-
</div>
|
|
34
|
-
))}
|
|
35
|
-
</div>
|
|
36
|
-
</article>
|
|
37
|
-
);
|
|
38
|
-
}
|
|
@@ -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
|
-
}
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
import type { Metadata } from "next";
|
|
2
|
-
import { AccountIframe } from "@/components/account-iframe";
|
|
3
|
-
import { brand } from "@/lib/brand";
|
|
4
|
-
|
|
5
|
-
export const metadata: Metadata = {
|
|
6
|
-
title: `Addresses — ${brand.name}`,
|
|
7
|
-
};
|
|
8
|
-
|
|
9
|
-
export default function AddressesPage() {
|
|
10
|
-
return (
|
|
11
|
-
<article className="max-w-5xl mx-auto px-6 sm:px-8 py-12">
|
|
12
|
-
<p className="text-[11px] font-semibold uppercase tracking-[0.16em] text-primary mb-2">
|
|
13
|
-
Account
|
|
14
|
-
</p>
|
|
15
|
-
<h1 className="font-serif text-[clamp(2rem,4vw,2.75rem)] font-semibold mb-8 -tracking-[0.02em]">
|
|
16
|
-
Your addresses
|
|
17
|
-
</h1>
|
|
18
|
-
<AccountIframe section="addresses" />
|
|
19
|
-
</article>
|
|
20
|
-
);
|
|
21
|
-
}
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
import type { Metadata } from "next";
|
|
2
|
-
import { AccountIframe } from "@/components/account-iframe";
|
|
3
|
-
import { brand } from "@/lib/brand";
|
|
4
|
-
|
|
5
|
-
export const metadata: Metadata = {
|
|
6
|
-
title: `Orders — ${brand.name}`,
|
|
7
|
-
};
|
|
8
|
-
|
|
9
|
-
export default function OrdersPage() {
|
|
10
|
-
return (
|
|
11
|
-
<article className="max-w-5xl mx-auto px-6 sm:px-8 py-12">
|
|
12
|
-
<p className="text-[11px] font-semibold uppercase tracking-[0.16em] text-primary mb-2">
|
|
13
|
-
Account
|
|
14
|
-
</p>
|
|
15
|
-
<h1 className="font-serif text-[clamp(2rem,4vw,2.75rem)] font-semibold mb-8 -tracking-[0.02em]">
|
|
16
|
-
Your orders
|
|
17
|
-
</h1>
|
|
18
|
-
<AccountIframe section="orders" />
|
|
19
|
-
</article>
|
|
20
|
-
);
|
|
21
|
-
}
|
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
import type { Metadata } from "next";
|
|
2
|
-
import { AccountIframe } from "@/components/account-iframe";
|
|
3
|
-
import { brand } from "@/lib/brand";
|
|
4
|
-
|
|
5
|
-
export const metadata: Metadata = {
|
|
6
|
-
title: `Account — ${brand.name}`,
|
|
7
|
-
description: brand.account.signupSubtitle,
|
|
8
|
-
};
|
|
9
|
-
|
|
10
|
-
export default function AccountPage() {
|
|
11
|
-
return (
|
|
12
|
-
<article className="max-w-5xl mx-auto px-6 sm:px-8 py-12">
|
|
13
|
-
<p className="text-[11px] font-semibold uppercase tracking-[0.16em] text-primary mb-2">
|
|
14
|
-
{brand.account.accountEyebrow}
|
|
15
|
-
</p>
|
|
16
|
-
<h1 className="font-serif text-[clamp(2rem,4vw,2.75rem)] font-semibold mb-8 -tracking-[0.02em]">
|
|
17
|
-
{brand.account.accountTitle}
|
|
18
|
-
</h1>
|
|
19
|
-
<AccountIframe />
|
|
20
|
-
</article>
|
|
21
|
-
);
|
|
22
|
-
}
|