@digilogiclabs/create-saas-app 2.9.1 → 2.11.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 (377) hide show
  1. package/README.md +153 -113
  2. package/dist/.tsbuildinfo +1 -1
  3. package/dist/cli/commands/create.d.ts.map +1 -1
  4. package/dist/cli/commands/create.js +2 -6
  5. package/dist/cli/commands/create.js.map +1 -1
  6. package/dist/generators/template-generator.d.ts.map +1 -1
  7. package/dist/generators/template-generator.js +6 -3
  8. package/dist/generators/template-generator.js.map +1 -1
  9. package/dist/templates/shared/auth/supabase/web/src/middleware.ts +63 -0
  10. package/dist/templates/shared/database/supabase/web/src/lib/supabase/server.ts +3 -1
  11. package/dist/templates/shared/design/web/src/config/design.config.ts +14 -14
  12. package/dist/templates/shared/landing/web/src/components/LandingPage.tsx +0 -3
  13. package/dist/templates/shared/security/web/src/lib/api-security.ts +2 -2
  14. package/dist/templates/web/ai-platform/template/next.config.js +14 -14
  15. package/dist/templates/web/ai-platform/template/package.json +11 -22
  16. package/dist/templates/web/ai-platform/template/postcss.config.mjs +8 -0
  17. package/dist/templates/web/ai-platform/template/src/app/api/auth/route.ts +57 -0
  18. package/dist/templates/web/ai-platform/template/src/app/chat/page.tsx +234 -235
  19. package/dist/templates/web/ai-platform/template/src/app/dashboard/page.tsx +142 -142
  20. package/dist/templates/web/ai-platform/template/src/app/error.tsx +13 -13
  21. package/dist/templates/web/ai-platform/template/src/app/globals.css +97 -34
  22. package/dist/templates/web/ai-platform/template/src/app/layout.tsx +3 -0
  23. package/dist/templates/web/ai-platform/template/src/app/loading.tsx +22 -22
  24. package/dist/templates/web/ai-platform/template/src/app/login/page.tsx +112 -0
  25. package/dist/templates/web/ai-platform/template/src/app/models/page.tsx +186 -0
  26. package/dist/templates/web/ai-platform/template/src/app/page.tsx +248 -154
  27. package/dist/templates/web/ai-platform/template/src/app/playground/page.tsx +251 -0
  28. package/dist/templates/web/ai-platform/template/src/app/settings/page.tsx +190 -0
  29. package/dist/templates/web/ai-platform/template/src/app/signup/page.tsx +133 -0
  30. package/dist/templates/web/ai-platform/template/src/lib/auth-server.ts +32 -33
  31. package/dist/templates/web/ai-platform/template/src/lib/auth-session.ts +52 -0
  32. package/dist/templates/web/base/template/next.config.js +14 -15
  33. package/dist/templates/web/base/template/package.json +16 -31
  34. package/dist/templates/web/base/template/postcss.config.mjs +8 -0
  35. package/dist/templates/web/base/template/src/app/error.tsx +97 -97
  36. package/dist/templates/web/base/template/src/app/globals.css +87 -148
  37. package/dist/templates/web/base/template/src/app/layout.tsx +4 -1
  38. package/dist/templates/web/base/template/src/app/loading.tsx +52 -52
  39. package/dist/templates/web/base/template/tsconfig.json +27 -33
  40. package/dist/templates/web/iot-dashboard/template/next.config.js +14 -14
  41. package/dist/templates/web/iot-dashboard/template/package.json +12 -16
  42. package/dist/templates/web/iot-dashboard/template/postcss.config.mjs +8 -0
  43. package/dist/templates/web/iot-dashboard/template/src/app/alerts/page.tsx +157 -0
  44. package/dist/templates/web/iot-dashboard/template/src/app/api/auth/route.ts +57 -0
  45. package/dist/templates/web/iot-dashboard/template/src/app/dashboard/page.tsx +224 -224
  46. package/dist/templates/web/iot-dashboard/template/src/app/devices/[id]/page.tsx +204 -0
  47. package/dist/templates/web/iot-dashboard/template/src/app/devices/new/page.tsx +139 -0
  48. package/dist/templates/web/iot-dashboard/template/src/app/devices/page.tsx +171 -0
  49. package/dist/templates/web/iot-dashboard/template/src/app/error.tsx +8 -8
  50. package/dist/templates/web/iot-dashboard/template/src/app/globals.css +97 -20
  51. package/dist/templates/web/iot-dashboard/template/src/app/layout.tsx +3 -0
  52. package/dist/templates/web/iot-dashboard/template/src/app/loading.tsx +5 -5
  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/page.tsx +266 -189
  55. package/dist/templates/web/iot-dashboard/template/src/app/settings/page.tsx +186 -0
  56. package/dist/templates/web/iot-dashboard/template/src/app/signup/page.tsx +133 -0
  57. package/dist/templates/web/iot-dashboard/template/src/lib/auth-server.ts +32 -33
  58. package/dist/templates/web/iot-dashboard/template/src/lib/auth-session.ts +52 -0
  59. package/dist/templates/web/marketplace/template/next.config.js +14 -14
  60. package/dist/templates/web/marketplace/template/package.json +11 -18
  61. package/dist/templates/web/marketplace/template/postcss.config.mjs +8 -0
  62. package/dist/templates/web/marketplace/template/src/app/api/auth/route.ts +57 -0
  63. package/dist/templates/web/marketplace/template/src/app/cart/page.tsx +147 -147
  64. package/dist/templates/web/marketplace/template/src/app/dashboard/page.tsx +149 -149
  65. package/dist/templates/web/marketplace/template/src/app/error.tsx +7 -7
  66. package/dist/templates/web/marketplace/template/src/app/globals.css +97 -20
  67. package/dist/templates/web/marketplace/template/src/app/layout.tsx +3 -0
  68. package/dist/templates/web/marketplace/template/src/app/loading.tsx +5 -5
  69. package/dist/templates/web/marketplace/template/src/app/login/page.tsx +112 -0
  70. package/dist/templates/web/marketplace/template/src/app/orders/page.tsx +160 -0
  71. package/dist/templates/web/marketplace/template/src/app/page.tsx +370 -169
  72. package/dist/templates/web/marketplace/template/src/app/products/[id]/page.tsx +218 -0
  73. package/dist/templates/web/marketplace/template/src/app/products/page.tsx +129 -129
  74. package/dist/templates/web/marketplace/template/src/app/settings/page.tsx +150 -0
  75. package/dist/templates/web/marketplace/template/src/app/signup/page.tsx +133 -0
  76. package/dist/templates/web/marketplace/template/src/lib/auth-server.ts +32 -33
  77. package/dist/templates/web/marketplace/template/src/lib/auth-session.ts +52 -0
  78. package/dist/templates/web/micro-saas/template/next.config.js +14 -14
  79. package/dist/templates/web/micro-saas/template/package.json +9 -8
  80. package/dist/templates/web/micro-saas/template/postcss.config.mjs +8 -0
  81. package/dist/templates/web/micro-saas/template/src/app/api/auth/route.ts +57 -0
  82. package/dist/templates/web/micro-saas/template/src/app/dashboard/page.tsx +145 -117
  83. package/dist/templates/web/micro-saas/template/src/app/error.tsx +7 -7
  84. package/dist/templates/web/micro-saas/template/src/app/globals.css +97 -20
  85. package/dist/templates/web/micro-saas/template/src/app/layout.tsx +3 -0
  86. package/dist/templates/web/micro-saas/template/src/app/loading.tsx +43 -27
  87. package/dist/templates/web/micro-saas/template/src/app/login/page.tsx +112 -87
  88. package/dist/templates/web/micro-saas/template/src/app/page.tsx +227 -137
  89. package/dist/templates/web/micro-saas/template/src/app/signup/page.tsx +133 -108
  90. package/dist/templates/web/micro-saas/template/src/lib/auth-server.ts +32 -33
  91. package/dist/templates/web/micro-saas/template/src/lib/auth-session.ts +52 -0
  92. package/dist/templates/web/ui-auth/template/next.config.js +14 -12
  93. package/dist/templates/web/ui-auth/template/package.json +16 -26
  94. package/dist/templates/web/ui-auth/template/postcss.config.mjs +8 -0
  95. package/dist/templates/web/ui-auth/template/src/app/error.tsx +67 -67
  96. package/dist/templates/web/ui-auth/template/src/app/globals.css +85 -84
  97. package/dist/templates/web/ui-auth/template/src/app/layout.tsx +4 -1
  98. package/dist/templates/web/ui-auth/template/src/app/loading.tsx +20 -38
  99. package/dist/templates/web/ui-auth/template/tsconfig.json +27 -33
  100. package/dist/templates/web/ui-auth-ai/template/next.config.js +15 -13
  101. package/dist/templates/web/ui-auth-ai/template/package.json +25 -21
  102. package/dist/templates/web/ui-auth-ai/template/postcss.config.mjs +8 -0
  103. package/dist/templates/web/ui-auth-ai/template/src/app/error.tsx +7 -7
  104. package/dist/templates/web/ui-auth-ai/template/src/app/globals.css +87 -25
  105. package/dist/templates/web/ui-auth-ai/template/src/app/layout.tsx +3 -0
  106. package/dist/templates/web/ui-auth-ai/template/src/app/loading.tsx +4 -4
  107. package/dist/templates/web/ui-auth-ai/template/tsconfig.json +27 -28
  108. package/dist/templates/web/ui-auth-payments/template/next.config.js +14 -12
  109. package/dist/templates/web/ui-auth-payments/template/package.json +16 -29
  110. package/dist/templates/web/ui-auth-payments/template/postcss.config.mjs +8 -0
  111. package/dist/templates/web/ui-auth-payments/template/src/app/error.tsx +67 -67
  112. package/dist/templates/web/ui-auth-payments/template/src/app/globals.css +89 -204
  113. package/dist/templates/web/ui-auth-payments/template/src/app/layout.tsx +4 -1
  114. package/dist/templates/web/ui-auth-payments/template/src/app/loading.tsx +20 -20
  115. package/dist/templates/web/ui-auth-payments/template/tsconfig.json +27 -33
  116. package/dist/templates/web/ui-auth-payments-ai/template/next.config.js +14 -12
  117. package/dist/templates/web/ui-auth-payments-ai/template/package.json +17 -33
  118. package/dist/templates/web/ui-auth-payments-ai/template/postcss.config.mjs +8 -0
  119. package/dist/templates/web/ui-auth-payments-ai/template/src/app/error.tsx +67 -67
  120. package/dist/templates/web/ui-auth-payments-ai/template/src/app/globals.css +85 -85
  121. package/dist/templates/web/ui-auth-payments-ai/template/src/app/layout.tsx +4 -1
  122. package/dist/templates/web/ui-auth-payments-ai/template/src/app/loading.tsx +20 -20
  123. package/dist/templates/web/ui-auth-payments-ai/template/tsconfig.json +27 -33
  124. package/dist/templates/web/ui-auth-payments-audio/template/next.config.js +14 -12
  125. package/dist/templates/web/ui-auth-payments-audio/template/package.json +17 -30
  126. package/dist/templates/web/ui-auth-payments-audio/template/postcss.config.mjs +8 -0
  127. package/dist/templates/web/ui-auth-payments-audio/template/src/app/error.tsx +67 -67
  128. package/dist/templates/web/ui-auth-payments-audio/template/src/app/globals.css +85 -85
  129. package/dist/templates/web/ui-auth-payments-audio/template/src/app/layout.tsx +4 -1
  130. package/dist/templates/web/ui-auth-payments-audio/template/src/app/loading.tsx +20 -20
  131. package/dist/templates/web/ui-auth-payments-audio/template/tsconfig.json +27 -33
  132. package/dist/templates/web/ui-auth-payments-video/template/next.config.js +14 -12
  133. package/dist/templates/web/ui-auth-payments-video/template/package.json +17 -30
  134. package/dist/templates/web/ui-auth-payments-video/template/postcss.config.mjs +8 -0
  135. package/dist/templates/web/ui-auth-payments-video/template/src/app/error.tsx +67 -67
  136. package/dist/templates/web/ui-auth-payments-video/template/src/app/globals.css +89 -221
  137. package/dist/templates/web/ui-auth-payments-video/template/src/app/layout.tsx +4 -1
  138. package/dist/templates/web/ui-auth-payments-video/template/src/app/loading.tsx +20 -20
  139. package/dist/templates/web/ui-auth-payments-video/template/tsconfig.json +27 -33
  140. package/dist/templates/web/ui-only/template/next.config.js +14 -12
  141. package/dist/templates/web/ui-only/template/package.json +15 -25
  142. package/dist/templates/web/ui-only/template/postcss.config.mjs +8 -0
  143. package/dist/templates/web/ui-only/template/src/app/error.tsx +67 -67
  144. package/dist/templates/web/ui-only/template/src/app/globals.css +85 -31
  145. package/dist/templates/web/ui-only/template/src/app/layout.tsx +4 -1
  146. package/dist/templates/web/ui-only/template/src/app/loading.tsx +20 -20
  147. package/dist/templates/web/ui-only/template/tsconfig.json +27 -33
  148. package/package.json +1 -1
  149. package/src/templates/shared/auth/supabase/web/src/middleware.ts +63 -0
  150. package/src/templates/shared/database/supabase/web/src/lib/supabase/server.ts +3 -1
  151. package/src/templates/shared/design/web/src/config/design.config.ts +14 -14
  152. package/src/templates/shared/landing/web/src/components/LandingPage.tsx +0 -3
  153. package/src/templates/shared/security/web/src/lib/api-security.ts +2 -2
  154. package/src/templates/web/ai-platform/template/next.config.js +14 -14
  155. package/src/templates/web/ai-platform/template/package.json +11 -22
  156. package/src/templates/web/ai-platform/template/postcss.config.mjs +8 -0
  157. package/src/templates/web/ai-platform/template/src/app/api/auth/route.ts +57 -0
  158. package/src/templates/web/ai-platform/template/src/app/chat/page.tsx +234 -235
  159. package/src/templates/web/ai-platform/template/src/app/dashboard/page.tsx +142 -142
  160. package/src/templates/web/ai-platform/template/src/app/error.tsx +13 -13
  161. package/src/templates/web/ai-platform/template/src/app/globals.css +97 -34
  162. package/src/templates/web/ai-platform/template/src/app/layout.tsx +3 -0
  163. package/src/templates/web/ai-platform/template/src/app/loading.tsx +22 -22
  164. package/src/templates/web/ai-platform/template/src/app/login/page.tsx +112 -0
  165. package/src/templates/web/ai-platform/template/src/app/models/page.tsx +186 -0
  166. package/src/templates/web/ai-platform/template/src/app/page.tsx +248 -154
  167. package/src/templates/web/ai-platform/template/src/app/playground/page.tsx +251 -0
  168. package/src/templates/web/ai-platform/template/src/app/settings/page.tsx +190 -0
  169. package/src/templates/web/ai-platform/template/src/app/signup/page.tsx +133 -0
  170. package/src/templates/web/ai-platform/template/src/lib/auth-server.ts +32 -33
  171. package/src/templates/web/ai-platform/template/src/lib/auth-session.ts +52 -0
  172. package/src/templates/web/base/template/next.config.js +14 -15
  173. package/src/templates/web/base/template/package.json +16 -31
  174. package/src/templates/web/base/template/postcss.config.mjs +8 -0
  175. package/src/templates/web/base/template/src/app/error.tsx +97 -97
  176. package/src/templates/web/base/template/src/app/globals.css +87 -148
  177. package/src/templates/web/base/template/src/app/layout.tsx +4 -1
  178. package/src/templates/web/base/template/src/app/loading.tsx +52 -52
  179. package/src/templates/web/base/template/tsconfig.json +27 -33
  180. package/src/templates/web/iot-dashboard/template/next.config.js +14 -14
  181. package/src/templates/web/iot-dashboard/template/package.json +12 -16
  182. package/src/templates/web/iot-dashboard/template/postcss.config.mjs +8 -0
  183. package/src/templates/web/iot-dashboard/template/src/app/alerts/page.tsx +157 -0
  184. package/src/templates/web/iot-dashboard/template/src/app/api/auth/route.ts +57 -0
  185. package/src/templates/web/iot-dashboard/template/src/app/dashboard/page.tsx +224 -224
  186. package/src/templates/web/iot-dashboard/template/src/app/devices/[id]/page.tsx +204 -0
  187. package/src/templates/web/iot-dashboard/template/src/app/devices/new/page.tsx +139 -0
  188. package/src/templates/web/iot-dashboard/template/src/app/devices/page.tsx +171 -0
  189. package/src/templates/web/iot-dashboard/template/src/app/error.tsx +8 -8
  190. package/src/templates/web/iot-dashboard/template/src/app/globals.css +97 -20
  191. package/src/templates/web/iot-dashboard/template/src/app/layout.tsx +3 -0
  192. package/src/templates/web/iot-dashboard/template/src/app/loading.tsx +5 -5
  193. package/src/templates/web/iot-dashboard/template/src/app/login/page.tsx +112 -0
  194. package/src/templates/web/iot-dashboard/template/src/app/page.tsx +266 -189
  195. package/src/templates/web/iot-dashboard/template/src/app/settings/page.tsx +186 -0
  196. package/src/templates/web/iot-dashboard/template/src/app/signup/page.tsx +133 -0
  197. package/src/templates/web/iot-dashboard/template/src/lib/auth-server.ts +32 -33
  198. package/src/templates/web/iot-dashboard/template/src/lib/auth-session.ts +52 -0
  199. package/src/templates/web/marketplace/template/next.config.js +14 -14
  200. package/src/templates/web/marketplace/template/package.json +11 -18
  201. package/src/templates/web/marketplace/template/postcss.config.mjs +8 -0
  202. package/src/templates/web/marketplace/template/src/app/api/auth/route.ts +57 -0
  203. package/src/templates/web/marketplace/template/src/app/cart/page.tsx +147 -147
  204. package/src/templates/web/marketplace/template/src/app/dashboard/page.tsx +149 -149
  205. package/src/templates/web/marketplace/template/src/app/error.tsx +7 -7
  206. package/src/templates/web/marketplace/template/src/app/globals.css +97 -20
  207. package/src/templates/web/marketplace/template/src/app/layout.tsx +3 -0
  208. package/src/templates/web/marketplace/template/src/app/loading.tsx +5 -5
  209. package/src/templates/web/marketplace/template/src/app/login/page.tsx +112 -0
  210. package/src/templates/web/marketplace/template/src/app/orders/page.tsx +160 -0
  211. package/src/templates/web/marketplace/template/src/app/page.tsx +370 -169
  212. package/src/templates/web/marketplace/template/src/app/products/[id]/page.tsx +218 -0
  213. package/src/templates/web/marketplace/template/src/app/products/page.tsx +129 -129
  214. package/src/templates/web/marketplace/template/src/app/settings/page.tsx +150 -0
  215. package/src/templates/web/marketplace/template/src/app/signup/page.tsx +133 -0
  216. package/src/templates/web/marketplace/template/src/lib/auth-server.ts +32 -33
  217. package/src/templates/web/marketplace/template/src/lib/auth-session.ts +52 -0
  218. package/src/templates/web/micro-saas/template/next.config.js +14 -14
  219. package/src/templates/web/micro-saas/template/package.json +9 -8
  220. package/src/templates/web/micro-saas/template/postcss.config.mjs +8 -0
  221. package/src/templates/web/micro-saas/template/src/app/api/auth/route.ts +57 -0
  222. package/src/templates/web/micro-saas/template/src/app/dashboard/page.tsx +145 -117
  223. package/src/templates/web/micro-saas/template/src/app/error.tsx +7 -7
  224. package/src/templates/web/micro-saas/template/src/app/globals.css +97 -20
  225. package/src/templates/web/micro-saas/template/src/app/layout.tsx +3 -0
  226. package/src/templates/web/micro-saas/template/src/app/loading.tsx +43 -27
  227. package/src/templates/web/micro-saas/template/src/app/login/page.tsx +112 -87
  228. package/src/templates/web/micro-saas/template/src/app/page.tsx +227 -137
  229. package/src/templates/web/micro-saas/template/src/app/signup/page.tsx +133 -108
  230. package/src/templates/web/micro-saas/template/src/lib/auth-server.ts +32 -33
  231. package/src/templates/web/micro-saas/template/src/lib/auth-session.ts +52 -0
  232. package/src/templates/web/ui-auth/template/next.config.js +14 -12
  233. package/src/templates/web/ui-auth/template/package.json +16 -26
  234. package/src/templates/web/ui-auth/template/postcss.config.mjs +8 -0
  235. package/src/templates/web/ui-auth/template/src/app/error.tsx +67 -67
  236. package/src/templates/web/ui-auth/template/src/app/globals.css +85 -84
  237. package/src/templates/web/ui-auth/template/src/app/layout.tsx +4 -1
  238. package/src/templates/web/ui-auth/template/src/app/loading.tsx +20 -38
  239. package/src/templates/web/ui-auth/template/tsconfig.json +27 -33
  240. package/src/templates/web/ui-auth-ai/template/next.config.js +15 -13
  241. package/src/templates/web/ui-auth-ai/template/package.json +25 -21
  242. package/src/templates/web/ui-auth-ai/template/postcss.config.mjs +8 -0
  243. package/src/templates/web/ui-auth-ai/template/src/app/error.tsx +7 -7
  244. package/src/templates/web/ui-auth-ai/template/src/app/globals.css +87 -25
  245. package/src/templates/web/ui-auth-ai/template/src/app/layout.tsx +3 -0
  246. package/src/templates/web/ui-auth-ai/template/src/app/loading.tsx +4 -4
  247. package/src/templates/web/ui-auth-ai/template/tsconfig.json +27 -28
  248. package/src/templates/web/ui-auth-payments/template/next.config.js +14 -12
  249. package/src/templates/web/ui-auth-payments/template/package.json +16 -29
  250. package/src/templates/web/ui-auth-payments/template/postcss.config.mjs +8 -0
  251. package/src/templates/web/ui-auth-payments/template/src/app/error.tsx +67 -67
  252. package/src/templates/web/ui-auth-payments/template/src/app/globals.css +89 -204
  253. package/src/templates/web/ui-auth-payments/template/src/app/layout.tsx +4 -1
  254. package/src/templates/web/ui-auth-payments/template/src/app/loading.tsx +20 -20
  255. package/src/templates/web/ui-auth-payments/template/tsconfig.json +27 -33
  256. package/src/templates/web/ui-auth-payments-ai/template/next.config.js +14 -12
  257. package/src/templates/web/ui-auth-payments-ai/template/package.json +17 -33
  258. package/src/templates/web/ui-auth-payments-ai/template/postcss.config.mjs +8 -0
  259. package/src/templates/web/ui-auth-payments-ai/template/src/app/error.tsx +67 -67
  260. package/src/templates/web/ui-auth-payments-ai/template/src/app/globals.css +85 -85
  261. package/src/templates/web/ui-auth-payments-ai/template/src/app/layout.tsx +4 -1
  262. package/src/templates/web/ui-auth-payments-ai/template/src/app/loading.tsx +20 -20
  263. package/src/templates/web/ui-auth-payments-ai/template/tsconfig.json +27 -33
  264. package/src/templates/web/ui-auth-payments-audio/template/next.config.js +14 -12
  265. package/src/templates/web/ui-auth-payments-audio/template/package.json +17 -30
  266. package/src/templates/web/ui-auth-payments-audio/template/postcss.config.mjs +8 -0
  267. package/src/templates/web/ui-auth-payments-audio/template/src/app/error.tsx +67 -67
  268. package/src/templates/web/ui-auth-payments-audio/template/src/app/globals.css +85 -85
  269. package/src/templates/web/ui-auth-payments-audio/template/src/app/layout.tsx +4 -1
  270. package/src/templates/web/ui-auth-payments-audio/template/src/app/loading.tsx +20 -20
  271. package/src/templates/web/ui-auth-payments-audio/template/tsconfig.json +27 -33
  272. package/src/templates/web/ui-auth-payments-video/template/next.config.js +14 -12
  273. package/src/templates/web/ui-auth-payments-video/template/package.json +17 -30
  274. package/src/templates/web/ui-auth-payments-video/template/postcss.config.mjs +8 -0
  275. package/src/templates/web/ui-auth-payments-video/template/src/app/error.tsx +67 -67
  276. package/src/templates/web/ui-auth-payments-video/template/src/app/globals.css +89 -221
  277. package/src/templates/web/ui-auth-payments-video/template/src/app/layout.tsx +4 -1
  278. package/src/templates/web/ui-auth-payments-video/template/src/app/loading.tsx +20 -20
  279. package/src/templates/web/ui-auth-payments-video/template/tsconfig.json +27 -33
  280. package/src/templates/web/ui-only/template/next.config.js +14 -12
  281. package/src/templates/web/ui-only/template/package.json +15 -25
  282. package/src/templates/web/ui-only/template/postcss.config.mjs +8 -0
  283. package/src/templates/web/ui-only/template/src/app/error.tsx +67 -67
  284. package/src/templates/web/ui-only/template/src/app/globals.css +85 -31
  285. package/src/templates/web/ui-only/template/src/app/layout.tsx +4 -1
  286. package/src/templates/web/ui-only/template/src/app/loading.tsx +20 -20
  287. package/src/templates/web/ui-only/template/tsconfig.json +27 -33
  288. package/dist/templates/web/ai-platform/template/middleware.ts +0 -55
  289. package/dist/templates/web/ai-platform/template/src/lib/supabase/client.ts +0 -8
  290. package/dist/templates/web/ai-platform/template/src/lib/supabase/server.ts +0 -27
  291. package/dist/templates/web/base/template/postcss.config.js +0 -7
  292. package/dist/templates/web/base/template/tailwind.config.js +0 -77
  293. package/dist/templates/web/iot-dashboard/template/middleware.ts +0 -56
  294. package/dist/templates/web/iot-dashboard/template/src/lib/supabase/client.ts +0 -8
  295. package/dist/templates/web/iot-dashboard/template/src/lib/supabase/server.ts +0 -27
  296. package/dist/templates/web/marketplace/template/middleware.ts +0 -56
  297. package/dist/templates/web/marketplace/template/src/lib/supabase/client.ts +0 -8
  298. package/dist/templates/web/marketplace/template/src/lib/supabase/server.ts +0 -27
  299. package/dist/templates/web/micro-saas/template/middleware.ts +0 -53
  300. package/dist/templates/web/micro-saas/template/src/lib/supabase/client.ts +0 -8
  301. package/dist/templates/web/micro-saas/template/src/lib/supabase/server.ts +0 -29
  302. package/dist/templates/web/ui-auth/template/.claude +0 -21
  303. package/dist/templates/web/ui-auth/template/context.md +0 -105
  304. package/dist/templates/web/ui-auth/template/postcss.config.js +0 -7
  305. package/dist/templates/web/ui-auth/template/tailwind.config.js +0 -77
  306. package/dist/templates/web/ui-auth-ai/template/postcss.config.js +0 -6
  307. package/dist/templates/web/ui-auth-ai/template/tailwind.config.js +0 -22
  308. package/dist/templates/web/ui-auth-payments/template/middleware.ts +0 -68
  309. package/dist/templates/web/ui-auth-payments/template/package-lock.json +0 -12240
  310. package/dist/templates/web/ui-auth-payments/template/postcss.config.js +0 -7
  311. package/dist/templates/web/ui-auth-payments/template/tailwind.config.js +0 -77
  312. package/dist/templates/web/ui-auth-payments/template/tsconfig.tsbuildinfo +0 -1
  313. package/dist/templates/web/ui-auth-payments-ai/template/.claude +0 -21
  314. package/dist/templates/web/ui-auth-payments-ai/template/context.md +0 -169
  315. package/dist/templates/web/ui-auth-payments-ai/template/middleware.ts +0 -68
  316. package/dist/templates/web/ui-auth-payments-ai/template/package-lock.json +0 -12241
  317. package/dist/templates/web/ui-auth-payments-ai/template/postcss.config.js +0 -7
  318. package/dist/templates/web/ui-auth-payments-ai/template/tailwind.config.js +0 -77
  319. package/dist/templates/web/ui-auth-payments-ai/template/tsconfig.tsbuildinfo +0 -1
  320. package/dist/templates/web/ui-auth-payments-audio/template/middleware.ts +0 -68
  321. package/dist/templates/web/ui-auth-payments-audio/template/package-lock.json +0 -12241
  322. package/dist/templates/web/ui-auth-payments-audio/template/postcss.config.js +0 -7
  323. package/dist/templates/web/ui-auth-payments-audio/template/tailwind.config.js +0 -77
  324. package/dist/templates/web/ui-auth-payments-audio/template/tsconfig.tsbuildinfo +0 -1
  325. package/dist/templates/web/ui-auth-payments-video/template/postcss.config.js +0 -7
  326. package/dist/templates/web/ui-auth-payments-video/template/tailwind.config.js +0 -77
  327. package/dist/templates/web/ui-only/template/postcss.config.js +0 -7
  328. package/dist/templates/web/ui-only/template/tailwind.config.js +0 -77
  329. package/src/templates/web/ai-platform/template/middleware.ts +0 -55
  330. package/src/templates/web/ai-platform/template/src/lib/supabase/client.ts +0 -8
  331. package/src/templates/web/ai-platform/template/src/lib/supabase/server.ts +0 -27
  332. package/src/templates/web/base/template/postcss.config.js +0 -7
  333. package/src/templates/web/base/template/tailwind.config.js +0 -77
  334. package/src/templates/web/iot-dashboard/template/middleware.ts +0 -56
  335. package/src/templates/web/iot-dashboard/template/src/lib/supabase/client.ts +0 -8
  336. package/src/templates/web/iot-dashboard/template/src/lib/supabase/server.ts +0 -27
  337. package/src/templates/web/marketplace/template/middleware.ts +0 -56
  338. package/src/templates/web/marketplace/template/src/lib/supabase/client.ts +0 -8
  339. package/src/templates/web/marketplace/template/src/lib/supabase/server.ts +0 -27
  340. package/src/templates/web/micro-saas/template/middleware.ts +0 -53
  341. package/src/templates/web/micro-saas/template/src/lib/supabase/client.ts +0 -8
  342. package/src/templates/web/micro-saas/template/src/lib/supabase/server.ts +0 -29
  343. package/src/templates/web/ui-auth/template/.claude +0 -21
  344. package/src/templates/web/ui-auth/template/context.md +0 -105
  345. package/src/templates/web/ui-auth/template/postcss.config.js +0 -7
  346. package/src/templates/web/ui-auth/template/tailwind.config.js +0 -77
  347. package/src/templates/web/ui-auth-ai/template/postcss.config.js +0 -6
  348. package/src/templates/web/ui-auth-ai/template/tailwind.config.js +0 -22
  349. package/src/templates/web/ui-auth-payments/template/middleware.ts +0 -68
  350. package/src/templates/web/ui-auth-payments/template/package-lock.json +0 -12240
  351. package/src/templates/web/ui-auth-payments/template/postcss.config.js +0 -7
  352. package/src/templates/web/ui-auth-payments/template/tailwind.config.js +0 -77
  353. package/src/templates/web/ui-auth-payments/template/tsconfig.tsbuildinfo +0 -1
  354. package/src/templates/web/ui-auth-payments-ai/template/.claude +0 -21
  355. package/src/templates/web/ui-auth-payments-ai/template/context.md +0 -169
  356. package/src/templates/web/ui-auth-payments-ai/template/middleware.ts +0 -68
  357. package/src/templates/web/ui-auth-payments-ai/template/package-lock.json +0 -12241
  358. package/src/templates/web/ui-auth-payments-ai/template/postcss.config.js +0 -7
  359. package/src/templates/web/ui-auth-payments-ai/template/tailwind.config.js +0 -77
  360. package/src/templates/web/ui-auth-payments-ai/template/tsconfig.tsbuildinfo +0 -1
  361. package/src/templates/web/ui-auth-payments-audio/template/middleware.ts +0 -68
  362. package/src/templates/web/ui-auth-payments-audio/template/package-lock.json +0 -12241
  363. package/src/templates/web/ui-auth-payments-audio/template/postcss.config.js +0 -7
  364. package/src/templates/web/ui-auth-payments-audio/template/tailwind.config.js +0 -77
  365. package/src/templates/web/ui-auth-payments-audio/template/tsconfig.tsbuildinfo +0 -1
  366. package/src/templates/web/ui-auth-payments-video/template/postcss.config.js +0 -7
  367. package/src/templates/web/ui-auth-payments-video/template/tailwind.config.js +0 -77
  368. package/src/templates/web/ui-only/template/postcss.config.js +0 -7
  369. package/src/templates/web/ui-only/template/tailwind.config.js +0 -77
  370. /package/dist/templates/shared/admin/web/{components → src/components}/admin-nav.tsx +0 -0
  371. /package/dist/templates/shared/auth/keycloak/web/{auth.config.ts → src/auth.config.ts} +0 -0
  372. /package/dist/templates/shared/auth/keycloak/web/{auth.ts → src/auth.ts} +0 -0
  373. /package/dist/templates/shared/middleware/web/{middleware.ts → src/middleware.ts} +0 -0
  374. /package/src/templates/shared/admin/web/{components → src/components}/admin-nav.tsx +0 -0
  375. /package/src/templates/shared/auth/keycloak/web/{auth.config.ts → src/auth.config.ts} +0 -0
  376. /package/src/templates/shared/auth/keycloak/web/{auth.ts → src/auth.ts} +0 -0
  377. /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
+ }