@digilogiclabs/create-saas-app 2.9.0 → 2.10.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 (343) hide show
  1. package/dist/.tsbuildinfo +1 -1
  2. package/dist/generators/template-generator.d.ts.map +1 -1
  3. package/dist/generators/template-generator.js +6 -3
  4. package/dist/generators/template-generator.js.map +1 -1
  5. package/dist/templates/shared/auth/supabase/web/src/middleware.ts +63 -0
  6. package/dist/templates/shared/database/supabase/web/src/lib/supabase/server.ts +3 -1
  7. package/dist/templates/shared/design/web/src/config/design.config.ts +14 -14
  8. package/dist/templates/shared/landing/web/src/components/LandingPage.tsx +0 -3
  9. package/dist/templates/shared/security/web/src/lib/api-security.ts +2 -2
  10. package/dist/templates/web/ai-platform/template/next.config.js +14 -14
  11. package/dist/templates/web/ai-platform/template/package.json +11 -22
  12. package/dist/templates/web/ai-platform/template/postcss.config.mjs +8 -0
  13. package/dist/templates/web/ai-platform/template/src/app/chat/page.tsx +234 -235
  14. package/dist/templates/web/ai-platform/template/src/app/dashboard/page.tsx +142 -142
  15. package/dist/templates/web/ai-platform/template/src/app/error.tsx +13 -13
  16. package/dist/templates/web/ai-platform/template/src/app/globals.css +97 -34
  17. package/dist/templates/web/ai-platform/template/src/app/layout.tsx +3 -0
  18. package/dist/templates/web/ai-platform/template/src/app/loading.tsx +22 -22
  19. package/dist/templates/web/ai-platform/template/src/app/page.tsx +249 -155
  20. package/dist/templates/web/ai-platform/template/src/components/providers/app-providers.tsx +5 -2
  21. package/dist/templates/web/ai-platform/template/src/lib/auth-server.ts +32 -33
  22. package/dist/templates/web/base/template/next.config.js +14 -15
  23. package/dist/templates/web/base/template/package.json +16 -31
  24. package/dist/templates/web/base/template/postcss.config.mjs +8 -0
  25. package/dist/templates/web/base/template/src/app/error.tsx +97 -97
  26. package/dist/templates/web/base/template/src/app/globals.css +87 -148
  27. package/dist/templates/web/base/template/src/app/layout.tsx +4 -1
  28. package/dist/templates/web/base/template/src/app/loading.tsx +52 -52
  29. package/dist/templates/web/base/template/src/components/providers/app-providers.tsx +5 -2
  30. package/dist/templates/web/base/template/tsconfig.json +27 -33
  31. package/dist/templates/web/iot-dashboard/template/next.config.js +14 -14
  32. package/dist/templates/web/iot-dashboard/template/package.json +12 -16
  33. package/dist/templates/web/iot-dashboard/template/postcss.config.mjs +8 -0
  34. package/dist/templates/web/iot-dashboard/template/src/app/dashboard/page.tsx +224 -224
  35. package/dist/templates/web/iot-dashboard/template/src/app/error.tsx +8 -8
  36. package/dist/templates/web/iot-dashboard/template/src/app/globals.css +97 -20
  37. package/dist/templates/web/iot-dashboard/template/src/app/layout.tsx +3 -0
  38. package/dist/templates/web/iot-dashboard/template/src/app/loading.tsx +5 -5
  39. package/dist/templates/web/iot-dashboard/template/src/app/page.tsx +266 -189
  40. package/dist/templates/web/iot-dashboard/template/src/components/providers/app-providers.tsx +5 -2
  41. package/dist/templates/web/iot-dashboard/template/src/lib/auth-server.ts +32 -33
  42. package/dist/templates/web/marketplace/template/next.config.js +14 -14
  43. package/dist/templates/web/marketplace/template/package.json +11 -18
  44. package/dist/templates/web/marketplace/template/postcss.config.mjs +8 -0
  45. package/dist/templates/web/marketplace/template/src/app/cart/page.tsx +147 -147
  46. package/dist/templates/web/marketplace/template/src/app/dashboard/page.tsx +149 -149
  47. package/dist/templates/web/marketplace/template/src/app/error.tsx +7 -7
  48. package/dist/templates/web/marketplace/template/src/app/globals.css +97 -20
  49. package/dist/templates/web/marketplace/template/src/app/layout.tsx +3 -0
  50. package/dist/templates/web/marketplace/template/src/app/loading.tsx +5 -5
  51. package/dist/templates/web/marketplace/template/src/app/page.tsx +370 -169
  52. package/dist/templates/web/marketplace/template/src/app/products/page.tsx +129 -129
  53. package/dist/templates/web/marketplace/template/src/components/providers/app-providers.tsx +5 -2
  54. package/dist/templates/web/marketplace/template/src/lib/auth-server.ts +32 -33
  55. package/dist/templates/web/micro-saas/template/next.config.js +14 -14
  56. package/dist/templates/web/micro-saas/template/package.json +9 -8
  57. package/dist/templates/web/micro-saas/template/postcss.config.mjs +8 -0
  58. package/dist/templates/web/micro-saas/template/src/app/dashboard/page.tsx +145 -117
  59. package/dist/templates/web/micro-saas/template/src/app/error.tsx +7 -7
  60. package/dist/templates/web/micro-saas/template/src/app/globals.css +97 -20
  61. package/dist/templates/web/micro-saas/template/src/app/layout.tsx +3 -0
  62. package/dist/templates/web/micro-saas/template/src/app/loading.tsx +43 -27
  63. package/dist/templates/web/micro-saas/template/src/app/login/page.tsx +101 -87
  64. package/dist/templates/web/micro-saas/template/src/app/page.tsx +227 -137
  65. package/dist/templates/web/micro-saas/template/src/app/signup/page.tsx +122 -108
  66. package/dist/templates/web/micro-saas/template/src/components/providers/app-providers.tsx +5 -2
  67. package/dist/templates/web/micro-saas/template/src/lib/auth-server.ts +32 -33
  68. package/dist/templates/web/ui-auth/template/next.config.js +14 -12
  69. package/dist/templates/web/ui-auth/template/package.json +16 -26
  70. package/dist/templates/web/ui-auth/template/postcss.config.mjs +8 -0
  71. package/dist/templates/web/ui-auth/template/src/app/error.tsx +67 -67
  72. package/dist/templates/web/ui-auth/template/src/app/globals.css +85 -84
  73. package/dist/templates/web/ui-auth/template/src/app/layout.tsx +4 -1
  74. package/dist/templates/web/ui-auth/template/src/app/loading.tsx +20 -38
  75. package/dist/templates/web/ui-auth/template/src/components/providers/app-providers.tsx +5 -2
  76. package/dist/templates/web/ui-auth/template/tsconfig.json +27 -33
  77. package/dist/templates/web/ui-auth-ai/template/next.config.js +15 -13
  78. package/dist/templates/web/ui-auth-ai/template/package.json +25 -21
  79. package/dist/templates/web/ui-auth-ai/template/postcss.config.mjs +8 -0
  80. package/dist/templates/web/ui-auth-ai/template/src/app/error.tsx +7 -7
  81. package/dist/templates/web/ui-auth-ai/template/src/app/globals.css +87 -25
  82. package/dist/templates/web/ui-auth-ai/template/src/app/layout.tsx +3 -0
  83. package/dist/templates/web/ui-auth-ai/template/src/app/loading.tsx +4 -4
  84. package/dist/templates/web/ui-auth-ai/template/tsconfig.json +27 -28
  85. package/dist/templates/web/ui-auth-payments/template/next.config.js +14 -12
  86. package/dist/templates/web/ui-auth-payments/template/package.json +16 -29
  87. package/dist/templates/web/ui-auth-payments/template/postcss.config.mjs +8 -0
  88. package/dist/templates/web/ui-auth-payments/template/src/app/error.tsx +67 -67
  89. package/dist/templates/web/ui-auth-payments/template/src/app/globals.css +89 -204
  90. package/dist/templates/web/ui-auth-payments/template/src/app/layout.tsx +4 -1
  91. package/dist/templates/web/ui-auth-payments/template/src/app/loading.tsx +20 -20
  92. package/dist/templates/web/ui-auth-payments/template/tsconfig.json +27 -33
  93. package/dist/templates/web/ui-auth-payments-ai/template/next.config.js +14 -12
  94. package/dist/templates/web/ui-auth-payments-ai/template/package.json +17 -33
  95. package/dist/templates/web/ui-auth-payments-ai/template/postcss.config.mjs +8 -0
  96. package/dist/templates/web/ui-auth-payments-ai/template/src/app/error.tsx +67 -67
  97. package/dist/templates/web/ui-auth-payments-ai/template/src/app/globals.css +85 -85
  98. package/dist/templates/web/ui-auth-payments-ai/template/src/app/layout.tsx +4 -1
  99. package/dist/templates/web/ui-auth-payments-ai/template/src/app/loading.tsx +20 -20
  100. package/dist/templates/web/ui-auth-payments-ai/template/src/components/providers/app-providers.tsx +5 -2
  101. package/dist/templates/web/ui-auth-payments-ai/template/tsconfig.json +27 -33
  102. package/dist/templates/web/ui-auth-payments-audio/template/next.config.js +14 -12
  103. package/dist/templates/web/ui-auth-payments-audio/template/package.json +17 -30
  104. package/dist/templates/web/ui-auth-payments-audio/template/postcss.config.mjs +8 -0
  105. package/dist/templates/web/ui-auth-payments-audio/template/src/app/error.tsx +67 -67
  106. package/dist/templates/web/ui-auth-payments-audio/template/src/app/globals.css +85 -85
  107. package/dist/templates/web/ui-auth-payments-audio/template/src/app/layout.tsx +4 -1
  108. package/dist/templates/web/ui-auth-payments-audio/template/src/app/loading.tsx +20 -20
  109. package/dist/templates/web/ui-auth-payments-audio/template/src/components/providers/app-providers.tsx +5 -2
  110. package/dist/templates/web/ui-auth-payments-audio/template/tsconfig.json +27 -33
  111. package/dist/templates/web/ui-auth-payments-video/template/next.config.js +14 -12
  112. package/dist/templates/web/ui-auth-payments-video/template/package.json +17 -30
  113. package/dist/templates/web/ui-auth-payments-video/template/postcss.config.mjs +8 -0
  114. package/dist/templates/web/ui-auth-payments-video/template/src/app/error.tsx +67 -67
  115. package/dist/templates/web/ui-auth-payments-video/template/src/app/globals.css +89 -221
  116. package/dist/templates/web/ui-auth-payments-video/template/src/app/layout.tsx +4 -1
  117. package/dist/templates/web/ui-auth-payments-video/template/src/app/loading.tsx +20 -20
  118. package/dist/templates/web/ui-auth-payments-video/template/src/components/providers/app-providers.tsx +5 -2
  119. package/dist/templates/web/ui-auth-payments-video/template/tsconfig.json +27 -33
  120. package/dist/templates/web/ui-only/template/next.config.js +14 -12
  121. package/dist/templates/web/ui-only/template/package.json +15 -25
  122. package/dist/templates/web/ui-only/template/postcss.config.mjs +8 -0
  123. package/dist/templates/web/ui-only/template/src/app/error.tsx +67 -67
  124. package/dist/templates/web/ui-only/template/src/app/globals.css +85 -31
  125. package/dist/templates/web/ui-only/template/src/app/layout.tsx +4 -1
  126. package/dist/templates/web/ui-only/template/src/app/loading.tsx +20 -20
  127. package/dist/templates/web/ui-only/template/src/components/providers/app-providers.tsx +20 -26
  128. package/dist/templates/web/ui-only/template/tsconfig.json +27 -33
  129. package/package.json +1 -1
  130. package/src/templates/shared/auth/supabase/web/src/middleware.ts +63 -0
  131. package/src/templates/shared/database/supabase/web/src/lib/supabase/server.ts +3 -1
  132. package/src/templates/shared/design/web/src/config/design.config.ts +14 -14
  133. package/src/templates/shared/landing/web/src/components/LandingPage.tsx +0 -3
  134. package/src/templates/shared/security/web/src/lib/api-security.ts +2 -2
  135. package/src/templates/web/ai-platform/template/next.config.js +14 -14
  136. package/src/templates/web/ai-platform/template/package.json +11 -22
  137. package/src/templates/web/ai-platform/template/postcss.config.mjs +8 -0
  138. package/src/templates/web/ai-platform/template/src/app/chat/page.tsx +234 -235
  139. package/src/templates/web/ai-platform/template/src/app/dashboard/page.tsx +142 -142
  140. package/src/templates/web/ai-platform/template/src/app/error.tsx +13 -13
  141. package/src/templates/web/ai-platform/template/src/app/globals.css +97 -34
  142. package/src/templates/web/ai-platform/template/src/app/layout.tsx +3 -0
  143. package/src/templates/web/ai-platform/template/src/app/loading.tsx +22 -22
  144. package/src/templates/web/ai-platform/template/src/app/page.tsx +249 -155
  145. package/src/templates/web/ai-platform/template/src/components/providers/app-providers.tsx +5 -2
  146. package/src/templates/web/ai-platform/template/src/lib/auth-server.ts +32 -33
  147. package/src/templates/web/base/template/next.config.js +14 -15
  148. package/src/templates/web/base/template/package.json +16 -31
  149. package/src/templates/web/base/template/postcss.config.mjs +8 -0
  150. package/src/templates/web/base/template/src/app/error.tsx +97 -97
  151. package/src/templates/web/base/template/src/app/globals.css +87 -148
  152. package/src/templates/web/base/template/src/app/layout.tsx +4 -1
  153. package/src/templates/web/base/template/src/app/loading.tsx +52 -52
  154. package/src/templates/web/base/template/src/components/providers/app-providers.tsx +5 -2
  155. package/src/templates/web/base/template/tsconfig.json +27 -33
  156. package/src/templates/web/iot-dashboard/template/next.config.js +14 -14
  157. package/src/templates/web/iot-dashboard/template/package.json +12 -16
  158. package/src/templates/web/iot-dashboard/template/postcss.config.mjs +8 -0
  159. package/src/templates/web/iot-dashboard/template/src/app/dashboard/page.tsx +224 -224
  160. package/src/templates/web/iot-dashboard/template/src/app/error.tsx +8 -8
  161. package/src/templates/web/iot-dashboard/template/src/app/globals.css +97 -20
  162. package/src/templates/web/iot-dashboard/template/src/app/layout.tsx +3 -0
  163. package/src/templates/web/iot-dashboard/template/src/app/loading.tsx +5 -5
  164. package/src/templates/web/iot-dashboard/template/src/app/page.tsx +266 -189
  165. package/src/templates/web/iot-dashboard/template/src/components/providers/app-providers.tsx +5 -2
  166. package/src/templates/web/iot-dashboard/template/src/lib/auth-server.ts +32 -33
  167. package/src/templates/web/marketplace/template/next.config.js +14 -14
  168. package/src/templates/web/marketplace/template/package.json +11 -18
  169. package/src/templates/web/marketplace/template/postcss.config.mjs +8 -0
  170. package/src/templates/web/marketplace/template/src/app/cart/page.tsx +147 -147
  171. package/src/templates/web/marketplace/template/src/app/dashboard/page.tsx +149 -149
  172. package/src/templates/web/marketplace/template/src/app/error.tsx +7 -7
  173. package/src/templates/web/marketplace/template/src/app/globals.css +97 -20
  174. package/src/templates/web/marketplace/template/src/app/layout.tsx +3 -0
  175. package/src/templates/web/marketplace/template/src/app/loading.tsx +5 -5
  176. package/src/templates/web/marketplace/template/src/app/page.tsx +370 -169
  177. package/src/templates/web/marketplace/template/src/app/products/page.tsx +129 -129
  178. package/src/templates/web/marketplace/template/src/components/providers/app-providers.tsx +5 -2
  179. package/src/templates/web/marketplace/template/src/lib/auth-server.ts +32 -33
  180. package/src/templates/web/micro-saas/template/next.config.js +14 -14
  181. package/src/templates/web/micro-saas/template/package.json +9 -8
  182. package/src/templates/web/micro-saas/template/postcss.config.mjs +8 -0
  183. package/src/templates/web/micro-saas/template/src/app/dashboard/page.tsx +145 -117
  184. package/src/templates/web/micro-saas/template/src/app/error.tsx +7 -7
  185. package/src/templates/web/micro-saas/template/src/app/globals.css +97 -20
  186. package/src/templates/web/micro-saas/template/src/app/layout.tsx +3 -0
  187. package/src/templates/web/micro-saas/template/src/app/loading.tsx +43 -27
  188. package/src/templates/web/micro-saas/template/src/app/login/page.tsx +101 -87
  189. package/src/templates/web/micro-saas/template/src/app/page.tsx +227 -137
  190. package/src/templates/web/micro-saas/template/src/app/signup/page.tsx +122 -108
  191. package/src/templates/web/micro-saas/template/src/components/providers/app-providers.tsx +5 -2
  192. package/src/templates/web/micro-saas/template/src/lib/auth-server.ts +32 -33
  193. package/src/templates/web/ui-auth/template/next.config.js +14 -12
  194. package/src/templates/web/ui-auth/template/package.json +16 -26
  195. package/src/templates/web/ui-auth/template/postcss.config.mjs +8 -0
  196. package/src/templates/web/ui-auth/template/src/app/error.tsx +67 -67
  197. package/src/templates/web/ui-auth/template/src/app/globals.css +85 -84
  198. package/src/templates/web/ui-auth/template/src/app/layout.tsx +4 -1
  199. package/src/templates/web/ui-auth/template/src/app/loading.tsx +20 -38
  200. package/src/templates/web/ui-auth/template/src/components/providers/app-providers.tsx +5 -2
  201. package/src/templates/web/ui-auth/template/tsconfig.json +27 -33
  202. package/src/templates/web/ui-auth-ai/template/next.config.js +15 -13
  203. package/src/templates/web/ui-auth-ai/template/package.json +25 -21
  204. package/src/templates/web/ui-auth-ai/template/postcss.config.mjs +8 -0
  205. package/src/templates/web/ui-auth-ai/template/src/app/error.tsx +7 -7
  206. package/src/templates/web/ui-auth-ai/template/src/app/globals.css +87 -25
  207. package/src/templates/web/ui-auth-ai/template/src/app/layout.tsx +3 -0
  208. package/src/templates/web/ui-auth-ai/template/src/app/loading.tsx +4 -4
  209. package/src/templates/web/ui-auth-ai/template/tsconfig.json +27 -28
  210. package/src/templates/web/ui-auth-payments/template/next.config.js +14 -12
  211. package/src/templates/web/ui-auth-payments/template/package.json +16 -29
  212. package/src/templates/web/ui-auth-payments/template/postcss.config.mjs +8 -0
  213. package/src/templates/web/ui-auth-payments/template/src/app/error.tsx +67 -67
  214. package/src/templates/web/ui-auth-payments/template/src/app/globals.css +89 -204
  215. package/src/templates/web/ui-auth-payments/template/src/app/layout.tsx +4 -1
  216. package/src/templates/web/ui-auth-payments/template/src/app/loading.tsx +20 -20
  217. package/src/templates/web/ui-auth-payments/template/tsconfig.json +27 -33
  218. package/src/templates/web/ui-auth-payments-ai/template/next.config.js +14 -12
  219. package/src/templates/web/ui-auth-payments-ai/template/package.json +17 -33
  220. package/src/templates/web/ui-auth-payments-ai/template/postcss.config.mjs +8 -0
  221. package/src/templates/web/ui-auth-payments-ai/template/src/app/error.tsx +67 -67
  222. package/src/templates/web/ui-auth-payments-ai/template/src/app/globals.css +85 -85
  223. package/src/templates/web/ui-auth-payments-ai/template/src/app/layout.tsx +4 -1
  224. package/src/templates/web/ui-auth-payments-ai/template/src/app/loading.tsx +20 -20
  225. package/src/templates/web/ui-auth-payments-ai/template/src/components/providers/app-providers.tsx +5 -2
  226. package/src/templates/web/ui-auth-payments-ai/template/tsconfig.json +27 -33
  227. package/src/templates/web/ui-auth-payments-audio/template/next.config.js +14 -12
  228. package/src/templates/web/ui-auth-payments-audio/template/package.json +17 -30
  229. package/src/templates/web/ui-auth-payments-audio/template/postcss.config.mjs +8 -0
  230. package/src/templates/web/ui-auth-payments-audio/template/src/app/error.tsx +67 -67
  231. package/src/templates/web/ui-auth-payments-audio/template/src/app/globals.css +85 -85
  232. package/src/templates/web/ui-auth-payments-audio/template/src/app/layout.tsx +4 -1
  233. package/src/templates/web/ui-auth-payments-audio/template/src/app/loading.tsx +20 -20
  234. package/src/templates/web/ui-auth-payments-audio/template/src/components/providers/app-providers.tsx +5 -2
  235. package/src/templates/web/ui-auth-payments-audio/template/tsconfig.json +27 -33
  236. package/src/templates/web/ui-auth-payments-video/template/next.config.js +14 -12
  237. package/src/templates/web/ui-auth-payments-video/template/package.json +17 -30
  238. package/src/templates/web/ui-auth-payments-video/template/postcss.config.mjs +8 -0
  239. package/src/templates/web/ui-auth-payments-video/template/src/app/error.tsx +67 -67
  240. package/src/templates/web/ui-auth-payments-video/template/src/app/globals.css +89 -221
  241. package/src/templates/web/ui-auth-payments-video/template/src/app/layout.tsx +4 -1
  242. package/src/templates/web/ui-auth-payments-video/template/src/app/loading.tsx +20 -20
  243. package/src/templates/web/ui-auth-payments-video/template/src/components/providers/app-providers.tsx +5 -2
  244. package/src/templates/web/ui-auth-payments-video/template/tsconfig.json +27 -33
  245. package/src/templates/web/ui-only/template/next.config.js +14 -12
  246. package/src/templates/web/ui-only/template/package.json +15 -25
  247. package/src/templates/web/ui-only/template/postcss.config.mjs +8 -0
  248. package/src/templates/web/ui-only/template/src/app/error.tsx +67 -67
  249. package/src/templates/web/ui-only/template/src/app/globals.css +85 -31
  250. package/src/templates/web/ui-only/template/src/app/layout.tsx +4 -1
  251. package/src/templates/web/ui-only/template/src/app/loading.tsx +20 -20
  252. package/src/templates/web/ui-only/template/src/components/providers/app-providers.tsx +20 -26
  253. package/src/templates/web/ui-only/template/tsconfig.json +27 -33
  254. package/dist/templates/web/ai-platform/template/middleware.ts +0 -55
  255. package/dist/templates/web/ai-platform/template/src/lib/supabase/client.ts +0 -8
  256. package/dist/templates/web/ai-platform/template/src/lib/supabase/server.ts +0 -27
  257. package/dist/templates/web/base/template/postcss.config.js +0 -7
  258. package/dist/templates/web/base/template/tailwind.config.js +0 -77
  259. package/dist/templates/web/iot-dashboard/template/middleware.ts +0 -56
  260. package/dist/templates/web/iot-dashboard/template/src/lib/supabase/client.ts +0 -8
  261. package/dist/templates/web/iot-dashboard/template/src/lib/supabase/server.ts +0 -27
  262. package/dist/templates/web/marketplace/template/middleware.ts +0 -56
  263. package/dist/templates/web/marketplace/template/src/lib/supabase/client.ts +0 -8
  264. package/dist/templates/web/marketplace/template/src/lib/supabase/server.ts +0 -27
  265. package/dist/templates/web/micro-saas/template/middleware.ts +0 -53
  266. package/dist/templates/web/micro-saas/template/src/lib/supabase/client.ts +0 -8
  267. package/dist/templates/web/micro-saas/template/src/lib/supabase/server.ts +0 -29
  268. package/dist/templates/web/ui-auth/template/.claude +0 -21
  269. package/dist/templates/web/ui-auth/template/context.md +0 -105
  270. package/dist/templates/web/ui-auth/template/postcss.config.js +0 -7
  271. package/dist/templates/web/ui-auth/template/tailwind.config.js +0 -77
  272. package/dist/templates/web/ui-auth-ai/template/postcss.config.js +0 -6
  273. package/dist/templates/web/ui-auth-ai/template/tailwind.config.js +0 -22
  274. package/dist/templates/web/ui-auth-payments/template/middleware.ts +0 -68
  275. package/dist/templates/web/ui-auth-payments/template/package-lock.json +0 -12240
  276. package/dist/templates/web/ui-auth-payments/template/postcss.config.js +0 -7
  277. package/dist/templates/web/ui-auth-payments/template/tailwind.config.js +0 -77
  278. package/dist/templates/web/ui-auth-payments/template/tsconfig.tsbuildinfo +0 -1
  279. package/dist/templates/web/ui-auth-payments-ai/template/.claude +0 -21
  280. package/dist/templates/web/ui-auth-payments-ai/template/context.md +0 -169
  281. package/dist/templates/web/ui-auth-payments-ai/template/middleware.ts +0 -68
  282. package/dist/templates/web/ui-auth-payments-ai/template/package-lock.json +0 -12241
  283. package/dist/templates/web/ui-auth-payments-ai/template/postcss.config.js +0 -7
  284. package/dist/templates/web/ui-auth-payments-ai/template/tailwind.config.js +0 -77
  285. package/dist/templates/web/ui-auth-payments-ai/template/tsconfig.tsbuildinfo +0 -1
  286. package/dist/templates/web/ui-auth-payments-audio/template/middleware.ts +0 -68
  287. package/dist/templates/web/ui-auth-payments-audio/template/package-lock.json +0 -12241
  288. package/dist/templates/web/ui-auth-payments-audio/template/postcss.config.js +0 -7
  289. package/dist/templates/web/ui-auth-payments-audio/template/tailwind.config.js +0 -77
  290. package/dist/templates/web/ui-auth-payments-audio/template/tsconfig.tsbuildinfo +0 -1
  291. package/dist/templates/web/ui-auth-payments-video/template/postcss.config.js +0 -7
  292. package/dist/templates/web/ui-auth-payments-video/template/tailwind.config.js +0 -77
  293. package/dist/templates/web/ui-only/template/postcss.config.js +0 -7
  294. package/dist/templates/web/ui-only/template/tailwind.config.js +0 -77
  295. package/src/templates/web/ai-platform/template/middleware.ts +0 -55
  296. package/src/templates/web/ai-platform/template/src/lib/supabase/client.ts +0 -8
  297. package/src/templates/web/ai-platform/template/src/lib/supabase/server.ts +0 -27
  298. package/src/templates/web/base/template/postcss.config.js +0 -7
  299. package/src/templates/web/base/template/tailwind.config.js +0 -77
  300. package/src/templates/web/iot-dashboard/template/middleware.ts +0 -56
  301. package/src/templates/web/iot-dashboard/template/src/lib/supabase/client.ts +0 -8
  302. package/src/templates/web/iot-dashboard/template/src/lib/supabase/server.ts +0 -27
  303. package/src/templates/web/marketplace/template/middleware.ts +0 -56
  304. package/src/templates/web/marketplace/template/src/lib/supabase/client.ts +0 -8
  305. package/src/templates/web/marketplace/template/src/lib/supabase/server.ts +0 -27
  306. package/src/templates/web/micro-saas/template/middleware.ts +0 -53
  307. package/src/templates/web/micro-saas/template/src/lib/supabase/client.ts +0 -8
  308. package/src/templates/web/micro-saas/template/src/lib/supabase/server.ts +0 -29
  309. package/src/templates/web/ui-auth/template/.claude +0 -21
  310. package/src/templates/web/ui-auth/template/context.md +0 -105
  311. package/src/templates/web/ui-auth/template/postcss.config.js +0 -7
  312. package/src/templates/web/ui-auth/template/tailwind.config.js +0 -77
  313. package/src/templates/web/ui-auth-ai/template/postcss.config.js +0 -6
  314. package/src/templates/web/ui-auth-ai/template/tailwind.config.js +0 -22
  315. package/src/templates/web/ui-auth-payments/template/middleware.ts +0 -68
  316. package/src/templates/web/ui-auth-payments/template/package-lock.json +0 -12240
  317. package/src/templates/web/ui-auth-payments/template/postcss.config.js +0 -7
  318. package/src/templates/web/ui-auth-payments/template/tailwind.config.js +0 -77
  319. package/src/templates/web/ui-auth-payments/template/tsconfig.tsbuildinfo +0 -1
  320. package/src/templates/web/ui-auth-payments-ai/template/.claude +0 -21
  321. package/src/templates/web/ui-auth-payments-ai/template/context.md +0 -169
  322. package/src/templates/web/ui-auth-payments-ai/template/middleware.ts +0 -68
  323. package/src/templates/web/ui-auth-payments-ai/template/package-lock.json +0 -12241
  324. package/src/templates/web/ui-auth-payments-ai/template/postcss.config.js +0 -7
  325. package/src/templates/web/ui-auth-payments-ai/template/tailwind.config.js +0 -77
  326. package/src/templates/web/ui-auth-payments-ai/template/tsconfig.tsbuildinfo +0 -1
  327. package/src/templates/web/ui-auth-payments-audio/template/middleware.ts +0 -68
  328. package/src/templates/web/ui-auth-payments-audio/template/package-lock.json +0 -12241
  329. package/src/templates/web/ui-auth-payments-audio/template/postcss.config.js +0 -7
  330. package/src/templates/web/ui-auth-payments-audio/template/tailwind.config.js +0 -77
  331. package/src/templates/web/ui-auth-payments-audio/template/tsconfig.tsbuildinfo +0 -1
  332. package/src/templates/web/ui-auth-payments-video/template/postcss.config.js +0 -7
  333. package/src/templates/web/ui-auth-payments-video/template/tailwind.config.js +0 -77
  334. package/src/templates/web/ui-only/template/postcss.config.js +0 -7
  335. package/src/templates/web/ui-only/template/tailwind.config.js +0 -77
  336. /package/dist/templates/shared/admin/web/{components → src/components}/admin-nav.tsx +0 -0
  337. /package/dist/templates/shared/auth/keycloak/web/{auth.config.ts → src/auth.config.ts} +0 -0
  338. /package/dist/templates/shared/auth/keycloak/web/{auth.ts → src/auth.ts} +0 -0
  339. /package/dist/templates/shared/middleware/web/{middleware.ts → src/middleware.ts} +0 -0
  340. /package/src/templates/shared/admin/web/{components → src/components}/admin-nav.tsx +0 -0
  341. /package/src/templates/shared/auth/keycloak/web/{auth.config.ts → src/auth.config.ts} +0 -0
  342. /package/src/templates/shared/auth/keycloak/web/{auth.ts → src/auth.ts} +0 -0
  343. /package/src/templates/shared/middleware/web/{middleware.ts → src/middleware.ts} +0 -0
