@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,141 +1,145 @@
1
- 'use client'
2
-
3
- import { useState } from 'react'
4
- import { useGenerateAudio, useJobStatus } from '@digilogiclabs/saas-factory-ai/react'
5
- import { Button } from '@/components/ui/button'
6
- import { Input } from '@/components/ui/input'
7
- import { Label } from '@/components/ui/label'
8
- import { Select, SelectContent, SelectItem, SelectTrigger, SelectValue } from '@/components/ui/select'
9
- import { JobProgress } from '@digilogiclabs/saas-factory-ai/react'
10
-
11
- export function AudioGenerator() {
12
- const [prompt, setPrompt] = useState('')
13
- const [style, setStyle] = useState('lofi')
14
- const [duration, setDuration] = useState(30)
15
- const [jobId, setJobId] = useState<string | null>(null)
16
- const [audioUrl, setAudioUrl] = useState<string | null>(null)
17
-
18
- const { generate, loading, error } = useGenerateAudio()
19
- const { status } = useJobStatus(jobId)
20
-
21
- const handleGenerate = async () => {
22
- if (!prompt.trim()) return
23
-
24
- try {
25
- const result = await generate(prompt, {
26
- style,
27
- durationSec: duration,
28
- format: 'mp3'
29
- })
30
- setJobId(result.jobId)
31
- setAudioUrl(null)
32
- } catch (err) {
33
- console.error('Audio generation failed:', err)
34
- }
35
- }
36
-
37
- const handleJobComplete = (result: any) => {
38
- if (result.url) {
39
- setAudioUrl(result.url)
40
- }
41
- }
42
-
43
- return (
44
- <div className="space-y-6">
45
- <div className="grid grid-cols-1 gap-4">
46
- <div>
47
- <Label htmlFor="prompt">Audio Description</Label>
48
- <Input
49
- id="prompt"
50
- value={prompt}
51
- onChange={(e) => setPrompt(e.target.value)}
52
- placeholder="Describe the audio you want to generate..."
53
- className="mt-1"
54
- />
55
- </div>
56
-
57
- <div className="grid grid-cols-2 gap-4">
58
- <div>
59
- <Label htmlFor="style">Style</Label>
60
- <Select value={style} onValueChange={setStyle}>
61
- <SelectTrigger className="mt-1">
62
- <SelectValue />
63
- </SelectTrigger>
64
- <SelectContent>
65
- <SelectItem value="lofi">Lo-Fi</SelectItem>
66
- <SelectItem value="jazz">Jazz</SelectItem>
67
- <SelectItem value="classical">Classical</SelectItem>
68
- <SelectItem value="electronic">Electronic</SelectItem>
69
- <SelectItem value="ambient">Ambient</SelectItem>
70
- </SelectContent>
71
- </Select>
72
- </div>
73
-
74
- <div>
75
- <Label htmlFor="duration">Duration (seconds)</Label>
76
- <Input
77
- id="duration"
78
- type="number"
79
- value={duration}
80
- onChange={(e) => setDuration(parseInt(e.target.value) || 30)}
81
- min={10}
82
- max={300}
83
- className="mt-1"
84
- />
85
- </div>
86
- </div>
87
- </div>
88
-
89
- <div className="flex justify-center">
90
- <Button
91
- onClick={handleGenerate}
92
- disabled={loading || !prompt.trim() || !!jobId}
93
- className="px-8"
94
- >
95
- {loading ? 'Starting Generation...' : 'Generate Audio'}
96
- </Button>
97
- </div>
98
-
99
- {error && (
100
- <div className="p-4 bg-red-50 border border-red-200 rounded-md">
101
- <p className="text-sm text-red-600">{error.message}</p>
102
- </div>
103
- )}
104
-
105
- {jobId && (
106
- <div className="space-y-4">
107
- <JobProgress
108
- jobId={jobId}
109
- onComplete={handleJobComplete}
110
- className="p-4 bg-gray-50 rounded-md"
111
- />
112
- </div>
113
- )}
114
-
115
- {audioUrl && (
116
- <div className="p-4 bg-green-50 border border-green-200 rounded-md">
117
- <h4 className="font-medium text-green-800 mb-3">Generated Audio</h4>
118
- <audio controls className="w-full">
119
- <source src={audioUrl} type="audio/mpeg" />
120
- Your browser does not support the audio element.
121
- </audio>
122
- <div className="mt-3">
123
- <Button
124
- variant="outline"
125
- onClick={() => {
126
- const link = document.createElement('a')
127
- link.href = audioUrl
128
- link.download = 'generated-audio.mp3'
129
- document.body.appendChild(link)
130
- link.click()
131
- document.body.removeChild(link)
132
- }}
133
- >
134
- Download Audio
135
- </Button>
136
- </div>
137
- </div>
138
- )}
139
- </div>
140
- )
1
+ 'use client'
2
+
3
+ import { useState } from 'react'
4
+ import { Button } from '@/components/ui/button'
5
+ import { Input } from '@/components/ui/input'
6
+ import { Label } from '@/components/ui/label'
7
+ // Using native select for simplicity
8
+
9
+ // TODO: Replace with your AI SDK hooks
10
+ function useGenerateAudio() {
11
+ return { generate: async (_prompt: string, _opts?: Record<string, unknown>) => ({ jobId: '' }), loading: false, error: null as string | null }
12
+ }
13
+ function useJobStatus(_id: string | null) {
14
+ return { status: null as string | null }
15
+ }
16
+ function JobProgress({ jobId, onComplete, className }: { jobId?: string; onComplete?: (result: unknown) => void; className?: string; status?: string | null }) {
17
+ return status ? <div className="text-sm text-muted-foreground">Status: {status}</div> : null
18
+ }
19
+
20
+ export function AudioGenerator() {
21
+ const [prompt, setPrompt] = useState('')
22
+ const [style, setStyle] = useState('lofi')
23
+ const [duration, setDuration] = useState(30)
24
+ const [jobId, setJobId] = useState<string | null>(null)
25
+ const [audioUrl, setAudioUrl] = useState<string | null>(null)
26
+
27
+ const { generate, loading, error } = useGenerateAudio()
28
+ const { status } = useJobStatus(jobId)
29
+
30
+ const handleGenerate = async () => {
31
+ if (!prompt.trim()) return
32
+
33
+ try {
34
+ const result = await generate(prompt, {
35
+ style,
36
+ durationSec: duration,
37
+ format: 'mp3'
38
+ })
39
+ setJobId(result.jobId)
40
+ setAudioUrl(null)
41
+ } catch (err) {
42
+ console.error('Audio generation failed:', err)
43
+ }
44
+ }
45
+
46
+ const handleJobComplete = (result: any) => {
47
+ if (result.url) {
48
+ setAudioUrl(result.url)
49
+ }
50
+ }
51
+
52
+ return (
53
+ <div className="space-y-6">
54
+ <div className="grid grid-cols-1 gap-4">
55
+ <div>
56
+ <Label htmlFor="prompt">Audio Description</Label>
57
+ <Input
58
+ id="prompt"
59
+ value={prompt}
60
+ onChange={(e) => setPrompt(e.target.value)}
61
+ placeholder="Describe the audio you want to generate..."
62
+ className="mt-1"
63
+ />
64
+ </div>
65
+
66
+ <div className="grid grid-cols-2 gap-4">
67
+ <div>
68
+ <Label htmlFor="style">Style</Label>
69
+ <select value={style} onChange={(e) => setStyle(e.target.value)} className="mt-1 flex h-10 w-full rounded-md border border-input bg-background px-3 py-2 text-sm ring-offset-background focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring">
70
+ <option value="lofi">Lo-Fi</option>
71
+ <option value="jazz">Jazz</option>
72
+ <option value="classical">Classical</option>
73
+ <option value="electronic">Electronic</option>
74
+ <option value="ambient">Ambient</option>
75
+ </select>
76
+ </div>
77
+
78
+ <div>
79
+ <Label htmlFor="duration">Duration (seconds)</Label>
80
+ <Input
81
+ id="duration"
82
+ type="number"
83
+ value={duration}
84
+ onChange={(e) => setDuration(parseInt(e.target.value) || 30)}
85
+ min={10}
86
+ max={300}
87
+ className="mt-1"
88
+ />
89
+ </div>
90
+ </div>
91
+ </div>
92
+
93
+ <div className="flex justify-center">
94
+ <Button
95
+ onClick={handleGenerate}
96
+ disabled={loading || !prompt.trim() || !!jobId}
97
+ className="px-8"
98
+ >
99
+ {loading ? 'Starting Generation...' : 'Generate Audio'}
100
+ </Button>
101
+ </div>
102
+
103
+ {error && (
104
+ <div className="p-4 bg-red-50 border border-red-200 rounded-md">
105
+ <p className="text-sm text-red-600">{error}</p>
106
+ </div>
107
+ )}
108
+
109
+ {jobId && (
110
+ <div className="space-y-4">
111
+ <JobProgress
112
+ jobId={jobId}
113
+ onComplete={handleJobComplete}
114
+ className="p-4 bg-muted rounded-md"
115
+ />
116
+ </div>
117
+ )}
118
+
119
+ {audioUrl && (
120
+ <div className="p-4 bg-green-50 border border-green-200 rounded-md">
121
+ <h4 className="font-medium text-green-800 mb-3">Generated Audio</h4>
122
+ <audio controls className="w-full">
123
+ <source src={audioUrl} type="audio/mpeg" />
124
+ Your browser does not support the audio element.
125
+ </audio>
126
+ <div className="mt-3">
127
+ <Button
128
+ variant="outline"
129
+ onClick={() => {
130
+ const link = document.createElement('a')
131
+ link.href = audioUrl
132
+ link.download = 'generated-audio.mp3'
133
+ document.body.appendChild(link)
134
+ link.click()
135
+ document.body.removeChild(link)
136
+ }}
137
+ >
138
+ Download Audio
139
+ </Button>
140
+ </div>
141
+ </div>
142
+ )}
143
+ </div>
144
+ )
141
145
  }
@@ -1,158 +1,157 @@
1
- 'use client'
2
-
3
- import { useState } from 'react'
4
- import { useGenerateVideo, useJobStatus } from '@digilogiclabs/saas-factory-ai/react'
5
- import { Button } from '@/components/ui/button'
6
- import { Input } from '@/components/ui/input'
7
- import { Label } from '@/components/ui/label'
8
- import { Select, SelectContent, SelectItem, SelectTrigger, SelectValue } from '@/components/ui/select'
9
- import { Textarea } from '@/components/ui/textarea'
10
- import { JobProgress } from '@digilogiclabs/saas-factory-ai/react'
11
-
12
- export function VideoGenerator() {
13
- const [prompt, setPrompt] = useState('')
14
- const [style, setStyle] = useState('realistic')
15
- const [duration, setDuration] = useState(10)
16
- const [resolution, setResolution] = useState('720p')
17
- const [jobId, setJobId] = useState<string | null>(null)
18
- const [videoUrl, setVideoUrl] = useState<string | null>(null)
19
-
20
- const { generate, loading, error } = useGenerateVideo()
21
- const { status } = useJobStatus(jobId)
22
-
23
- const handleGenerate = async () => {
24
- if (!prompt.trim()) return
25
-
26
- try {
27
- const result = await generate(prompt, {
28
- style,
29
- durationSec: duration,
30
- resolution,
31
- format: 'mp4'
32
- })
33
- setJobId(result.jobId)
34
- setVideoUrl(null)
35
- } catch (err) {
36
- console.error('Video generation failed:', err)
37
- }
38
- }
39
-
40
- const handleJobComplete = (result: any) => {
41
- if (result.url) {
42
- setVideoUrl(result.url)
43
- }
44
- }
45
-
46
- return (
47
- <div className="space-y-6">
48
- <div className="grid grid-cols-1 gap-4">
49
- <div>
50
- <Label htmlFor="video-prompt">Video Description</Label>
51
- <Textarea
52
- id="video-prompt"
53
- value={prompt}
54
- onChange={(e) => setPrompt(e.target.value)}
55
- placeholder="Describe the video you want to generate in detail..."
56
- className="mt-1 min-h-[100px]"
57
- />
58
- </div>
59
-
60
- <div className="grid grid-cols-3 gap-4">
61
- <div>
62
- <Label htmlFor="video-style">Style</Label>
63
- <Select value={style} onValueChange={setStyle}>
64
- <SelectTrigger className="mt-1">
65
- <SelectValue />
66
- </SelectTrigger>
67
- <SelectContent>
68
- <SelectItem value="realistic">Realistic</SelectItem>
69
- <SelectItem value="animated">Animated</SelectItem>
70
- <SelectItem value="cinematic">Cinematic</SelectItem>
71
- <SelectItem value="artistic">Artistic</SelectItem>
72
- <SelectItem value="documentary">Documentary</SelectItem>
73
- </SelectContent>
74
- </Select>
75
- </div>
76
-
77
- <div>
78
- <Label htmlFor="video-duration">Duration (seconds)</Label>
79
- <Input
80
- id="video-duration"
81
- type="number"
82
- value={duration}
83
- onChange={(e) => setDuration(parseInt(e.target.value) || 10)}
84
- min={5}
85
- max={60}
86
- className="mt-1"
87
- />
88
- </div>
89
-
90
- <div>
91
- <Label htmlFor="video-resolution">Resolution</Label>
92
- <Select value={resolution} onValueChange={setResolution}>
93
- <SelectTrigger className="mt-1">
94
- <SelectValue />
95
- </SelectTrigger>
96
- <SelectContent>
97
- <SelectItem value="480p">480p (SD)</SelectItem>
98
- <SelectItem value="720p">720p (HD)</SelectItem>
99
- <SelectItem value="1080p">1080p (Full HD)</SelectItem>
100
- </SelectContent>
101
- </Select>
102
- </div>
103
- </div>
104
- </div>
105
-
106
- <div className="flex justify-center">
107
- <Button
108
- onClick={handleGenerate}
109
- disabled={loading || !prompt.trim() || !!jobId}
110
- className="px-8"
111
- >
112
- {loading ? 'Starting Generation...' : 'Generate Video'}
113
- </Button>
114
- </div>
115
-
116
- {error && (
117
- <div className="p-4 bg-red-50 border border-red-200 rounded-md">
118
- <p className="text-sm text-red-600">{error.message}</p>
119
- </div>
120
- )}
121
-
122
- {jobId && (
123
- <div className="space-y-4">
124
- <JobProgress
125
- jobId={jobId}
126
- onComplete={handleJobComplete}
127
- className="p-4 bg-gray-50 rounded-md"
128
- />
129
- </div>
130
- )}
131
-
132
- {videoUrl && (
133
- <div className="p-4 bg-green-50 border border-green-200 rounded-md">
134
- <h4 className="font-medium text-green-800 mb-3">Generated Video</h4>
135
- <video controls className="w-full rounded-md" style={{ maxHeight: '400px' }}>
136
- <source src={videoUrl} type="video/mp4" />
137
- Your browser does not support the video element.
138
- </video>
139
- <div className="mt-3">
140
- <Button
141
- variant="outline"
142
- onClick={() => {
143
- const link = document.createElement('a')
144
- link.href = videoUrl
145
- link.download = 'generated-video.mp4'
146
- document.body.appendChild(link)
147
- link.click()
148
- document.body.removeChild(link)
149
- }}
150
- >
151
- Download Video
152
- </Button>
153
- </div>
154
- </div>
155
- )}
156
- </div>
157
- )
1
+ 'use client'
2
+
3
+ import { useState } from 'react'
4
+ import { Button } from '@/components/ui/button'
5
+ import { Input } from '@/components/ui/input'
6
+ import { Label } from '@/components/ui/label'
7
+ // Using native select for simplicity
8
+ import { Textarea } from '@/components/ui/textarea'
9
+
10
+ // TODO: Replace with your AI SDK hooks
11
+ function useGenerateVideo() {
12
+ return { generate: async (_prompt: string, _opts?: Record<string, unknown>) => ({ jobId: '' }), loading: false, error: null as string | null }
13
+ }
14
+ function useJobStatus(_id: string | null) {
15
+ return { status: null as string | null }
16
+ }
17
+ function JobProgress({ jobId, onComplete, className }: { jobId?: string; onComplete?: (result: unknown) => void; className?: string; status?: string | null }) {
18
+ return status ? <div className="text-sm text-muted-foreground">Status: {status}</div> : null
19
+ }
20
+
21
+ export function VideoGenerator() {
22
+ const [prompt, setPrompt] = useState('')
23
+ const [style, setStyle] = useState('realistic')
24
+ const [duration, setDuration] = useState(10)
25
+ const [resolution, setResolution] = useState('720p')
26
+ const [jobId, setJobId] = useState<string | null>(null)
27
+ const [videoUrl, setVideoUrl] = useState<string | null>(null)
28
+
29
+ const { generate, loading, error } = useGenerateVideo()
30
+ const { status } = useJobStatus(jobId)
31
+
32
+ const handleGenerate = async () => {
33
+ if (!prompt.trim()) return
34
+
35
+ try {
36
+ const result = await generate(prompt, {
37
+ style,
38
+ durationSec: duration,
39
+ resolution,
40
+ format: 'mp4'
41
+ })
42
+ setJobId(result.jobId)
43
+ setVideoUrl(null)
44
+ } catch (err) {
45
+ console.error('Video generation failed:', err)
46
+ }
47
+ }
48
+
49
+ const handleJobComplete = (result: any) => {
50
+ if (result.url) {
51
+ setVideoUrl(result.url)
52
+ }
53
+ }
54
+
55
+ return (
56
+ <div className="space-y-6">
57
+ <div className="grid grid-cols-1 gap-4">
58
+ <div>
59
+ <Label htmlFor="video-prompt">Video Description</Label>
60
+ <Textarea
61
+ id="video-prompt"
62
+ value={prompt}
63
+ onChange={(e) => setPrompt(e.target.value)}
64
+ placeholder="Describe the video you want to generate in detail..."
65
+ className="mt-1 min-h-[100px]"
66
+ />
67
+ </div>
68
+
69
+ <div className="grid grid-cols-3 gap-4">
70
+ <div>
71
+ <Label htmlFor="video-style">Style</Label>
72
+ <select value={style} onChange={(e) => setStyle(e.target.value)} className="mt-1 flex h-10 w-full rounded-md border border-input bg-background px-3 py-2 text-sm ring-offset-background focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring">
73
+ <option value="realistic">Realistic</option>
74
+ <option value="animated">Animated</option>
75
+ <option value="cinematic">Cinematic</option>
76
+ <option value="artistic">Artistic</option>
77
+ <option value="documentary">Documentary</option>
78
+ </select>
79
+ </div>
80
+
81
+ <div>
82
+ <Label htmlFor="video-duration">Duration (seconds)</Label>
83
+ <Input
84
+ id="video-duration"
85
+ type="number"
86
+ value={duration}
87
+ onChange={(e) => setDuration(parseInt(e.target.value) || 10)}
88
+ min={5}
89
+ max={60}
90
+ className="mt-1"
91
+ />
92
+ </div>
93
+
94
+ <div>
95
+ <Label htmlFor="video-resolution">Resolution</Label>
96
+ <select value={resolution} onChange={(e) => setResolution(e.target.value)} className="mt-1 flex h-10 w-full rounded-md border border-input bg-background px-3 py-2 text-sm">
97
+ <option value="480p">480p (SD)</option>
98
+ <option value="720p">720p (HD)</option>
99
+ <option value="1080p">1080p (Full HD)</option>
100
+ </select>
101
+ </div>
102
+ </div>
103
+ </div>
104
+
105
+ <div className="flex justify-center">
106
+ <Button
107
+ onClick={handleGenerate}
108
+ disabled={loading || !prompt.trim() || !!jobId}
109
+ className="px-8"
110
+ >
111
+ {loading ? 'Starting Generation...' : 'Generate Video'}
112
+ </Button>
113
+ </div>
114
+
115
+ {error && (
116
+ <div className="p-4 bg-red-50 border border-red-200 rounded-md">
117
+ <p className="text-sm text-red-600">{error}</p>
118
+ </div>
119
+ )}
120
+
121
+ {jobId && (
122
+ <div className="space-y-4">
123
+ <JobProgress
124
+ jobId={jobId}
125
+ onComplete={handleJobComplete}
126
+ className="p-4 bg-muted rounded-md"
127
+ />
128
+ </div>
129
+ )}
130
+
131
+ {videoUrl && (
132
+ <div className="p-4 bg-green-50 border border-green-200 rounded-md">
133
+ <h4 className="font-medium text-green-800 mb-3">Generated Video</h4>
134
+ <video controls className="w-full rounded-md" style={{ maxHeight: '400px' }}>
135
+ <source src={videoUrl} type="video/mp4" />
136
+ Your browser does not support the video element.
137
+ </video>
138
+ <div className="mt-3">
139
+ <Button
140
+ variant="outline"
141
+ onClick={() => {
142
+ const link = document.createElement('a')
143
+ link.href = videoUrl
144
+ link.download = 'generated-video.mp4'
145
+ document.body.appendChild(link)
146
+ link.click()
147
+ document.body.removeChild(link)
148
+ }}
149
+ >
150
+ Download Video
151
+ </Button>
152
+ </div>
153
+ </div>
154
+ )}
155
+ </div>
156
+ )
158
157
  }