@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.
Files changed (451) hide show
  1. package/README.md +21 -16
  2. package/dist/styles.css +1 -1
  3. package/package.json +5 -9
  4. package/dist/cli/commands/deploy.mjs +0 -717
  5. package/dist/cli/commands/dev.mjs +0 -479
  6. package/dist/cli/commands/domains.mjs +0 -769
  7. package/dist/cli/commands/env.mjs +0 -705
  8. package/dist/cli/commands/link.mjs +0 -378
  9. package/dist/cli/commands/login.mjs +0 -584
  10. package/dist/cli/commands/logout.mjs +0 -75
  11. package/dist/cli/commands/logs.mjs +0 -432
  12. package/dist/cli/commands/projects.mjs +0 -473
  13. package/dist/cli/commands/repo.mjs +0 -584
  14. package/dist/cli/commands/rollback.mjs +0 -553
  15. package/dist/cli/commands/status.mjs +0 -450
  16. package/dist/cli/commands/unlink.mjs +0 -79
  17. package/dist/cli/commands/whoami.mjs +0 -285
  18. package/dist/cli.js +0 -184
  19. package/dist/dispatcher.mjs +0 -360
  20. package/registry/booking-page.json +0 -18
  21. package/registry/bookings-page.json +0 -17
  22. package/registry/service-card.json +0 -16
  23. package/registry/service-grid.json +0 -16
  24. package/templates/storefront-bakery/.claude/skills/cimplify-storefront/SKILL.md +0 -145
  25. package/templates/storefront-bakery/.cursor/rules/cimplify-storefront.mdc +0 -25
  26. package/templates/storefront-bakery/.env.example +0 -16
  27. package/templates/storefront-bakery/AGENTS.md +0 -120
  28. package/templates/storefront-bakery/CLAUDE.md +0 -22
  29. package/templates/storefront-bakery/README.md +0 -73
  30. package/templates/storefront-bakery/__tests__/brand.test.ts +0 -4
  31. package/templates/storefront-bakery/__tests__/cart-flow.test.ts +0 -4
  32. package/templates/storefront-bakery/__tests__/contract.test.ts +0 -4
  33. package/templates/storefront-bakery/app/about/page.tsx +0 -38
  34. package/templates/storefront-bakery/app/accessibility/page.tsx +0 -11
  35. package/templates/storefront-bakery/app/account/addresses/page.tsx +0 -21
  36. package/templates/storefront-bakery/app/account/orders/page.tsx +0 -21
  37. package/templates/storefront-bakery/app/account/page.tsx +0 -22
  38. package/templates/storefront-bakery/app/account/settings/page.tsx +0 -21
  39. package/templates/storefront-bakery/app/cart/page.tsx +0 -9
  40. package/templates/storefront-bakery/app/categories/[slug]/listing-client.tsx +0 -19
  41. package/templates/storefront-bakery/app/categories/[slug]/page.tsx +0 -118
  42. package/templates/storefront-bakery/app/checkout/page.tsx +0 -17
  43. package/templates/storefront-bakery/app/collections/[slug]/listing-client.tsx +0 -20
  44. package/templates/storefront-bakery/app/collections/[slug]/page.tsx +0 -118
  45. package/templates/storefront-bakery/app/contact/contact-form.tsx +0 -109
  46. package/templates/storefront-bakery/app/contact/page.tsx +0 -54
  47. package/templates/storefront-bakery/app/error.tsx +0 -60
  48. package/templates/storefront-bakery/app/faq/page.tsx +0 -46
  49. package/templates/storefront-bakery/app/globals.css +0 -47
  50. package/templates/storefront-bakery/app/layout.tsx +0 -82
  51. package/templates/storefront-bakery/app/llms.txt/route.ts +0 -94
  52. package/templates/storefront-bakery/app/login/page.tsx +0 -17
  53. package/templates/storefront-bakery/app/not-found.tsx +0 -39
  54. package/templates/storefront-bakery/app/opensearch.xml/route.ts +0 -37
  55. package/templates/storefront-bakery/app/orders/[id]/page.tsx +0 -21
  56. package/templates/storefront-bakery/app/page.tsx +0 -97
  57. package/templates/storefront-bakery/app/privacy/page.tsx +0 -44
  58. package/templates/storefront-bakery/app/returns/page.tsx +0 -11
  59. package/templates/storefront-bakery/app/robots.ts +0 -18
  60. package/templates/storefront-bakery/app/search/page.tsx +0 -38
  61. package/templates/storefront-bakery/app/search/search-client.tsx +0 -7
  62. package/templates/storefront-bakery/app/shipping/page.tsx +0 -16
  63. package/templates/storefront-bakery/app/shop/page.tsx +0 -31
  64. package/templates/storefront-bakery/app/shop/shop-client.tsx +0 -27
  65. package/templates/storefront-bakery/app/signup/page.tsx +0 -17
  66. package/templates/storefront-bakery/app/sitemap-page/page.tsx +0 -167
  67. package/templates/storefront-bakery/app/sitemap.ts +0 -62
  68. package/templates/storefront-bakery/app/terms/page.tsx +0 -44
  69. package/templates/storefront-bakery/app/track-order/page.tsx +0 -24
  70. package/templates/storefront-bakery/app/track-order/track-order-form.tsx +0 -69
  71. package/templates/storefront-bakery/components/account-iframe.tsx +0 -13
  72. package/templates/storefront-bakery/components/cart-drawer.tsx +0 -14
  73. package/templates/storefront-bakery/components/cart-pill.tsx +0 -36
  74. package/templates/storefront-bakery/components/category-grid.tsx +0 -28
  75. package/templates/storefront-bakery/components/collection-strip.tsx +0 -45
  76. package/templates/storefront-bakery/components/footer.tsx +0 -148
  77. package/templates/storefront-bakery/components/header.tsx +0 -43
  78. package/templates/storefront-bakery/components/hero.tsx +0 -25
  79. package/templates/storefront-bakery/components/nav-link.tsx +0 -20
  80. package/templates/storefront-bakery/components/policy-page.tsx +0 -49
  81. package/templates/storefront-bakery/components/product-modal.tsx +0 -104
  82. package/templates/storefront-bakery/components/providers.tsx +0 -35
  83. package/templates/storefront-bakery/components/store-product-card.tsx +0 -87
  84. package/templates/storefront-bakery/lib/brand.ts +0 -570
  85. package/templates/storefront-bakery/lib/cart.ts +0 -12
  86. package/templates/storefront-bakery/next.config.ts +0 -42
  87. package/templates/storefront-bakery/package.json +0 -35
  88. package/templates/storefront-bakery/postcss.config.mjs +0 -7
  89. package/templates/storefront-bakery/tsconfig.json +0 -23
  90. package/templates/storefront-bakery/vitest.config.ts +0 -9
  91. package/templates/storefront-fashion/.claude/skills/cimplify-storefront/SKILL.md +0 -145
  92. package/templates/storefront-fashion/.cursor/rules/cimplify-storefront.mdc +0 -25
  93. package/templates/storefront-fashion/.env.example +0 -16
  94. package/templates/storefront-fashion/AGENTS.md +0 -126
  95. package/templates/storefront-fashion/CLAUDE.md +0 -22
  96. package/templates/storefront-fashion/README.md +0 -77
  97. package/templates/storefront-fashion/__tests__/brand.test.ts +0 -4
  98. package/templates/storefront-fashion/__tests__/cart-flow.test.ts +0 -55
  99. package/templates/storefront-fashion/__tests__/contract.test.ts +0 -4
  100. package/templates/storefront-fashion/app/about/page.tsx +0 -41
  101. package/templates/storefront-fashion/app/accessibility/page.tsx +0 -11
  102. package/templates/storefront-fashion/app/account/addresses/page.tsx +0 -21
  103. package/templates/storefront-fashion/app/account/orders/page.tsx +0 -21
  104. package/templates/storefront-fashion/app/account/page.tsx +0 -22
  105. package/templates/storefront-fashion/app/account/settings/page.tsx +0 -21
  106. package/templates/storefront-fashion/app/cart/page.tsx +0 -9
  107. package/templates/storefront-fashion/app/categories/[slug]/listing-client.tsx +0 -19
  108. package/templates/storefront-fashion/app/categories/[slug]/page.tsx +0 -130
  109. package/templates/storefront-fashion/app/checkout/page.tsx +0 -17
  110. package/templates/storefront-fashion/app/collections/[slug]/listing-client.tsx +0 -20
  111. package/templates/storefront-fashion/app/collections/[slug]/page.tsx +0 -130
  112. package/templates/storefront-fashion/app/contact/contact-form.tsx +0 -109
  113. package/templates/storefront-fashion/app/contact/page.tsx +0 -54
  114. package/templates/storefront-fashion/app/error.tsx +0 -61
  115. package/templates/storefront-fashion/app/faq/page.tsx +0 -46
  116. package/templates/storefront-fashion/app/globals.css +0 -46
  117. package/templates/storefront-fashion/app/layout.tsx +0 -78
  118. package/templates/storefront-fashion/app/llms.txt/route.ts +0 -94
  119. package/templates/storefront-fashion/app/login/page.tsx +0 -17
  120. package/templates/storefront-fashion/app/lookbook/page.tsx +0 -132
  121. package/templates/storefront-fashion/app/not-found.tsx +0 -39
  122. package/templates/storefront-fashion/app/opensearch.xml/route.ts +0 -37
  123. package/templates/storefront-fashion/app/orders/[id]/page.tsx +0 -24
  124. package/templates/storefront-fashion/app/page.tsx +0 -183
  125. package/templates/storefront-fashion/app/privacy/page.tsx +0 -44
  126. package/templates/storefront-fashion/app/products/[slug]/page.tsx +0 -165
  127. package/templates/storefront-fashion/app/products/[slug]/product-detail.tsx +0 -70
  128. package/templates/storefront-fashion/app/returns/page.tsx +0 -11
  129. package/templates/storefront-fashion/app/robots.ts +0 -18
  130. package/templates/storefront-fashion/app/search/page.tsx +0 -38
  131. package/templates/storefront-fashion/app/search/search-client.tsx +0 -7
  132. package/templates/storefront-fashion/app/shipping/page.tsx +0 -16
  133. package/templates/storefront-fashion/app/shop/page.tsx +0 -63
  134. package/templates/storefront-fashion/app/shop/shop-client.tsx +0 -32
  135. package/templates/storefront-fashion/app/signup/page.tsx +0 -17
  136. package/templates/storefront-fashion/app/sitemap-page/page.tsx +0 -167
  137. package/templates/storefront-fashion/app/sitemap.ts +0 -59
  138. package/templates/storefront-fashion/app/size-guide/page.tsx +0 -155
  139. package/templates/storefront-fashion/app/terms/page.tsx +0 -44
  140. package/templates/storefront-fashion/app/track-order/page.tsx +0 -24
  141. package/templates/storefront-fashion/app/track-order/track-order-form.tsx +0 -69
  142. package/templates/storefront-fashion/components/account-iframe.tsx +0 -13
  143. package/templates/storefront-fashion/components/brand-marquee.tsx +0 -27
  144. package/templates/storefront-fashion/components/cart-drawer.tsx +0 -14
  145. package/templates/storefront-fashion/components/cart-pill.tsx +0 -36
  146. package/templates/storefront-fashion/components/category-grid.tsx +0 -28
  147. package/templates/storefront-fashion/components/category-tiles.tsx +0 -104
  148. package/templates/storefront-fashion/components/collection-strip.tsx +0 -45
  149. package/templates/storefront-fashion/components/feature-hero.tsx +0 -82
  150. package/templates/storefront-fashion/components/footer.tsx +0 -153
  151. package/templates/storefront-fashion/components/header.tsx +0 -43
  152. package/templates/storefront-fashion/components/hero.tsx +0 -28
  153. package/templates/storefront-fashion/components/nav-link.tsx +0 -20
  154. package/templates/storefront-fashion/components/newsletter.tsx +0 -50
  155. package/templates/storefront-fashion/components/policy-page.tsx +0 -49
  156. package/templates/storefront-fashion/components/promo-banner.tsx +0 -41
  157. package/templates/storefront-fashion/components/providers.tsx +0 -35
  158. package/templates/storefront-fashion/components/section-heading.tsx +0 -37
  159. package/templates/storefront-fashion/components/store-product-card.tsx +0 -87
  160. package/templates/storefront-fashion/components/trade-in-cta.tsx +0 -54
  161. package/templates/storefront-fashion/components/trust-bar.tsx +0 -66
  162. package/templates/storefront-fashion/e2e/visual.spec.ts +0 -52
  163. package/templates/storefront-fashion/lib/brand.ts +0 -518
  164. package/templates/storefront-fashion/lib/cart.ts +0 -12
  165. package/templates/storefront-fashion/next.config.ts +0 -42
  166. package/templates/storefront-fashion/package.json +0 -38
  167. package/templates/storefront-fashion/playwright.config.ts +0 -48
  168. package/templates/storefront-fashion/postcss.config.mjs +0 -7
  169. package/templates/storefront-fashion/tsconfig.json +0 -23
  170. package/templates/storefront-fashion/vitest.config.ts +0 -9
  171. package/templates/storefront-grocery/.claude/skills/cimplify-storefront/SKILL.md +0 -145
  172. package/templates/storefront-grocery/.cursor/rules/cimplify-storefront.mdc +0 -25
  173. package/templates/storefront-grocery/.env.example +0 -16
  174. package/templates/storefront-grocery/AGENTS.md +0 -96
  175. package/templates/storefront-grocery/CLAUDE.md +0 -22
  176. package/templates/storefront-grocery/README.md +0 -73
  177. package/templates/storefront-grocery/__tests__/brand.test.ts +0 -4
  178. package/templates/storefront-grocery/__tests__/cart-flow.test.ts +0 -4
  179. package/templates/storefront-grocery/__tests__/contract.test.ts +0 -4
  180. package/templates/storefront-grocery/app/about/page.tsx +0 -38
  181. package/templates/storefront-grocery/app/accessibility/page.tsx +0 -11
  182. package/templates/storefront-grocery/app/account/addresses/page.tsx +0 -21
  183. package/templates/storefront-grocery/app/account/orders/page.tsx +0 -21
  184. package/templates/storefront-grocery/app/account/page.tsx +0 -22
  185. package/templates/storefront-grocery/app/account/settings/page.tsx +0 -21
  186. package/templates/storefront-grocery/app/cart/page.tsx +0 -9
  187. package/templates/storefront-grocery/app/categories/[slug]/listing-client.tsx +0 -19
  188. package/templates/storefront-grocery/app/categories/[slug]/page.tsx +0 -118
  189. package/templates/storefront-grocery/app/checkout/page.tsx +0 -17
  190. package/templates/storefront-grocery/app/collections/[slug]/listing-client.tsx +0 -20
  191. package/templates/storefront-grocery/app/collections/[slug]/page.tsx +0 -118
  192. package/templates/storefront-grocery/app/contact/contact-form.tsx +0 -109
  193. package/templates/storefront-grocery/app/contact/page.tsx +0 -54
  194. package/templates/storefront-grocery/app/error.tsx +0 -60
  195. package/templates/storefront-grocery/app/faq/page.tsx +0 -46
  196. package/templates/storefront-grocery/app/globals.css +0 -45
  197. package/templates/storefront-grocery/app/layout.tsx +0 -77
  198. package/templates/storefront-grocery/app/llms.txt/route.ts +0 -94
  199. package/templates/storefront-grocery/app/login/page.tsx +0 -17
  200. package/templates/storefront-grocery/app/not-found.tsx +0 -39
  201. package/templates/storefront-grocery/app/opensearch.xml/route.ts +0 -37
  202. package/templates/storefront-grocery/app/orders/[id]/page.tsx +0 -21
  203. package/templates/storefront-grocery/app/page.tsx +0 -97
  204. package/templates/storefront-grocery/app/privacy/page.tsx +0 -44
  205. package/templates/storefront-grocery/app/returns/page.tsx +0 -11
  206. package/templates/storefront-grocery/app/robots.ts +0 -18
  207. package/templates/storefront-grocery/app/search/page.tsx +0 -38
  208. package/templates/storefront-grocery/app/search/search-client.tsx +0 -7
  209. package/templates/storefront-grocery/app/shipping/page.tsx +0 -16
  210. package/templates/storefront-grocery/app/shop/page.tsx +0 -31
  211. package/templates/storefront-grocery/app/shop/shop-client.tsx +0 -27
  212. package/templates/storefront-grocery/app/signup/page.tsx +0 -17
  213. package/templates/storefront-grocery/app/sitemap-page/page.tsx +0 -167
  214. package/templates/storefront-grocery/app/sitemap.ts +0 -62
  215. package/templates/storefront-grocery/app/terms/page.tsx +0 -44
  216. package/templates/storefront-grocery/app/track-order/page.tsx +0 -24
  217. package/templates/storefront-grocery/app/track-order/track-order-form.tsx +0 -69
  218. package/templates/storefront-grocery/components/account-iframe.tsx +0 -13
  219. package/templates/storefront-grocery/components/cart-drawer.tsx +0 -14
  220. package/templates/storefront-grocery/components/cart-pill.tsx +0 -36
  221. package/templates/storefront-grocery/components/category-grid.tsx +0 -28
  222. package/templates/storefront-grocery/components/collection-strip.tsx +0 -45
  223. package/templates/storefront-grocery/components/footer.tsx +0 -148
  224. package/templates/storefront-grocery/components/header.tsx +0 -43
  225. package/templates/storefront-grocery/components/hero.tsx +0 -25
  226. package/templates/storefront-grocery/components/nav-link.tsx +0 -20
  227. package/templates/storefront-grocery/components/policy-page.tsx +0 -49
  228. package/templates/storefront-grocery/components/product-modal.tsx +0 -104
  229. package/templates/storefront-grocery/components/providers.tsx +0 -35
  230. package/templates/storefront-grocery/components/store-product-card.tsx +0 -87
  231. package/templates/storefront-grocery/lib/brand.ts +0 -375
  232. package/templates/storefront-grocery/lib/cart.ts +0 -12
  233. package/templates/storefront-grocery/next.config.ts +0 -42
  234. package/templates/storefront-grocery/package.json +0 -35
  235. package/templates/storefront-grocery/postcss.config.mjs +0 -7
  236. package/templates/storefront-grocery/tsconfig.json +0 -23
  237. package/templates/storefront-grocery/vitest.config.ts +0 -9
  238. package/templates/storefront-restaurant/.claude/skills/cimplify-storefront/SKILL.md +0 -145
  239. package/templates/storefront-restaurant/.cursor/rules/cimplify-storefront.mdc +0 -25
  240. package/templates/storefront-restaurant/.env.example +0 -16
  241. package/templates/storefront-restaurant/AGENTS.md +0 -102
  242. package/templates/storefront-restaurant/CLAUDE.md +0 -22
  243. package/templates/storefront-restaurant/README.md +0 -73
  244. package/templates/storefront-restaurant/__tests__/brand.test.ts +0 -4
  245. package/templates/storefront-restaurant/__tests__/cart-flow.test.ts +0 -4
  246. package/templates/storefront-restaurant/__tests__/contract.test.ts +0 -4
  247. package/templates/storefront-restaurant/app/about/page.tsx +0 -38
  248. package/templates/storefront-restaurant/app/accessibility/page.tsx +0 -11
  249. package/templates/storefront-restaurant/app/account/addresses/page.tsx +0 -21
  250. package/templates/storefront-restaurant/app/account/orders/page.tsx +0 -21
  251. package/templates/storefront-restaurant/app/account/page.tsx +0 -22
  252. package/templates/storefront-restaurant/app/account/settings/page.tsx +0 -21
  253. package/templates/storefront-restaurant/app/cart/page.tsx +0 -9
  254. package/templates/storefront-restaurant/app/categories/[slug]/listing-client.tsx +0 -19
  255. package/templates/storefront-restaurant/app/categories/[slug]/page.tsx +0 -118
  256. package/templates/storefront-restaurant/app/checkout/page.tsx +0 -17
  257. package/templates/storefront-restaurant/app/collections/[slug]/listing-client.tsx +0 -20
  258. package/templates/storefront-restaurant/app/collections/[slug]/page.tsx +0 -118
  259. package/templates/storefront-restaurant/app/contact/contact-form.tsx +0 -109
  260. package/templates/storefront-restaurant/app/contact/page.tsx +0 -54
  261. package/templates/storefront-restaurant/app/error.tsx +0 -60
  262. package/templates/storefront-restaurant/app/faq/page.tsx +0 -46
  263. package/templates/storefront-restaurant/app/globals.css +0 -44
  264. package/templates/storefront-restaurant/app/layout.tsx +0 -82
  265. package/templates/storefront-restaurant/app/llms.txt/route.ts +0 -94
  266. package/templates/storefront-restaurant/app/login/page.tsx +0 -17
  267. package/templates/storefront-restaurant/app/not-found.tsx +0 -39
  268. package/templates/storefront-restaurant/app/opensearch.xml/route.ts +0 -37
  269. package/templates/storefront-restaurant/app/orders/[id]/page.tsx +0 -21
  270. package/templates/storefront-restaurant/app/page.tsx +0 -97
  271. package/templates/storefront-restaurant/app/privacy/page.tsx +0 -44
  272. package/templates/storefront-restaurant/app/reservations/page.tsx +0 -66
  273. package/templates/storefront-restaurant/app/reservations/reservations-client.tsx +0 -234
  274. package/templates/storefront-restaurant/app/returns/page.tsx +0 -11
  275. package/templates/storefront-restaurant/app/robots.ts +0 -18
  276. package/templates/storefront-restaurant/app/search/page.tsx +0 -38
  277. package/templates/storefront-restaurant/app/search/search-client.tsx +0 -7
  278. package/templates/storefront-restaurant/app/shipping/page.tsx +0 -16
  279. package/templates/storefront-restaurant/app/shop/page.tsx +0 -31
  280. package/templates/storefront-restaurant/app/shop/shop-client.tsx +0 -27
  281. package/templates/storefront-restaurant/app/signup/page.tsx +0 -17
  282. package/templates/storefront-restaurant/app/sitemap-page/page.tsx +0 -167
  283. package/templates/storefront-restaurant/app/sitemap.ts +0 -62
  284. package/templates/storefront-restaurant/app/terms/page.tsx +0 -44
  285. package/templates/storefront-restaurant/app/track-order/page.tsx +0 -24
  286. package/templates/storefront-restaurant/app/track-order/track-order-form.tsx +0 -69
  287. package/templates/storefront-restaurant/components/account-iframe.tsx +0 -13
  288. package/templates/storefront-restaurant/components/cart-drawer.tsx +0 -14
  289. package/templates/storefront-restaurant/components/cart-pill.tsx +0 -36
  290. package/templates/storefront-restaurant/components/category-grid.tsx +0 -28
  291. package/templates/storefront-restaurant/components/collection-strip.tsx +0 -45
  292. package/templates/storefront-restaurant/components/footer.tsx +0 -148
  293. package/templates/storefront-restaurant/components/header.tsx +0 -43
  294. package/templates/storefront-restaurant/components/hero.tsx +0 -25
  295. package/templates/storefront-restaurant/components/nav-link.tsx +0 -20
  296. package/templates/storefront-restaurant/components/policy-page.tsx +0 -49
  297. package/templates/storefront-restaurant/components/product-modal.tsx +0 -104
  298. package/templates/storefront-restaurant/components/providers.tsx +0 -35
  299. package/templates/storefront-restaurant/components/store-product-card.tsx +0 -87
  300. package/templates/storefront-restaurant/lib/brand.ts +0 -377
  301. package/templates/storefront-restaurant/lib/cart.ts +0 -12
  302. package/templates/storefront-restaurant/next.config.ts +0 -42
  303. package/templates/storefront-restaurant/package.json +0 -35
  304. package/templates/storefront-restaurant/postcss.config.mjs +0 -7
  305. package/templates/storefront-restaurant/tsconfig.json +0 -23
  306. package/templates/storefront-restaurant/vitest.config.ts +0 -9
  307. package/templates/storefront-retail/.claude/skills/cimplify-storefront/SKILL.md +0 -145
  308. package/templates/storefront-retail/.cursor/rules/cimplify-storefront.mdc +0 -25
  309. package/templates/storefront-retail/.env.example +0 -16
  310. package/templates/storefront-retail/AGENTS.md +0 -117
  311. package/templates/storefront-retail/CLAUDE.md +0 -22
  312. package/templates/storefront-retail/README.md +0 -77
  313. package/templates/storefront-retail/__tests__/brand.test.ts +0 -4
  314. package/templates/storefront-retail/__tests__/cart-flow.test.ts +0 -4
  315. package/templates/storefront-retail/__tests__/contract.test.ts +0 -4
  316. package/templates/storefront-retail/app/about/page.tsx +0 -41
  317. package/templates/storefront-retail/app/accessibility/page.tsx +0 -11
  318. package/templates/storefront-retail/app/account/addresses/page.tsx +0 -21
  319. package/templates/storefront-retail/app/account/orders/page.tsx +0 -21
  320. package/templates/storefront-retail/app/account/page.tsx +0 -22
  321. package/templates/storefront-retail/app/account/settings/page.tsx +0 -21
  322. package/templates/storefront-retail/app/cart/page.tsx +0 -9
  323. package/templates/storefront-retail/app/categories/[slug]/listing-client.tsx +0 -19
  324. package/templates/storefront-retail/app/categories/[slug]/page.tsx +0 -130
  325. package/templates/storefront-retail/app/checkout/page.tsx +0 -17
  326. package/templates/storefront-retail/app/collections/[slug]/listing-client.tsx +0 -20
  327. package/templates/storefront-retail/app/collections/[slug]/page.tsx +0 -130
  328. package/templates/storefront-retail/app/contact/contact-form.tsx +0 -109
  329. package/templates/storefront-retail/app/contact/page.tsx +0 -54
  330. package/templates/storefront-retail/app/error.tsx +0 -61
  331. package/templates/storefront-retail/app/faq/page.tsx +0 -46
  332. package/templates/storefront-retail/app/globals.css +0 -47
  333. package/templates/storefront-retail/app/layout.tsx +0 -77
  334. package/templates/storefront-retail/app/llms.txt/route.ts +0 -94
  335. package/templates/storefront-retail/app/login/page.tsx +0 -17
  336. package/templates/storefront-retail/app/not-found.tsx +0 -39
  337. package/templates/storefront-retail/app/opensearch.xml/route.ts +0 -37
  338. package/templates/storefront-retail/app/orders/[id]/page.tsx +0 -24
  339. package/templates/storefront-retail/app/page.tsx +0 -182
  340. package/templates/storefront-retail/app/privacy/page.tsx +0 -44
  341. package/templates/storefront-retail/app/products/[slug]/page.tsx +0 -165
  342. package/templates/storefront-retail/app/products/[slug]/product-detail.tsx +0 -70
  343. package/templates/storefront-retail/app/returns/page.tsx +0 -11
  344. package/templates/storefront-retail/app/robots.ts +0 -18
  345. package/templates/storefront-retail/app/search/page.tsx +0 -38
  346. package/templates/storefront-retail/app/search/search-client.tsx +0 -7
  347. package/templates/storefront-retail/app/shipping/page.tsx +0 -16
  348. package/templates/storefront-retail/app/shop/page.tsx +0 -63
  349. package/templates/storefront-retail/app/shop/shop-client.tsx +0 -32
  350. package/templates/storefront-retail/app/signup/page.tsx +0 -17
  351. package/templates/storefront-retail/app/sitemap-page/page.tsx +0 -167
  352. package/templates/storefront-retail/app/sitemap.ts +0 -59
  353. package/templates/storefront-retail/app/terms/page.tsx +0 -44
  354. package/templates/storefront-retail/app/track-order/page.tsx +0 -24
  355. package/templates/storefront-retail/app/track-order/track-order-form.tsx +0 -69
  356. package/templates/storefront-retail/components/account-iframe.tsx +0 -13
  357. package/templates/storefront-retail/components/brand-marquee.tsx +0 -27
  358. package/templates/storefront-retail/components/cart-drawer.tsx +0 -14
  359. package/templates/storefront-retail/components/cart-pill.tsx +0 -36
  360. package/templates/storefront-retail/components/category-grid.tsx +0 -28
  361. package/templates/storefront-retail/components/category-tiles.tsx +0 -104
  362. package/templates/storefront-retail/components/collection-strip.tsx +0 -45
  363. package/templates/storefront-retail/components/feature-hero.tsx +0 -84
  364. package/templates/storefront-retail/components/footer.tsx +0 -153
  365. package/templates/storefront-retail/components/header.tsx +0 -45
  366. package/templates/storefront-retail/components/hero.tsx +0 -28
  367. package/templates/storefront-retail/components/nav-link.tsx +0 -20
  368. package/templates/storefront-retail/components/newsletter.tsx +0 -50
  369. package/templates/storefront-retail/components/policy-page.tsx +0 -49
  370. package/templates/storefront-retail/components/promo-banner.tsx +0 -41
  371. package/templates/storefront-retail/components/providers.tsx +0 -35
  372. package/templates/storefront-retail/components/section-heading.tsx +0 -37
  373. package/templates/storefront-retail/components/store-product-card.tsx +0 -87
  374. package/templates/storefront-retail/components/trade-in-cta.tsx +0 -54
  375. package/templates/storefront-retail/components/trust-bar.tsx +0 -66
  376. package/templates/storefront-retail/lib/brand.ts +0 -664
  377. package/templates/storefront-retail/lib/cart.ts +0 -12
  378. package/templates/storefront-retail/next.config.ts +0 -42
  379. package/templates/storefront-retail/package.json +0 -35
  380. package/templates/storefront-retail/postcss.config.mjs +0 -7
  381. package/templates/storefront-retail/tsconfig.json +0 -23
  382. package/templates/storefront-retail/vitest.config.ts +0 -9
  383. package/templates/storefront-services/.claude/skills/cimplify-storefront/SKILL.md +0 -145
  384. package/templates/storefront-services/.cursor/rules/cimplify-storefront.mdc +0 -25
  385. package/templates/storefront-services/.env.example +0 -16
  386. package/templates/storefront-services/AGENTS.md +0 -101
  387. package/templates/storefront-services/CLAUDE.md +0 -22
  388. package/templates/storefront-services/README.md +0 -73
  389. package/templates/storefront-services/__tests__/brand.test.ts +0 -4
  390. package/templates/storefront-services/__tests__/cart-flow.test.ts +0 -4
  391. package/templates/storefront-services/__tests__/contract.test.ts +0 -4
  392. package/templates/storefront-services/app/about/page.tsx +0 -38
  393. package/templates/storefront-services/app/accessibility/page.tsx +0 -11
  394. package/templates/storefront-services/app/account/addresses/page.tsx +0 -21
  395. package/templates/storefront-services/app/account/orders/page.tsx +0 -21
  396. package/templates/storefront-services/app/account/page.tsx +0 -22
  397. package/templates/storefront-services/app/account/settings/page.tsx +0 -21
  398. package/templates/storefront-services/app/book/book-client.tsx +0 -195
  399. package/templates/storefront-services/app/book/page.tsx +0 -65
  400. package/templates/storefront-services/app/cart/page.tsx +0 -9
  401. package/templates/storefront-services/app/categories/[slug]/listing-client.tsx +0 -19
  402. package/templates/storefront-services/app/categories/[slug]/page.tsx +0 -118
  403. package/templates/storefront-services/app/checkout/page.tsx +0 -17
  404. package/templates/storefront-services/app/collections/[slug]/listing-client.tsx +0 -20
  405. package/templates/storefront-services/app/collections/[slug]/page.tsx +0 -118
  406. package/templates/storefront-services/app/contact/contact-form.tsx +0 -109
  407. package/templates/storefront-services/app/contact/page.tsx +0 -54
  408. package/templates/storefront-services/app/error.tsx +0 -60
  409. package/templates/storefront-services/app/faq/page.tsx +0 -46
  410. package/templates/storefront-services/app/globals.css +0 -45
  411. package/templates/storefront-services/app/layout.tsx +0 -82
  412. package/templates/storefront-services/app/llms.txt/route.ts +0 -94
  413. package/templates/storefront-services/app/login/page.tsx +0 -17
  414. package/templates/storefront-services/app/not-found.tsx +0 -39
  415. package/templates/storefront-services/app/opensearch.xml/route.ts +0 -37
  416. package/templates/storefront-services/app/orders/[id]/page.tsx +0 -21
  417. package/templates/storefront-services/app/page.tsx +0 -97
  418. package/templates/storefront-services/app/privacy/page.tsx +0 -44
  419. package/templates/storefront-services/app/returns/page.tsx +0 -11
  420. package/templates/storefront-services/app/robots.ts +0 -18
  421. package/templates/storefront-services/app/search/page.tsx +0 -38
  422. package/templates/storefront-services/app/search/search-client.tsx +0 -7
  423. package/templates/storefront-services/app/shipping/page.tsx +0 -16
  424. package/templates/storefront-services/app/shop/page.tsx +0 -31
  425. package/templates/storefront-services/app/shop/shop-client.tsx +0 -27
  426. package/templates/storefront-services/app/signup/page.tsx +0 -17
  427. package/templates/storefront-services/app/sitemap-page/page.tsx +0 -167
  428. package/templates/storefront-services/app/sitemap.ts +0 -62
  429. package/templates/storefront-services/app/terms/page.tsx +0 -44
  430. package/templates/storefront-services/app/track-order/page.tsx +0 -24
  431. package/templates/storefront-services/app/track-order/track-order-form.tsx +0 -69
  432. package/templates/storefront-services/components/account-iframe.tsx +0 -13
  433. package/templates/storefront-services/components/cart-drawer.tsx +0 -14
  434. package/templates/storefront-services/components/cart-pill.tsx +0 -36
  435. package/templates/storefront-services/components/category-grid.tsx +0 -28
  436. package/templates/storefront-services/components/collection-strip.tsx +0 -45
  437. package/templates/storefront-services/components/footer.tsx +0 -148
  438. package/templates/storefront-services/components/header.tsx +0 -43
  439. package/templates/storefront-services/components/hero.tsx +0 -25
  440. package/templates/storefront-services/components/nav-link.tsx +0 -20
  441. package/templates/storefront-services/components/policy-page.tsx +0 -49
  442. package/templates/storefront-services/components/product-modal.tsx +0 -104
  443. package/templates/storefront-services/components/providers.tsx +0 -35
  444. package/templates/storefront-services/components/store-product-card.tsx +0 -87
  445. package/templates/storefront-services/lib/brand.ts +0 -396
  446. package/templates/storefront-services/lib/cart.ts +0 -12
  447. package/templates/storefront-services/next.config.ts +0 -42
  448. package/templates/storefront-services/package.json +0 -35
  449. package/templates/storefront-services/postcss.config.mjs +0 -7
  450. package/templates/storefront-services/tsconfig.json +0 -23
  451. package/templates/storefront-services/vitest.config.ts +0 -9