@@ -1,189 +1,266 @@
1
- 'use client'
2
-
3
- import { Button, Card, PulseIndicator } from '@digilogiclabs/saas-factory-ui'
4
- import { useAuth } from '@digilogiclabs/app-sdk'
5
- import { Cpu, Activity, Signal, Bell, Settings, ArrowRight, User, LogOut, Wifi, ThermometerSun, Gauge, Shield } from 'lucide-react'
6
- import Link from 'next/link'
7
-
8
- const FEATURES = [
9
- {
10
- icon: Cpu,
11
- title: 'Device Management',
12
- description: 'Monitor and control all your IoT devices from one dashboard',
13
- },
14
- {
15
- icon: Activity,
16
- title: 'Real-time Telemetry',
17
- description: 'Live data streams with historical analysis and trends',
18
- },
19
- {
20
- icon: Bell,
21
- title: 'Smart Alerts',
22
- description: 'Configurable alerts and notifications for critical events',
23
- },
24
- {
25
- icon: Shield,
26
- title: 'Secure & Scalable',
27
- description: 'Enterprise-grade security for your connected devices',
28
- },
29
- ]
30
-
31
- const DEVICE_TYPES = [
32
- { name: 'Temperature Sensors', count: 24, icon: ThermometerSun, status: 'online' },
33
- { name: 'Pressure Gauges', count: 12, icon: Gauge, status: 'online' },
34
- { name: 'Network Gateways', count: 8, icon: Wifi, status: 'online' },
35
- { name: 'Motion Sensors', count: 18, icon: Signal, status: 'partial' },
36
- ]
37
-
38
- export default function Home() {
39
- const { user, signOut, loading } = useAuth()
40
-
41
- const projectName = "{{titleCaseName}}"
42
-
43
- const handleSignOut = async () => {
44
- try {
45
- await signOut()
46
- } catch (err) {
47
- console.error('Sign out error:', err)
48
- }
49
- }
50
-
51
- return (
52
- <main className="min-h-screen bg-slate-50 dark:bg-slate-900">
53
- {/* Header */}
54
- <header className="bg-white dark:bg-slate-800 border-b border-slate-200 dark:border-slate-700 sticky top-0 z-50">
55
- <div className="max-w-7xl mx-auto px-4 py-4">
56
- <div className="flex items-center justify-between">
57
- <Link href="/" className="flex items-center gap-2">
58
- <div className="w-8 h-8 bg-emerald-600 rounded-lg flex items-center justify-center">
59
- <Cpu className="w-5 h-5 text-white" />
60
- </div>
61
- <span className="text-2xl font-bold text-slate-900 dark:text-white">{projectName}</span>
62
- </Link>
63
-
64
- <nav className="hidden md:flex items-center gap-6">
65
- <Link href="/devices" className="text-slate-600 dark:text-slate-300 hover:text-slate-900 dark:hover:text-white transition">
66
- Devices
67
- </Link>
68
- <Link href="/analytics" className="text-slate-600 dark:text-slate-300 hover:text-slate-900 dark:hover:text-white transition">
69
- Analytics
70
- </Link>
71
- <Link href="/alerts" className="text-slate-600 dark:text-slate-300 hover:text-slate-900 dark:hover:text-white transition">
72
- Alerts
73
- </Link>
74
- </nav>
75
-
76
- <div className="flex items-center gap-4">
77
- {loading ? (
78
- <div className="text-sm text-slate-600">Loading...</div>
79
- ) : user ? (
80
- <div className="flex items-center gap-2">
81
- <Link href="/dashboard">
82
- <Button variant="outline" size="sm">
83
- <User className="w-4 h-4 mr-2" />
84
- Dashboard
85
- </Button>
86
- </Link>
87
- <Button variant="ghost" size="sm" onClick={handleSignOut}>
88
- <LogOut className="w-4 h-4" />
89
- </Button>
90
- </div>
91
- ) : (
92
- <div className="flex gap-2">
93
- <Link href="/login">
94
- <Button variant="outline" size="sm">Sign In</Button>
95
- </Link>
96
- <Link href="/signup">
97
- <Button size="sm" className="bg-emerald-600 hover:bg-emerald-700">Get Started</Button>
98
- </Link>
99
- </div>
100
- )}
101
- </div>
102
- </div>
103
- </div>
104
- </header>
105
-
106
- <div className="max-w-7xl mx-auto px-4 py-16">
107
- {/* Hero */}
108
- <div className="text-center mb-16">
109
- <div className="inline-flex items-center px-4 py-2 rounded-full bg-emerald-100 dark:bg-emerald-900/30 text-emerald-700 dark:text-emerald-400 text-sm mb-6">
110
- <Signal className="w-4 h-4 mr-2" />
111
- IoT Management Platform
112
- </div>
113
- <h1 className="text-5xl font-bold text-slate-900 dark:text-white mb-6">
114
- Monitor Your <span className="text-emerald-600">Connected Devices</span>
115
- </h1>
116
- <p className="text-xl text-slate-600 dark:text-slate-300 max-w-2xl mx-auto mb-8">
117
- Real-time monitoring, analytics, and control for your IoT infrastructure.
118
- Built for scale, designed for simplicity.
119
- </p>
120
- <div className="flex gap-4 justify-center">
121
- <Link href="/dashboard">
122
- <Button size="lg" className="bg-emerald-600 hover:bg-emerald-700">
123
- <Activity className="w-5 h-5 mr-2" />
124
- View Dashboard
125
- </Button>
126
- </Link>
127
- <Link href="/devices">
128
- <Button size="lg" variant="outline">
129
- Manage Devices
130
- </Button>
131
- </Link>
132
- </div>
133
- </div>
134
-
135
- {/* Device Overview */}
136
- <div className="grid md:grid-cols-2 lg:grid-cols-4 gap-4 mb-16">
137
- {DEVICE_TYPES.map((device) => (
138
- <Card key={device.name} className="p-6">
139
- <div className="flex items-center justify-between mb-3">
140
- <div className="w-10 h-10 bg-emerald-100 dark:bg-emerald-900/30 rounded-lg flex items-center justify-center">
141
- <device.icon className="w-5 h-5 text-emerald-600" />
142
- </div>
143
- <PulseIndicator
144
- status={device.status === 'online' ? 'success' : 'loading'}
145
- label={device.status === 'online' ? 'All Online' : 'Partial'}
146
- size="sm"
147
- />
148
- </div>
149
- <h3 className="font-semibold text-slate-900 dark:text-white">{device.name}</h3>
150
- <p className="text-2xl font-bold text-emerald-600">{device.count}</p>
151
- </Card>
152
- ))}
153
- </div>
154
-
155
- {/* Features */}
156
- <div className="mb-16">
157
- <h2 className="text-3xl font-bold text-slate-900 dark:text-white text-center mb-12">
158
- Everything You Need
159
- </h2>
160
- <div className="grid md:grid-cols-2 lg:grid-cols-4 gap-6">
161
- {FEATURES.map((feature) => (
162
- <Card key={feature.title} className="p-6 text-center">
163
- <div className="w-12 h-12 bg-emerald-100 dark:bg-emerald-900/30 rounded-lg flex items-center justify-center mx-auto mb-4">
164
- <feature.icon className="w-6 h-6 text-emerald-600" />
165
- </div>
166
- <h3 className="text-lg font-semibold text-slate-900 dark:text-white mb-2">{feature.title}</h3>
167
- <p className="text-slate-600 dark:text-slate-400 text-sm">{feature.description}</p>
168
- </Card>
169
- ))}
170
- </div>
171
- </div>
172
-
173
- {/* CTA */}
174
- <Card className="p-12 bg-gradient-to-r from-emerald-600 to-teal-600 text-white text-center">
175
- <h2 className="text-3xl font-bold mb-4">Ready to Connect?</h2>
176
- <p className="text-white/80 mb-8 max-w-md mx-auto">
177
- Start monitoring your IoT devices in minutes. Free tier available for up to 10 devices.
178
- </p>
179
- <Link href="/signup">
180
- <Button size="lg" variant="secondary">
181
- Get Started Free
182
- <ArrowRight className="w-5 h-5 ml-2" />
183
- </Button>
184
- </Link>
185
- </Card>
186
- </div>
187
- </main>
188
- )
189
- }
1
+ 'use client'
2
+
3
+ import { Button, Card, CardContent } from '@digilogiclabs/saas-factory-ui'
4
+ import { Cpu, Activity, Signal, Bell, Shield, ArrowRight, Wifi, ThermometerSun, Gauge, Sun, Moon, Radio } from 'lucide-react'
5
+ import { useTheme } from 'next-themes'
6
+ import Link from 'next/link'
7
+ import { useEffect, useState } from 'react'
8
+
9
+ const DEVICE_TYPES = [
10
+ {
11
+ name: 'Temperature Sensors',
12
+ count: 24,
13
+ icon: ThermometerSun,
14
+ status: 'online' as const,
15
+ color: 'text-emerald-500',
16
+ bg: 'bg-emerald-500/10',
17
+ },
18
+ {
19
+ name: 'Pressure Gauges',
20
+ count: 12,
21
+ icon: Gauge,
22
+ status: 'online' as const,
23
+ color: 'text-cyan-500',
24
+ bg: 'bg-cyan-500/10',
25
+ },
26
+ {
27
+ name: 'Network Gateways',
28
+ count: 8,
29
+ icon: Wifi,
30
+ status: 'online' as const,
31
+ color: 'text-violet-500',
32
+ bg: 'bg-violet-500/10',
33
+ },
34
+ {
35
+ name: 'Motion Sensors',
36
+ count: 18,
37
+ icon: Radio,
38
+ status: 'partial' as const,
39
+ color: 'text-amber-500',
40
+ bg: 'bg-amber-500/10',
41
+ },
42
+ ]
43
+
44
+ const FEATURES = [
45
+ {
46
+ icon: Cpu,
47
+ title: 'Device Management',
48
+ description: 'Register, provision, and manage your entire device fleet from a single pane of glass.',
49
+ color: 'text-emerald-500 group-hover:text-emerald-400',
50
+ bg: 'bg-emerald-500/10 group-hover:bg-emerald-500/20',
51
+ border: 'group-hover:border-emerald-500/30',
52
+ },
53
+ {
54
+ icon: Activity,
55
+ title: 'Real-time Telemetry',
56
+ description: 'Live data streams with historical analysis, trend detection, and customizable dashboards.',
57
+ color: 'text-cyan-500 group-hover:text-cyan-400',
58
+ bg: 'bg-cyan-500/10 group-hover:bg-cyan-500/20',
59
+ border: 'group-hover:border-cyan-500/30',
60
+ },
61
+ {
62
+ icon: Bell,
63
+ title: 'Smart Alerts',
64
+ description: 'Configurable thresholds and anomaly detection with multi-channel notifications.',
65
+ color: 'text-amber-500 group-hover:text-amber-400',
66
+ bg: 'bg-amber-500/10 group-hover:bg-amber-500/20',
67
+ border: 'group-hover:border-amber-500/30',
68
+ },
69
+ {
70
+ icon: Shield,
71
+ title: 'Secure & Scalable',
72
+ description: 'End-to-end encryption, device authentication, and infrastructure that scales with your fleet.',
73
+ color: 'text-violet-500 group-hover:text-violet-400',
74
+ bg: 'bg-violet-500/10 group-hover:bg-violet-500/20',
75
+ border: 'group-hover:border-violet-500/30',
76
+ },
77
+ ]
78
+
79
+ function ThemeToggle() {
80
+ const { theme, setTheme } = useTheme()
81
+ const [mounted, setMounted] = useState(false)
82
+ useEffect(() => setMounted(true), [])
83
+ if (!mounted) return <div className="w-9 h-9" />
84
+ return (
85
+ <button
86
+ onClick={() => setTheme(theme === 'dark' ? 'light' : 'dark')}
87
+ className="inline-flex items-center justify-center w-9 h-9 rounded-md border border-border bg-background hover:bg-accent hover:text-accent-foreground active:scale-95 transition-all duration-200 cursor-pointer"
88
+ aria-label="Toggle theme"
89
+ >
90
+ {theme === 'dark' ? <Sun className="w-4 h-4" /> : <Moon className="w-4 h-4" />}
91
+ </button>
92
+ )
93
+ }
94
+
95
+ export default function Home() {
96
+ return (
97
+ <main id="main-content" className="min-h-screen bg-background text-foreground">
98
+ {/* Nav */}
99
+ <nav className="sticky top-0 z-50 border-b border-border bg-background/80 backdrop-blur-lg">
100
+ <div className="max-w-6xl mx-auto px-4 sm:px-6 h-16 flex items-center justify-between">
101
+ <Link href="/" className="flex items-center gap-2 hover:opacity-80 active:scale-[0.97] transition-all duration-200">
102
+ <div className="w-8 h-8 rounded-lg bg-gradient-to-br from-brand-from via-brand-via to-brand-to flex items-center justify-center">
103
+ <Cpu className="w-4 h-4 text-white" />
104
+ </div>
105
+ <span className="font-bold text-lg">{`{{titleCaseName}}`}</span>
106
+ </Link>
107
+ <div className="hidden md:flex items-center gap-6">
108
+ <Link href="/dashboard" className="text-sm text-muted-foreground hover:text-foreground transition-colors">
109
+ Devices
110
+ </Link>
111
+ <Link href="/dashboard" className="text-sm text-muted-foreground hover:text-foreground transition-colors">
112
+ Analytics
113
+ </Link>
114
+ <Link href="/dashboard" className="text-sm text-muted-foreground hover:text-foreground transition-colors">
115
+ Alerts
116
+ </Link>
117
+ </div>
118
+ <div className="flex items-center gap-2">
119
+ <ThemeToggle />
120
+ <Link href="/login">
121
+ <Button variant="ghost" size="sm" className="hover:bg-accent active:scale-95 transition-all duration-200 cursor-pointer">Sign In</Button>
122
+ </Link>
123
+ <Link href="/signup">
124
+ <Button size="sm" className="hover:brightness-110 active:scale-95 transition-all duration-200 cursor-pointer shadow-sm hover:shadow-md">Get Started</Button>
125
+ </Link>
126
+ </div>
127
+ </div>
128
+ </nav>
129
+
130
+ {/* Hero */}
131
+ <section className="relative overflow-hidden">
132
+ <div className="absolute inset-0 bg-gradient-to-b from-primary/5 to-transparent" />
133
+ <div className="relative max-w-6xl mx-auto px-4 sm:px-6 pt-16 sm:pt-24 pb-16 text-center">
134
+ <div className="inline-flex items-center gap-2 px-4 py-1.5 rounded-full border border-border bg-muted text-muted-foreground text-sm font-medium mb-8 hover:bg-accent hover:border-primary/20 transition-colors duration-200 cursor-default">
135
+ <Signal className="w-3.5 h-3.5 text-primary" />
136
+ IoT Management Platform
137
+ </div>
138
+ <h1 className="text-4xl sm:text-5xl lg:text-6xl font-extrabold tracking-tight mb-6">
139
+ Monitor Your
140
+ <br />
141
+ <span className="text-primary">Connected Devices</span>
142
+ </h1>
143
+ <p className="text-lg sm:text-xl text-muted-foreground max-w-2xl mx-auto mb-10 leading-relaxed">
144
+ Real-time monitoring, analytics, and control for your IoT infrastructure.
145
+ Built for scale, designed for simplicity.
146
+ </p>
147
+ <div className="flex flex-col sm:flex-row gap-3 justify-center">
148
+ <Link href="/dashboard">
149
+ <Button size="lg" className="w-full sm:w-auto text-base px-8 h-12 hover:brightness-110 active:scale-[0.97] transition-all duration-200 cursor-pointer shadow-md hover:shadow-lg">
150
+ <Activity className="w-4 h-4 mr-2" />
151
+ View Dashboard
152
+ </Button>
153
+ </Link>
154
+ <Link href="/dashboard">
155
+ <Button variant="outline" size="lg" className="w-full sm:w-auto text-base px-8 h-12 hover:bg-accent hover:border-primary/30 active:scale-[0.97] transition-all duration-200 cursor-pointer">
156
+ Manage Devices
157
+ </Button>
158
+ </Link>
159
+ </div>
160
+ </div>
161
+ </section>
162
+
163
+ {/* Device Overview */}
164
+ <section className="max-w-6xl mx-auto px-4 sm:px-6 pb-16 sm:pb-24">
165
+ <div className="grid grid-cols-2 lg:grid-cols-4 gap-4">
166
+ {DEVICE_TYPES.map((device) => (
167
+ <Card key={device.name} className="group cursor-default hover:shadow-lg hover:-translate-y-0.5 transition-all duration-300">
168
+ <CardContent className="p-5 sm:p-6">
169
+ <div className="flex items-center justify-between mb-4">
170
+ <div className={`w-10 h-10 ${device.bg} rounded-xl flex items-center justify-center transition-colors duration-300`}>
171
+ <device.icon className={`w-5 h-5 ${device.color} transition-colors duration-300`} />
172
+ </div>
173
+ <div className="flex items-center gap-1.5">
174
+ <span className={`w-2 h-2 rounded-full ${device.status === 'online' ? 'bg-emerald-500' : 'bg-amber-500'}`} />
175
+ <span className="text-xs text-muted-foreground">
176
+ {device.status === 'online' ? 'All Online' : 'Partial'}
177
+ </span>
178
+ </div>
179
+ </div>
180
+ <h3 className="text-sm font-medium text-muted-foreground mb-1">{device.name}</h3>
181
+ <p className="text-3xl font-bold text-primary">{device.count}</p>
182
+ </CardContent>
183
+ </Card>
184
+ ))}
185
+ </div>
186
+ </section>
187
+
188
+ {/* Features */}
189
+ <section className="bg-muted/50">
190
+ <div className="max-w-6xl mx-auto px-4 sm:px-6 py-16 sm:py-24">
191
+ <div className="text-center mb-12 sm:mb-16">
192
+ <h2 className="text-3xl sm:text-4xl font-bold mb-4">Everything You Need</h2>
193
+ <p className="text-muted-foreground text-lg max-w-xl mx-auto">
194
+ A complete toolkit for managing your connected device infrastructure.
195
+ </p>
196
+ </div>
197
+ <div className="grid sm:grid-cols-2 lg:grid-cols-4 gap-6">
198
+ {FEATURES.map((feature) => (
199
+ <Card key={feature.title} className={`group cursor-default hover:shadow-xl hover:-translate-y-1 ${feature.border} transition-all duration-300`}>
200
+ <CardContent className="p-6 sm:p-8">
201
+ <div className={`w-12 h-12 ${feature.bg} rounded-xl flex items-center justify-center mb-5 transition-colors duration-300`}>
202
+ <feature.icon className={`w-6 h-6 ${feature.color} transition-colors duration-300`} />
203
+ </div>
204
+ <h3 className="text-lg font-semibold mb-3 group-hover:text-primary transition-colors duration-200">{feature.title}</h3>
205
+ <p className="text-muted-foreground text-sm leading-relaxed">
206
+ {feature.description}
207
+ </p>
208
+ </CardContent>
209
+ </Card>
210
+ ))}
211
+ </div>
212
+ </div>
213
+ </section>
214
+
215
+ {/* CTA */}
216
+ <section className="max-w-6xl mx-auto px-4 sm:px-6 py-16 sm:py-24">
217
+ <div className="overflow-hidden rounded-2xl bg-gradient-to-br from-brand-from via-brand-via to-brand-to text-white p-8 sm:p-12 text-center hover:shadow-2xl hover:shadow-primary/20 transition-shadow duration-500">
218
+ <h2 className="text-3xl sm:text-4xl font-bold mb-4">Ready to Connect?</h2>
219
+ <p className="text-white/80 text-lg mb-8 max-w-lg mx-auto">
220
+ Start monitoring your IoT devices in minutes. Free tier available for up to 10 devices.
221
+ </p>
222
+ <Link href="/signup">
223
+ <Button variant="secondary" size="lg" className="px-8 h-12 text-base font-semibold hover:brightness-110 active:scale-[0.97] transition-all duration-200 cursor-pointer shadow-lg hover:shadow-xl">
224
+ Get Started Free
225
+ <ArrowRight className="w-4 h-4 ml-2" />
226
+ </Button>
227
+ </Link>
228
+ <p className="text-white/60 text-sm mt-4">No credit card required</p>
229
+ </div>
230
+ </section>
231
+
232
+ {/* Footer */}
233
+ <footer className="border-t border-border">
234
+ <div className="max-w-6xl mx-auto px-4 sm:px-6 py-8">
235
+ <div className="flex flex-col sm:flex-row items-center justify-between gap-6">
236
+ <Link href="/" className="flex items-center gap-2 hover:opacity-80 active:scale-[0.97] transition-all duration-200">
237
+ <div className="w-6 h-6 rounded bg-gradient-to-br from-brand-from via-brand-via to-brand-to flex items-center justify-center">
238
+ <Cpu className="w-3 h-3 text-white" />
239
+ </div>
240
+ <span className="text-sm font-medium">{`{{titleCaseName}}`}</span>
241
+ </Link>
242
+ <nav className="flex items-center gap-6">
243
+ <Link href="/dashboard" className="text-sm text-muted-foreground hover:text-foreground transition-colors">
244
+ Devices
245
+ </Link>
246
+ <Link href="/dashboard" className="text-sm text-muted-foreground hover:text-foreground transition-colors">
247
+ Analytics
248
+ </Link>
249
+ <Link href="/dashboard" className="text-sm text-muted-foreground hover:text-foreground transition-colors">
250
+ Alerts
251
+ </Link>
252
+ <Link href="/login" className="text-sm text-muted-foreground hover:text-foreground transition-colors">
253
+ Sign In
254
+ </Link>
255
+ </nav>
256
+ </div>
257
+ <div className="mt-6 pt-6 border-t border-border text-center">
258
+ <p className="text-xs text-muted-foreground">
259
+ Built with DLL Platform. Ship fast, own everything.
260
+ </p>
261
+ </div>
262
+ </div>
263
+ </footer>
264
+ </main>
265
+ )
266
+ }
@@ -2,6 +2,7 @@
2
2
 
