@digilogiclabs/create-saas-app 2.10.0 → 2.12.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 (416) hide show
  1. package/CHANGELOG.md +6 -0
  2. package/README.md +153 -113
  3. package/dist/.tsbuildinfo +1 -1
  4. package/dist/cli/commands/create.d.ts.map +1 -1
  5. package/dist/cli/commands/create.js +2 -6
  6. package/dist/cli/commands/create.js.map +1 -1
  7. package/dist/cli/index.js +1 -1
  8. package/dist/cli/index.js.map +1 -1
  9. package/dist/generators/template-generator.d.ts.map +1 -1
  10. package/dist/generators/template-generator.js +15 -8
  11. package/dist/generators/template-generator.js.map +1 -1
  12. package/dist/templates/shared/admin/web/src/components/admin-nav.tsx +3 -3
  13. package/dist/templates/shared/auth/supabase/web/src/lib/auth-session.ts +36 -16
  14. package/dist/templates/shared/auth/supabase/web/src/middleware.ts +6 -0
  15. package/dist/templates/shared/cookie-consent/web/components/cookie-consent.tsx +5 -5
  16. package/dist/templates/shared/design/web/src/components/ui/button.tsx +56 -0
  17. package/dist/templates/shared/email/web/src/lib/email/client.ts +1 -1
  18. package/dist/templates/shared/error-pages/web/src/app/error.tsx +13 -11
  19. package/dist/templates/shared/error-pages/web/src/app/global-error.tsx +2 -0
  20. package/dist/templates/shared/error-pages/web/src/app/not-found.tsx +6 -6
  21. package/dist/templates/shared/legal/web/src/app/(legal)/privacy/page.tsx +4 -4
  22. package/dist/templates/shared/legal/web/src/app/(legal)/terms/page.tsx +4 -4
  23. package/dist/templates/shared/loading/web/components/skeleton.tsx +4 -4
  24. package/dist/templates/shared/mock/web/.env.local +55 -0
  25. package/dist/templates/shared/mock/web/src/components/mock-auth-provider.tsx +72 -0
  26. package/dist/templates/shared/mock/web/src/components/mock-banner.tsx +29 -0
  27. package/dist/templates/shared/mock/web/src/lib/mock.ts +147 -0
  28. package/dist/templates/shared/payments/web/src/app/api/webhooks/stripe/route.ts +10 -4
  29. package/dist/templates/shared/redis/web/src/lib/redis.ts +1 -1
  30. package/dist/templates/web/ai-platform/template/src/app/api/auth/route.ts +57 -0
  31. package/dist/templates/web/ai-platform/template/src/app/login/page.tsx +112 -0
  32. package/dist/templates/web/ai-platform/template/src/app/models/page.tsx +186 -0
  33. package/dist/templates/web/ai-platform/template/src/app/playground/page.tsx +251 -0
  34. package/dist/templates/web/ai-platform/template/src/app/settings/page.tsx +190 -0
  35. package/dist/templates/web/ai-platform/template/src/app/signup/page.tsx +133 -0
  36. package/dist/templates/web/ai-platform/template/src/lib/auth-session.ts +52 -0
  37. package/dist/templates/web/base/template/eslint.config.mjs +14 -0
  38. package/dist/templates/web/base/template/src/app/auth/callback/route.ts +1 -1
  39. package/dist/templates/web/base/template/src/app/checkout/page.tsx +76 -103
  40. package/dist/templates/web/base/template/src/app/dashboard/page.tsx +145 -329
  41. package/dist/templates/web/base/template/src/app/layout.tsx +40 -38
  42. package/dist/templates/web/base/template/src/app/login/page.tsx +116 -66
  43. package/dist/templates/web/base/template/src/app/page.tsx +97 -193
  44. package/dist/templates/web/base/template/src/app/settings/page.tsx +154 -0
  45. package/dist/templates/web/base/template/src/app/signup/page.tsx +117 -66
  46. package/dist/templates/web/base/template/src/components/providers/app-providers.tsx +8 -3
  47. package/dist/templates/web/base/template/src/components/shared/header.tsx +229 -63
  48. package/dist/templates/web/iot-dashboard/template/src/app/alerts/page.tsx +157 -0
  49. package/dist/templates/web/iot-dashboard/template/src/app/api/auth/route.ts +57 -0
  50. package/dist/templates/web/iot-dashboard/template/src/app/devices/[id]/page.tsx +204 -0
  51. package/dist/templates/web/iot-dashboard/template/src/app/devices/new/page.tsx +139 -0
  52. package/dist/templates/web/iot-dashboard/template/src/app/devices/page.tsx +171 -0
  53. package/dist/templates/web/iot-dashboard/template/src/app/login/page.tsx +112 -0
  54. package/dist/templates/web/iot-dashboard/template/src/app/settings/page.tsx +186 -0
  55. package/dist/templates/web/iot-dashboard/template/src/app/signup/page.tsx +133 -0
  56. package/dist/templates/web/iot-dashboard/template/src/lib/auth-session.ts +52 -0
  57. package/dist/templates/web/marketplace/template/src/app/api/auth/route.ts +57 -0
  58. package/dist/templates/web/marketplace/template/src/app/login/page.tsx +112 -0
  59. package/dist/templates/web/marketplace/template/src/app/orders/page.tsx +160 -0
  60. package/dist/templates/web/marketplace/template/src/app/products/[id]/page.tsx +218 -0
  61. package/dist/templates/web/marketplace/template/src/app/settings/page.tsx +150 -0
  62. package/dist/templates/web/marketplace/template/src/app/signup/page.tsx +133 -0
  63. package/dist/templates/web/marketplace/template/src/lib/auth-session.ts +52 -0
  64. package/dist/templates/web/micro-saas/template/src/app/api/auth/route.ts +57 -0
  65. package/dist/templates/web/micro-saas/template/src/app/login/page.tsx +14 -3
  66. package/dist/templates/web/micro-saas/template/src/app/signup/page.tsx +15 -4
  67. package/dist/templates/web/micro-saas/template/src/lib/auth-session.ts +52 -0
  68. package/dist/templates/web/ui-auth/template/eslint.config.mjs +14 -0
  69. package/dist/templates/web/ui-auth/template/src/app/checkout/page.tsx +3 -3
  70. package/dist/templates/web/ui-auth/template/src/app/dev-setup/page.tsx +81 -91
  71. package/dist/templates/web/ui-auth/template/src/app/layout.tsx +38 -36
  72. package/dist/templates/web/ui-auth/template/src/app/login/page.tsx +22 -45
  73. package/dist/templates/web/ui-auth/template/src/app/page.tsx +106 -306
  74. package/dist/templates/web/ui-auth/template/src/app/setup/page.tsx +387 -402
  75. package/dist/templates/web/ui-auth/template/src/app/signup/page.tsx +24 -47
  76. package/dist/templates/web/ui-auth/template/src/components/providers/app-providers.tsx +8 -3
  77. package/dist/templates/web/ui-auth/template/src/components/shared/header.tsx +229 -94
  78. package/dist/templates/web/ui-auth-ai/template/src/app/layout.tsx +38 -45
  79. package/dist/templates/web/ui-auth-ai/template/src/app/login/page.tsx +86 -0
  80. package/dist/templates/web/ui-auth-ai/template/src/app/page.tsx +107 -193
  81. package/dist/templates/web/ui-auth-ai/template/src/app/signup/page.tsx +105 -0
  82. package/dist/templates/web/ui-auth-ai/template/src/components/ai/audio-generator.tsx +144 -140
  83. package/dist/templates/web/ui-auth-ai/template/src/components/ai/video-generator.tsx +156 -157
  84. package/dist/templates/web/ui-auth-ai/template/src/components/auth/login-form.tsx +7 -3
  85. package/dist/templates/web/ui-auth-ai/template/src/components/providers/app-providers.tsx +25 -0
  86. package/dist/templates/web/ui-auth-ai/template/src/components/shared/footer.tsx +36 -0
  87. package/dist/templates/web/ui-auth-ai/template/src/components/shared/header.tsx +228 -0
  88. package/dist/templates/web/ui-auth-ai/template/src/components/ui/button.tsx +5 -5
  89. package/dist/templates/web/ui-auth-ai/template/src/components/ui/input.tsx +1 -1
  90. package/dist/templates/web/ui-auth-ai/template/src/components/ui/select.tsx +1 -1
  91. package/dist/templates/web/ui-auth-ai/template/src/components/ui/textarea.tsx +1 -1
  92. package/dist/templates/web/ui-auth-ai/template/src/components/ui/theme-toggle.tsx +34 -0
  93. package/dist/templates/web/ui-auth-ai/template/src/lib/supabase.ts +6 -4
  94. package/dist/templates/web/ui-auth-ai/template/src/providers/auth-provider.tsx +7 -5
  95. package/dist/templates/web/ui-auth-payments/template/src/app/billing/page.tsx +63 -192
  96. package/dist/templates/web/ui-auth-payments/template/src/app/checkout/page.tsx +104 -296
  97. package/dist/templates/web/ui-auth-payments/template/src/app/dashboard/page.tsx +27 -27
  98. package/dist/templates/web/ui-auth-payments/template/src/app/dev-setup/page.tsx +70 -81
  99. package/dist/templates/web/ui-auth-payments/template/src/app/layout.tsx +38 -36
  100. package/dist/templates/web/ui-auth-payments/template/src/app/login/loading.tsx +9 -9
  101. package/dist/templates/web/ui-auth-payments/template/src/app/login/page.tsx +4 -104
  102. package/dist/templates/web/ui-auth-payments/template/src/app/page.tsx +69 -337
  103. package/dist/templates/web/ui-auth-payments/template/src/app/setup/page.tsx +55 -68
  104. package/dist/templates/web/ui-auth-payments/template/src/app/signup/loading.tsx +13 -13
  105. package/dist/templates/web/ui-auth-payments/template/src/app/signup/page.tsx +4 -123
  106. package/dist/templates/web/ui-auth-payments/template/src/components/client/auth-status.tsx +37 -52
  107. package/dist/templates/web/ui-auth-payments/template/src/components/client/login-form.tsx +49 -103
  108. package/dist/templates/web/ui-auth-payments/template/src/components/client/newsletter-signup.tsx +4 -4
  109. package/dist/templates/web/ui-auth-payments/template/src/components/client/signup-form.tsx +60 -140
  110. package/dist/templates/web/ui-auth-payments/template/src/components/providers/app-providers.tsx +25 -28
  111. package/dist/templates/web/ui-auth-payments/template/src/components/shared/header.tsx +229 -230
  112. package/dist/templates/web/ui-auth-payments/template/src/lib/actions/auth.ts +245 -245
  113. package/dist/templates/web/ui-auth-payments/template/src/lib/actions/index.ts +339 -339
  114. package/dist/templates/web/ui-auth-payments-ai/template/src/app/ai/page.tsx +305 -309
  115. package/dist/templates/web/ui-auth-payments-ai/template/src/app/billing/page.tsx +62 -312
  116. package/dist/templates/web/ui-auth-payments-ai/template/src/app/checkout/page.tsx +109 -125
  117. package/dist/templates/web/ui-auth-payments-ai/template/src/app/dashboard/page.tsx +27 -27
  118. package/dist/templates/web/ui-auth-payments-ai/template/src/app/dev-setup/page.tsx +68 -83
  119. package/dist/templates/web/ui-auth-payments-ai/template/src/app/layout.tsx +40 -38
  120. package/dist/templates/web/ui-auth-payments-ai/template/src/app/onboarding/page.tsx +20 -20
  121. package/dist/templates/web/ui-auth-payments-ai/template/src/app/page.tsx +140 -394
  122. package/dist/templates/web/ui-auth-payments-ai/template/src/app/settings/page.tsx +28 -27
  123. package/dist/templates/web/ui-auth-payments-ai/template/src/app/setup/page.tsx +51 -66
  124. package/dist/templates/web/ui-auth-payments-ai/template/src/components/client/auth-status.tsx +37 -52
  125. package/dist/templates/web/ui-auth-payments-ai/template/src/components/client/login-form.tsx +50 -79
  126. package/dist/templates/web/ui-auth-payments-ai/template/src/components/client/signup-form.tsx +58 -111
  127. package/dist/templates/web/ui-auth-payments-ai/template/src/components/providers/app-providers.tsx +8 -3
  128. package/dist/templates/web/ui-auth-payments-ai/template/src/components/shared/header.tsx +229 -252
  129. package/dist/templates/web/ui-auth-payments-ai/template/src/lib/actions/auth.ts +245 -245
  130. package/dist/templates/web/ui-auth-payments-audio/template/src/app/billing/page.tsx +63 -192
  131. package/dist/templates/web/ui-auth-payments-audio/template/src/app/checkout/page.tsx +109 -125
  132. package/dist/templates/web/ui-auth-payments-audio/template/src/app/dashboard/page.tsx +27 -27
  133. package/dist/templates/web/ui-auth-payments-audio/template/src/app/layout.tsx +40 -38
  134. package/dist/templates/web/ui-auth-payments-audio/template/src/app/page.tsx +122 -385
  135. package/dist/templates/web/ui-auth-payments-audio/template/src/app/setup/page.tsx +340 -344
  136. package/dist/templates/web/ui-auth-payments-audio/template/src/components/client/auth-status.tsx +37 -52
  137. package/dist/templates/web/ui-auth-payments-audio/template/src/components/client/login-form.tsx +49 -103
  138. package/dist/templates/web/ui-auth-payments-audio/template/src/components/client/signup-form.tsx +60 -140
  139. package/dist/templates/web/ui-auth-payments-audio/template/src/components/providers/app-providers.tsx +8 -3
  140. package/dist/templates/web/ui-auth-payments-audio/template/src/components/shared/header.tsx +229 -252
  141. package/dist/templates/web/ui-auth-payments-audio/template/src/lib/actions/auth.ts +3 -3
  142. package/dist/templates/web/ui-auth-payments-video/template/src/app/billing/page.tsx +63 -192
  143. package/dist/templates/web/ui-auth-payments-video/template/src/app/checkout/page.tsx +109 -125
  144. package/dist/templates/web/ui-auth-payments-video/template/src/app/layout.tsx +38 -36
  145. package/dist/templates/web/ui-auth-payments-video/template/src/app/login/page.tsx +9 -109
  146. package/dist/templates/web/ui-auth-payments-video/template/src/app/page.tsx +132 -392
  147. package/dist/templates/web/ui-auth-payments-video/template/src/app/setup/page.tsx +346 -350
  148. package/dist/templates/web/ui-auth-payments-video/template/src/app/signup/page.tsx +9 -128
  149. package/dist/templates/web/ui-auth-payments-video/template/src/components/client/login-form.tsx +90 -0
  150. package/dist/templates/web/ui-auth-payments-video/template/src/components/client/signup-form.tsx +105 -0
  151. package/dist/templates/web/ui-auth-payments-video/template/src/components/providers/app-providers.tsx +8 -3
  152. package/dist/templates/web/ui-auth-payments-video/template/src/components/shared/header.tsx +229 -246
  153. package/dist/templates/web/ui-only/template/eslint.config.mjs +14 -0
  154. package/dist/templates/web/ui-only/template/src/app/checkout/page.tsx +2 -2
  155. package/dist/templates/web/ui-only/template/src/app/login/page.tsx +69 -63
  156. package/dist/templates/web/ui-only/template/src/app/page.tsx +69 -91
  157. package/dist/templates/web/ui-only/template/src/app/signup/page.tsx +94 -79
  158. package/dist/templates/web/ui-only/template/src/components/providers/app-providers.tsx +1 -6
  159. package/dist/templates/web/ui-only/template/src/components/shared/header.tsx +90 -53
  160. package/dist/templates/web/ui-package-test/template/package.json +19 -23
  161. package/dist/templates/web/ui-package-test/template/postcss.config.mjs +8 -0
  162. package/dist/templates/web/ui-package-test/template/src/app/globals.css +88 -0
  163. package/dist/templates/web/ui-package-test/template/src/app/layout.tsx +27 -0
  164. package/dist/templates/web/ui-package-test/template/src/app/page.tsx +46 -106
  165. package/package.json +1 -1
  166. package/src/templates/shared/admin/web/src/components/admin-nav.tsx +3 -3
  167. package/src/templates/shared/auth/supabase/web/src/lib/auth-session.ts +36 -16
  168. package/src/templates/shared/auth/supabase/web/src/middleware.ts +6 -0
  169. package/src/templates/shared/cookie-consent/web/components/cookie-consent.tsx +5 -5
  170. package/src/templates/shared/design/web/src/components/ui/button.tsx +56 -0
  171. package/src/templates/shared/email/web/src/lib/email/client.ts +1 -1
  172. package/src/templates/shared/error-pages/web/src/app/error.tsx +13 -11
  173. package/src/templates/shared/error-pages/web/src/app/global-error.tsx +2 -0
  174. package/src/templates/shared/error-pages/web/src/app/not-found.tsx +6 -6
  175. package/src/templates/shared/legal/web/src/app/(legal)/privacy/page.tsx +4 -4
  176. package/src/templates/shared/legal/web/src/app/(legal)/terms/page.tsx +4 -4
  177. package/src/templates/shared/loading/web/components/skeleton.tsx +4 -4
  178. package/src/templates/shared/mock/web/.env.local +55 -0
  179. package/src/templates/shared/mock/web/src/components/mock-auth-provider.tsx +72 -0
  180. package/src/templates/shared/mock/web/src/components/mock-banner.tsx +29 -0
  181. package/src/templates/shared/mock/web/src/lib/mock.ts +147 -0
  182. package/src/templates/shared/payments/web/src/app/api/webhooks/stripe/route.ts +10 -4
  183. package/src/templates/shared/redis/web/src/lib/redis.ts +1 -1
  184. package/src/templates/web/ai-platform/template/src/app/api/auth/route.ts +57 -0
  185. package/src/templates/web/ai-platform/template/src/app/login/page.tsx +112 -0
  186. package/src/templates/web/ai-platform/template/src/app/models/page.tsx +186 -0
  187. package/src/templates/web/ai-platform/template/src/app/playground/page.tsx +251 -0
  188. package/src/templates/web/ai-platform/template/src/app/settings/page.tsx +190 -0
  189. package/src/templates/web/ai-platform/template/src/app/signup/page.tsx +133 -0
  190. package/src/templates/web/ai-platform/template/src/lib/auth-session.ts +52 -0
  191. package/src/templates/web/base/template/eslint.config.mjs +14 -0
  192. package/src/templates/web/base/template/src/app/auth/callback/route.ts +1 -1
  193. package/src/templates/web/base/template/src/app/checkout/page.tsx +76 -103
  194. package/src/templates/web/base/template/src/app/dashboard/page.tsx +145 -329
  195. package/src/templates/web/base/template/src/app/layout.tsx +40 -38
  196. package/src/templates/web/base/template/src/app/login/page.tsx +116 -66
  197. package/src/templates/web/base/template/src/app/page.tsx +97 -193
  198. package/src/templates/web/base/template/src/app/settings/page.tsx +154 -0
  199. package/src/templates/web/base/template/src/app/signup/page.tsx +117 -66
  200. package/src/templates/web/base/template/src/components/providers/app-providers.tsx +8 -3
  201. package/src/templates/web/base/template/src/components/shared/header.tsx +229 -63
  202. package/src/templates/web/iot-dashboard/template/src/app/alerts/page.tsx +157 -0
  203. package/src/templates/web/iot-dashboard/template/src/app/api/auth/route.ts +57 -0
  204. package/src/templates/web/iot-dashboard/template/src/app/devices/[id]/page.tsx +204 -0
  205. package/src/templates/web/iot-dashboard/template/src/app/devices/new/page.tsx +139 -0
  206. package/src/templates/web/iot-dashboard/template/src/app/devices/page.tsx +171 -0
  207. package/src/templates/web/iot-dashboard/template/src/app/login/page.tsx +112 -0
  208. package/src/templates/web/iot-dashboard/template/src/app/settings/page.tsx +186 -0
  209. package/src/templates/web/iot-dashboard/template/src/app/signup/page.tsx +133 -0
  210. package/src/templates/web/iot-dashboard/template/src/lib/auth-session.ts +52 -0
  211. package/src/templates/web/marketplace/template/src/app/api/auth/route.ts +57 -0
  212. package/src/templates/web/marketplace/template/src/app/login/page.tsx +112 -0
  213. package/src/templates/web/marketplace/template/src/app/orders/page.tsx +160 -0
  214. package/src/templates/web/marketplace/template/src/app/products/[id]/page.tsx +218 -0
  215. package/src/templates/web/marketplace/template/src/app/settings/page.tsx +150 -0
  216. package/src/templates/web/marketplace/template/src/app/signup/page.tsx +133 -0
  217. package/src/templates/web/marketplace/template/src/lib/auth-session.ts +52 -0
  218. package/src/templates/web/micro-saas/template/src/app/api/auth/route.ts +57 -0
  219. package/src/templates/web/micro-saas/template/src/app/login/page.tsx +14 -3
  220. package/src/templates/web/micro-saas/template/src/app/signup/page.tsx +15 -4
  221. package/src/templates/web/micro-saas/template/src/lib/auth-session.ts +52 -0
  222. package/src/templates/web/ui-auth/template/eslint.config.mjs +14 -0
  223. package/src/templates/web/ui-auth/template/src/app/checkout/page.tsx +3 -3
  224. package/src/templates/web/ui-auth/template/src/app/dev-setup/page.tsx +81 -91
  225. package/src/templates/web/ui-auth/template/src/app/layout.tsx +38 -36
  226. package/src/templates/web/ui-auth/template/src/app/login/page.tsx +22 -45
  227. package/src/templates/web/ui-auth/template/src/app/page.tsx +106 -306
  228. package/src/templates/web/ui-auth/template/src/app/setup/page.tsx +387 -402
  229. package/src/templates/web/ui-auth/template/src/app/signup/page.tsx +24 -47
  230. package/src/templates/web/ui-auth/template/src/components/providers/app-providers.tsx +8 -3
  231. package/src/templates/web/ui-auth/template/src/components/shared/header.tsx +229 -94
  232. package/src/templates/web/ui-auth-ai/template/src/app/layout.tsx +38 -45
  233. package/src/templates/web/ui-auth-ai/template/src/app/login/page.tsx +86 -0
  234. package/src/templates/web/ui-auth-ai/template/src/app/page.tsx +107 -193
  235. package/src/templates/web/ui-auth-ai/template/src/app/signup/page.tsx +105 -0
  236. package/src/templates/web/ui-auth-ai/template/src/components/ai/audio-generator.tsx +144 -140
  237. package/src/templates/web/ui-auth-ai/template/src/components/ai/video-generator.tsx +156 -157
  238. package/src/templates/web/ui-auth-ai/template/src/components/auth/login-form.tsx +7 -3
  239. package/src/templates/web/ui-auth-ai/template/src/components/providers/app-providers.tsx +25 -0
  240. package/src/templates/web/ui-auth-ai/template/src/components/shared/footer.tsx +36 -0
  241. package/src/templates/web/ui-auth-ai/template/src/components/shared/header.tsx +228 -0
  242. package/src/templates/web/ui-auth-ai/template/src/components/ui/button.tsx +5 -5
  243. package/src/templates/web/ui-auth-ai/template/src/components/ui/input.tsx +1 -1
  244. package/src/templates/web/ui-auth-ai/template/src/components/ui/select.tsx +1 -1
  245. package/src/templates/web/ui-auth-ai/template/src/components/ui/textarea.tsx +1 -1
  246. package/src/templates/web/ui-auth-ai/template/src/components/ui/theme-toggle.tsx +34 -0
  247. package/src/templates/web/ui-auth-ai/template/src/lib/supabase.ts +6 -4
  248. package/src/templates/web/ui-auth-ai/template/src/providers/auth-provider.tsx +7 -5
  249. package/src/templates/web/ui-auth-payments/template/src/app/billing/page.tsx +63 -192
  250. package/src/templates/web/ui-auth-payments/template/src/app/checkout/page.tsx +104 -296
  251. package/src/templates/web/ui-auth-payments/template/src/app/dashboard/page.tsx +27 -27
  252. package/src/templates/web/ui-auth-payments/template/src/app/dev-setup/page.tsx +70 -81
  253. package/src/templates/web/ui-auth-payments/template/src/app/layout.tsx +38 -36
  254. package/src/templates/web/ui-auth-payments/template/src/app/login/loading.tsx +9 -9
  255. package/src/templates/web/ui-auth-payments/template/src/app/login/page.tsx +4 -104
  256. package/src/templates/web/ui-auth-payments/template/src/app/page.tsx +69 -337
  257. package/src/templates/web/ui-auth-payments/template/src/app/setup/page.tsx +55 -68
  258. package/src/templates/web/ui-auth-payments/template/src/app/signup/loading.tsx +13 -13
  259. package/src/templates/web/ui-auth-payments/template/src/app/signup/page.tsx +4 -123
  260. package/src/templates/web/ui-auth-payments/template/src/components/client/auth-status.tsx +37 -52
  261. package/src/templates/web/ui-auth-payments/template/src/components/client/login-form.tsx +49 -103
  262. package/src/templates/web/ui-auth-payments/template/src/components/client/newsletter-signup.tsx +4 -4
  263. package/src/templates/web/ui-auth-payments/template/src/components/client/signup-form.tsx +60 -140
  264. package/src/templates/web/ui-auth-payments/template/src/components/providers/app-providers.tsx +25 -28
  265. package/src/templates/web/ui-auth-payments/template/src/components/shared/header.tsx +229 -230
  266. package/src/templates/web/ui-auth-payments/template/src/lib/actions/auth.ts +245 -245
  267. package/src/templates/web/ui-auth-payments/template/src/lib/actions/index.ts +339 -339
  268. package/src/templates/web/ui-auth-payments-ai/template/src/app/ai/page.tsx +305 -309
  269. package/src/templates/web/ui-auth-payments-ai/template/src/app/billing/page.tsx +62 -312
  270. package/src/templates/web/ui-auth-payments-ai/template/src/app/checkout/page.tsx +109 -125
  271. package/src/templates/web/ui-auth-payments-ai/template/src/app/dashboard/page.tsx +27 -27
  272. package/src/templates/web/ui-auth-payments-ai/template/src/app/dev-setup/page.tsx +68 -83
  273. package/src/templates/web/ui-auth-payments-ai/template/src/app/layout.tsx +40 -38
  274. package/src/templates/web/ui-auth-payments-ai/template/src/app/onboarding/page.tsx +20 -20
  275. package/src/templates/web/ui-auth-payments-ai/template/src/app/page.tsx +140 -394
  276. package/src/templates/web/ui-auth-payments-ai/template/src/app/settings/page.tsx +28 -27
  277. package/src/templates/web/ui-auth-payments-ai/template/src/app/setup/page.tsx +51 -66
  278. package/src/templates/web/ui-auth-payments-ai/template/src/components/client/auth-status.tsx +37 -52
  279. package/src/templates/web/ui-auth-payments-ai/template/src/components/client/login-form.tsx +50 -79
  280. package/src/templates/web/ui-auth-payments-ai/template/src/components/client/signup-form.tsx +58 -111
  281. package/src/templates/web/ui-auth-payments-ai/template/src/components/providers/app-providers.tsx +8 -3
  282. package/src/templates/web/ui-auth-payments-ai/template/src/components/shared/header.tsx +229 -252
  283. package/src/templates/web/ui-auth-payments-ai/template/src/lib/actions/auth.ts +245 -245
  284. package/src/templates/web/ui-auth-payments-audio/template/src/app/billing/page.tsx +63 -192
  285. package/src/templates/web/ui-auth-payments-audio/template/src/app/checkout/page.tsx +109 -125
  286. package/src/templates/web/ui-auth-payments-audio/template/src/app/dashboard/page.tsx +27 -27
  287. package/src/templates/web/ui-auth-payments-audio/template/src/app/layout.tsx +40 -38
  288. package/src/templates/web/ui-auth-payments-audio/template/src/app/page.tsx +122 -385
  289. package/src/templates/web/ui-auth-payments-audio/template/src/app/setup/page.tsx +340 -344
  290. package/src/templates/web/ui-auth-payments-audio/template/src/components/client/auth-status.tsx +37 -52
  291. package/src/templates/web/ui-auth-payments-audio/template/src/components/client/login-form.tsx +49 -103
  292. package/src/templates/web/ui-auth-payments-audio/template/src/components/client/signup-form.tsx +60 -140
  293. package/src/templates/web/ui-auth-payments-audio/template/src/components/providers/app-providers.tsx +8 -3
  294. package/src/templates/web/ui-auth-payments-audio/template/src/components/shared/header.tsx +229 -252
  295. package/src/templates/web/ui-auth-payments-audio/template/src/lib/actions/auth.ts +3 -3
  296. package/src/templates/web/ui-auth-payments-video/template/src/app/billing/page.tsx +63 -192
  297. package/src/templates/web/ui-auth-payments-video/template/src/app/checkout/page.tsx +109 -125
  298. package/src/templates/web/ui-auth-payments-video/template/src/app/layout.tsx +38 -36
  299. package/src/templates/web/ui-auth-payments-video/template/src/app/login/page.tsx +9 -109
  300. package/src/templates/web/ui-auth-payments-video/template/src/app/page.tsx +132 -392
  301. package/src/templates/web/ui-auth-payments-video/template/src/app/setup/page.tsx +346 -350
  302. package/src/templates/web/ui-auth-payments-video/template/src/app/signup/page.tsx +9 -128
  303. package/src/templates/web/ui-auth-payments-video/template/src/components/client/login-form.tsx +90 -0
  304. package/src/templates/web/ui-auth-payments-video/template/src/components/client/signup-form.tsx +105 -0
  305. package/src/templates/web/ui-auth-payments-video/template/src/components/providers/app-providers.tsx +8 -3
  306. package/src/templates/web/ui-auth-payments-video/template/src/components/shared/header.tsx +229 -246
  307. package/src/templates/web/ui-only/template/eslint.config.mjs +14 -0
  308. package/src/templates/web/ui-only/template/src/app/checkout/page.tsx +2 -2
  309. package/src/templates/web/ui-only/template/src/app/login/page.tsx +69 -63
  310. package/src/templates/web/ui-only/template/src/app/page.tsx +69 -91
  311. package/src/templates/web/ui-only/template/src/app/signup/page.tsx +94 -79
  312. package/src/templates/web/ui-only/template/src/components/providers/app-providers.tsx +1 -6
  313. package/src/templates/web/ui-only/template/src/components/shared/header.tsx +90 -53
  314. package/src/templates/web/ui-package-test/template/package.json +19 -23
  315. package/src/templates/web/ui-package-test/template/postcss.config.mjs +8 -0
  316. package/src/templates/web/ui-package-test/template/src/app/globals.css +88 -0
  317. package/src/templates/web/ui-package-test/template/src/app/layout.tsx +27 -0
  318. package/src/templates/web/ui-package-test/template/src/app/page.tsx +46 -106
  319. package/dist/templates/mobile/ui-auth-payments-ai-rag/template/README.md +0 -655
  320. package/dist/templates/mobile/ui-auth-payments-ai-rag/template/app/(tabs)/ai.tsx +0 -683
  321. package/dist/templates/mobile/ui-auth-payments-ai-rag/template/app/_layout.tsx +0 -124
  322. package/dist/templates/mobile/ui-auth-payments-ai-rag/template/app.json +0 -74
  323. package/dist/templates/mobile/ui-auth-payments-ai-rag/template/babel.config.js +0 -25
  324. package/dist/templates/mobile/ui-auth-payments-ai-rag/template/docs/MOBILE-SETUP.md +0 -787
  325. package/dist/templates/mobile/ui-auth-payments-ai-rag/template/eas.json +0 -25
  326. package/dist/templates/mobile/ui-auth-payments-ai-rag/template/expo-env.d.ts +0 -3
  327. package/dist/templates/mobile/ui-auth-payments-ai-rag/template/hooks/useRAGSystem.ts +0 -346
  328. package/dist/templates/mobile/ui-auth-payments-ai-rag/template/jest-setup.ts +0 -37
  329. package/dist/templates/mobile/ui-auth-payments-ai-rag/template/lib/rag/config.ts +0 -180
  330. package/dist/templates/mobile/ui-auth-payments-ai-rag/template/metro.config.js +0 -11
  331. package/dist/templates/mobile/ui-auth-payments-ai-rag/template/package.json +0 -122
  332. package/dist/templates/mobile/ui-auth-payments-ai-rag/template/scripts/setup-rag.js +0 -599
  333. package/dist/templates/mobile/ui-auth-payments-ai-rag/template/tsconfig.json +0 -32
  334. package/dist/templates/web/base/template/.eslintrc.js +0 -8
  335. package/dist/templates/web/base/template/src/components/__tests__/example.test.tsx +0 -49
  336. package/dist/templates/web/base/template/src/test/setup.ts +0 -74
  337. package/dist/templates/web/base/template/vitest.config.ts +0 -17
  338. package/dist/templates/web/ui-auth/template/.eslintrc.js +0 -8
  339. package/dist/templates/web/ui-auth/template/src/components/__tests__/example.test.tsx +0 -49
  340. package/dist/templates/web/ui-auth/template/src/test/setup.ts +0 -74
  341. package/dist/templates/web/ui-auth/template/vitest.config.ts +0 -17
  342. package/dist/templates/web/ui-auth-payments/template/src/components/__tests__/example.test.tsx +0 -49
  343. package/dist/templates/web/ui-auth-payments/template/src/test/setup.ts +0 -74
  344. package/dist/templates/web/ui-auth-payments/template/vitest.config.ts +0 -17
  345. package/dist/templates/web/ui-auth-payments-ai/template/src/components/__tests__/example.test.tsx +0 -49
  346. package/dist/templates/web/ui-auth-payments-ai/template/src/test/setup.ts +0 -74
  347. package/dist/templates/web/ui-auth-payments-ai/template/vitest.config.ts +0 -17
  348. package/dist/templates/web/ui-auth-payments-ai-rag/template/README.md +0 -434
  349. package/dist/templates/web/ui-auth-payments-ai-rag/template/components/rag/KnowledgeManager.tsx +0 -642
  350. package/dist/templates/web/ui-auth-payments-ai-rag/template/components/rag/RAGAnalytics.tsx +0 -466
  351. package/dist/templates/web/ui-auth-payments-ai-rag/template/components/rag/RAGChatInterface.tsx +0 -393
  352. package/dist/templates/web/ui-auth-payments-ai-rag/template/docs/GETTING-STARTED.md +0 -457
  353. package/dist/templates/web/ui-auth-payments-ai-rag/template/hooks/useRAGSystem.ts +0 -478
  354. package/dist/templates/web/ui-auth-payments-ai-rag/template/lib/rag/config.ts +0 -250
  355. package/dist/templates/web/ui-auth-payments-ai-rag/template/package.json +0 -73
  356. package/dist/templates/web/ui-auth-payments-ai-rag/template/scripts/setup-rag.js +0 -622
  357. package/dist/templates/web/ui-auth-payments-ai-rag/template/src/app/ai/page.tsx +0 -396
  358. package/dist/templates/web/ui-auth-payments-audio/template/src/components/__tests__/example.test.tsx +0 -49
  359. package/dist/templates/web/ui-auth-payments-audio/template/src/test/setup.ts +0 -74
  360. package/dist/templates/web/ui-auth-payments-audio/template/vitest.config.ts +0 -17
  361. package/dist/templates/web/ui-auth-payments-video/template/src/components/__tests__/example.test.tsx +0 -49
  362. package/dist/templates/web/ui-auth-payments-video/template/src/test/setup.ts +0 -74
  363. package/dist/templates/web/ui-auth-payments-video/template/vitest.config.ts +0 -17
  364. package/dist/templates/web/ui-only/template/.eslintrc.js +0 -8
  365. package/dist/templates/web/ui-only/template/src/components/__tests__/example.test.tsx +0 -49
  366. package/dist/templates/web/ui-only/template/src/test/setup.ts +0 -74
  367. package/dist/templates/web/ui-only/template/vitest.config.ts +0 -17
  368. package/src/templates/mobile/ui-auth-payments-ai-rag/template/README.md +0 -655
  369. package/src/templates/mobile/ui-auth-payments-ai-rag/template/app/(tabs)/ai.tsx +0 -683
  370. package/src/templates/mobile/ui-auth-payments-ai-rag/template/app/_layout.tsx +0 -124
  371. package/src/templates/mobile/ui-auth-payments-ai-rag/template/app.json +0 -74
  372. package/src/templates/mobile/ui-auth-payments-ai-rag/template/babel.config.js +0 -25
  373. package/src/templates/mobile/ui-auth-payments-ai-rag/template/docs/MOBILE-SETUP.md +0 -787
  374. package/src/templates/mobile/ui-auth-payments-ai-rag/template/eas.json +0 -25
  375. package/src/templates/mobile/ui-auth-payments-ai-rag/template/expo-env.d.ts +0 -3
  376. package/src/templates/mobile/ui-auth-payments-ai-rag/template/hooks/useRAGSystem.ts +0 -346
  377. package/src/templates/mobile/ui-auth-payments-ai-rag/template/jest-setup.ts +0 -37
  378. package/src/templates/mobile/ui-auth-payments-ai-rag/template/lib/rag/config.ts +0 -180
  379. package/src/templates/mobile/ui-auth-payments-ai-rag/template/metro.config.js +0 -11
  380. package/src/templates/mobile/ui-auth-payments-ai-rag/template/package.json +0 -122
  381. package/src/templates/mobile/ui-auth-payments-ai-rag/template/scripts/setup-rag.js +0 -599
  382. package/src/templates/mobile/ui-auth-payments-ai-rag/template/tsconfig.json +0 -32
  383. package/src/templates/web/base/template/.eslintrc.js +0 -8
  384. package/src/templates/web/base/template/src/components/__tests__/example.test.tsx +0 -49
  385. package/src/templates/web/base/template/src/test/setup.ts +0 -74
  386. package/src/templates/web/base/template/vitest.config.ts +0 -17
  387. package/src/templates/web/ui-auth/template/.eslintrc.js +0 -8
  388. package/src/templates/web/ui-auth/template/src/components/__tests__/example.test.tsx +0 -49
  389. package/src/templates/web/ui-auth/template/src/test/setup.ts +0 -74
  390. package/src/templates/web/ui-auth/template/vitest.config.ts +0 -17
  391. package/src/templates/web/ui-auth-payments/template/src/components/__tests__/example.test.tsx +0 -49
  392. package/src/templates/web/ui-auth-payments/template/src/test/setup.ts +0 -74
  393. package/src/templates/web/ui-auth-payments/template/vitest.config.ts +0 -17
  394. package/src/templates/web/ui-auth-payments-ai/template/src/components/__tests__/example.test.tsx +0 -49
  395. package/src/templates/web/ui-auth-payments-ai/template/src/test/setup.ts +0 -74
  396. package/src/templates/web/ui-auth-payments-ai/template/vitest.config.ts +0 -17
  397. package/src/templates/web/ui-auth-payments-ai-rag/template/README.md +0 -434
  398. package/src/templates/web/ui-auth-payments-ai-rag/template/components/rag/KnowledgeManager.tsx +0 -642
  399. package/src/templates/web/ui-auth-payments-ai-rag/template/components/rag/RAGAnalytics.tsx +0 -466
  400. package/src/templates/web/ui-auth-payments-ai-rag/template/components/rag/RAGChatInterface.tsx +0 -393
  401. package/src/templates/web/ui-auth-payments-ai-rag/template/docs/GETTING-STARTED.md +0 -457
  402. package/src/templates/web/ui-auth-payments-ai-rag/template/hooks/useRAGSystem.ts +0 -478
  403. package/src/templates/web/ui-auth-payments-ai-rag/template/lib/rag/config.ts +0 -250
  404. package/src/templates/web/ui-auth-payments-ai-rag/template/package.json +0 -73
  405. package/src/templates/web/ui-auth-payments-ai-rag/template/scripts/setup-rag.js +0 -622
  406. package/src/templates/web/ui-auth-payments-ai-rag/template/src/app/ai/page.tsx +0 -396
  407. package/src/templates/web/ui-auth-payments-audio/template/src/components/__tests__/example.test.tsx +0 -49
  408. package/src/templates/web/ui-auth-payments-audio/template/src/test/setup.ts +0 -74
  409. package/src/templates/web/ui-auth-payments-audio/template/vitest.config.ts +0 -17
  410. package/src/templates/web/ui-auth-payments-video/template/src/components/__tests__/example.test.tsx +0 -49
  411. package/src/templates/web/ui-auth-payments-video/template/src/test/setup.ts +0 -74
  412. package/src/templates/web/ui-auth-payments-video/template/vitest.config.ts +0 -17
  413. package/src/templates/web/ui-only/template/.eslintrc.js +0 -8
  414. package/src/templates/web/ui-only/template/src/components/__tests__/example.test.tsx +0 -49
  415. package/src/templates/web/ui-only/template/src/test/setup.ts +0 -74
  416. package/src/templates/web/ui-only/template/vitest.config.ts +0 -17