@@ -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 Collection,
10
- type Product,
11
- } from "@cimplify/sdk/server";
12
- import { ListingClient } from "./listing-client";
13
- import { brand } from "@/lib/brand";
14
-
15
- interface CollectionData {
16
- collection: Collection;
17
- products: Product[];
18
- }
19
-
20
- async function getCollection(slug: string): Promise<CollectionData | null> {
21
- "use cache";
22
- cacheTag(tags.collections());
23
- cacheLife("hours");
24
-
25
- const client = getServerClient();
26
- const colRes = await client.catalogue.getCollectionBySlug(slug);
27
- if (!colRes.ok) return null;
28
-
29
- cacheTag(tags.collection(colRes.value.id), tags.collectionProducts(colRes.value.id));
30
- const r = await client.catalogue.getCollectionProducts(colRes.value.id);
31
- const products = r.ok
32
- ? ((r.value as { items?: Product[] }).items ?? (r.value as Product[]))
33
- : [];
34
- return { collection: colRes.value, products };
35
- }
36
-
37
- export async function generateMetadata({
38
- params,
39
- }: {
40
- params: Promise<{ slug: string }>;
41
- }): Promise<Metadata> {
42
- const { slug } = await params;
43
- const data = await getCollection(slug);
44
- if (!data) return {};
45
- return {
46
- title: `${data.collection.name} — ${brand.name}`,
47
- description: data.collection.description ?? undefined,
48
- };
49
- }
50
-
51
- export default async function CollectionPage({
52
- params,
53
- }: {
54
- params: Promise<{ slug: string }>;
55
- }) {
56
- return (
57
- <Suspense fallback={<CollectionSkeleton />}>
58
- <CollectionContent params={params} />
59
- </Suspense>
60
- );
61
- }
62
-
63
- async function CollectionContent({
64
- params,
65
- }: {
66
- params: Promise<{ slug: string }>;
67
- }) {
68
- const { slug } = await params;
69
- const data = await getCollection(slug);
70
- if (!data) notFound();
71
-
72
- const { collection, products } = data;
73
- return (
74
- <>
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
- <span className="text-background/90">Collections</span>
82
- <span>/</span>
83
- <span className="text-background/90">{collection.name}</span>
84
- </nav>
85
- <h1 className="text-[clamp(2rem,4vw,3rem)] font-bold m-0 -tracking-[0.025em]">
86
- {collection.name}
87
- </h1>
88
- {collection.description && (
89
- <p className="mt-3 max-w-2xl text-base text-background/75">
90
- {collection.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 CollectionSkeleton() {
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,109 +0,0 @@
1
- "use client";
2
-
3
- import { useState } from "react";
4
-
5
- /**
6
- * Local-only contact form. On submit, fakes a successful response so the
7
- * template ships a usable interaction. Wire to a real handler (Server
8
- * Action posting to your CRM, support inbox, or Cimplify Support API)
9
- * before going to production.
10
- */
11
- export function ContactForm({ reasons }: { reasons: string[] }) {
12
- const [submitted, setSubmitted] = useState(false);
13
- const [reason, setReason] = useState(reasons[0] ?? "");
14
-
15
- if (submitted) {
16
- return (
17
- <div className="rounded-2xl border border-border bg-card p-8">
18
- <p className="text-[11px] font-semibold uppercase tracking-[0.16em] text-primary mb-2">
19
- ✓ Sent
20
- </p>
21
- <h2 className="font-serif text-2xl font-semibold mb-2">Thanks — we'll be in touch.</h2>
22
- <p className="text-muted-foreground">
23
- We respond within one business day. Check your spam folder if you don't see a
24
- reply by tomorrow.
25
- </p>
26
- </div>
27
- );
28
- }
29
-
30
- return (
31
- <form
32
- onSubmit={(e) => {
33
- e.preventDefault();
34
- setSubmitted(true);
35
- }}
36
- className="space-y-5"
37
- >
38
- <div className="grid grid-cols-1 sm:grid-cols-2 gap-4">
39
- <Field label="Your name" name="name" required />
40
- <Field label="Email" name="email" type="email" required />
41
- </div>
42
- <div>
43
- <label className="text-xs font-semibold uppercase tracking-wider text-muted-foreground block mb-1.5">
44
- What's it about?
45
- </label>
46
- <select
47
- name="reason"
48
- value={reason}
49
- onChange={(e) => setReason(e.target.value)}
50
- className="w-full px-4 py-2.5 rounded-md bg-background border border-border focus:border-primary focus:ring-2 focus:ring-primary/20 outline-none text-sm"
51
- >
52
- {reasons.map((r) => (
53
- <option key={r} value={r}>
54
- {r}
55
- </option>
56
- ))}
57
- </select>
58
- </div>
59
- <Field label="Order number (optional)" name="order" />
60
- <div>
61
- <label className="text-xs font-semibold uppercase tracking-wider text-muted-foreground block mb-1.5">
62
- Message
63
- </label>
64
- <textarea
65
- name="message"
66
- required
67
- rows={6}
68
- className="w-full px-4 py-2.5 rounded-md bg-background border border-border focus:border-primary focus:ring-2 focus:ring-primary/20 outline-none text-sm resize-y"
69
- />
70
- </div>
71
- <button
72
- type="submit"
73
- className="inline-flex items-center justify-center px-5 py-3 rounded-md bg-primary text-primary-foreground font-semibold text-sm hover:bg-primary/90 transition-colors"
74
- >
75
- Send message
76
- </button>
77
- </form>
78
- );
79
- }
80
-
81
- function Field({
82
- label,
83
- name,
84
- type = "text",
85
- required,
86
- }: {
87
- label: string;
88
- name: string;
89
- type?: string;
90
- required?: boolean;
91
- }) {
92
- return (
93
- <div>
94
- <label
95
- htmlFor={name}
96
- className="text-xs font-semibold uppercase tracking-wider text-muted-foreground block mb-1.5"
97
- >
98
- {label}
99
- </label>
100
- <input
101
- id={name}
102
- name={name}
103
- type={type}
104
- required={required}
105
- className="w-full px-4 py-2.5 rounded-md bg-background border border-border focus:border-primary focus:ring-2 focus:ring-primary/20 outline-none text-sm"
106
- />
107
- </div>
108
- );
109
- }
@@ -1,54 +0,0 @@
1
- import type { Metadata } from "next";
2
- import { ContactForm } from "./contact-form";
3
- import { brand } from "@/lib/brand";
4
-
5
- export const metadata: Metadata = {
6
- title: `Contact — ${brand.name}`,
7
- description: brand.contactPage.body,
8
- };
9
-
10
- export default function ContactPage() {
11
- const c = brand.contactPage;
12
- return (
13
- <article className="max-w-5xl mx-auto px-6 sm:px-8 py-16">
14
- <p className="text-[11px] font-semibold uppercase tracking-[0.16em] text-primary mb-2">
15
- {c.eyebrow}
16
- </p>
17
- <h1 className="font-serif text-[clamp(2.25rem,5vw,3.5rem)] font-semibold mb-4 -tracking-[0.02em]">
18
- {c.title}
19
- </h1>
20
- <p className="text-lg text-muted-foreground max-w-2xl mb-12 leading-relaxed">{c.body}</p>
21
-
22
- <div className="grid grid-cols-1 lg:grid-cols-[1.5fr_1fr] gap-10 items-start">
23
- <ContactForm reasons={c.reasons} />
24
- <aside className="space-y-5 lg:pl-10 lg:border-l border-border">
25
- <div>
26
- <p className="text-[11px] font-semibold uppercase tracking-[0.16em] text-muted-foreground mb-3">
27
- Direct lines
28
- </p>
29
- <ul className="space-y-3 list-none p-0 m-0">
30
- {c.directLines.map((line) => (
31
- <li key={line.label}>
32
- <p className="text-xs text-muted-foreground m-0">{line.label}</p>
33
- <a
34
- href={line.href}
35
- className="text-foreground hover:text-primary transition-colors"
36
- >
37
- {line.value}
38
- </a>
39
- </li>
40
- ))}
41
- </ul>
42
- </div>
43
- <div>
44
- <p className="text-[11px] font-semibold uppercase tracking-[0.16em] text-muted-foreground mb-3">
45
- Visit
46
- </p>
47
- <p className="text-foreground m-0">{brand.contact.address}</p>
48
- <p className="text-xs text-muted-foreground mt-1">{brand.contact.hours}</p>
49
- </div>
50
- </aside>
51
- </div>
52
- </article>
53
- );
54
- }
@@ -1,61 +0,0 @@
1
- "use client";
2
-
3
- import { useEffect } from "react";
4
- import Link from "next/link";
5
-
6
- /**
7
- * Root error boundary. Next.js calls this whenever a thrown error escapes
8
- * a Server Component without being caught by a closer `error.tsx`.
9
- *
10
- * Wire `reportError` (Sentry, Datadog, etc.) here so production failures
11
- * surface — silently recovering hides real bugs.
12
- */
13
- export default function GlobalError({
14
- error,
15
- reset,
16
- }: {
17
- error: Error & { digest?: string };
18
- reset: () => void;
19
- }) {
20
- useEffect(() => {
21
- // TODO: replace with your error reporter
22
- // eslint-disable-next-line no-console
23
- console.error("Storefront error:", error);
24
- }, [error]);
25
-
26
- return (
27
- <section className="max-w-2xl mx-auto px-6 sm:px-8 py-20 text-center">
28
- <p className="text-[11px] font-mono uppercase tracking-[0.16em] text-primary mb-3">
29
- Something broke
30
- </p>
31
- <h1 className="text-[clamp(2rem,4vw,3rem)] font-bold mb-4 -tracking-[0.025em]">
32
- That wasn&apos;t supposed to happen.
33
- </h1>
34
- <p className="text-muted-foreground leading-relaxed mb-8">
35
- We&apos;ve been notified. Refresh the page, or head back home — most
36
- of the time the second try just works.
37
- </p>
38
- {error.digest && (
39
- <p className="text-xs font-mono text-muted-foreground mb-6">
40
- Reference:{" "}
41
- <code className="text-foreground">{error.digest}</code>
42
- </p>
43
- )}
44
- <div className="flex flex-wrap items-center justify-center gap-3">
45
- <button
46
- type="button"
47
- onClick={reset}
48
- className="inline-flex items-center gap-2 px-5 py-2.5 rounded-md bg-primary text-primary-foreground font-semibold text-sm hover:bg-primary/90 transition-colors"
49
- >
50
- Try again
51
- </button>
52
- <Link
53
- href="/"
54
- className="inline-flex items-center gap-2 px-5 py-2.5 rounded-md border border-border hover:bg-muted transition-colors text-sm font-medium"
55
- >
56
- Back home
57
- </Link>
58
- </div>
59
- </section>
60
- );
61
- }
@@ -1,46 +0,0 @@
1
- import type { Metadata } from "next";
2
- import { brand } from "@/lib/brand";
3
-
4
- export const metadata: Metadata = {
5
- title: `Support — ${brand.name}`,
6
- description: "Shipping, warranty, repairs, returns, payment — answers to the questions we hear most often.",
7
- };
8
-
9
- export default function FaqPage() {
10
- const f = brand.faq;
11
- return (
12
- <article className="max-w-3xl mx-auto px-8 py-16">
13
- <p className="text-[11px] font-mono uppercase tracking-[0.16em] text-primary mb-2">
14
- {f.eyebrow}
15
- </p>
16
- <h1 className="text-[clamp(2.25rem,5vw,3.5rem)] font-bold mb-10 -tracking-[0.025em]">
17
- {f.title}
18
- </h1>
19
- <div className="space-y-12">
20
- {f.sections.map((section) => (
21
- <section key={section.title}>
22
- <h2 className="text-2xl font-semibold mb-5 -tracking-[0.02em]">{section.title}</h2>
23
- <dl className="space-y-6">
24
- {section.items.map((item) => (
25
- <div key={item.q}>
26
- <dt className="font-semibold text-foreground mb-1.5">{item.q}</dt>
27
- <dd className="text-muted-foreground leading-relaxed">{item.a}</dd>
28
- </div>
29
- ))}
30
- </dl>
31
- </section>
32
- ))}
33
- </div>
34
- <p className="mt-12 pt-8 border-t border-border text-sm text-muted-foreground">
35
- {f.contactPrompt}{" "}
36
- <a
37
- href={`mailto:${f.contactEmail}`}
38
- className="text-primary font-semibold hover:underline"
39
- >
40
- {f.contactEmail}
41
- </a>{" "}
42
- and a real human will reply within 24 hours.
43
- </p>
44
- </article>
45
- );
46
- }
@@ -1,47 +0,0 @@
1
- @import "tailwindcss";
2
-
3
- /* Scan the SDK's bundled JS so utility classes used inside its components
4
- land in the compiled stylesheet alongside our own. */
5
- @source "../node_modules/@cimplify/sdk/dist";
6
-
7
- /* Currents Electronics palette — cool navy chrome, electric blue accent.
8
- Modern retail aesthetic; tweak these tokens to retheme everything. */
9
- @theme {
10
- --color-background: oklch(0.99 0.005 240);
11
- --color-foreground: oklch(0.2 0.03 250);
12
- --color-card: oklch(1 0 0);
13
- --color-card-foreground: oklch(0.2 0.03 250);
14
- --color-popover: oklch(1 0 0);
15
- --color-popover-foreground: oklch(0.2 0.03 250);
16
- --color-primary: oklch(0.55 0.22 255);
17
- --color-primary-foreground: oklch(0.99 0 0);
18
- --color-secondary: oklch(0.95 0.02 250);
19
- --color-secondary-foreground: oklch(0.25 0.05 250);
20
- --color-muted: oklch(0.96 0.01 250);
21
- --color-muted-foreground: oklch(0.5 0.03 250);
22
- --color-accent: oklch(0.92 0.07 240);
23
- --color-accent-foreground: oklch(0.25 0.1 250);
24
- --color-destructive: oklch(0.58 0.24 27);
25
- --color-destructive-foreground: oklch(0.99 0 0);
26
- --color-border: oklch(0.92 0.01 250);
27
- --color-input: oklch(0.94 0.01 250);
28
- --color-ring: oklch(0.55 0.22 255);
29
- --radius: 0.5rem;
30
- }
31
-
32
- @layer base {
33
- html, body {
34
- margin: 0;
35
- padding: 0;
36
- background: var(--color-background);
37
- color: var(--color-foreground);
38
- -webkit-font-smoothing: antialiased;
39
- -moz-osx-font-smoothing: grayscale;
40
- }
41
- a { color: inherit; text-decoration: none; }
42
- h1, h2, h3, h4 {
43
- font-family: var(--font-sans);
44
- letter-spacing: -0.02em;
45
- font-weight: 600;
46
- }
47
- }
@@ -1,77 +0,0 @@
1
- import type { Metadata } from "next";
2
- import { Inter, JetBrains_Mono } from "next/font/google";
3
- import "./globals.css";
4
- import { Providers } from "@/components/providers";
5
- import { Header } from "@/components/header";
6
- import { Footer } from "@/components/footer";
7
- import { CartDrawer } from "@/components/cart-drawer";
8
- import { brand } from "@/lib/brand";
9
-
10
- const inter = Inter({
11
- subsets: ["latin"],
12
- variable: "--font-sans",
13
- display: "swap",
14
- });
15
-
16
- const mono = JetBrains_Mono({
17
- subsets: ["latin"],
18
- variable: "--font-mono",
19
- display: "swap",
20
- });
21
-
22
- const SITE_URL =
23
- process.env.NEXT_PUBLIC_SITE_URL?.trim() || "https://example.com";
24
-
25
- export const metadata: Metadata = {
26
- metadataBase: new URL(SITE_URL),
27
- title: {
28
- default: brand.name,
29
- template: `%s — ${brand.name}`,
30
- },
31
- description: brand.description,
32
- openGraph: {
33
- type: "website",
34
- siteName: brand.name,
35
- locale: brand.locale,
36
- },
37
- twitter: { card: "summary_large_image" },
38
- };
39
-
40
- const ORGANIZATION_LD = {
41
- "@context": "https://schema.org",
42
- "@type": brand.schemaType,
43
- name: brand.name,
44
- url: SITE_URL,
45
- description: brand.description,
46
- email: brand.contact.email,
47
- telephone: brand.contact.phoneTel,
48
- address: {
49
- "@type": "PostalAddress",
50
- streetAddress: brand.contact.streetAddress,
51
- addressLocality: brand.contact.city,
52
- addressCountry: brand.contact.countryCode,
53
- },
54
- sameAs: brand.socials.map((s) => s.href),
55
- };
56
-
57
- export default function RootLayout({ children }: { children: React.ReactNode }) {
58
- return (
59
- <html lang="en" suppressHydrationWarning className={`${inter.variable} ${mono.variable}`}>
60
- <body
61
- suppressHydrationWarning
62
- className="min-h-screen flex flex-col bg-background text-foreground font-sans"
63
- >
64
- <script
65
- type="application/ld+json"
66
- dangerouslySetInnerHTML={{ __html: JSON.stringify(ORGANIZATION_LD) }}
67
- />
68
- <Providers>
69
- <Header />
70
- <main className="flex-1 pb-12 w-full">{children}</main>
71
- <Footer />
72
- <CartDrawer />
73
- </Providers>
74
- </body>
75
- </html>
76
- );
77
- }
@@ -1,94 +0,0 @@
1
- import { cacheTag, cacheLife } from "next/cache";
2
- import { getServerClient, tags, type Product } from "@cimplify/sdk/server";
3
- import { brand } from "@/lib/brand";
4
-
5
- const SITE_URL =
6
- process.env.NEXT_PUBLIC_SITE_URL?.trim() || "https://example.com";
7
-
8
- async function buildLlmsTxt(): Promise<string> {
9
- "use cache";
10
- cacheTag(tags.products(), tags.categories(), tags.collections());
11
- cacheLife("hours");
12
-
13
- const client = getServerClient();
14
- const [productsRes, categoriesRes, collectionsRes] = await Promise.all([
15
- client.catalogue.getProducts({ limit: 500 }),
16
- client.catalogue.getCategories(),
17
- client.catalogue.getCollections(),
18
- ]);
19
-
20
- const products: Product[] = productsRes.ok ? productsRes.value.items : [];
21
- const categories = categoriesRes.ok ? categoriesRes.value : [];
22
- const collections = collectionsRes.ok ? collectionsRes.value : [];
23
-
24
- const lines: string[] = [];
25
- lines.push(`# ${brand.name}`);
26
- lines.push("");
27
- lines.push(`> ${brand.llms.summary}`);
28
- lines.push("");
29
- lines.push("## Browse");
30
- lines.push(`- [Home](${SITE_URL}/)`);
31
- lines.push(`- [Shop](${SITE_URL}/shop): Full catalogue with filter and sort.`);
32
-
33
- if (categories.length > 0) {
34
- lines.push("");
35
- lines.push("## Categories");
36
- for (const c of categories) {
37
- lines.push(
38
- `- [${c.name}](${SITE_URL}/categories/${c.slug})${c.description ? `: ${c.description}` : ""}`,
39
- );
40
- }
41
- }
42
-
43
- if (collections.length > 0) {
44
- lines.push("");
45
- lines.push("## Collections");
46
- for (const c of collections) {
47
- lines.push(
48
- `- [${c.name}](${SITE_URL}/collections/${c.slug})${c.description ? `: ${c.description}` : ""}`,
49
- );
50
- }
51
- }
52
-
53
- if (products.length > 0) {
54
- lines.push("");
55
- lines.push("## Products");
56
- for (const p of products) {
57
- const slug = p.slug ?? p.id;
58
- const price = `${brand.currency} ${p.default_price}`;
59
- const desc = p.description ? ` — ${p.description.replace(/\s+/g, " ").slice(0, 200)}` : "";
60
- lines.push(`- [${p.name}](${SITE_URL}/products/${slug}) (${price})${desc}`);
61
- }
62
- }
63
-
64
- lines.push("");
65
- lines.push("## Information");
66
- lines.push(`- [About](${SITE_URL}/about)`);
67
- lines.push(`- [Support / FAQ](${SITE_URL}/faq)`);
68
- lines.push(`- [Terms of Service](${SITE_URL}/terms)`);
69
- lines.push(`- [Privacy Policy](${SITE_URL}/privacy)`);
70
- lines.push(`- [Sitemap (XML)](${SITE_URL}/sitemap.xml)`);
71
- lines.push("");
72
- lines.push("## Contact");
73
- lines.push(`- Email: ${brand.contact.email}`);
74
- lines.push(`- Phone: ${brand.contact.phone}`);
75
- lines.push(`- Address: ${brand.contact.address}`);
76
-
77
- return lines.join("\n") + "\n";
78
- }
79
-
80
- /**
81
- * `/llms.txt` — machine-readable site index for LLMs (per llmstxt.org).
82
- * Lets coding agents and chat assistants find products, categories, and
83
- * support pages without scraping HTML. Plain Markdown so it streams cheaply
84
- * into context windows.
85
- */
86
- export async function GET(): Promise<Response> {
87
- const body = await buildLlmsTxt();
88
- return new Response(body, {
89
- headers: {
90
- "Content-Type": "text/plain; charset=utf-8",
91
- "Cache-Control": "public, max-age=0, s-maxage=3600, stale-while-revalidate=86400",
92
- },
93
- });
94
- }
@@ -1,17 +0,0 @@
1
- import type { Metadata } from "next";
2
- import { redirect } from "next/navigation";
3
- import { brand } from "@/lib/brand";
4
-
5
- export const metadata: Metadata = {
6
- title: `Sign in — ${brand.name}`,
7
- description: brand.account.loginSubtitle,
8
- };
9
-
10
- /**
11
- * Cimplify Link (the iframe in `<CimplifyAccount>`) handles sign-in
12
- * automatically when no session exists. We just bounce /login to /account
13
- * so consumers landing here get the right UI without a duplicate form.
14
- */
15
- export default function LoginPage(): never {
16
- redirect("/account");
17
- }
@@ -1,39 +0,0 @@
1
- import type { Metadata } from "next";
2
- import Link from "next/link";
3
- import { brand } from "@/lib/brand";
4
-
5
- export const metadata: Metadata = {
6
- title: `Page not found — ${brand.name}`,
7
- description: "We couldn't find that page.",
8
- };
9
-
10
- export default function NotFound() {
11
- return (
12
- <section className="max-w-2xl mx-auto px-6 sm:px-8 py-20 text-center">
13
- <p className="text-[11px] font-mono uppercase tracking-[0.16em] text-primary mb-3">
14
- 404
15
- </p>
16
- <h1 className="text-[clamp(2.5rem,5vw,4rem)] font-bold mb-4 -tracking-[0.03em]">
17
- Page not found.
18
- </h1>
19
- <p className="text-muted-foreground leading-relaxed mb-8">
20
- The URL you followed might be old, a typo, or pointing at a product
21
- that&apos;s no longer in stock. Try the menu or head back home.
22
- </p>
23
- <div className="flex flex-wrap items-center justify-center gap-3">
24
- <Link
25
- href="/shop"
26
- className="inline-flex items-center gap-2 px-5 py-2.5 rounded-md bg-primary text-primary-foreground font-semibold text-sm hover:bg-primary/90 transition-colors"
27
- >
28
- Browse the shop
29
- </Link>
30
- <Link
31
- href="/"
32
- className="inline-flex items-center gap-2 px-5 py-2.5 rounded-md border border-border hover:bg-muted transition-colors text-sm font-medium"
33
- >
34
- Back home
35
- </Link>
36
- </div>
37
- </section>
38
- );
39
- }