3
3
  import { ThemeProvider } from 'next-themes'
4
4
  import { Toaster } from '@digilogiclabs/saas-factory-ui'
5
+ import { DLLProvider } from '@digilogiclabs/app-sdk'
5
6
 
6
7
  interface AppProvidersProps {
7
8
  children: React.ReactNode
@@ -10,8 +11,10 @@ interface AppProvidersProps {
10
11
  export function AppProviders({ children }: AppProvidersProps) {
11
12
  return (
12
13
  <ThemeProvider attribute="class" defaultTheme="system" enableSystem disableTransitionOnChange>
13
- {children}
14
- <Toaster />
14
+ <DLLProvider>
15
+ {children}
16
+ <Toaster />
17
+ </DLLProvider>
15
18
  </ThemeProvider>
16
19
  )
17
20
  }
@@ -1,33 +1,32 @@
1
- import { redirect } from 'next/navigation'
2
- import { createClient } from './supabase/server'
3
-
4
- export interface AuthUser {
5
- id: string
6
- email: string | null
7
- name?: string | null
8
- }
9
-
10
- export async function getUser(): Promise<AuthUser | null> {
11
- const supabase = await createClient()
12
- const { data: { user }, error } = await supabase.auth.getUser()
13
-
14
- if (error || !user) {
15
- return null
16
- }
17
-
18
- return {
19
- id: user.id,
20
- email: user.email ?? null,
21
- name: user.user_metadata?.name ?? user.user_metadata?.full_name ?? null,
22
- }
23
- }
24
-
25
- export async function requireAuth(): Promise<AuthUser> {
26
- const user = await getUser()
27
-
28
- if (!user) {
29
- redirect('/login')
30
- }
31
-
32
- return user
33
- }
1
+ import { redirect } from 'next/navigation'
2
+ import { getSession, getUser as getSessionUser } from './auth-session'
3
+
4
+ export interface AuthUser {
5
+ id: string
6
+ email: string | null
7
+ name?: string | null
8
+ }
9
+
10
+ export async function getUser(): Promise<AuthUser | null> {
11
+ const user = await getSessionUser()
12
+
13
+ if (!user || !user.id) {
14
+ return null
15
+ }
16
+
17
+ return {
18
+ id: user.id,
19
+ email: user.email ?? null,
20
+ name: user.name ?? null,
21
+ }
22
+ }
23
+
24
+ export async function requireAuth(): Promise<AuthUser> {
25
+ const user = await getUser()
26
+
27
+ if (!user) {
28
+ redirect('/login')
29
+ }
30
+
31
+ return user
32
+ }
@@ -1,14 +1,14 @@
1
- /** @type {import('next').NextConfig} */
2
- const nextConfig = {
3
- reactStrictMode: true,
4
- images: {
5
- remotePatterns: [
6
- {
7
- protocol: 'https',
8
- hostname: '**.supabase.co',
9
- },
10
- ],
11
- },
12
- }
13
-
14
- module.exports = nextConfig
1
+ /** @type {import('next').NextConfig} */
2
+ const nextConfig = {
3
+ reactStrictMode: true,
4
+ images: {
5
+ remotePatterns: [
6
+ {
7
+ protocol: 'https',
8
+ hostname: '**',
9
+ },
10
+ ],
11
+ },
12
+ }
13
+
14
+ module.exports = nextConfig
@@ -8,40 +8,33 @@
8
8
  "build": "next build",
9
9
  "start": "next start",
10
10
  "lint": "next lint",
11
- "type-check": "tsc --noEmit",
12
- "test": "vitest",
13
- "test:run": "vitest run"
11
+ "type-check": "tsc --noEmit"
14
12
  },
15
13
  "dependencies": {
16
- "next": "^15.0.0",
14
+ "next": "^15.5.0",
17
15
  "react": "^19.0.0",
18
16
  "react-dom": "^19.0.0",
19
- "@digilogiclabs/platform-core": "^1.13.0",
20
- "@digilogiclabs/app-sdk": "^1.0.0",
21
- "@digilogiclabs/saas-factory-ui": "^1.4.0",
22
- "stripe": "^16.12.0",
23
- "@stripe/react-stripe-js": "^2.8.0",
24
- "@stripe/stripe-js": "^4.10.0",
25
- "tailwindcss": "^4.0.0",
26
- "clsx": "^2.0.0",
17
+ "@digilogiclabs/platform-core": "^1.14.0",
18
+ "@digilogiclabs/app-sdk": "^1.1.0",
19
+ "@digilogiclabs/saas-factory-ui": "^1.8.1",
20
+ "tailwindcss": "^4.1.0",
21
+ "@tailwindcss/postcss": "^4.1.0",
22
+ "clsx": "^2.1.0",
27
23
  "class-variance-authority": "^0.7.0",
28
- "tailwind-merge": "^2.0.0",
24
+ "tailwind-merge": "^2.6.0",
29
25
  "next-themes": "^0.4.0",
30
26
  "lucide-react": "^0.460.0",
31
27
  "zod": "^4.1.0",
32
28
  "zustand": "^4.5.0"
33
29
  },
34
30
  "devDependencies": {
35
- "typescript": "^5.7.0",
31
+ "typescript": "^5.8.0",
36
32
  "@types/node": "^22.0.0",
37
33
  "@types/react": "^19.0.0",
38
34
  "@types/react-dom": "^19.0.0",
39
35
  "eslint": "^9.0.0",
40
36
  "eslint-config-next": "^15.0.0",
41
- "prettier": "^3.4.0",
42
- "vitest": "^2.1.0",
43
- "@testing-library/react": "^16.0.0",
44
- "@testing-library/jest-dom": "^6.6.0"
37
+ "prettier": "^3.4.0"
45
38
  },
46
39
  "engines": {
47
40
  "node": ">=20.0.0"