@digilogiclabs/create-saas-app 1.1.2 → 1.4.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 (222) hide show
  1. package/CHANGELOG.md +7 -7
  2. package/README.md +46 -22
  3. package/bin/index.js +36 -36
  4. package/dist/.tsbuildinfo +1 -1
  5. package/dist/index.js +59 -15
  6. package/dist/index.js.map +1 -1
  7. package/dist/templates/mobile/base/template/.env.example +15 -15
  8. package/dist/templates/mobile/base/template/app/checkout.tsx +20 -20
  9. package/dist/templates/web/base/template/src/app/checkout/page.tsx +28 -28
  10. package/dist/templates/web/ui-auth/template/next.config.js +12 -0
  11. package/dist/templates/web/ui-auth/template/package.json +40 -0
  12. package/dist/templates/web/ui-auth/template/postcss.config.js +7 -0
  13. package/dist/templates/web/ui-auth/template/src/app/auth/callback/route.ts +12 -0
  14. package/{src/templates/web/web-ui-package → dist/templates/web/ui-auth}/template/src/app/checkout/page.tsx +25 -28
  15. package/dist/templates/web/ui-auth/template/src/app/globals.css +42 -0
  16. package/dist/templates/web/ui-auth/template/src/app/layout.tsx +29 -0
  17. package/dist/templates/web/ui-auth/template/src/app/login/page.tsx +109 -0
  18. package/dist/templates/web/ui-auth/template/src/app/page.tsx +129 -0
  19. package/dist/templates/web/ui-auth/template/src/app/signup/page.tsx +128 -0
  20. package/dist/templates/web/ui-auth/template/src/components/providers/app-providers.tsx +25 -0
  21. package/{src/templates/web/web-ui-package → dist/templates/web/ui-auth}/template/src/components/shared/header.tsx +17 -8
  22. package/dist/templates/web/ui-auth/template/src/components/ui/badge.tsx +36 -0
  23. package/dist/templates/web/ui-auth/template/src/lib/utils.ts +7 -0
  24. package/dist/templates/web/ui-auth/template/tailwind.config.js +77 -0
  25. package/dist/templates/web/ui-auth/template/tsconfig.json +33 -0
  26. package/dist/templates/web/ui-auth-payments/template/README.md +165 -0
  27. package/dist/templates/web/ui-auth-payments/template/next.config.js +12 -0
  28. package/dist/templates/web/ui-auth-payments/template/package.json +42 -0
  29. package/dist/templates/web/ui-auth-payments/template/postcss.config.js +7 -0
  30. package/dist/templates/web/ui-auth-payments/template/src/app/auth/callback/route.ts +12 -0
  31. package/dist/templates/web/ui-auth-payments/template/src/app/billing/page.tsx +211 -0
  32. package/dist/templates/web/ui-auth-payments/template/src/app/checkout/page.tsx +142 -0
  33. package/dist/templates/web/ui-auth-payments/template/src/app/globals.css +42 -0
  34. package/dist/templates/web/ui-auth-payments/template/src/app/layout.tsx +29 -0
  35. package/dist/templates/web/ui-auth-payments/template/src/app/login/page.tsx +109 -0
  36. package/dist/templates/web/ui-auth-payments/template/src/app/page.tsx +143 -0
  37. package/dist/templates/web/ui-auth-payments/template/src/app/signup/page.tsx +128 -0
  38. package/dist/templates/web/ui-auth-payments/template/src/components/providers/app-providers.tsx +28 -0
  39. package/dist/templates/web/ui-auth-payments/template/src/components/shared/header.tsx +60 -0
  40. package/dist/templates/web/ui-auth-payments/template/src/components/ui/badge.tsx +36 -0
  41. package/dist/templates/web/ui-auth-payments/template/src/lib/utils.ts +7 -0
  42. package/dist/templates/web/ui-auth-payments/template/tailwind.config.js +77 -0
  43. package/dist/templates/web/ui-auth-payments/template/tsconfig.json +33 -0
  44. package/dist/templates/web/ui-auth-payments-audio/template/README.md +187 -0
  45. package/{src/templates/web/web-ui-package → dist/templates/web/ui-auth-payments-audio}/template/next.config.js +0 -3
  46. package/dist/templates/web/ui-auth-payments-audio/template/package.json +42 -0
  47. package/dist/templates/web/ui-auth-payments-audio/template/src/app/auth/callback/route.ts +12 -0
  48. package/dist/templates/web/ui-auth-payments-audio/template/src/app/billing/page.tsx +211 -0
  49. package/dist/templates/web/ui-auth-payments-audio/template/src/app/checkout/page.tsx +142 -0
  50. package/dist/templates/web/ui-auth-payments-audio/template/src/app/login/page.tsx +109 -0
  51. package/dist/templates/web/ui-auth-payments-audio/template/src/app/page.tsx +181 -0
  52. package/dist/templates/web/ui-auth-payments-audio/template/src/app/signup/page.tsx +128 -0
  53. package/dist/templates/web/ui-auth-payments-audio/template/src/components/providers/app-providers.tsx +28 -0
  54. package/dist/templates/web/ui-auth-payments-audio/template/src/components/shared/header.tsx +60 -0
  55. package/{src/templates/web/web-ui-package → dist/templates/web/ui-auth-payments-audio}/template/tailwind.config.js +1 -1
  56. package/dist/templates/web/ui-auth-payments-video/template/README.md +190 -0
  57. package/dist/templates/web/{web-ui-package → ui-auth-payments-video}/template/next.config.js +0 -3
  58. package/dist/templates/web/ui-auth-payments-video/template/package.json +42 -0
  59. package/dist/templates/web/ui-auth-payments-video/template/src/app/auth/callback/route.ts +12 -0
  60. package/dist/templates/web/ui-auth-payments-video/template/src/app/billing/page.tsx +211 -0
  61. package/dist/templates/web/ui-auth-payments-video/template/src/app/checkout/page.tsx +142 -0
  62. package/dist/templates/web/ui-auth-payments-video/template/src/app/login/page.tsx +109 -0
  63. package/dist/templates/web/ui-auth-payments-video/template/src/app/page.tsx +187 -0
  64. package/dist/templates/web/ui-auth-payments-video/template/src/app/signup/page.tsx +128 -0
  65. package/dist/templates/web/ui-auth-payments-video/template/src/components/providers/app-providers.tsx +28 -0
  66. package/dist/templates/web/ui-auth-payments-video/template/src/components/shared/header.tsx +60 -0
  67. package/dist/templates/web/{web-ui-package → ui-auth-payments-video}/template/tailwind.config.js +1 -1
  68. package/dist/templates/web/ui-only/template/next.config.js +12 -0
  69. package/dist/templates/web/{web-ui-package → ui-only}/template/package.json +3 -3
  70. package/dist/templates/web/ui-only/template/postcss.config.js +7 -0
  71. package/dist/templates/web/ui-only/template/src/app/auth/callback/route.ts +12 -0
  72. package/dist/templates/web/{web-ui-package → ui-only}/template/src/app/checkout/page.tsx +25 -28
  73. package/dist/templates/web/ui-only/template/src/app/globals.css +42 -0
  74. package/dist/templates/web/ui-only/template/src/app/layout.tsx +29 -0
  75. package/dist/templates/web/ui-only/template/src/app/login/page.tsx +63 -0
  76. package/dist/templates/web/ui-only/template/src/app/signup/page.tsx +79 -0
  77. package/dist/templates/web/ui-only/template/src/components/providers/app-providers.tsx +22 -0
  78. package/dist/templates/web/{web-ui-package → ui-only}/template/src/components/shared/header.tsx +17 -8
  79. package/dist/templates/web/ui-only/template/src/components/ui/badge.tsx +36 -0
  80. package/dist/templates/web/ui-only/template/src/lib/utils.ts +7 -0
  81. package/dist/templates/web/ui-only/template/tailwind.config.js +77 -0
  82. package/dist/templates/web/ui-only/template/tsconfig.json +33 -0
  83. package/dist/templates/web/ui-package-test/template/package.json +2 -2
  84. package/package.json +1 -1
  85. package/src/templates/mobile/base/template/.env.example +15 -15
  86. package/src/templates/mobile/base/template/app/checkout.tsx +20 -20
  87. package/src/templates/web/base/template/src/app/checkout/page.tsx +28 -28
  88. package/src/templates/web/ui-auth/template/README.md +68 -0
  89. package/src/templates/web/ui-auth/template/next.config.js +12 -0
  90. package/src/templates/web/ui-auth/template/package.json +40 -0
  91. package/src/templates/web/ui-auth/template/postcss.config.js +7 -0
  92. package/src/templates/web/ui-auth/template/src/app/auth/callback/route.ts +12 -0
  93. package/src/templates/web/ui-auth/template/src/app/checkout/page.tsx +25 -0
  94. package/src/templates/web/ui-auth/template/src/app/globals.css +42 -0
  95. package/src/templates/web/ui-auth/template/src/app/layout.tsx +29 -0
  96. package/src/templates/web/ui-auth/template/src/app/login/page.tsx +109 -0
  97. package/src/templates/web/ui-auth/template/src/app/page.tsx +129 -0
  98. package/src/templates/web/ui-auth/template/src/app/signup/page.tsx +128 -0
  99. package/src/templates/web/ui-auth/template/src/components/providers/app-providers.tsx +25 -0
  100. package/src/templates/web/ui-auth/template/src/components/shared/header.tsx +51 -0
  101. package/src/templates/web/ui-auth/template/src/components/ui/badge.tsx +36 -0
  102. package/src/templates/web/ui-auth/template/src/lib/utils.ts +7 -0
  103. package/src/templates/web/ui-auth/template/tailwind.config.js +77 -0
  104. package/src/templates/web/ui-auth/template/tsconfig.json +33 -0
  105. package/src/templates/web/ui-auth-payments/template/README.md +165 -0
  106. package/src/templates/web/ui-auth-payments/template/next.config.js +12 -0
  107. package/src/templates/web/ui-auth-payments/template/package.json +42 -0
  108. package/src/templates/web/ui-auth-payments/template/postcss.config.js +7 -0
  109. package/src/templates/web/ui-auth-payments/template/src/app/auth/callback/route.ts +12 -0
  110. package/src/templates/web/ui-auth-payments/template/src/app/billing/page.tsx +211 -0
  111. package/src/templates/web/ui-auth-payments/template/src/app/checkout/page.tsx +142 -0
  112. package/src/templates/web/ui-auth-payments/template/src/app/globals.css +42 -0
  113. package/src/templates/web/ui-auth-payments/template/src/app/layout.tsx +29 -0
  114. package/src/templates/web/ui-auth-payments/template/src/app/login/page.tsx +109 -0
  115. package/src/templates/web/ui-auth-payments/template/src/app/page.tsx +143 -0
  116. package/src/templates/web/ui-auth-payments/template/src/app/signup/page.tsx +128 -0
  117. package/src/templates/web/ui-auth-payments/template/src/components/providers/app-providers.tsx +28 -0
  118. package/src/templates/web/ui-auth-payments/template/src/components/shared/header.tsx +60 -0
  119. package/src/templates/web/ui-auth-payments/template/src/components/ui/badge.tsx +36 -0
  120. package/src/templates/web/ui-auth-payments/template/src/lib/utils.ts +7 -0
  121. package/src/templates/web/ui-auth-payments/template/tailwind.config.js +77 -0
  122. package/src/templates/web/ui-auth-payments/template/tsconfig.json +33 -0
  123. package/src/templates/web/ui-auth-payments-audio/template/README.md +187 -0
  124. package/src/templates/web/ui-auth-payments-audio/template/next.config.js +12 -0
  125. package/src/templates/web/ui-auth-payments-audio/template/package.json +42 -0
  126. package/src/templates/web/ui-auth-payments-audio/template/postcss.config.js +7 -0
  127. package/src/templates/web/ui-auth-payments-audio/template/src/app/auth/callback/route.ts +12 -0
  128. package/src/templates/web/ui-auth-payments-audio/template/src/app/billing/page.tsx +211 -0
  129. package/src/templates/web/ui-auth-payments-audio/template/src/app/checkout/page.tsx +142 -0
  130. package/src/templates/web/ui-auth-payments-audio/template/src/app/globals.css +42 -0
  131. package/src/templates/web/ui-auth-payments-audio/template/src/app/layout.tsx +29 -0
  132. package/src/templates/web/ui-auth-payments-audio/template/src/app/login/page.tsx +109 -0
  133. package/src/templates/web/ui-auth-payments-audio/template/src/app/page.tsx +181 -0
  134. package/src/templates/web/ui-auth-payments-audio/template/src/app/signup/page.tsx +128 -0
  135. package/src/templates/web/ui-auth-payments-audio/template/src/components/providers/app-providers.tsx +28 -0
  136. package/src/templates/web/ui-auth-payments-audio/template/src/components/shared/header.tsx +60 -0
  137. package/src/templates/web/ui-auth-payments-audio/template/src/components/ui/badge.tsx +36 -0
  138. package/src/templates/web/ui-auth-payments-audio/template/src/lib/utils.ts +7 -0
  139. package/src/templates/web/ui-auth-payments-audio/template/tailwind.config.js +77 -0
  140. package/src/templates/web/ui-auth-payments-audio/template/tsconfig.json +33 -0
  141. package/src/templates/web/ui-auth-payments-video/template/README.md +190 -0
  142. package/src/templates/web/ui-auth-payments-video/template/next.config.js +12 -0
  143. package/src/templates/web/ui-auth-payments-video/template/package.json +42 -0
  144. package/src/templates/web/ui-auth-payments-video/template/postcss.config.js +7 -0
  145. package/src/templates/web/ui-auth-payments-video/template/src/app/auth/callback/route.ts +12 -0
  146. package/src/templates/web/ui-auth-payments-video/template/src/app/billing/page.tsx +211 -0
  147. package/src/templates/web/ui-auth-payments-video/template/src/app/checkout/page.tsx +142 -0
  148. package/src/templates/web/ui-auth-payments-video/template/src/app/globals.css +42 -0
  149. package/src/templates/web/ui-auth-payments-video/template/src/app/layout.tsx +29 -0
  150. package/src/templates/web/ui-auth-payments-video/template/src/app/login/page.tsx +109 -0
  151. package/src/templates/web/ui-auth-payments-video/template/src/app/page.tsx +187 -0
  152. package/src/templates/web/ui-auth-payments-video/template/src/app/signup/page.tsx +128 -0
  153. package/src/templates/web/ui-auth-payments-video/template/src/components/providers/app-providers.tsx +28 -0
  154. package/src/templates/web/ui-auth-payments-video/template/src/components/shared/header.tsx +60 -0
  155. package/src/templates/web/ui-auth-payments-video/template/src/components/ui/badge.tsx +36 -0
  156. package/src/templates/web/ui-auth-payments-video/template/src/lib/utils.ts +7 -0
  157. package/src/templates/web/ui-auth-payments-video/template/tailwind.config.js +77 -0
  158. package/src/templates/web/ui-auth-payments-video/template/tsconfig.json +33 -0
  159. package/src/templates/web/ui-only/template/.env.example +15 -0
  160. package/src/templates/web/ui-only/template/README.md +68 -0
  161. package/src/templates/web/ui-only/template/next.config.js +12 -0
  162. package/src/templates/web/{web-ui-package → ui-only}/template/package.json +3 -3
  163. package/src/templates/web/ui-only/template/postcss.config.js +7 -0
  164. package/src/templates/web/ui-only/template/src/app/auth/callback/route.ts +12 -0
  165. package/src/templates/web/ui-only/template/src/app/checkout/page.tsx +25 -0
  166. package/src/templates/web/ui-only/template/src/app/globals.css +42 -0
  167. package/src/templates/web/ui-only/template/src/app/layout.tsx +29 -0
  168. package/src/templates/web/ui-only/template/src/app/login/page.tsx +63 -0
  169. package/src/templates/web/ui-only/template/src/app/signup/page.tsx +79 -0
  170. package/src/templates/web/ui-only/template/src/components/providers/app-providers.tsx +22 -0
  171. package/src/templates/web/ui-only/template/src/components/shared/header.tsx +51 -0
  172. package/src/templates/web/ui-only/template/src/components/ui/badge.tsx +36 -0
  173. package/src/templates/web/ui-only/template/src/lib/utils.ts +7 -0
  174. package/src/templates/web/ui-only/template/tailwind.config.js +77 -0
  175. package/src/templates/web/ui-only/template/tsconfig.json +33 -0
  176. package/src/templates/web/ui-only/template.backup/.env.example +15 -0
  177. package/{dist/mobile/base/template → src/templates/web/ui-only/template.backup.20250817}/.env.example +15 -15
  178. package/src/templates/web/ui-package-test/template/package.json +2 -2
  179. package/dist/templates/web/web-ui-package/template/src/app/auth/callback/route.ts +0 -18
  180. package/dist/templates/web/web-ui-package/template/src/app/login/page.tsx +0 -39
  181. package/dist/templates/web/web-ui-package/template/src/app/signup/page.tsx +0 -39
  182. package/dist/templates/web/web-ui-package/template/src/components/providers/app-providers.tsx +0 -29
  183. package/src/templates/web/web-ui-package/template/.eslintrc.js +0 -8
  184. package/src/templates/web/web-ui-package/template/src/app/auth/callback/route.ts +0 -18
  185. package/src/templates/web/web-ui-package/template/src/app/login/page.tsx +0 -39
  186. package/src/templates/web/web-ui-package/template/src/app/signup/page.tsx +0 -39
  187. package/src/templates/web/web-ui-package/template/src/components/providers/app-providers.tsx +0 -29
  188. /package/dist/{web/base → templates/web/ui-auth}/template/.env.example +0 -0
  189. /package/dist/templates/web/{web-ui-package → ui-auth}/template/.eslintrc.js +0 -0
  190. /package/dist/templates/web/{web-ui-package → ui-auth}/template/README.md +0 -0
  191. /package/dist/{web/base → templates/web/ui-auth}/template.backup/.env.example +0 -0
  192. /package/dist/{web/base → templates/web/ui-auth}/template.backup.20250817/.env.example +0 -0
  193. /package/dist/templates/web/{web-ui-package → ui-auth-payments}/template/.env.example +0 -0
  194. /package/dist/templates/web/{web-ui-package/template.backup.20250817 → ui-auth-payments-audio/template}/.env.example +0 -0
  195. /package/dist/templates/web/{web-ui-package → ui-auth-payments-audio}/template/postcss.config.js +0 -0
  196. /package/dist/templates/web/{web-ui-package → ui-auth-payments-audio}/template/src/app/globals.css +0 -0
  197. /package/dist/templates/web/{web-ui-package → ui-auth-payments-audio}/template/src/app/layout.tsx +0 -0
  198. /package/dist/templates/web/{web-ui-package → ui-auth-payments-audio}/template/src/components/ui/badge.tsx +0 -0
  199. /package/dist/templates/web/{web-ui-package → ui-auth-payments-audio}/template/src/lib/utils.ts +0 -0
  200. /package/dist/templates/web/{web-ui-package → ui-auth-payments-audio}/template/tsconfig.json +0 -0
  201. /package/dist/templates/web/{web-ui-package/template.backup → ui-auth-payments-video/template}/.env.example +0 -0
  202. /package/{src/templates/web/web-ui-package → dist/templates/web/ui-auth-payments-video}/template/postcss.config.js +0 -0
  203. /package/{src/templates/web/web-ui-package → dist/templates/web/ui-auth-payments-video}/template/src/app/globals.css +0 -0
  204. /package/{src/templates/web/web-ui-package → dist/templates/web/ui-auth-payments-video}/template/src/app/layout.tsx +0 -0
  205. /package/{src/templates/web/web-ui-package → dist/templates/web/ui-auth-payments-video}/template/src/components/ui/badge.tsx +0 -0
  206. /package/{src/templates/web/web-ui-package → dist/templates/web/ui-auth-payments-video}/template/src/lib/utils.ts +0 -0
  207. /package/{src/templates/web/web-ui-package → dist/templates/web/ui-auth-payments-video}/template/tsconfig.json +0 -0
  208. /package/dist/{web/ui-package-test → templates/web/ui-only}/template/.env.example +0 -0
  209. /package/dist/{web/base → templates/web/ui-only}/template/.eslintrc.js +0 -0
  210. /package/{src/templates/web/web-ui-package → dist/templates/web/ui-only}/template/README.md +0 -0
  211. /package/dist/templates/web/{web-ui-package → ui-only}/template/src/app/page.tsx +0 -0
  212. /package/dist/{web/ui-package-test → templates/web/ui-only}/template.backup/.env.example +0 -0
  213. /package/dist/{web/ui-package-test → templates/web/ui-only}/template.backup.20250817/.env.example +0 -0
  214. /package/src/templates/web/{web-ui-package → ui-auth}/template/.env.example +0 -0
  215. /package/{dist/web/ui-package-test → src/templates/web/ui-auth}/template/.eslintrc.js +0 -0
  216. /package/src/templates/web/{web-ui-package → ui-auth}/template.backup/.env.example +0 -0
  217. /package/src/templates/web/{web-ui-package → ui-auth}/template.backup.20250817/.env.example +0 -0
  218. /package/{dist/web/web-ui-package → src/templates/web/ui-auth-payments}/template/.env.example +0 -0
  219. /package/{dist/web/web-ui-package/template.backup.20250817 → src/templates/web/ui-auth-payments-audio/template}/.env.example +0 -0
  220. /package/{dist/web/web-ui-package/template.backup → src/templates/web/ui-auth-payments-video/template}/.env.example +0 -0
  221. /package/{dist/web/web-ui-package → src/templates/web/ui-only}/template/.eslintrc.js +0 -0
  222. /package/src/templates/web/{web-ui-package → ui-only}/template/src/app/page.tsx +0 -0
