@cimplify/sdk 0.44.34 → 0.45.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +21 -16
- package/dist/styles.css +1 -1
- package/package.json +5 -9
- package/dist/cli/commands/deploy.mjs +0 -717
- package/dist/cli/commands/dev.mjs +0 -479
- package/dist/cli/commands/domains.mjs +0 -769
- package/dist/cli/commands/env.mjs +0 -705
- package/dist/cli/commands/link.mjs +0 -378
- package/dist/cli/commands/login.mjs +0 -584
- package/dist/cli/commands/logout.mjs +0 -75
- package/dist/cli/commands/logs.mjs +0 -432
- package/dist/cli/commands/projects.mjs +0 -473
- package/dist/cli/commands/repo.mjs +0 -584
- package/dist/cli/commands/rollback.mjs +0 -553
- package/dist/cli/commands/status.mjs +0 -450
- package/dist/cli/commands/unlink.mjs +0 -79
- package/dist/cli/commands/whoami.mjs +0 -285
- package/dist/cli.js +0 -184
- package/dist/dispatcher.mjs +0 -360
- package/registry/booking-page.json +0 -18
- package/registry/bookings-page.json +0 -17
- package/registry/service-card.json +0 -16
- package/registry/service-grid.json +0 -16
- package/templates/storefront-bakery/.claude/skills/cimplify-storefront/SKILL.md +0 -145
- package/templates/storefront-bakery/.cursor/rules/cimplify-storefront.mdc +0 -25
- package/templates/storefront-bakery/.env.example +0 -16
- package/templates/storefront-bakery/AGENTS.md +0 -120
- package/templates/storefront-bakery/CLAUDE.md +0 -22
- package/templates/storefront-bakery/README.md +0 -73
- package/templates/storefront-bakery/__tests__/brand.test.ts +0 -4
- package/templates/storefront-bakery/__tests__/cart-flow.test.ts +0 -4
- package/templates/storefront-bakery/__tests__/contract.test.ts +0 -4
- package/templates/storefront-bakery/app/about/page.tsx +0 -38
- package/templates/storefront-bakery/app/accessibility/page.tsx +0 -11
- package/templates/storefront-bakery/app/account/addresses/page.tsx +0 -21
- package/templates/storefront-bakery/app/account/orders/page.tsx +0 -21
- package/templates/storefront-bakery/app/account/page.tsx +0 -22
- package/templates/storefront-bakery/app/account/settings/page.tsx +0 -21
- package/templates/storefront-bakery/app/cart/page.tsx +0 -9
- package/templates/storefront-bakery/app/categories/[slug]/listing-client.tsx +0 -19
- package/templates/storefront-bakery/app/categories/[slug]/page.tsx +0 -118
- package/templates/storefront-bakery/app/checkout/page.tsx +0 -17
- package/templates/storefront-bakery/app/collections/[slug]/listing-client.tsx +0 -20
- package/templates/storefront-bakery/app/collections/[slug]/page.tsx +0 -118
- package/templates/storefront-bakery/app/contact/contact-form.tsx +0 -109
- package/templates/storefront-bakery/app/contact/page.tsx +0 -54
- package/templates/storefront-bakery/app/error.tsx +0 -60
- package/templates/storefront-bakery/app/faq/page.tsx +0 -46
- package/templates/storefront-bakery/app/globals.css +0 -47
- package/templates/storefront-bakery/app/layout.tsx +0 -82
- package/templates/storefront-bakery/app/llms.txt/route.ts +0 -94
- package/templates/storefront-bakery/app/login/page.tsx +0 -17
- package/templates/storefront-bakery/app/not-found.tsx +0 -39
- package/templates/storefront-bakery/app/opensearch.xml/route.ts +0 -37
- package/templates/storefront-bakery/app/orders/[id]/page.tsx +0 -21
- package/templates/storefront-bakery/app/page.tsx +0 -97
- package/templates/storefront-bakery/app/privacy/page.tsx +0 -44
- package/templates/storefront-bakery/app/returns/page.tsx +0 -11
- package/templates/storefront-bakery/app/robots.ts +0 -18
- package/templates/storefront-bakery/app/search/page.tsx +0 -38
- package/templates/storefront-bakery/app/search/search-client.tsx +0 -7
- package/templates/storefront-bakery/app/shipping/page.tsx +0 -16
- package/templates/storefront-bakery/app/shop/page.tsx +0 -31
- package/templates/storefront-bakery/app/shop/shop-client.tsx +0 -27
- package/templates/storefront-bakery/app/signup/page.tsx +0 -17
- package/templates/storefront-bakery/app/sitemap-page/page.tsx +0 -167
- package/templates/storefront-bakery/app/sitemap.ts +0 -62
- package/templates/storefront-bakery/app/terms/page.tsx +0 -44
- package/templates/storefront-bakery/app/track-order/page.tsx +0 -24
- package/templates/storefront-bakery/app/track-order/track-order-form.tsx +0 -69
- package/templates/storefront-bakery/components/account-iframe.tsx +0 -13
- package/templates/storefront-bakery/components/cart-drawer.tsx +0 -14
- package/templates/storefront-bakery/components/cart-pill.tsx +0 -36
- package/templates/storefront-bakery/components/category-grid.tsx +0 -28
- package/templates/storefront-bakery/components/collection-strip.tsx +0 -45
- package/templates/storefront-bakery/components/footer.tsx +0 -148
- package/templates/storefront-bakery/components/header.tsx +0 -43
- package/templates/storefront-bakery/components/hero.tsx +0 -25
- package/templates/storefront-bakery/components/nav-link.tsx +0 -20
- package/templates/storefront-bakery/components/policy-page.tsx +0 -49
- package/templates/storefront-bakery/components/product-modal.tsx +0 -104
- package/templates/storefront-bakery/components/providers.tsx +0 -35
- package/templates/storefront-bakery/components/store-product-card.tsx +0 -87
- package/templates/storefront-bakery/lib/brand.ts +0 -570
- package/templates/storefront-bakery/lib/cart.ts +0 -12
- package/templates/storefront-bakery/next.config.ts +0 -42
- package/templates/storefront-bakery/package.json +0 -35
- package/templates/storefront-bakery/postcss.config.mjs +0 -7
- package/templates/storefront-bakery/tsconfig.json +0 -23
- package/templates/storefront-bakery/vitest.config.ts +0 -9
- package/templates/storefront-fashion/.claude/skills/cimplify-storefront/SKILL.md +0 -145
- package/templates/storefront-fashion/.cursor/rules/cimplify-storefront.mdc +0 -25
- package/templates/storefront-fashion/.env.example +0 -16
- package/templates/storefront-fashion/AGENTS.md +0 -126
- package/templates/storefront-fashion/CLAUDE.md +0 -22
- package/templates/storefront-fashion/README.md +0 -77
- package/templates/storefront-fashion/__tests__/brand.test.ts +0 -4
- package/templates/storefront-fashion/__tests__/cart-flow.test.ts +0 -55
- package/templates/storefront-fashion/__tests__/contract.test.ts +0 -4
- package/templates/storefront-fashion/app/about/page.tsx +0 -41
- package/templates/storefront-fashion/app/accessibility/page.tsx +0 -11
- package/templates/storefront-fashion/app/account/addresses/page.tsx +0 -21
- package/templates/storefront-fashion/app/account/orders/page.tsx +0 -21
- package/templates/storefront-fashion/app/account/page.tsx +0 -22
- package/templates/storefront-fashion/app/account/settings/page.tsx +0 -21
- package/templates/storefront-fashion/app/cart/page.tsx +0 -9
- package/templates/storefront-fashion/app/categories/[slug]/listing-client.tsx +0 -19
- package/templates/storefront-fashion/app/categories/[slug]/page.tsx +0 -130
- package/templates/storefront-fashion/app/checkout/page.tsx +0 -17
- package/templates/storefront-fashion/app/collections/[slug]/listing-client.tsx +0 -20
- package/templates/storefront-fashion/app/collections/[slug]/page.tsx +0 -130
- package/templates/storefront-fashion/app/contact/contact-form.tsx +0 -109
- package/templates/storefront-fashion/app/contact/page.tsx +0 -54
- package/templates/storefront-fashion/app/error.tsx +0 -61
- package/templates/storefront-fashion/app/faq/page.tsx +0 -46
- package/templates/storefront-fashion/app/globals.css +0 -46
- package/templates/storefront-fashion/app/layout.tsx +0 -78
- package/templates/storefront-fashion/app/llms.txt/route.ts +0 -94
- package/templates/storefront-fashion/app/login/page.tsx +0 -17
- package/templates/storefront-fashion/app/lookbook/page.tsx +0 -132
- package/templates/storefront-fashion/app/not-found.tsx +0 -39
- package/templates/storefront-fashion/app/opensearch.xml/route.ts +0 -37
- package/templates/storefront-fashion/app/orders/[id]/page.tsx +0 -24
- package/templates/storefront-fashion/app/page.tsx +0 -183
- package/templates/storefront-fashion/app/privacy/page.tsx +0 -44
- package/templates/storefront-fashion/app/products/[slug]/page.tsx +0 -165
- package/templates/storefront-fashion/app/products/[slug]/product-detail.tsx +0 -70
- package/templates/storefront-fashion/app/returns/page.tsx +0 -11
- package/templates/storefront-fashion/app/robots.ts +0 -18
- package/templates/storefront-fashion/app/search/page.tsx +0 -38
- package/templates/storefront-fashion/app/search/search-client.tsx +0 -7
- package/templates/storefront-fashion/app/shipping/page.tsx +0 -16
- package/templates/storefront-fashion/app/shop/page.tsx +0 -63
- package/templates/storefront-fashion/app/shop/shop-client.tsx +0 -32
- package/templates/storefront-fashion/app/signup/page.tsx +0 -17
- package/templates/storefront-fashion/app/sitemap-page/page.tsx +0 -167
- package/templates/storefront-fashion/app/sitemap.ts +0 -59
- package/templates/storefront-fashion/app/size-guide/page.tsx +0 -155
- package/templates/storefront-fashion/app/terms/page.tsx +0 -44
- package/templates/storefront-fashion/app/track-order/page.tsx +0 -24
- package/templates/storefront-fashion/app/track-order/track-order-form.tsx +0 -69
- package/templates/storefront-fashion/components/account-iframe.tsx +0 -13
- package/templates/storefront-fashion/components/brand-marquee.tsx +0 -27
- package/templates/storefront-fashion/components/cart-drawer.tsx +0 -14
- package/templates/storefront-fashion/components/cart-pill.tsx +0 -36
- package/templates/storefront-fashion/components/category-grid.tsx +0 -28
- package/templates/storefront-fashion/components/category-tiles.tsx +0 -104
- package/templates/storefront-fashion/components/collection-strip.tsx +0 -45
- package/templates/storefront-fashion/components/feature-hero.tsx +0 -82
- package/templates/storefront-fashion/components/footer.tsx +0 -153
- package/templates/storefront-fashion/components/header.tsx +0 -43
- package/templates/storefront-fashion/components/hero.tsx +0 -28
- package/templates/storefront-fashion/components/nav-link.tsx +0 -20
- package/templates/storefront-fashion/components/newsletter.tsx +0 -50
- package/templates/storefront-fashion/components/policy-page.tsx +0 -49
- package/templates/storefront-fashion/components/promo-banner.tsx +0 -41
- package/templates/storefront-fashion/components/providers.tsx +0 -35
- package/templates/storefront-fashion/components/section-heading.tsx +0 -37
- package/templates/storefront-fashion/components/store-product-card.tsx +0 -87
- package/templates/storefront-fashion/components/trade-in-cta.tsx +0 -54
- package/templates/storefront-fashion/components/trust-bar.tsx +0 -66
- package/templates/storefront-fashion/e2e/visual.spec.ts +0 -52
- package/templates/storefront-fashion/lib/brand.ts +0 -518
- package/templates/storefront-fashion/lib/cart.ts +0 -12
- package/templates/storefront-fashion/next.config.ts +0 -42
- package/templates/storefront-fashion/package.json +0 -38
- package/templates/storefront-fashion/playwright.config.ts +0 -48
- package/templates/storefront-fashion/postcss.config.mjs +0 -7
- package/templates/storefront-fashion/tsconfig.json +0 -23
- package/templates/storefront-fashion/vitest.config.ts +0 -9
- package/templates/storefront-grocery/.claude/skills/cimplify-storefront/SKILL.md +0 -145
- package/templates/storefront-grocery/.cursor/rules/cimplify-storefront.mdc +0 -25
- package/templates/storefront-grocery/.env.example +0 -16
- package/templates/storefront-grocery/AGENTS.md +0 -96
- package/templates/storefront-grocery/CLAUDE.md +0 -22
- package/templates/storefront-grocery/README.md +0 -73
- package/templates/storefront-grocery/__tests__/brand.test.ts +0 -4
- package/templates/storefront-grocery/__tests__/cart-flow.test.ts +0 -4
- package/templates/storefront-grocery/__tests__/contract.test.ts +0 -4
- package/templates/storefront-grocery/app/about/page.tsx +0 -38
- package/templates/storefront-grocery/app/accessibility/page.tsx +0 -11
- package/templates/storefront-grocery/app/account/addresses/page.tsx +0 -21
- package/templates/storefront-grocery/app/account/orders/page.tsx +0 -21
- package/templates/storefront-grocery/app/account/page.tsx +0 -22
- package/templates/storefront-grocery/app/account/settings/page.tsx +0 -21
- package/templates/storefront-grocery/app/cart/page.tsx +0 -9
- package/templates/storefront-grocery/app/categories/[slug]/listing-client.tsx +0 -19
- package/templates/storefront-grocery/app/categories/[slug]/page.tsx +0 -118
- package/templates/storefront-grocery/app/checkout/page.tsx +0 -17
- package/templates/storefront-grocery/app/collections/[slug]/listing-client.tsx +0 -20
- package/templates/storefront-grocery/app/collections/[slug]/page.tsx +0 -118
- package/templates/storefront-grocery/app/contact/contact-form.tsx +0 -109
- package/templates/storefront-grocery/app/contact/page.tsx +0 -54
- package/templates/storefront-grocery/app/error.tsx +0 -60
- package/templates/storefront-grocery/app/faq/page.tsx +0 -46
- package/templates/storefront-grocery/app/globals.css +0 -45
- package/templates/storefront-grocery/app/layout.tsx +0 -77
- package/templates/storefront-grocery/app/llms.txt/route.ts +0 -94
- package/templates/storefront-grocery/app/login/page.tsx +0 -17
- package/templates/storefront-grocery/app/not-found.tsx +0 -39
- package/templates/storefront-grocery/app/opensearch.xml/route.ts +0 -37
- package/templates/storefront-grocery/app/orders/[id]/page.tsx +0 -21
- package/templates/storefront-grocery/app/page.tsx +0 -97
- package/templates/storefront-grocery/app/privacy/page.tsx +0 -44
- package/templates/storefront-grocery/app/returns/page.tsx +0 -11
- package/templates/storefront-grocery/app/robots.ts +0 -18
- package/templates/storefront-grocery/app/search/page.tsx +0 -38
- package/templates/storefront-grocery/app/search/search-client.tsx +0 -7
- package/templates/storefront-grocery/app/shipping/page.tsx +0 -16
- package/templates/storefront-grocery/app/shop/page.tsx +0 -31
- package/templates/storefront-grocery/app/shop/shop-client.tsx +0 -27
- package/templates/storefront-grocery/app/signup/page.tsx +0 -17
- package/templates/storefront-grocery/app/sitemap-page/page.tsx +0 -167
- package/templates/storefront-grocery/app/sitemap.ts +0 -62
- package/templates/storefront-grocery/app/terms/page.tsx +0 -44
- package/templates/storefront-grocery/app/track-order/page.tsx +0 -24
- package/templates/storefront-grocery/app/track-order/track-order-form.tsx +0 -69
- package/templates/storefront-grocery/components/account-iframe.tsx +0 -13
- package/templates/storefront-grocery/components/cart-drawer.tsx +0 -14
- package/templates/storefront-grocery/components/cart-pill.tsx +0 -36
- package/templates/storefront-grocery/components/category-grid.tsx +0 -28
- package/templates/storefront-grocery/components/collection-strip.tsx +0 -45
- package/templates/storefront-grocery/components/footer.tsx +0 -148
- package/templates/storefront-grocery/components/header.tsx +0 -43
- package/templates/storefront-grocery/components/hero.tsx +0 -25
- package/templates/storefront-grocery/components/nav-link.tsx +0 -20
- package/templates/storefront-grocery/components/policy-page.tsx +0 -49
- package/templates/storefront-grocery/components/product-modal.tsx +0 -104
- package/templates/storefront-grocery/components/providers.tsx +0 -35
- package/templates/storefront-grocery/components/store-product-card.tsx +0 -87
- package/templates/storefront-grocery/lib/brand.ts +0 -375
- package/templates/storefront-grocery/lib/cart.ts +0 -12
- package/templates/storefront-grocery/next.config.ts +0 -42
- package/templates/storefront-grocery/package.json +0 -35
- package/templates/storefront-grocery/postcss.config.mjs +0 -7
- package/templates/storefront-grocery/tsconfig.json +0 -23
- package/templates/storefront-grocery/vitest.config.ts +0 -9
- package/templates/storefront-restaurant/.claude/skills/cimplify-storefront/SKILL.md +0 -145
- package/templates/storefront-restaurant/.cursor/rules/cimplify-storefront.mdc +0 -25
- package/templates/storefront-restaurant/.env.example +0 -16
- package/templates/storefront-restaurant/AGENTS.md +0 -102
- package/templates/storefront-restaurant/CLAUDE.md +0 -22
- package/templates/storefront-restaurant/README.md +0 -73
- package/templates/storefront-restaurant/__tests__/brand.test.ts +0 -4
- package/templates/storefront-restaurant/__tests__/cart-flow.test.ts +0 -4
- package/templates/storefront-restaurant/__tests__/contract.test.ts +0 -4
- package/templates/storefront-restaurant/app/about/page.tsx +0 -38
- package/templates/storefront-restaurant/app/accessibility/page.tsx +0 -11
- package/templates/storefront-restaurant/app/account/addresses/page.tsx +0 -21
- package/templates/storefront-restaurant/app/account/orders/page.tsx +0 -21
- package/templates/storefront-restaurant/app/account/page.tsx +0 -22
- package/templates/storefront-restaurant/app/account/settings/page.tsx +0 -21
- package/templates/storefront-restaurant/app/cart/page.tsx +0 -9
- package/templates/storefront-restaurant/app/categories/[slug]/listing-client.tsx +0 -19
- package/templates/storefront-restaurant/app/categories/[slug]/page.tsx +0 -118
- package/templates/storefront-restaurant/app/checkout/page.tsx +0 -17
- package/templates/storefront-restaurant/app/collections/[slug]/listing-client.tsx +0 -20
- package/templates/storefront-restaurant/app/collections/[slug]/page.tsx +0 -118
- package/templates/storefront-restaurant/app/contact/contact-form.tsx +0 -109
- package/templates/storefront-restaurant/app/contact/page.tsx +0 -54
- package/templates/storefront-restaurant/app/error.tsx +0 -60
- package/templates/storefront-restaurant/app/faq/page.tsx +0 -46
- package/templates/storefront-restaurant/app/globals.css +0 -44
- package/templates/storefront-restaurant/app/layout.tsx +0 -82
- package/templates/storefront-restaurant/app/llms.txt/route.ts +0 -94
- package/templates/storefront-restaurant/app/login/page.tsx +0 -17
- package/templates/storefront-restaurant/app/not-found.tsx +0 -39
- package/templates/storefront-restaurant/app/opensearch.xml/route.ts +0 -37
- package/templates/storefront-restaurant/app/orders/[id]/page.tsx +0 -21
- package/templates/storefront-restaurant/app/page.tsx +0 -97
- package/templates/storefront-restaurant/app/privacy/page.tsx +0 -44
- package/templates/storefront-restaurant/app/reservations/page.tsx +0 -66
- package/templates/storefront-restaurant/app/reservations/reservations-client.tsx +0 -234
- package/templates/storefront-restaurant/app/returns/page.tsx +0 -11
- package/templates/storefront-restaurant/app/robots.ts +0 -18
- package/templates/storefront-restaurant/app/search/page.tsx +0 -38
- package/templates/storefront-restaurant/app/search/search-client.tsx +0 -7
- package/templates/storefront-restaurant/app/shipping/page.tsx +0 -16
- package/templates/storefront-restaurant/app/shop/page.tsx +0 -31
- package/templates/storefront-restaurant/app/shop/shop-client.tsx +0 -27
- package/templates/storefront-restaurant/app/signup/page.tsx +0 -17
- package/templates/storefront-restaurant/app/sitemap-page/page.tsx +0 -167
- package/templates/storefront-restaurant/app/sitemap.ts +0 -62
- package/templates/storefront-restaurant/app/terms/page.tsx +0 -44
- package/templates/storefront-restaurant/app/track-order/page.tsx +0 -24
- package/templates/storefront-restaurant/app/track-order/track-order-form.tsx +0 -69
- package/templates/storefront-restaurant/components/account-iframe.tsx +0 -13
- package/templates/storefront-restaurant/components/cart-drawer.tsx +0 -14
- package/templates/storefront-restaurant/components/cart-pill.tsx +0 -36
- package/templates/storefront-restaurant/components/category-grid.tsx +0 -28
- package/templates/storefront-restaurant/components/collection-strip.tsx +0 -45
- package/templates/storefront-restaurant/components/footer.tsx +0 -148
- package/templates/storefront-restaurant/components/header.tsx +0 -43
- package/templates/storefront-restaurant/components/hero.tsx +0 -25
- package/templates/storefront-restaurant/components/nav-link.tsx +0 -20
- package/templates/storefront-restaurant/components/policy-page.tsx +0 -49
- package/templates/storefront-restaurant/components/product-modal.tsx +0 -104
- package/templates/storefront-restaurant/components/providers.tsx +0 -35
- package/templates/storefront-restaurant/components/store-product-card.tsx +0 -87
- package/templates/storefront-restaurant/lib/brand.ts +0 -377
- package/templates/storefront-restaurant/lib/cart.ts +0 -12
- package/templates/storefront-restaurant/next.config.ts +0 -42
- package/templates/storefront-restaurant/package.json +0 -35
- package/templates/storefront-restaurant/postcss.config.mjs +0 -7
- package/templates/storefront-restaurant/tsconfig.json +0 -23
- package/templates/storefront-restaurant/vitest.config.ts +0 -9
- package/templates/storefront-retail/.claude/skills/cimplify-storefront/SKILL.md +0 -145
- package/templates/storefront-retail/.cursor/rules/cimplify-storefront.mdc +0 -25
- package/templates/storefront-retail/.env.example +0 -16
- package/templates/storefront-retail/AGENTS.md +0 -117
- package/templates/storefront-retail/CLAUDE.md +0 -22
- package/templates/storefront-retail/README.md +0 -77
- package/templates/storefront-retail/__tests__/brand.test.ts +0 -4
- package/templates/storefront-retail/__tests__/cart-flow.test.ts +0 -4
- package/templates/storefront-retail/__tests__/contract.test.ts +0 -4
- package/templates/storefront-retail/app/about/page.tsx +0 -41
- package/templates/storefront-retail/app/accessibility/page.tsx +0 -11
- package/templates/storefront-retail/app/account/addresses/page.tsx +0 -21
- package/templates/storefront-retail/app/account/orders/page.tsx +0 -21
- package/templates/storefront-retail/app/account/page.tsx +0 -22
- package/templates/storefront-retail/app/account/settings/page.tsx +0 -21
- package/templates/storefront-retail/app/cart/page.tsx +0 -9
- package/templates/storefront-retail/app/categories/[slug]/listing-client.tsx +0 -19
- package/templates/storefront-retail/app/categories/[slug]/page.tsx +0 -130
- package/templates/storefront-retail/app/checkout/page.tsx +0 -17
- package/templates/storefront-retail/app/collections/[slug]/listing-client.tsx +0 -20
- package/templates/storefront-retail/app/collections/[slug]/page.tsx +0 -130
- package/templates/storefront-retail/app/contact/contact-form.tsx +0 -109
- package/templates/storefront-retail/app/contact/page.tsx +0 -54
- package/templates/storefront-retail/app/error.tsx +0 -61
- package/templates/storefront-retail/app/faq/page.tsx +0 -46
- package/templates/storefront-retail/app/globals.css +0 -47
- package/templates/storefront-retail/app/layout.tsx +0 -77
- package/templates/storefront-retail/app/llms.txt/route.ts +0 -94
- package/templates/storefront-retail/app/login/page.tsx +0 -17
- package/templates/storefront-retail/app/not-found.tsx +0 -39
- package/templates/storefront-retail/app/opensearch.xml/route.ts +0 -37
- package/templates/storefront-retail/app/orders/[id]/page.tsx +0 -24
- package/templates/storefront-retail/app/page.tsx +0 -182
- package/templates/storefront-retail/app/privacy/page.tsx +0 -44
- package/templates/storefront-retail/app/products/[slug]/page.tsx +0 -165
- package/templates/storefront-retail/app/products/[slug]/product-detail.tsx +0 -70
- package/templates/storefront-retail/app/returns/page.tsx +0 -11
- package/templates/storefront-retail/app/robots.ts +0 -18
- package/templates/storefront-retail/app/search/page.tsx +0 -38
- package/templates/storefront-retail/app/search/search-client.tsx +0 -7
- package/templates/storefront-retail/app/shipping/page.tsx +0 -16
- package/templates/storefront-retail/app/shop/page.tsx +0 -63
- package/templates/storefront-retail/app/shop/shop-client.tsx +0 -32
- package/templates/storefront-retail/app/signup/page.tsx +0 -17
- package/templates/storefront-retail/app/sitemap-page/page.tsx +0 -167
- package/templates/storefront-retail/app/sitemap.ts +0 -59
- package/templates/storefront-retail/app/terms/page.tsx +0 -44
- package/templates/storefront-retail/app/track-order/page.tsx +0 -24
- package/templates/storefront-retail/app/track-order/track-order-form.tsx +0 -69
- package/templates/storefront-retail/components/account-iframe.tsx +0 -13
- package/templates/storefront-retail/components/brand-marquee.tsx +0 -27
- package/templates/storefront-retail/components/cart-drawer.tsx +0 -14
- package/templates/storefront-retail/components/cart-pill.tsx +0 -36
- package/templates/storefront-retail/components/category-grid.tsx +0 -28
- package/templates/storefront-retail/components/category-tiles.tsx +0 -104
- package/templates/storefront-retail/components/collection-strip.tsx +0 -45
- package/templates/storefront-retail/components/feature-hero.tsx +0 -84
- package/templates/storefront-retail/components/footer.tsx +0 -153
- package/templates/storefront-retail/components/header.tsx +0 -45
- package/templates/storefront-retail/components/hero.tsx +0 -28
- package/templates/storefront-retail/components/nav-link.tsx +0 -20
- package/templates/storefront-retail/components/newsletter.tsx +0 -50
- package/templates/storefront-retail/components/policy-page.tsx +0 -49
- package/templates/storefront-retail/components/promo-banner.tsx +0 -41
- package/templates/storefront-retail/components/providers.tsx +0 -35
- package/templates/storefront-retail/components/section-heading.tsx +0 -37
- package/templates/storefront-retail/components/store-product-card.tsx +0 -87
- package/templates/storefront-retail/components/trade-in-cta.tsx +0 -54
- package/templates/storefront-retail/components/trust-bar.tsx +0 -66
- package/templates/storefront-retail/lib/brand.ts +0 -664
- package/templates/storefront-retail/lib/cart.ts +0 -12
- package/templates/storefront-retail/next.config.ts +0 -42
- package/templates/storefront-retail/package.json +0 -35
- package/templates/storefront-retail/postcss.config.mjs +0 -7
- package/templates/storefront-retail/tsconfig.json +0 -23
- package/templates/storefront-retail/vitest.config.ts +0 -9
- package/templates/storefront-services/.claude/skills/cimplify-storefront/SKILL.md +0 -145
- package/templates/storefront-services/.cursor/rules/cimplify-storefront.mdc +0 -25
- package/templates/storefront-services/.env.example +0 -16
- package/templates/storefront-services/AGENTS.md +0 -101
- package/templates/storefront-services/CLAUDE.md +0 -22
- package/templates/storefront-services/README.md +0 -73
- package/templates/storefront-services/__tests__/brand.test.ts +0 -4
- package/templates/storefront-services/__tests__/cart-flow.test.ts +0 -4
- package/templates/storefront-services/__tests__/contract.test.ts +0 -4
- package/templates/storefront-services/app/about/page.tsx +0 -38
- package/templates/storefront-services/app/accessibility/page.tsx +0 -11
- package/templates/storefront-services/app/account/addresses/page.tsx +0 -21
- package/templates/storefront-services/app/account/orders/page.tsx +0 -21
- package/templates/storefront-services/app/account/page.tsx +0 -22
- package/templates/storefront-services/app/account/settings/page.tsx +0 -21
- package/templates/storefront-services/app/book/book-client.tsx +0 -195
- package/templates/storefront-services/app/book/page.tsx +0 -65
- package/templates/storefront-services/app/cart/page.tsx +0 -9
- package/templates/storefront-services/app/categories/[slug]/listing-client.tsx +0 -19
- package/templates/storefront-services/app/categories/[slug]/page.tsx +0 -118
- package/templates/storefront-services/app/checkout/page.tsx +0 -17
- package/templates/storefront-services/app/collections/[slug]/listing-client.tsx +0 -20
- package/templates/storefront-services/app/collections/[slug]/page.tsx +0 -118
- package/templates/storefront-services/app/contact/contact-form.tsx +0 -109
- package/templates/storefront-services/app/contact/page.tsx +0 -54
- package/templates/storefront-services/app/error.tsx +0 -60
- package/templates/storefront-services/app/faq/page.tsx +0 -46
- package/templates/storefront-services/app/globals.css +0 -45
- package/templates/storefront-services/app/layout.tsx +0 -82
- package/templates/storefront-services/app/llms.txt/route.ts +0 -94
- package/templates/storefront-services/app/login/page.tsx +0 -17
- package/templates/storefront-services/app/not-found.tsx +0 -39
- package/templates/storefront-services/app/opensearch.xml/route.ts +0 -37
- package/templates/storefront-services/app/orders/[id]/page.tsx +0 -21
- package/templates/storefront-services/app/page.tsx +0 -97
- package/templates/storefront-services/app/privacy/page.tsx +0 -44
- package/templates/storefront-services/app/returns/page.tsx +0 -11
- package/templates/storefront-services/app/robots.ts +0 -18
- package/templates/storefront-services/app/search/page.tsx +0 -38
- package/templates/storefront-services/app/search/search-client.tsx +0 -7
- package/templates/storefront-services/app/shipping/page.tsx +0 -16
- package/templates/storefront-services/app/shop/page.tsx +0 -31
- package/templates/storefront-services/app/shop/shop-client.tsx +0 -27
- package/templates/storefront-services/app/signup/page.tsx +0 -17
- package/templates/storefront-services/app/sitemap-page/page.tsx +0 -167
- package/templates/storefront-services/app/sitemap.ts +0 -62
- package/templates/storefront-services/app/terms/page.tsx +0 -44
- package/templates/storefront-services/app/track-order/page.tsx +0 -24
- package/templates/storefront-services/app/track-order/track-order-form.tsx +0 -69
- package/templates/storefront-services/components/account-iframe.tsx +0 -13
- package/templates/storefront-services/components/cart-drawer.tsx +0 -14
- package/templates/storefront-services/components/cart-pill.tsx +0 -36
- package/templates/storefront-services/components/category-grid.tsx +0 -28
- package/templates/storefront-services/components/collection-strip.tsx +0 -45
- package/templates/storefront-services/components/footer.tsx +0 -148
- package/templates/storefront-services/components/header.tsx +0 -43
- package/templates/storefront-services/components/hero.tsx +0 -25
- package/templates/storefront-services/components/nav-link.tsx +0 -20
- package/templates/storefront-services/components/policy-page.tsx +0 -49
- package/templates/storefront-services/components/product-modal.tsx +0 -104
- package/templates/storefront-services/components/providers.tsx +0 -35
- package/templates/storefront-services/components/store-product-card.tsx +0 -87
- package/templates/storefront-services/lib/brand.ts +0 -396
- package/templates/storefront-services/lib/cart.ts +0 -12
- package/templates/storefront-services/next.config.ts +0 -42
- package/templates/storefront-services/package.json +0 -35
- package/templates/storefront-services/postcss.config.mjs +0 -7
- package/templates/storefront-services/tsconfig.json +0 -23
- package/templates/storefront-services/vitest.config.ts +0 -9
|
@@ -1,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 (retail: Currents Electronics).
|
|
11
|
-
NEXT_PUBLIC_CIMPLIFY_BUSINESS_ID=bus_currents_electronics
|
|
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,117 +0,0 @@
|
|
|
1
|
-
# AGENTS.md — Retail / electronics 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 { … }` block 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
|
-
- **Inter + JetBrains Mono** — clean modern sans, mono-spaced labels for spec-feel.
|
|
14
|
-
- **Cool navy + electric blue**: dark foreground, electric primary.
|
|
15
|
-
- **Sharp corners**: `0.5rem` — modern retail.
|
|
16
|
-
- **Section heroes** in dark with mono-spaced eyebrow labels.
|
|
17
|
-
|
|
18
|
-
## Page surface
|
|
19
|
-
|
|
20
|
-
```
|
|
21
|
-
app/
|
|
22
|
-
page.tsx Multi-section home — split hero, trust bar, category tiles,
|
|
23
|
-
promo banner, "Just dropped" grid, brand strip, collections,
|
|
24
|
-
trade-in CTA, best sellers, newsletter
|
|
25
|
-
shop/page.tsx SDK <CataloguePage/> with custom hero
|
|
26
|
-
search/page.tsx Search (SDK <SearchPage/>)
|
|
27
|
-
collections/[slug]/page.tsx Collection landing
|
|
28
|
-
categories/[slug]/page.tsx Category landing
|
|
29
|
-
products/[slug]/page.tsx Full product detail page (Product JSON-LD)
|
|
30
|
-
|
|
31
|
-
cart/page.tsx SDK <CartPage/>
|
|
32
|
-
checkout/page.tsx SDK <CheckoutPage/>
|
|
33
|
-
orders/[id]/page.tsx Post-checkout confirmation
|
|
34
|
-
|
|
35
|
-
account/page.tsx <CimplifyAccount /> (iframe)
|
|
36
|
-
account/orders/page.tsx <CimplifyAccount section="orders" />
|
|
37
|
-
account/addresses/page.tsx <CimplifyAccount section="addresses" />
|
|
38
|
-
account/settings/page.tsx <CimplifyAccount section="settings" />
|
|
39
|
-
login/page.tsx, signup/page.tsx redirects → /account
|
|
40
|
-
|
|
41
|
-
contact/page.tsx Branded contact form
|
|
42
|
-
track-order/page.tsx Guest lookup → /orders/[id]
|
|
43
|
-
|
|
44
|
-
about/page.tsx, faq/page.tsx Brand pages
|
|
45
|
-
shipping/page.tsx, returns/page.tsx, accessibility/page.tsx Standalone policies
|
|
46
|
-
terms/page.tsx, privacy/page.tsx
|
|
47
|
-
|
|
48
|
-
sitemap-page/page.tsx HTML sitemap
|
|
49
|
-
sitemap.ts, robots.ts XML sitemap, robots.txt
|
|
50
|
-
llms.txt/route.ts LLM-friendly site index
|
|
51
|
-
opensearch.xml/route.ts Browser search description
|
|
52
|
-
error.tsx, not-found.tsx Global boundaries
|
|
53
|
-
```
|
|
54
|
-
|
|
55
|
-
## File ↔ brand-field map
|
|
56
|
-
|
|
57
|
-
| File | Reads from `brand` |
|
|
58
|
-
|---|---|
|
|
59
|
-
| `app/layout.tsx` | identity, contact, socials, schemaType (Store JSON-LD) |
|
|
60
|
-
| `app/page.tsx` | `brand.hero`, `brand.trustItems`, `brand.brandStrip`, `brand.promo`, `brand.tradeIn`, `brand.newsletter` |
|
|
61
|
-
| `app/about/page.tsx` | `brand.about` |
|
|
62
|
-
| `app/faq/page.tsx` | `brand.faq` |
|
|
63
|
-
| `app/terms/page.tsx` | `brand.terms` |
|
|
64
|
-
| `app/privacy/page.tsx` | `brand.privacy` |
|
|
65
|
-
| `app/shipping/page.tsx` | `brand.shipping` (warranty + returns + same-day delivery copy) |
|
|
66
|
-
| `app/returns/page.tsx` | `brand.returns` |
|
|
67
|
-
| `app/accessibility/page.tsx` | `brand.accessibility` |
|
|
68
|
-
| `app/contact/page.tsx` | `brand.contactPage`, `brand.contact` |
|
|
69
|
-
| `app/track-order/page.tsx` | `brand.trackOrder` |
|
|
70
|
-
| `app/account/*/page.tsx` | `brand.account` (Cimplify Link iframe owns the UI) |
|
|
71
|
-
| `app/products/[slug]/page.tsx` | `brand.name`, `brand.currency` (Product JSON-LD: brand, offer, availability) |
|
|
72
|
-
| `app/llms.txt/route.ts` | `brand.llms`, contact, currency |
|
|
73
|
-
| `app/opensearch.xml/route.ts` | `brand.shortName`, `brand.name` |
|
|
74
|
-
| `components/header.tsx` | `brand.shortName`, `brand.microTag`, `brand.header.nav` |
|
|
75
|
-
| `components/footer.tsx` | `brand.footer`, `brand.contact`, `brand.socials` |
|
|
76
|
-
| `components/promo-banner.tsx` | `brand.promo` (renders nothing if absent) |
|
|
77
|
-
| `components/trade-in-cta.tsx` | `brand.tradeIn` (renders nothing if absent) |
|
|
78
|
-
| `components/brand-marquee.tsx` | `brand.brandStrip` |
|
|
79
|
-
| `components/trust-bar.tsx` | `brand.trustItems` |
|
|
80
|
-
| `components/newsletter.tsx` | `brand.newsletter` |
|
|
81
|
-
|
|
82
|
-
## Retail-specific notes
|
|
83
|
-
|
|
84
|
-
- Product detail is a **full `/products/[slug]` page** with image gallery, customizer, related products rail, and Product JSON-LD. Consideration purchases (phones, laptops, headphones) need real estate. Don't replace with a modal.
|
|
85
|
-
- Schema.org `@type` is `Store`.
|
|
86
|
-
- Optional sections render conditionally: set `brand.promo`, `brand.tradeIn`, `brand.trustItems`, or `brand.brandStrip` to `undefined` to hide them.
|
|
87
|
-
- `app/page.tsx` uses an Unsplash fallback hero (`HERO_FALLBACK_IMAGE`) — replace with the merchant's own product photography.
|
|
88
|
-
|
|
89
|
-
## Known TODOs
|
|
90
|
-
|
|
91
|
-
- Contact form + newsletter signup currently fake their submit. Wire `client.support.sendMessage(...)` for contact and a real list provider for newsletter.
|
|
92
|
-
- Trust-bar / brand-marquee imagery / wordmarks are placeholders — swap for the merchant's real partners.
|
|
93
|
-
|
|
94
|
-
## Mock seed
|
|
95
|
-
|
|
96
|
-
Wired to `--seed retail` (Currents Electronics). Edit `dev:mock` in `package.json` to preview another seed.
|
|
97
|
-
|
|
98
|
-
## Customizing SDK components
|
|
99
|
-
|
|
100
|
-
For anything beyond `lib/brand.ts` + `app/globals.css`, lean on the SDK's prebuilt components rather than reinvent. **Especially for product customization** (variants, add-ons, bundles, composites, services with scheduling) — the SDK already gets price math, axis matching, and cart payload contracts right. Default to ejecting and restyling:
|
|
101
|
-
|
|
102
|
-
```bash
|
|
103
|
-
bunx @cimplify/sdk add cart-drawer
|
|
104
|
-
bunx @cimplify/sdk add variant-selector
|
|
105
|
-
bunx @cimplify/sdk add product-page
|
|
106
|
-
```
|
|
107
|
-
|
|
108
|
-
Then edit the local copy. **Don't change the cart payload shape** 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".
|
|
109
|
-
|
|
110
|
-
## Quick start
|
|
111
|
-
|
|
112
|
-
```bash
|
|
113
|
-
bun install
|
|
114
|
-
bun dev
|
|
115
|
-
```
|
|
116
|
-
|
|
117
|
-
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,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
|
-
}
|
|
@@ -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
|
-
}
|
|
@@ -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: `Settings — ${brand.name}`,
|
|
7
|
-
};
|
|
8
|
-
|
|
9
|
-
export default function SettingsPage() {
|
|
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
|
-
Settings
|
|
17
|
-
</h1>
|
|
18
|
-
<AccountIframe section="settings" />
|
|
19
|
-
</article>
|
|
20
|
-
);
|
|
21
|
-
}
|
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
"use client";
|
|
2
|
-
|
|
3
|
-
import { useRouter } from "next/navigation";
|
|
4
|
-
import { CartPage as SdkCartPage } from "@cimplify/sdk/react";
|
|
5
|
-
|
|
6
|
-
export default function CartPage() {
|
|
7
|
-
const router = useRouter();
|
|
8
|
-
return <SdkCartPage onCheckout={() => router.push("/checkout")} />;
|
|
9
|
-
}
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
"use client";
|
|
2
|
-
|
|
3
|
-
import { ProductGrid } from "@cimplify/sdk/react";
|
|
4
|
-
import type { Product } from "@cimplify/sdk";
|
|
5
|
-
import { StoreProductCard } from "@/components/store-product-card";
|
|
6
|
-
|
|
7
|
-
/**
|
|
8
|
-
* Client island for the category listing. Receives server-fetched products
|
|
9
|
-
* as props (serializable) and owns the `renderCard` function.
|
|
10
|
-
*/
|
|
11
|
-
export function ListingClient({ products }: { products: Product[] }) {
|
|
12
|
-
return (
|
|
13
|
-
<ProductGrid
|
|
14
|
-
products={products}
|
|
15
|
-
emptyMessage="No products in this category yet."
|
|
16
|
-
renderCard={(p) => <StoreProductCard product={p} />}
|
|
17
|
-
/>
|
|
18
|
-
);
|
|
19
|
-
}
|
|
@@ -1,130 +0,0 @@
|
|
|
1
|
-
import type { Metadata } from "next";
|
|
2
|
-
import { Suspense } from "react";
|
|
3
|
-
import Link from "next/link";
|
|
4
|
-
import { notFound } from "next/navigation";
|
|
5
|
-
import { cacheTag, cacheLife } from "next/cache";
|
|
6
|
-
import {
|
|
7
|
-
getServerClient,
|
|
8
|
-
tags,
|
|
9
|
-
type Category,
|
|
10
|
-
type Product,
|
|
11
|
-
} from "@cimplify/sdk/server";
|
|
12
|
-
import { ListingClient } from "./listing-client";
|
|
13
|
-
import { brand } from "@/lib/brand";
|
|
14
|
-
|
|
15
|
-
interface CategoryData {
|
|
16
|
-
category: Category;
|
|
17
|
-
products: Product[];
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
async function getCategory(slug: string): Promise<CategoryData | null> {
|
|
21
|
-
"use cache";
|
|
22
|
-
cacheTag(tags.categories());
|
|
23
|
-
cacheLife("hours");
|
|
24
|
-
|
|
25
|
-
const client = getServerClient();
|
|
26
|
-
const catRes = await client.catalogue.getCategoryBySlug(slug);
|
|
27
|
-
if (!catRes.ok) return null;
|
|
28
|
-
|
|
29
|
-
cacheTag(tags.category(catRes.value.id), tags.categoryProducts(catRes.value.id));
|
|
30
|
-
const r = await client.catalogue.getCategoryProducts(catRes.value.id);
|
|
31
|
-
const products = r.ok
|
|
32
|
-
? ((r.value as { items?: Product[] }).items ?? (r.value as Product[]))
|
|
33
|
-
: [];
|
|
34
|
-
return { category: catRes.value, products };
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
export async function generateMetadata({
|
|
38
|
-
params,
|
|
39
|
-
}: {
|
|
40
|
-
params: Promise<{ slug: string }>;
|
|
41
|
-
}): Promise<Metadata> {
|
|
42
|
-
const { slug } = await params;
|
|
43
|
-
const data = await getCategory(slug);
|
|
44
|
-
if (!data) return {};
|
|
45
|
-
return {
|
|
46
|
-
title: `${data.category.name} — ${brand.name}`,
|
|
47
|
-
description: data.category.description ?? undefined,
|
|
48
|
-
};
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
export default async function CategoryPage({
|
|
52
|
-
params,
|
|
53
|
-
}: {
|
|
54
|
-
params: Promise<{ slug: string }>;
|
|
55
|
-
}) {
|
|
56
|
-
return (
|
|
57
|
-
<Suspense fallback={<CategorySkeleton />}>
|
|
58
|
-
<CategoryContent params={params} />
|
|
59
|
-
</Suspense>
|
|
60
|
-
);
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
async function CategoryContent({
|
|
64
|
-
params,
|
|
65
|
-
}: {
|
|
66
|
-
params: Promise<{ slug: string }>;
|
|
67
|
-
}) {
|
|
68
|
-
const { slug } = await params;
|
|
69
|
-
const data = await getCategory(slug);
|
|
70
|
-
if (!data) notFound();
|
|
71
|
-
|
|
72
|
-
const { category, products } = data;
|
|
73
|
-
return (
|
|
74
|
-
<>
|
|
75
|
-
<section className="bg-foreground text-background relative overflow-hidden">
|
|
76
|
-
<div className="absolute inset-0 opacity-[0.04] pointer-events-none [background-image:radial-gradient(circle_at_2px_2px,white_1px,transparent_0)] [background-size:32px_32px]" />
|
|
77
|
-
<div className="relative max-w-7xl mx-auto px-6 sm:px-8 py-12 sm:py-14">
|
|
78
|
-
<nav className="text-[12px] font-mono text-background/60 mb-3 flex items-center gap-2">
|
|
79
|
-
<Link href="/" className="hover:text-background transition-colors">Home</Link>
|
|
80
|
-
<span>/</span>
|
|
81
|
-
<Link href="/shop" className="hover:text-background transition-colors">Shop</Link>
|
|
82
|
-
<span>/</span>
|
|
83
|
-
<span className="text-background/90">{category.name}</span>
|
|
84
|
-
</nav>
|
|
85
|
-
<h1 className="text-[clamp(2rem,4vw,3rem)] font-bold m-0 -tracking-[0.025em]">
|
|
86
|
-
{category.name}
|
|
87
|
-
</h1>
|
|
88
|
-
{category.description && (
|
|
89
|
-
<p className="mt-3 max-w-2xl text-base text-background/75">
|
|
90
|
-
{category.description}
|
|
91
|
-
</p>
|
|
92
|
-
)}
|
|
93
|
-
<p className="mt-4 text-[11px] font-mono uppercase tracking-[0.16em] text-background/60 tabular-nums">
|
|
94
|
-
{products.length} {products.length === 1 ? "product" : "products"}
|
|
95
|
-
</p>
|
|
96
|
-
</div>
|
|
97
|
-
</section>
|
|
98
|
-
<section className="max-w-7xl mx-auto px-6 sm:px-8 py-10 sm:py-12">
|
|
99
|
-
<ListingClient products={products} />
|
|
100
|
-
{products.length === 0 && (
|
|
101
|
-
<p className="text-center mt-8">
|
|
102
|
-
<Link href="/shop" className="text-primary font-semibold hover:underline">
|
|
103
|
-
← Browse all products
|
|
104
|
-
</Link>
|
|
105
|
-
</p>
|
|
106
|
-
)}
|
|
107
|
-
</section>
|
|
108
|
-
</>
|
|
109
|
-
);
|
|
110
|
-
}
|
|
111
|
-
|
|
112
|
-
function CategorySkeleton() {
|
|
113
|
-
return (
|
|
114
|
-
<>
|
|
115
|
-
<section className="bg-foreground py-12 sm:py-14">
|
|
116
|
-
<div className="max-w-7xl mx-auto px-6 sm:px-8">
|
|
117
|
-
<div className="h-3 w-32 bg-background/20 rounded mb-3 animate-pulse" />
|
|
118
|
-
<div className="h-12 w-72 bg-background/20 rounded animate-pulse" />
|
|
119
|
-
</div>
|
|
120
|
-
</section>
|
|
121
|
-
<section className="max-w-7xl mx-auto px-6 sm:px-8 py-10 sm:py-12">
|
|
122
|
-
<div className="grid grid-cols-2 md:grid-cols-3 lg:grid-cols-4 gap-3 sm:gap-4">
|
|
123
|
-
{Array.from({ length: 8 }).map((_, i) => (
|
|
124
|
-
<div key={i} className="aspect-[4/3] bg-muted rounded-2xl animate-pulse" />
|
|
125
|
-
))}
|
|
126
|
-
</div>
|
|
127
|
-
</section>
|
|
128
|
-
</>
|
|
129
|
-
);
|
|
130
|
-
}
|
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
"use client";
|
|
2
|
-
|
|
3
|
-
import { useRouter } from "next/navigation";
|
|
4
|
-
import { CheckoutPage as SdkCheckoutPage } from "@cimplify/sdk/react";
|
|
5
|
-
|
|
6
|
-
export default function CheckoutPage() {
|
|
7
|
-
const router = useRouter();
|
|
8
|
-
return (
|
|
9
|
-
<SdkCheckoutPage
|
|
10
|
-
onComplete={(result) => {
|
|
11
|
-
if (result.success && result.order) {
|
|
12
|
-
router.push(`/orders/${result.order.id}`);
|
|
13
|
-
}
|
|
14
|
-
}}
|
|
15
|
-
/>
|
|
16
|
-
);
|
|
17
|
-
}
|
|
@@ -1,20 +0,0 @@
|
|
|
1
|
-
"use client";
|
|
2
|
-
|
|
3
|
-
import { ProductGrid } from "@cimplify/sdk/react";
|
|
4
|
-
import type { Product } from "@cimplify/sdk";
|
|
5
|
-
import { StoreProductCard } from "@/components/store-product-card";
|
|
6
|
-
|
|
7
|
-
/**
|
|
8
|
-
* Client island for the collection listing. Receives server-fetched
|
|
9
|
-
* products as props (serializable) and owns the `renderCard` function
|
|
10
|
-
* (which can't cross the server/client boundary).
|
|
11
|
-
*/
|
|
12
|
-
export function ListingClient({ products }: { products: Product[] }) {
|
|
13
|
-
return (
|
|
14
|
-
<ProductGrid
|
|
15
|
-
products={products}
|
|
16
|
-
emptyMessage="No products in this collection yet."
|
|
17
|
-
renderCard={(p) => <StoreProductCard product={p} />}
|
|
18
|
-
/>
|
|
19
|
-
);
|
|
20
|
-
}
|