@@ -1,394 +1,140 @@
1
- 'use client'
2
-
3
- import {
4
- Button,
5
- Card,
6
- PageTransition,
7
- MobileContainer,
8
- MobileHero,
9
- ResponsiveGrid,
10
- NetworkAwareContent,
11
- OfflineWrapper,
12
- SwipeableCard,
13
- PullToRefresh,
14
- useNetworkInfo,
15
- useOfflineState,
16
- useAnimationTokens,
17
- useGlassmorphism
18
- } from '@digilogiclabs/saas-factory-ui'
19
- import {
20
- ArrowRight,
21
- Zap,
22
- Shield,
23
- Rocket,
24
- CheckCircle,
25
- LogOut,
26
- User,
27
- MessageSquare,
28
- Mic,
29
- Video,
30
- Image as ImageIcon,
31
- Brain,
32
- Sparkles,
33
- Wand2,
34
- Headphones,
35
- Monitor,
36
- FileText
37
- } from 'lucide-react'
38
- import { useAuth } from '@digilogiclabs/app-sdk'
39
- import {
40
- AIProvider,
41
- AIChat,
42
- AITextGenerator,
43
- AIAudioGenerator,
44
- AIVideoGenerator,
45
- AISetupStatus,
46
- getAIConfigFromEnv,
47
- validateAIConfig,
48
- type ChatMessage,
49
- type QuickStartOptions
50
- } from '@digilogiclabs/saas-factory-ai'
51
- import Link from 'next/link'
52
- import { useState } from 'react'
53
-
54
- export default function Home() {
55
- const { user, signOut, loading } = useAuth()
56
- const networkInfo = useNetworkInfo()
57
- const isOnline = useOfflineState()
58
- const [isRefreshing, setIsRefreshing] = useState(false)
59
- const [activeAITool, setActiveAITool] = useState<'text' | 'audio' | 'video' | 'chat'>('chat')
60
-
61
- // Modern design tokens
62
- const animations = useAnimationTokens()
63
- const glass = useGlassmorphism({ intensity: 'medium', border: true, accent: true })
64
-
65
- const projectName = "{{projectName}}"
66
- const projectDescription = "{{description}}"
67
-
68
- const heroConfig = {
69
- badge: {
70
- text: "🤖 AI-Powered Platform",
71
- variant: "secondary" as const,
72
- icon: Brain
73
- },
74
- title: {
75
- text: "Welcome to " + projectName,
76
- highlight: projectName,
77
- size: "xl" as const
78
- },
79
- description: projectDescription + ". Harness the power of AI for text generation, audio creation, video production, and intelligent conversations."
80
- }
81
-
82
- const handleSignOut = async () => {
83
- try {
84
- await signOut()
85
- } catch (err) {
86
- console.error('Sign out error:', err)
87
- }
88
- }
89
-
90
- const handleRefresh = async () => {
91
- setIsRefreshing(true)
92
- // Simulate refresh
93
- await new Promise(resolve => setTimeout(resolve, 1500))
94
- setIsRefreshing(false)
95
- }
96
-
97
- const aiTools = [
98
- {
99
- id: 'chat' as const,
100
- title: 'AI Chat',
101
- description: 'Intelligent conversations and assistance',
102
- icon: MessageSquare,
103
- color: 'blue',
104
- gradient: 'from-blue-500 to-cyan-500'
105
- },
106
- {
107
- id: 'text' as const,
108
- title: 'Text Generation',
109
- description: 'Create content, articles, and copy',
110
- icon: FileText,
111
- color: 'purple',
112
- gradient: 'from-purple-500 to-pink-500'
113
- },
114
- {
115
- id: 'audio' as const,
116
- title: 'Audio Generation',
117
- description: 'Generate music, voices, and sound effects',
118
- icon: Headphones,
119
- color: 'green',
120
- gradient: 'from-green-500 to-emerald-500'
121
- },
122
- {
123
- id: 'video' as const,
124
- title: 'Video Generation',
125
- description: 'Create videos, animations, and visual content',
126
- icon: Monitor,
127
- color: 'orange',
128
- gradient: 'from-orange-500 to-red-500'
129
- }
130
- ]
131
-
132
- const aiConfig = getAIConfigFromEnv()
133
-
134
- const renderAITool = () => {
135
- switch (activeAITool) {
136
- case 'chat':
137
- return (
138
- <div className={`${glass.card} ${glass.border} rounded-2xl p-6 h-96`}>
139
- <AIChat
140
- placeholder="Ask me anything..."
141
- showTypingIndicator={true}
142
- enableFileUpload={true}
143
- maxMessages={50}
144
- className="h-full"
145
- />
146
- </div>
147
- )
148
- case 'text':
149
- return (
150
- <div className={`${glass.card} ${glass.border} rounded-2xl p-6`}>
151
- <AITextGenerator
152
- placeholder="Describe what you want to generate..."
153
- maxLength={2000}
154
- showWordCount={true}
155
- templates={[
156
- 'Blog post',
157
- 'Product description',
158
- 'Email',
159
- 'Social media post',
160
- 'Technical documentation'
161
- ]}
162
- className="min-h-64"
163
- />
164
- </div>
165
- )
166
- case 'audio':
167
- return (
168
- <div className={`${glass.card} ${glass.border} rounded-2xl p-6`}>
169
- <AIAudioGenerator
170
- placeholder="Describe the audio you want to create..."
171
- supportedFormats={['mp3', 'wav', 'ogg']}
172
- maxDuration={300}
173
- showWaveform={true}
174
- className="min-h-64"
175
- />
176
- </div>
177
- )
178
- case 'video':
179
- return (
180
- <div className={`${glass.card} ${glass.border} rounded-2xl p-6`}>
181
- <AIVideoGenerator
182
- placeholder="Describe the video you want to create..."
183
- supportedFormats={['mp4', 'webm']}
184
- maxDuration={60}
185
- resolution="1080p"
186
- showPreview={true}
187
- className="min-h-64"
188
- />
189
- </div>
190
- )
191
- default:
192
- return null
193
- }
194
- }
195
-
196
- return (
197
- <AIProvider config={aiConfig}>
198
- <PageTransition type="fade" duration={300}>
199
- <OfflineWrapper
200
- cacheStrategy="stale-while-revalidate"
201
- showOfflineIndicator={true}
202
- backgroundSync={true}
203
- >
204
- <PullToRefresh
205
- onRefresh={handleRefresh}
206
- threshold={80}
207
- loadingIndicator="spinner"
208
- hapticOnTrigger={true}
209
- networkAware={true}
210
- >
211
- <main className="min-h-screen relative overflow-hidden bg-background">
212
- {/* Theme-aware gradient background */}
213
- <div className="absolute inset-0 bg-gradient-to-br from-primary/10 via-background to-secondary/10 dark:from-primary/20 dark:via-background dark:to-secondary/20" />
214
- <div className="absolute inset-0 bg-gradient-to-tr from-accent/5 via-transparent to-primary/5 dark:from-accent/10 dark:via-transparent dark:to-primary/10" />
215
- <div className="absolute inset-0 bg-[radial-gradient(ellipse_at_top_right,_var(--tw-gradient-stops))] from-primary/15 via-transparent to-transparent dark:from-primary/25 dark:via-transparent dark:to-transparent" />
216
- {/* Animated background particles - theme aware */}
217
- <div className="absolute inset-0 opacity-30 dark:opacity-20">
218
- <div className="absolute top-1/4 left-1/4 w-72 h-72 bg-primary/40 rounded-full mix-blend-multiply filter blur-3xl animate-pulse dark:bg-primary/60"></div>
219
- <div className="absolute top-3/4 right-1/4 w-72 h-72 bg-secondary/40 rounded-full mix-blend-multiply filter blur-3xl animate-pulse animation-delay-2000 dark:bg-secondary/60"></div>
220
- <div className="absolute top-1/2 left-1/2 w-72 h-72 bg-accent/40 rounded-full mix-blend-multiply filter blur-3xl animate-pulse animation-delay-4000 dark:bg-accent/60"></div>
221
- </div>
222
- {/* Subtle overlay for depth */}
223
- <div className="absolute inset-0 bg-gradient-to-b from-transparent via-background/5 to-background/20" />
224
- <div className="relative z-10">
225
- <MobileContainer className="py-8">
226
- {/* AI Configuration Status */}
227
- <AISetupStatus className="mb-6" />
228
-
229
- {/* Simple Auth Status */}
230
- {user && (
231
- <div className="flex justify-end mb-8">
232
- <div className="flex items-center gap-4">
233
- <span className="text-sm text-gray-600 dark:text-gray-300">
234
- Welcome, {user.email?.split('@')[0]}
235
- </span>
236
- <Button variant="outline" size="sm" onClick={handleSignOut}>
237
- <LogOut className="w-4 h-4 mr-2" />
238
- Sign Out
239
- </Button>
240
- </div>
241
- </div>
242
- )}
243
-
244
- {!user && !loading && (
245
- <div className="flex justify-end mb-8">
246
- <div className="flex gap-2">
247
- <Link href="/login">
248
- <Button variant="outline" size="sm">Sign In</Button>
249
- </Link>
250
- <Link href="/signup">
251
- <Button size="sm">Sign Up</Button>
252
- </Link>
253
- </div>
254
- </div>
255
- )}
256
-
257
- {/* Hero Section */}
258
- <MobileHero
259
- badge={heroConfig.badge}
260
- title={heroConfig.title}
261
- description={heroConfig.description}
262
- actions={[
263
- {
264
- label: "View Pricing",
265
- href: "/checkout",
266
- icon: ArrowRight,
267
- variant: "default",
268
- size: "lg"
269
- },
270
- {
271
- label: "Learn More",
272
- variant: "outline",
273
- size: "lg"
274
- }
275
- ]}
276
- className="text-center mb-12"
277
- />
278
-
279
- {/* AI Tool Selector */}
280
- <div className="mb-8">
281
- <h2 className="text-2xl font-bold text-center mb-6 bg-gradient-to-r from-purple-400 to-pink-400 bg-clip-text text-transparent">
282
- Choose Your AI Tool
283
- </h2>
284
- <div className="grid grid-cols-2 lg:grid-cols-4 gap-4 mb-8">
285
- {aiTools.map((tool) => {
286
- const Icon = tool.icon
287
- const isActive = activeAITool === tool.id
288
- return (
289
- <button
290
- key={tool.id}
291
- onClick={() => setActiveAITool(tool.id)}
292
- className={`
293
- ${glass.card} ${glass.border}
294
- rounded-2xl p-4 text-center transition-all duration-300
295
- ${isActive
296
- ? `bg-gradient-to-r ${tool.gradient} text-white shadow-lg scale-105`
297
- : `${animations.hover.scale} hover:shadow-lg`
298
- }
299
- `}
300
- >
301
- <div className={`mx-auto w-12 h-12 rounded-xl flex items-center justify-center mb-3 ${
302
- isActive ? 'bg-white/20' : glass.accent
303
- }`}>
304
- <Icon className={`h-6 w-6 ${isActive ? 'text-white' : `text-${tool.color}-400`}`} />
305
- </div>
306
- <h3 className="font-semibold text-sm mb-1">{tool.title}</h3>
307
- <p className={`text-xs ${isActive ? 'text-white/80' : 'text-gray-600 dark:text-gray-300'}`}>
308
- {tool.description}
309
- </p>
310
- </button>
311
- )
312
- })}
313
- </div>
314
- </div>
315
-
316
- {/* AI Tool Interface */}
317
- <div className="mb-12">
318
- {renderAITool()}
319
- </div>
320
-
321
- {/* Features Overview */}
322
- <ResponsiveGrid columns={{ base: 1, sm: 2, md: 4 }} gap={6} className="mb-16">
323
- <div className={`${glass.card} ${glass.border} text-center p-6 rounded-2xl ${animations.hover.scale} ${animations.transition.smooth}`}>
324
- <div className={`mx-auto w-12 h-12 ${glass.accent} rounded-xl flex items-center justify-center mb-4 ${animations.hover.glow}`}>
325
- <Brain className="h-6 w-6 text-purple-400" />
326
- </div>
327
- <h3 className="text-lg font-semibold mb-2">Advanced AI Models</h3>
328
- <p className="text-sm text-gray-600 dark:text-gray-300">
329
- Powered by the latest AI technology for superior results
330
- </p>
331
- </div>
332
-
333
- <div className={`${glass.card} ${glass.border} text-center p-6 rounded-2xl ${animations.hover.scale} ${animations.transition.smooth}`}>
334
- <div className={`mx-auto w-12 h-12 ${glass.accent} rounded-xl flex items-center justify-center mb-4 ${animations.hover.glow}`}>
335
- <Zap className="h-6 w-6 text-yellow-400" />
336
- </div>
337
- <h3 className="text-lg font-semibold mb-2">Lightning Fast</h3>
338
- <p className="text-sm text-gray-600 dark:text-gray-300">
339
- Generate content in seconds with optimized processing
340
- </p>
341
- </div>
342
-
343
- <div className={`${glass.card} ${glass.border} text-center p-6 rounded-2xl ${animations.hover.scale} ${animations.transition.smooth}`}>
344
- <div className={`mx-auto w-12 h-12 ${glass.accent} rounded-xl flex items-center justify-center mb-4 ${animations.hover.glow}`}>
345
- <Shield className="h-6 w-6 text-green-400" />
346
- </div>
347
- <h3 className="text-lg font-semibold mb-2">Secure & Private</h3>
348
- <p className="text-sm text-gray-600 dark:text-gray-300">
349
- Your data and creations are always protected and private
350
- </p>
351
- </div>
352
-
353
- <div className={`${glass.card} ${glass.border} text-center p-6 rounded-2xl ${animations.hover.scale} ${animations.transition.smooth}`}>
354
- <div className={`mx-auto w-12 h-12 ${glass.accent} rounded-xl flex items-center justify-center mb-4 ${animations.hover.glow}`}>
355
- <Sparkles className="h-6 w-6 text-pink-400" />
356
- </div>
357
- <h3 className="text-lg font-semibold mb-2">Creative Freedom</h3>
358
- <p className="text-sm text-gray-600 dark:text-gray-300">
359
- Unlimited possibilities for your creative projects
360
- </p>
361
- </div>
362
- </ResponsiveGrid>
363
-
364
- {/* Usage Stats */}
365
- <div className={`${glass.card} ${glass.border} rounded-2xl p-6 mb-16`}>
366
- <h2 className="text-xl font-bold text-center mb-6">Your AI Usage</h2>
367
- <div className="grid grid-cols-2 lg:grid-cols-4 gap-6">
368
- <div className="text-center">
369
- <div className="text-3xl font-bold text-purple-400 mb-2">1,247</div>
370
- <div className="text-sm text-gray-600 dark:text-gray-300">Text Generated</div>
371
- </div>
372
- <div className="text-center">
373
- <div className="text-3xl font-bold text-green-400 mb-2">23</div>
374
- <div className="text-sm text-gray-600 dark:text-gray-300">Audio Created</div>
375
- </div>
376
- <div className="text-center">
377
- <div className="text-3xl font-bold text-orange-400 mb-2">8</div>
378
- <div className="text-sm text-gray-600 dark:text-gray-300">Videos Made</div>
379
- </div>
380
- <div className="text-center">
381
- <div className="text-3xl font-bold text-blue-400 mb-2">5.2k</div>
382
- <div className="text-sm text-gray-600 dark:text-gray-300">Chat Messages</div>
383
- </div>
384
- </div>
385
- </div>
386
- </MobileContainer>
387
- </div>
388
- </main>
389
- </PullToRefresh>
390
- </OfflineWrapper>
391
- </PageTransition>
392
- </AIProvider>
393
- )
394
- }
1
+ import { ArrowRight, Zap, Shield, CreditCard, CheckCircle, Brain, Sparkles, MessageSquare } from 'lucide-react'
2
+
3
+ import Link from 'next/link'
4
+
5
+ const FEATURES = [
6
+ {
7
+ icon: Brain,
8
+ title: 'AI-Powered',
9
+ description: 'Integrated AI with OpenAI, Anthropic, and more. Chat, embeddings, and tool calling ready.',
10
+ color: 'text-violet-600 dark:text-violet-400 bg-violet-100 dark:bg-violet-900/30',
11
+ },
12
+ {
13
+ icon: Shield,
14
+ title: 'Secure Auth',
15
+ description: 'Complete authentication with Supabase — login, signup, OAuth, and sessions.',
16
+ color: 'text-emerald-600 dark:text-emerald-400 bg-emerald-100 dark:bg-emerald-900/30',
17
+ },
18
+ {
19
+ icon: CreditCard,
20
+ title: 'Stripe Billing',
21
+ description: 'Usage-based and subscription billing with Stripe. Webhooks and portal included.',
22
+ color: 'text-blue-600 dark:text-blue-400 bg-blue-100 dark:bg-blue-900/30',
23
+ },
24
+ {
25
+ icon: Sparkles,
26
+ title: 'Streaming Responses',
27
+ description: 'Real-time AI streaming with SSE. Token-by-token responses for great UX.',
28
+ color: 'text-amber-600 dark:text-amber-400 bg-amber-100 dark:bg-amber-900/30',
29
+ },
30
+ {
31
+ icon: MessageSquare,
32
+ title: 'Chat Interface',
33
+ description: 'Pre-built chat UI with message history, markdown rendering, and code blocks.',
34
+ color: 'text-pink-600 dark:text-pink-400 bg-pink-100 dark:bg-pink-900/30',
35
+ },
36
+ {
37
+ icon: Zap,
38
+ title: 'Production Ready',
39
+ description: 'Rate limiting, error handling, and observability built in from day one.',
40
+ color: 'text-orange-600 dark:text-orange-400 bg-orange-100 dark:bg-orange-900/30',
41
+ },
42
+ ]
43
+
44
+ export default function Home() {
45
+ return (
46
+ <main className="min-h-screen bg-background">
47
+ {/* Hero */}
48
+ <section className="mx-auto max-w-5xl px-4 py-24 text-center">
49
+ <div className="inline-flex items-center rounded-full border border-border bg-muted px-3 py-1 text-sm text-muted-foreground mb-6">
50
+ <Brain className="mr-1.5 h-3.5 w-3.5" />
51
+ AI + Auth + Payments
52
+ </div>
53
+ <h1 className="text-4xl font-bold tracking-tight text-foreground sm:text-6xl mb-4">
54
+ Build AI apps{' '}
55
+ <span className="text-primary">in minutes</span>
56
+ </h1>
57
+ <p className="mx-auto max-w-2xl text-lg text-muted-foreground mb-8">
58
+ A full-stack AI SaaS starter with authentication, Stripe billing,
59
+ and multi-provider AI integration. Ship your AI product today.
60
+ </p>
61
+ <div className="flex items-center justify-center gap-4">
62
+
63
+ <Link href="/signup" className="inline-flex items-center justify-center rounded-md bg-primary px-8 py-3 text-sm font-medium text-primary-foreground hover:bg-primary/90 transition-colors">
64
+ Start Building <ArrowRight className="ml-2 h-4 w-4" />
65
+ </Link>
66
+
67
+
68
+ <Link href="/ai" className="inline-flex items-center justify-center rounded-md border border-input bg-background px-8 py-3 text-sm font-medium text-foreground hover:bg-accent transition-colors">Try the AI Demo</Link>
69
+
70
+ </div>
71
+ </section>
72
+
73
+ {/* AI Demo Preview */}
74
+ <section className="mx-auto max-w-3xl px-4 pb-16">
75
+ <div className="rounded-xl border border-border bg-card overflow-hidden shadow-lg">
76
+ <div className="flex items-center gap-2 border-b border-border bg-muted/50 px-4 py-2">
77
+ <div className="h-3 w-3 rounded-full bg-destructive/50" />
78
+ <div className="h-3 w-3 rounded-full bg-accent/50" />
79
+ <div className="h-3 w-3 rounded-full bg-primary/50" />
80
+ <span className="ml-2 text-xs text-muted-foreground">AI Chat</span>
81
+ </div>
82
+ <div className="p-6 space-y-4">
83
+ <div className="flex gap-3">
84
+ <div className="h-8 w-8 rounded-full bg-muted flex items-center justify-center shrink-0">
85
+ <span className="text-xs font-medium text-muted-foreground">You</span>
86
+ </div>
87
+ <div className="rounded-lg bg-muted px-4 py-2 text-sm text-foreground">
88
+ How do I add authentication to my Next.js app?
89
+ </div>
90
+ </div>
91
+ <div className="flex gap-3">
92
+ <div className="h-8 w-8 rounded-full bg-primary/10 flex items-center justify-center shrink-0">
93
+ <Sparkles className="h-4 w-4 text-primary" />
94
+ </div>
95
+ <div className="rounded-lg border border-border px-4 py-2 text-sm text-foreground">
96
+ I can help with that! This template already includes Supabase auth.
97
+ Check <code className="text-primary">src/lib/supabase/</code> for the client setup,
98
+ and <code className="text-primary">src/middleware.ts</code> for route protection.
99
+ </div>
100
+ </div>
101
+ </div>
102
+ </div>
103
+ </section>
104
+
105
+ {/* Features */}
106
+ <section className="mx-auto max-w-5xl px-4 pb-24">
107
+ <div className="text-center mb-12">
108
+ <h2 className="text-3xl font-bold text-foreground mb-2">Everything You Need</h2>
109
+ <p className="text-muted-foreground">Build production AI apps without reinventing the wheel.</p>
110
+ </div>
111
+ <div className="grid gap-6 md:grid-cols-2 lg:grid-cols-3">
112
+ {FEATURES.map((feature) => (
113
+ <div key={feature.title} className="rounded-xl border border-border bg-card p-6">
114
+ <div className={`mb-4 flex h-10 w-10 items-center justify-center rounded-lg ${feature.color}`}>
115
+ <feature.icon className="h-5 w-5" />
116
+ </div>
117
+ <h3 className="text-lg font-semibold text-card-foreground mb-2">{feature.title}</h3>
118
+ <p className="text-sm text-muted-foreground">{feature.description}</p>
119
+ </div>
120
+ ))}
121
+ </div>
122
+ </section>
123
+
124
+ {/* CTA */}
125
+ <section className="mx-auto max-w-5xl px-4 pb-24">
126
+ <div className="rounded-xl border border-primary/20 bg-primary/5 p-8 md:p-12 text-center">
127
+ <h2 className="text-2xl font-bold text-foreground mb-2">Ready to build with AI?</h2>
128
+ <p className="text-muted-foreground mb-6 max-w-lg mx-auto">
129
+ Get started in minutes. Authentication, payments, and AI are pre-configured.
130
+ </p>
131
+
132
+ <Link href="/signup" className="inline-flex items-center justify-center rounded-md bg-primary px-8 py-3 text-sm font-medium text-primary-foreground hover:bg-primary/90 transition-colors">
133
+ Create Your Account <ArrowRight className="ml-2 h-4 w-4" />
134
+ </Link>
135
+
136
+ </div>
137
+ </section>
138
+ </main>
139
+ )
140
+ }