@@ -1,28 +1,28 @@
1
- 'use client';
2
-
3
- import React from 'react';
4
- import { useStripe } from '@digilogiclabs/saas-factory-payments';
5
- import { Button } from '@/components/ui/button';
6
-
7
- export default function CheckoutPage() {
8
- const { handleCheckout } = useStripe();
9
-
10
- const onCheckout = async () => {
11
- await handleCheckout({
12
- priceId: 'price_12345', // Replace with your actual price ID
13
- returnUrl: `${window.location.origin}/dashboard`,
14
- });
15
- };
16
-
17
- return (
18
- <div className="flex items-center justify-center min-h-screen bg-gray-100">
19
- <div className="p-8 bg-white rounded-lg shadow-md">
20
- <h1 className="text-2xl font-bold mb-4">Checkout</h1>
21
- <p className="mb-6">Click the button below to proceed to payment.</p>
22
- <Button onClick={onCheckout}>
23
- Proceed to Checkout
24
- </Button>
25
- </div>
26
- </div>
27
- );
28
- }
1
+ 'use client';
2
+
3
+ import React from 'react';
4
+ import { useStripe } from '@digilogiclabs/saas-factory-payments';
5
+ import { Button } from '@/components/ui/button';
6
+
7
+ export default function CheckoutPage() {
8
+ const { handleCheckout } = useStripe();
9
+
10
+ const onCheckout = async () => {
11
+ await handleCheckout({
12
+ priceId: 'price_12345', // Replace with your actual price ID
13
+ returnUrl: `${window.location.origin}/dashboard`,
14
+ });
15
+ };
16
+
17
+ return (
18
+ <div className="flex items-center justify-center min-h-screen bg-gray-100">
19
+ <div className="p-8 bg-white rounded-lg shadow-md">
20
+ <h1 className="text-2xl font-bold mb-4">Checkout</h1>
21
+ <p className="mb-6">Click the button below to proceed to payment.</p>
22
+ <Button onClick={onCheckout}>
23
+ Proceed to Checkout
24
+ </Button>
25
+ </div>
26
+ </div>
27
+ );
28
+ }
@@ -0,0 +1,12 @@
1
+ /** @type {import('next').NextConfig} */
2
+ const nextConfig = {
3
+ images: {
4
+ domains: ['localhost'],
5
+ },
6
+ env: {
7
+ CUSTOM_KEY: process.env.CUSTOM_KEY,
8
+ },
9
+ }
10
+
11
+ module.exports = nextConfig
12
+
@@ -0,0 +1,40 @@
1
+ {
2
+ "name": "{{packageName}}",
3
+ "version": "0.1.0",
4
+ "description": "{{description}} (with UI Package v0.11.1 + Auth v1.0.0)",
5
+ "private": true,
6
+ "scripts": {
7
+ "dev": "next dev",
8
+ "build": "next build",
9
+ "start": "next start",
10
+ "lint": "next lint",
11
+ "type-check": "tsc --noEmit"
12
+ },
13
+ "dependencies": {
14
+ "next": "^15.0.0",
15
+ "react": "^19.0.0",
16
+ "react-dom": "^19.0.0",
17
+ "@digilogiclabs/saas-factory-ui": "^0.11.1",
18
+ "@digilogiclabs/saas-factory-auth": "^1.0.0",
19
+ "tailwindcss": "^3.3.0",
20
+ "autoprefixer": "^10.4.16",
21
+ "postcss": "^8.4.31",
22
+ "clsx": "^2.0.0",
23
+ "class-variance-authority": "^0.7.0",
24
+ "tailwind-merge": "^2.0.0",
25
+ "next-themes": "^0.2.1",
26
+ "lucide-react": "^0.542.0"
27
+ },
28
+ "devDependencies": {
29
+ "typescript": "^5.0.0",
30
+ "@types/node": "^20.0.0",
31
+ "@types/react": "^19.0.0",
32
+ "@types/react-dom": "^19.0.0",
33
+ "eslint": "^8.0.0",
34
+ "eslint-config-next": "^15.0.0",
35
+ "prettier": "^3.0.0"
36
+ },
37
+ "engines": {
38
+ "node": ">=18.0.0"
39
+ }
40
+ }
@@ -0,0 +1,7 @@
1
+ module.exports = {
2
+ plugins: {
3
+ tailwindcss: {},
4
+ autoprefixer: {},
5
+ },
6
+ }
7
+
@@ -0,0 +1,12 @@
1
+ import { NextResponse } from 'next/server';
2
+ import type { NextRequest } from 'next/server';
3
+
4
+ export async function GET(request: NextRequest) {
5
+ const requestUrl = new URL(request.url);
6
+
7
+ // Placeholder auth callback - requires @digilogiclabs/saas-factory-auth package
8
+ console.log('Auth callback triggered - requires auth package for full functionality');
9
+
10
+ // URL to redirect to after sign in process completes
11
+ return NextResponse.redirect(requestUrl.origin);
12
+ }
@@ -1,28 +1,25 @@
1
- 'use client';
2
-
3
- import React from 'react';
4
- import { useStripe } from '@digilogiclabs/saas-factory-payments';
5
- import { Button } from '@/components/ui/button';
6
-
7
- export default function CheckoutPage() {
8
- const { handleCheckout } = useStripe();
9
-
10
- const onCheckout = async () => {
11
- await handleCheckout({
12
- priceId: 'price_12345', // Replace with your actual price ID
13
- returnUrl: `${window.location.origin}/dashboard`,
14
- });
15
- };
16
-
17
- return (
18
- <div className="flex items-center justify-center min-h-screen bg-gray-100">
19
- <div className="p-8 bg-white rounded-lg shadow-md">
20
- <h1 className="text-2xl font-bold mb-4">Checkout</h1>
21
- <p className="mb-6">Click the button below to proceed to payment.</p>
22
- <Button onClick={onCheckout}>
23
- Proceed to Checkout
24
- </Button>
25
- </div>
26
- </div>
27
- );
28
- }
1
+ 'use client';
2
+
3
+ import React from 'react';
4
+
5
+ export default function CheckoutPage() {
6
+ const onCheckout = async () => {
7
+ alert('Checkout functionality requires @digilogiclabs/saas-factory-payments package');
8
+ };
9
+
10
+ return (
11
+ <div className="flex items-center justify-center min-h-screen bg-gray-100">
12
+ <div className="p-8 bg-white rounded-lg shadow-md">
13
+ <h1 className="text-2xl font-bold mb-4">Checkout</h1>
14
+ <p className="mb-6">Click the button below to proceed to payment.</p>
15
+ <button
16
+ onClick={onCheckout}
17
+ className="px-4 py-2 bg-blue-600 text-white rounded hover:bg-blue-700"
18
+ >
19
+ Proceed to Checkout
20
+ </button>
21
+ </div>
22
+ </div>
23
+ );
24
+ }
25
+
@@ -0,0 +1,42 @@
1
+ @tailwind base;
2
+ @tailwind components;
3
+ @tailwind utilities;
4
+
5
+ /* Import SaaS Factory UI styles */
6
+ @import '@digilogiclabs/saas-factory-ui/dist/index.css';
7
+
8
+ @layer base {
9
+ :root {
10
+ --background: 0 0% 100%;
11
+ --foreground: 222.2 84% 4.9%;
12
+ --card: 0 0% 100%;
13
+ --card-foreground: 222.2 84% 4.9%;
14
+ --primary: 221.2 83.2% 53.3%;
15
+ --primary-foreground: 210 40% 98%;
16
+ --secondary: 210 40% 96%;
17
+ --secondary-foreground: 222.2 84% 4.9%;
18
+ --border: 214.3 31.8% 91.4%;
19
+ --radius: 0.5rem;
20
+ }
21
+
22
+ .dark {
23
+ --background: 222.2 84% 4.9%;
24
+ --foreground: 210 40% 98%;
25
+ --card: 222.2 84% 4.9%;
26
+ --card-foreground: 210 40% 98%;
27
+ --primary: 217.2 91.2% 59.8%;
28
+ --primary-foreground: 222.2 84% 4.9%;
29
+ --secondary: 217.2 32.6% 17.5%;
30
+ --secondary-foreground: 210 40% 98%;
31
+ --border: 217.2 32.6% 17.5%;
32
+ }
33
+ }
34
+
35
+ @layer base {
36
+ * {
37
+ @apply border-border;
38
+ }
39
+ body {
40
+ @apply bg-background text-foreground;
41
+ }
42
+ }
@@ -0,0 +1,29 @@
1
+ import type { Metadata } from 'next'
2
+ import { Inter } from 'next/font/google'
3
+ import './globals.css'
4
+ import { AppProviders } from '@/components/providers/app-providers'
5
+ import { Header } from '@/components/shared/header'
6
+
7
+ const inter = Inter({ subsets: ['latin'] })
8
+
9
+ export const metadata: Metadata = {
10
+ title: '{{titleCaseName}}',
11
+ description: '{{description}}',
12
+ }
13
+
14
+ export default function RootLayout({
15
+ children,
16
+ }: {
17
+ children: React.ReactNode
18
+ }) {
19
+ return (
20
+ <html lang="en" suppressHydrationWarning>
21
+ <body className={inter.className}>
22
+ <AppProviders>
23
+ <Header />
24
+ {children}
25
+ </AppProviders>
26
+ </body>
27
+ </html>
28
+ )
29
+ }
@@ -0,0 +1,109 @@
1
+ 'use client';
2
+
3
+ import React, { useState } from 'react';
4
+ import { Button, Card, Input, Label } from '@digilogiclabs/saas-factory-ui';
5
+ import { useAuth } from '@digilogiclabs/saas-factory-auth';
6
+ import { useRouter } from 'next/navigation';
7
+
8
+ export default function LoginPage() {
9
+ const [email, setEmail] = useState('');
10
+ const [password, setPassword] = useState('');
11
+ const { signIn, signInWithOAuth, loading, error, user } = useAuth();
12
+ const router = useRouter();
13
+
14
+ // Redirect if already logged in
15
+ React.useEffect(() => {
16
+ if (user) {
17
+ router.push('/');
18
+ }
19
+ }, [user, router]);
20
+
21
+ const handleLogin = async (e: React.FormEvent) => {
22
+ e.preventDefault();
23
+ try {
24
+ await signIn(email, password);
25
+ router.push('/');
26
+ } catch (err) {
27
+ console.error('Login error:', err);
28
+ }
29
+ };
30
+
31
+ const handleGoogleLogin = async () => {
32
+ try {
33
+ await signInWithOAuth('google', window.location.origin);
34
+ } catch (err) {
35
+ console.error('Google login error:', err);
36
+ }
37
+ };
38
+
39
+ if (loading) {
40
+ return (
41
+ <div className="flex items-center justify-center min-h-screen bg-gray-100">
42
+ <div>Loading...</div>
43
+ </div>
44
+ );
45
+ }
46
+
47
+ return (
48
+ <div className="flex items-center justify-center min-h-screen bg-gray-100">
49
+ <Card className="w-full max-w-md p-8">
50
+ <h1 className="text-2xl font-bold text-center mb-6">Sign In</h1>
51
+
52
+ {error && (
53
+ <div className="mb-4 p-3 bg-red-100 border border-red-400 text-red-700 rounded">
54
+ {error.message}
55
+ </div>
56
+ )}
57
+
58
+ <form onSubmit={handleLogin} className="space-y-4">
59
+ <div>
60
+ <Label htmlFor="email">Email</Label>
61
+ <Input
62
+ id="email"
63
+ type="email"
64
+ value={email}
65
+ onChange={(e) => setEmail(e.target.value)}
66
+ placeholder="Enter your email"
67
+ required
68
+ disabled={loading}
69
+ />
70
+ </div>
71
+ <div>
72
+ <Label htmlFor="password">Password</Label>
73
+ <Input
74
+ id="password"
75
+ type="password"
76
+ value={password}
77
+ onChange={(e) => setPassword(e.target.value)}
78
+ placeholder="Enter your password"
79
+ required
80
+ disabled={loading}
81
+ />
82
+ </div>
83
+ <Button type="submit" className="w-full" disabled={loading}>
84
+ {loading ? 'Signing In...' : 'Sign In'}
85
+ </Button>
86
+ <Button
87
+ type="button"
88
+ variant="outline"
89
+ className="w-full"
90
+ onClick={handleGoogleLogin}
91
+ disabled={loading}
92
+ >
93
+ Sign in with Google
94
+ </Button>
95
+ </form>
96
+
97
+ <div className="mt-4 text-center">
98
+ <p className="text-sm text-gray-600">
99
+ Don&apos;t have an account?{' '}
100
+ <a href="/signup" className="text-blue-600 hover:underline">
101
+ Sign up
102
+ </a>
103
+ </p>
104
+ </div>
105
+ </Card>
106
+ </div>
107
+ );
108
+ }
109
+
@@ -0,0 +1,129 @@
1
+ 'use client'
2
+
3
+ import { Button, Card } from '@digilogiclabs/saas-factory-ui'
4
+ import { ArrowRight, Zap, Shield, Rocket, CheckCircle, LogOut, User } from 'lucide-react'
5
+ import { useAuth } from '@digilogiclabs/saas-factory-auth'
6
+ import Link from 'next/link'
7
+
8
+ export default function Home() {
9
+ const { user, signOut, loading } = useAuth()
10
+
11
+ const handleSignOut = async () => {
12
+ try {
13
+ await signOut()
14
+ } catch (err) {
15
+ console.error('Sign out error:', err)
16
+ }
17
+ }
18
+
19
+ return (
20
+ <main className="min-h-screen bg-gradient-to-br from-blue-50 to-indigo-100 dark:from-gray-900 dark:to-gray-800">
21
+ <div className="container mx-auto px-4 py-16">
22
+ {/* Auth Status Bar */}
23
+ <div className="flex justify-end mb-8">
24
+ {loading ? (
25
+ <div className="text-sm text-gray-600">Loading...</div>
26
+ ) : user ? (
27
+ <div className="flex items-center gap-4">
28
+ <div className="flex items-center gap-2 text-sm text-gray-600 dark:text-gray-300">
29
+ <User className="w-4 h-4" />
30
+ Welcome, {user.email}
31
+ </div>
32
+ <Button variant="outline" size="sm" onClick={handleSignOut}>
33
+ <LogOut className="w-4 h-4 mr-2" />
34
+ Sign Out
35
+ </Button>
36
+ </div>
37
+ ) : (
38
+ <div className="flex gap-2">
39
+ <Link href="/login">
40
+ <Button variant="outline" size="sm">Sign In</Button>
41
+ </Link>
42
+ <Link href="/signup">
43
+ <Button size="sm">Sign Up</Button>
44
+ </Link>
45
+ </div>
46
+ )}
47
+ </div>
48
+
49
+ {/* Hero Section */}
50
+ <div className="text-center mb-16">
51
+ <div className="inline-flex items-center px-4 py-2 rounded-full text-sm font-medium bg-green-100 text-green-800 dark:bg-green-900 dark:text-green-200 mb-6">
52
+ <CheckCircle className="w-4 h-4 mr-2" />
53
+ UI Package v0.7.3 + Auth v0.4.4 Integrated Successfully
54
+ </div>
55
+ <h1 className="text-4xl md:text-6xl font-bold text-gray-900 dark:text-white mb-6">
56
+ Welcome to{' '}
57
+ <span className="text-blue-600 dark:text-blue-400">{{titleCaseName}}</span>
58
+ </h1>
59
+ <p className="text-xl text-gray-600 dark:text-gray-300 mb-8 max-w-2xl mx-auto">
60
+ {{description}}. This template uses the stable SaaS Factory UI package v0.7.3 with authentication v0.4.4.
61
+ </p>
62
+ <div className="flex flex-col sm:flex-row gap-4 justify-center">
63
+ <Button size="lg" className="text-lg px-8">
64
+ Get Started
65
+ <ArrowRight className="ml-2 h-5 w-5" />
66
+ </Button>
67
+ <Button variant="outline" size="lg" className="text-lg px-8">
68
+ Learn More
69
+ </Button>
70
+ </div>
71
+ </div>
72
+
73
+ {/* Component Showcase */}
74
+ <div className="grid md:grid-cols-3 gap-8 mb-16">
75
+ <Card className="text-center p-6">
76
+ <div className="mx-auto w-12 h-12 bg-blue-100 dark:bg-blue-900 rounded-lg flex items-center justify-center mb-4">
77
+ <Zap className="h-6 w-6 text-blue-600 dark:text-blue-400" />
78
+ </div>
79
+ <h3 className="text-xl font-semibold mb-2">UI Package Components</h3>
80
+ <p className="text-gray-600 dark:text-gray-300">
81
+ Button and Card components from @digilogiclabs/saas-factory-ui
82
+ </p>
83
+ </Card>
84
+
85
+ <Card className="text-center p-6">
86
+ <div className="mx-auto w-12 h-12 bg-green-100 dark:bg-green-900 rounded-lg flex items-center justify-center mb-4">
87
+ <Shield className="h-6 w-6 text-green-600 dark:text-green-400" />
88
+ </div>
89
+ <h3 className="text-xl font-semibold mb-2">Hybrid Architecture</h3>
90
+ <p className="text-gray-600 dark:text-gray-300">
91
+ Clean web build with no React Native contamination
92
+ </p>
93
+ </Card>
94
+
95
+ <Card className="text-center p-6">
96
+ <div className="mx-auto w-12 h-12 bg-purple-100 dark:bg-purple-900 rounded-lg flex items-center justify-center mb-4">
97
+ <Rocket className="h-6 w-6 text-purple-600 dark:text-purple-400" />
98
+ </div>
99
+ <h3 className="text-xl font-semibold mb-2">TypeScript Ready</h3>
100
+ <p className="text-gray-600 dark:text-gray-300">
101
+ Full type safety with enhanced component definitions
102
+ </p>
103
+ </Card>
104
+ </div>
105
+
106
+ {/* Button Variants Showcase */}
107
+ <Card className="max-w-4xl mx-auto p-8">
108
+ <div className="text-center mb-6">
109
+ <h2 className="text-2xl font-bold mb-2">UI Package Component Showcase</h2>
110
+ <p className="text-gray-600 dark:text-gray-300">
111
+ Testing Button variants from the stable UI package
112
+ </p>
113
+ </div>
114
+ <div className="flex flex-wrap justify-center gap-4 mb-6">
115
+ <Button>Default Button</Button>
116
+ <Button variant="secondary">Secondary Button</Button>
117
+ <Button variant="outline">Outline Button</Button>
118
+ <Button disabled>Disabled Button</Button>
119
+ </div>
120
+ <div className="text-center">
121
+ <p className="text-sm text-gray-500">
122
+ All components imported from @digilogiclabs/saas-factory-ui v0.7.3
123
+ </p>
124
+ </div>
125
+ </Card>
126
+ </div>
127
+ </main>
128
+ )
129
+ }
@@ -0,0 +1,128 @@
1
+ 'use client';
2
+
3
+ import React, { useState } from 'react';
4
+ import { Button, Card, Input, Label } from '@digilogiclabs/saas-factory-ui';
5
+ import { useAuth } from '@digilogiclabs/saas-factory-auth';
6
+ import { useRouter } from 'next/navigation';
7
+
8
+ export default function SignupPage() {
9
+ const [email, setEmail] = useState('');
10
+ const [password, setPassword] = useState('');
11
+ const [confirmPassword, setConfirmPassword] = useState('');
12
+ const { signUp, signInWithOAuth, loading, error, user } = useAuth();
13
+ const router = useRouter();
14
+
15
+ // Redirect if already logged in
16
+ React.useEffect(() => {
17
+ if (user) {
18
+ router.push('/');
19
+ }
20
+ }, [user, router]);
21
+
22
+ const handleSignup = async (e: React.FormEvent) => {
23
+ e.preventDefault();
24
+
25
+ if (password !== confirmPassword) {
26
+ alert('Passwords do not match');
27
+ return;
28
+ }
29
+
30
+ try {
31
+ await signUp(email, password);
32
+ router.push('/');
33
+ } catch (err) {
34
+ console.error('Signup error:', err);
35
+ }
36
+ };
37
+
38
+ const handleGoogleSignup = async () => {
39
+ try {
40
+ await signInWithOAuth('google', window.location.origin);
41
+ } catch (err) {
42
+ console.error('Google signup error:', err);
43
+ }
44
+ };
45
+
46
+ if (loading) {
47
+ return (
48
+ <div className="flex items-center justify-center min-h-screen bg-gray-100">
49
+ <div>Loading...</div>
50
+ </div>
51
+ );
52
+ }
53
+
54
+ return (
55
+ <div className="flex items-center justify-center min-h-screen bg-gray-100">
56
+ <Card className="w-full max-w-md p-8">
57
+ <h1 className="text-2xl font-bold text-center mb-6">Sign Up</h1>
58
+
59
+ {error && (
60
+ <div className="mb-4 p-3 bg-red-100 border border-red-400 text-red-700 rounded">
61
+ {error.message}
62
+ </div>
63
+ )}
64
+
65
+ <form onSubmit={handleSignup} className="space-y-4">
66
+ <div>
67
+ <Label htmlFor="email">Email</Label>
68
+ <Input
69
+ id="email"
70
+ type="email"
71
+ value={email}
72
+ onChange={(e) => setEmail(e.target.value)}
73
+ placeholder="Enter your email"
74
+ required
75
+ disabled={loading}
76
+ />
77
+ </div>
78
+ <div>
79
+ <Label htmlFor="password">Password</Label>
80
+ <Input
81
+ id="password"
82
+ type="password"
83
+ value={password}
84
+ onChange={(e) => setPassword(e.target.value)}
85
+ placeholder="Enter your password"
86
+ required
87
+ disabled={loading}
88
+ />
89
+ </div>
90
+ <div>
91
+ <Label htmlFor="confirmPassword">Confirm Password</Label>
92
+ <Input
93
+ id="confirmPassword"
94
+ type="password"
95
+ value={confirmPassword}
96
+ onChange={(e) => setConfirmPassword(e.target.value)}
97
+ placeholder="Confirm your password"
98
+ required
99
+ disabled={loading}
100
+ />
101
+ </div>
102
+ <Button type="submit" className="w-full" disabled={loading}>
103
+ {loading ? 'Signing Up...' : 'Sign Up'}
104
+ </Button>
105
+ <Button
106
+ type="button"
107
+ variant="outline"
108
+ className="w-full"
109
+ onClick={handleGoogleSignup}
110
+ disabled={loading}
111
+ >
112
+ Sign up with Google
113
+ </Button>
114
+ </form>
115
+
116
+ <div className="mt-4 text-center">
117
+ <p className="text-sm text-gray-600">
118
+ Already have an account?{' '}
119
+ <a href="/login" className="text-blue-600 hover:underline">
120
+ Sign in
121
+ </a>
122
+ </p>
123
+ </div>
124
+ </Card>
125
+ </div>
126
+ );
127
+ }
128
+
@@ -0,0 +1,25 @@
1
+ 'use client'
2
+
3
+ import React from 'react'
4
+ import { ThemeProvider } from 'next-themes'
5
+ import { AuthProvider } from '@digilogiclabs/saas-factory-auth'
6
+
7
+ interface AppProvidersProps {
8
+ children: React.ReactNode
9
+ }
10
+
11
+ export function AppProviders({ children }: AppProvidersProps) {
12
+ return (
13
+ <ThemeProvider
14
+ attribute="class"
15
+ defaultTheme="system"
16
+ enableSystem
17
+ disableTransitionOnChange
18
+ >
19
+ <AuthProvider>
20
+ {children}
21
+ </AuthProvider>
22
+ </ThemeProvider>
23
+ )
24
+ }
25
+