@digilogiclabs/create-saas-app 1.5.0 → 1.5.2
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.
- package/dist/.tsbuildinfo +1 -1
- package/dist/cli/commands/add.d.ts +6 -0
- package/dist/cli/commands/add.d.ts.map +1 -0
- package/dist/cli/commands/add.js +39 -0
- package/dist/cli/commands/add.js.map +1 -0
- package/dist/cli/commands/create.d.ts +28 -0
- package/dist/cli/commands/create.d.ts.map +1 -0
- package/dist/cli/commands/create.js +130 -0
- package/dist/cli/commands/create.js.map +1 -0
- package/dist/cli/commands/index.d.ts +4 -0
- package/dist/cli/commands/index.d.ts.map +1 -0
- package/dist/cli/commands/index.js +20 -0
- package/dist/cli/commands/index.js.map +1 -0
- package/dist/cli/commands/update.d.ts +6 -0
- package/dist/cli/commands/update.d.ts.map +1 -0
- package/dist/cli/commands/update.js +68 -0
- package/dist/cli/commands/update.js.map +1 -0
- package/dist/{index.d.ts → cli/index.d.ts} +2 -3
- package/dist/cli/index.d.ts.map +1 -0
- package/dist/cli/index.js +59 -0
- package/dist/cli/index.js.map +1 -0
- package/dist/cli/prompts/index.d.ts +2 -0
- package/dist/cli/prompts/index.d.ts.map +1 -0
- package/dist/cli/prompts/index.js +18 -0
- package/dist/cli/prompts/index.js.map +1 -0
- package/dist/cli/prompts/project-setup.d.ts +5 -0
- package/dist/cli/prompts/project-setup.d.ts.map +1 -0
- package/dist/cli/prompts/project-setup.js +251 -0
- package/dist/cli/prompts/project-setup.js.map +1 -0
- package/dist/cli/utils/git.d.ts +9 -0
- package/dist/cli/utils/git.d.ts.map +1 -0
- package/dist/cli/utils/git.js +77 -0
- package/dist/cli/utils/git.js.map +1 -0
- package/dist/cli/utils/index.d.ts +5 -0
- package/dist/cli/utils/index.d.ts.map +1 -0
- package/dist/cli/utils/index.js +21 -0
- package/dist/cli/utils/index.js.map +1 -0
- package/dist/cli/utils/logger.d.ts +16 -0
- package/dist/cli/utils/logger.d.ts.map +1 -0
- package/dist/cli/utils/logger.js +55 -0
- package/dist/cli/utils/logger.js.map +1 -0
- package/dist/cli/utils/package-manager.d.ts +8 -0
- package/dist/cli/utils/package-manager.d.ts.map +1 -0
- package/dist/cli/utils/package-manager.js +92 -0
- package/dist/cli/utils/package-manager.js.map +1 -0
- package/dist/cli/utils/spinner.d.ts +7 -0
- package/dist/cli/utils/spinner.d.ts.map +1 -0
- package/dist/cli/utils/spinner.js +48 -0
- package/dist/cli/utils/spinner.js.map +1 -0
- package/dist/cli/validators/dependencies.d.ts +15 -0
- package/dist/cli/validators/dependencies.d.ts.map +1 -0
- package/dist/cli/validators/dependencies.js +108 -0
- package/dist/cli/validators/dependencies.js.map +1 -0
- package/dist/cli/validators/index.d.ts +3 -0
- package/dist/cli/validators/index.d.ts.map +1 -0
- package/dist/cli/validators/index.js +19 -0
- package/dist/cli/validators/index.js.map +1 -0
- package/dist/cli/validators/project-name.d.ts +5 -0
- package/dist/cli/validators/project-name.d.ts.map +1 -0
- package/dist/cli/validators/project-name.js +151 -0
- package/dist/cli/validators/project-name.js.map +1 -0
- package/dist/generators/file-processor.d.ts +28 -0
- package/dist/generators/file-processor.d.ts.map +1 -0
- package/dist/generators/file-processor.js +203 -0
- package/dist/generators/file-processor.js.map +1 -0
- package/dist/generators/index.d.ts +4 -0
- package/dist/generators/index.d.ts.map +1 -0
- package/dist/generators/index.js +20 -0
- package/dist/generators/index.js.map +1 -0
- package/dist/generators/package-installer.d.ts +29 -0
- package/dist/generators/package-installer.d.ts.map +1 -0
- package/dist/generators/package-installer.js +167 -0
- package/dist/generators/package-installer.js.map +1 -0
- package/dist/generators/template-generator.d.ts +48 -0
- package/dist/generators/template-generator.d.ts.map +1 -0
- package/dist/generators/template-generator.js +276 -0
- package/dist/generators/template-generator.js.map +1 -0
- package/dist/index.js +3 -3
- package/dist/index.js.map +1 -1
- package/package.json +3 -3
- package/src/templates/web/base/template/package.json +58 -58
- package/src/templates/web/base/template/src/test/setup.ts +78 -78
- package/src/templates/web/ui-auth/template/package.json +50 -50
- package/src/templates/web/ui-auth/template/src/test/setup.ts +78 -78
- package/src/templates/web/ui-auth-payments/template/package-lock.json +12240 -0
- package/src/templates/web/ui-auth-payments/template/package.json +52 -52
- package/src/templates/web/ui-auth-payments/template/src/components/client/login-form.tsx +1 -1
- package/src/templates/web/ui-auth-payments/template/src/components/client/signup-form.tsx +3 -3
- package/src/templates/web/ui-auth-payments/template/src/test/setup.ts +78 -78
- package/src/templates/web/ui-auth-payments/template/tsconfig.tsbuildinfo +1 -0
- package/src/templates/web/ui-auth-payments-audio/template/package-lock.json +12241 -0
- package/src/templates/web/ui-auth-payments-audio/template/package.json +53 -52
- package/src/templates/web/ui-auth-payments-audio/template/src/app/login/page.tsx +2 -105
- package/src/templates/web/ui-auth-payments-audio/template/src/app/signup/page.tsx +2 -124
- package/{dist/templates/web/ui-auth-payments → src/templates/web/ui-auth-payments-audio}/template/src/components/client/login-form.tsx +1 -1
- package/{dist/templates/web/ui-auth-payments → src/templates/web/ui-auth-payments-audio}/template/src/components/client/signup-form.tsx +3 -3
- package/src/templates/web/ui-auth-payments-audio/template/src/lib/actions/index.ts +14 -0
- package/src/templates/web/ui-auth-payments-audio/template/src/test/setup.ts +78 -78
- package/src/templates/web/ui-auth-payments-audio/template/tsconfig.tsbuildinfo +1 -0
- package/src/templates/web/ui-auth-payments-video/template/package.json +53 -52
- package/src/templates/web/ui-auth-payments-video/template/src/test/setup.ts +78 -78
- package/src/templates/web/ui-only/template/package.json +49 -49
- package/src/templates/web/ui-only/template/src/test/setup.ts +78 -78
- package/src/templates/web/ui-package-test/template/package.json +42 -42
- package/dist/templates/mobile/base/template/.env.example +0 -15
- package/dist/templates/mobile/base/template/App.tsx +0 -88
- package/dist/templates/mobile/base/template/app/(auth)/login.tsx +0 -44
- package/dist/templates/mobile/base/template/app/(auth)/signup.tsx +0 -43
- package/dist/templates/mobile/base/template/app/checkout.tsx +0 -20
- package/dist/templates/mobile/base/template/package.json +0 -38
- package/dist/templates/shared/auth/firebase/web/config.ts +0 -23
- package/dist/templates/shared/auth/supabase/web/config.ts +0 -8
- package/dist/templates/web/base/template/.env.example +0 -15
- package/dist/templates/web/base/template/.eslintrc.js +0 -8
- package/dist/templates/web/base/template/README.md +0 -68
- package/dist/templates/web/base/template/next.config.js +0 -15
- package/dist/templates/web/base/template/package.json +0 -58
- package/dist/templates/web/base/template/postcss.config.js +0 -7
- package/dist/templates/web/base/template/src/app/auth/callback/route.ts +0 -18
- package/dist/templates/web/base/template/src/app/checkout/page.tsx +0 -28
- package/dist/templates/web/base/template/src/app/error.tsx +0 -97
- package/dist/templates/web/base/template/src/app/globals.css +0 -60
- package/dist/templates/web/base/template/src/app/layout.tsx +0 -35
- package/dist/templates/web/base/template/src/app/loading.tsx +0 -34
- package/dist/templates/web/base/template/src/app/login/page.tsx +0 -39
- package/dist/templates/web/base/template/src/app/page.tsx +0 -132
- package/dist/templates/web/base/template/src/app/signup/page.tsx +0 -39
- package/dist/templates/web/base/template/src/components/__tests__/example.test.tsx +0 -49
- package/dist/templates/web/base/template/src/components/providers/app-providers.tsx +0 -33
- package/dist/templates/web/base/template/src/components/providers/theme-provider.tsx +0 -94
- package/dist/templates/web/base/template/src/components/shared/footer.tsx +0 -36
- package/dist/templates/web/base/template/src/components/shared/header.tsx +0 -44
- package/dist/templates/web/base/template/src/components/ui/badge.tsx +0 -36
- package/dist/templates/web/base/template/src/components/ui/button.tsx +0 -56
- package/dist/templates/web/base/template/src/components/ui/card.tsx +0 -71
- package/dist/templates/web/base/template/src/components/ui/theme-toggle.tsx +0 -34
- package/dist/templates/web/base/template/src/lib/env.ts +0 -46
- package/dist/templates/web/base/template/src/lib/utils.ts +0 -140
- package/dist/templates/web/base/template/src/test/setup.ts +0 -79
- package/dist/templates/web/base/template/tailwind.config.js +0 -77
- package/dist/templates/web/base/template/tsconfig.json +0 -33
- package/dist/templates/web/base/template/vitest.config.ts +0 -17
- package/dist/templates/web/base/template.backup/.env.example +0 -15
- package/dist/templates/web/base/template.backup.20250817/.env.example +0 -15
- package/dist/templates/web/ui-auth/template/.env.example +0 -15
- package/dist/templates/web/ui-auth/template/.eslintrc.js +0 -8
- package/dist/templates/web/ui-auth/template/README.md +0 -68
- package/dist/templates/web/ui-auth/template/next.config.js +0 -12
- package/dist/templates/web/ui-auth/template/package.json +0 -50
- package/dist/templates/web/ui-auth/template/postcss.config.js +0 -7
- package/dist/templates/web/ui-auth/template/src/app/auth/callback/route.ts +0 -12
- package/dist/templates/web/ui-auth/template/src/app/checkout/page.tsx +0 -25
- package/dist/templates/web/ui-auth/template/src/app/error.tsx +0 -67
- package/dist/templates/web/ui-auth/template/src/app/globals.css +0 -42
- package/dist/templates/web/ui-auth/template/src/app/layout.tsx +0 -33
- package/dist/templates/web/ui-auth/template/src/app/loading.tsx +0 -20
- package/dist/templates/web/ui-auth/template/src/app/login/page.tsx +0 -109
- package/dist/templates/web/ui-auth/template/src/app/page.tsx +0 -129
- package/dist/templates/web/ui-auth/template/src/app/signup/page.tsx +0 -128
- package/dist/templates/web/ui-auth/template/src/components/__tests__/example.test.tsx +0 -49
- package/dist/templates/web/ui-auth/template/src/components/providers/app-providers.tsx +0 -29
- package/dist/templates/web/ui-auth/template/src/components/providers/theme-provider.tsx +0 -94
- package/dist/templates/web/ui-auth/template/src/components/shared/footer.tsx +0 -36
- package/dist/templates/web/ui-auth/template/src/components/shared/header.tsx +0 -53
- package/dist/templates/web/ui-auth/template/src/components/ui/badge.tsx +0 -36
- package/dist/templates/web/ui-auth/template/src/components/ui/theme-toggle.tsx +0 -34
- package/dist/templates/web/ui-auth/template/src/lib/env.ts +0 -49
- package/dist/templates/web/ui-auth/template/src/lib/utils.ts +0 -140
- package/dist/templates/web/ui-auth/template/src/test/setup.ts +0 -79
- package/dist/templates/web/ui-auth/template/tailwind.config.js +0 -77
- package/dist/templates/web/ui-auth/template/tsconfig.json +0 -33
- package/dist/templates/web/ui-auth/template/vitest.config.ts +0 -17
- package/dist/templates/web/ui-auth/template.backup/.env.example +0 -15
- package/dist/templates/web/ui-auth/template.backup.20250817/.env.example +0 -15
- package/dist/templates/web/ui-auth-payments/template/.env.example +0 -15
- package/dist/templates/web/ui-auth-payments/template/README.md +0 -165
- package/dist/templates/web/ui-auth-payments/template/next.config.js +0 -12
- package/dist/templates/web/ui-auth-payments/template/package.json +0 -52
- package/dist/templates/web/ui-auth-payments/template/postcss.config.js +0 -7
- package/dist/templates/web/ui-auth-payments/template/src/app/auth/callback/route.ts +0 -12
- package/dist/templates/web/ui-auth-payments/template/src/app/billing/page.tsx +0 -211
- package/dist/templates/web/ui-auth-payments/template/src/app/checkout/page.tsx +0 -142
- package/dist/templates/web/ui-auth-payments/template/src/app/error.tsx +0 -67
- package/dist/templates/web/ui-auth-payments/template/src/app/globals.css +0 -42
- package/dist/templates/web/ui-auth-payments/template/src/app/layout.tsx +0 -33
- package/dist/templates/web/ui-auth-payments/template/src/app/loading.tsx +0 -20
- package/dist/templates/web/ui-auth-payments/template/src/app/login/loading.tsx +0 -38
- package/dist/templates/web/ui-auth-payments/template/src/app/login/page.tsx +0 -109
- package/dist/templates/web/ui-auth-payments/template/src/app/page.tsx +0 -143
- package/dist/templates/web/ui-auth-payments/template/src/app/signup/loading.tsx +0 -50
- package/dist/templates/web/ui-auth-payments/template/src/app/signup/page.tsx +0 -128
- package/dist/templates/web/ui-auth-payments/template/src/components/__tests__/example.test.tsx +0 -49
- package/dist/templates/web/ui-auth-payments/template/src/components/client/newsletter-signup.tsx +0 -68
- package/dist/templates/web/ui-auth-payments/template/src/components/providers/app-providers.tsx +0 -32
- package/dist/templates/web/ui-auth-payments/template/src/components/providers/theme-provider.tsx +0 -94
- package/dist/templates/web/ui-auth-payments/template/src/components/shared/footer.tsx +0 -36
- package/dist/templates/web/ui-auth-payments/template/src/components/shared/header.tsx +0 -62
- package/dist/templates/web/ui-auth-payments/template/src/components/ui/badge.tsx +0 -36
- package/dist/templates/web/ui-auth-payments/template/src/components/ui/theme-toggle.tsx +0 -34
- package/dist/templates/web/ui-auth-payments/template/src/lib/actions/index.ts +0 -340
- package/dist/templates/web/ui-auth-payments/template/src/lib/auth-server.ts +0 -177
- package/dist/templates/web/ui-auth-payments/template/src/lib/env.ts +0 -49
- package/dist/templates/web/ui-auth-payments/template/src/lib/utils.ts +0 -140
- package/dist/templates/web/ui-auth-payments/template/src/test/setup.ts +0 -79
- package/dist/templates/web/ui-auth-payments/template/tailwind.config.js +0 -77
- package/dist/templates/web/ui-auth-payments/template/tsconfig.json +0 -33
- package/dist/templates/web/ui-auth-payments/template/vitest.config.ts +0 -17
- package/dist/templates/web/ui-auth-payments-audio/template/.env.example +0 -15
- package/dist/templates/web/ui-auth-payments-audio/template/README.md +0 -187
- package/dist/templates/web/ui-auth-payments-audio/template/next.config.js +0 -12
- package/dist/templates/web/ui-auth-payments-audio/template/package.json +0 -52
- package/dist/templates/web/ui-auth-payments-audio/template/postcss.config.js +0 -7
- package/dist/templates/web/ui-auth-payments-audio/template/src/app/auth/callback/route.ts +0 -12
- package/dist/templates/web/ui-auth-payments-audio/template/src/app/billing/page.tsx +0 -211
- package/dist/templates/web/ui-auth-payments-audio/template/src/app/checkout/page.tsx +0 -142
- package/dist/templates/web/ui-auth-payments-audio/template/src/app/error.tsx +0 -67
- package/dist/templates/web/ui-auth-payments-audio/template/src/app/globals.css +0 -42
- package/dist/templates/web/ui-auth-payments-audio/template/src/app/layout.tsx +0 -35
- package/dist/templates/web/ui-auth-payments-audio/template/src/app/loading.tsx +0 -20
- package/dist/templates/web/ui-auth-payments-audio/template/src/app/login/page.tsx +0 -109
- package/dist/templates/web/ui-auth-payments-audio/template/src/app/page.tsx +0 -181
- package/dist/templates/web/ui-auth-payments-audio/template/src/app/signup/page.tsx +0 -128
- package/dist/templates/web/ui-auth-payments-audio/template/src/components/__tests__/example.test.tsx +0 -49
- package/dist/templates/web/ui-auth-payments-audio/template/src/components/providers/app-providers.tsx +0 -32
- package/dist/templates/web/ui-auth-payments-audio/template/src/components/providers/theme-provider.tsx +0 -94
- package/dist/templates/web/ui-auth-payments-audio/template/src/components/shared/footer.tsx +0 -36
- package/dist/templates/web/ui-auth-payments-audio/template/src/components/shared/header.tsx +0 -62
- package/dist/templates/web/ui-auth-payments-audio/template/src/components/ui/badge.tsx +0 -36
- package/dist/templates/web/ui-auth-payments-audio/template/src/components/ui/theme-toggle.tsx +0 -34
- package/dist/templates/web/ui-auth-payments-audio/template/src/lib/env.ts +0 -49
- package/dist/templates/web/ui-auth-payments-audio/template/src/lib/utils.ts +0 -140
- package/dist/templates/web/ui-auth-payments-audio/template/src/test/setup.ts +0 -79
- package/dist/templates/web/ui-auth-payments-audio/template/tailwind.config.js +0 -77
- package/dist/templates/web/ui-auth-payments-audio/template/tsconfig.json +0 -33
- package/dist/templates/web/ui-auth-payments-audio/template/vitest.config.ts +0 -17
- package/dist/templates/web/ui-auth-payments-video/template/.env.example +0 -15
- package/dist/templates/web/ui-auth-payments-video/template/README.md +0 -190
- package/dist/templates/web/ui-auth-payments-video/template/next.config.js +0 -12
- package/dist/templates/web/ui-auth-payments-video/template/package.json +0 -52
- package/dist/templates/web/ui-auth-payments-video/template/postcss.config.js +0 -7
- package/dist/templates/web/ui-auth-payments-video/template/src/app/auth/callback/route.ts +0 -12
- package/dist/templates/web/ui-auth-payments-video/template/src/app/billing/page.tsx +0 -211
- package/dist/templates/web/ui-auth-payments-video/template/src/app/checkout/page.tsx +0 -142
- package/dist/templates/web/ui-auth-payments-video/template/src/app/error.tsx +0 -67
- package/dist/templates/web/ui-auth-payments-video/template/src/app/globals.css +0 -42
- package/dist/templates/web/ui-auth-payments-video/template/src/app/layout.tsx +0 -33
- package/dist/templates/web/ui-auth-payments-video/template/src/app/loading.tsx +0 -20
- package/dist/templates/web/ui-auth-payments-video/template/src/app/login/page.tsx +0 -109
- package/dist/templates/web/ui-auth-payments-video/template/src/app/page.tsx +0 -187
- package/dist/templates/web/ui-auth-payments-video/template/src/app/signup/page.tsx +0 -128
- package/dist/templates/web/ui-auth-payments-video/template/src/components/__tests__/example.test.tsx +0 -49
- package/dist/templates/web/ui-auth-payments-video/template/src/components/providers/app-providers.tsx +0 -32
- package/dist/templates/web/ui-auth-payments-video/template/src/components/providers/theme-provider.tsx +0 -94
- package/dist/templates/web/ui-auth-payments-video/template/src/components/shared/footer.tsx +0 -36
- package/dist/templates/web/ui-auth-payments-video/template/src/components/shared/header.tsx +0 -62
- package/dist/templates/web/ui-auth-payments-video/template/src/components/ui/badge.tsx +0 -36
- package/dist/templates/web/ui-auth-payments-video/template/src/components/ui/theme-toggle.tsx +0 -34
- package/dist/templates/web/ui-auth-payments-video/template/src/lib/env.ts +0 -49
- package/dist/templates/web/ui-auth-payments-video/template/src/lib/utils.ts +0 -140
- package/dist/templates/web/ui-auth-payments-video/template/src/test/setup.ts +0 -79
- package/dist/templates/web/ui-auth-payments-video/template/tailwind.config.js +0 -77
- package/dist/templates/web/ui-auth-payments-video/template/tsconfig.json +0 -33
- package/dist/templates/web/ui-auth-payments-video/template/vitest.config.ts +0 -17
- package/dist/templates/web/ui-only/template/.env.example +0 -15
- package/dist/templates/web/ui-only/template/.eslintrc.js +0 -8
- package/dist/templates/web/ui-only/template/README.md +0 -68
- package/dist/templates/web/ui-only/template/next.config.js +0 -12
- package/dist/templates/web/ui-only/template/package.json +0 -49
- package/dist/templates/web/ui-only/template/postcss.config.js +0 -7
- package/dist/templates/web/ui-only/template/src/app/auth/callback/route.ts +0 -12
- package/dist/templates/web/ui-only/template/src/app/checkout/page.tsx +0 -25
- package/dist/templates/web/ui-only/template/src/app/error.tsx +0 -67
- package/dist/templates/web/ui-only/template/src/app/globals.css +0 -42
- package/dist/templates/web/ui-only/template/src/app/layout.tsx +0 -33
- package/dist/templates/web/ui-only/template/src/app/loading.tsx +0 -20
- package/dist/templates/web/ui-only/template/src/app/login/page.tsx +0 -63
- package/dist/templates/web/ui-only/template/src/app/page.tsx +0 -91
- package/dist/templates/web/ui-only/template/src/app/signup/page.tsx +0 -79
- package/dist/templates/web/ui-only/template/src/components/__tests__/example.test.tsx +0 -49
- package/dist/templates/web/ui-only/template/src/components/providers/app-providers.tsx +0 -26
- package/dist/templates/web/ui-only/template/src/components/providers/theme-provider.tsx +0 -94
- package/dist/templates/web/ui-only/template/src/components/shared/footer.tsx +0 -36
- package/dist/templates/web/ui-only/template/src/components/shared/header.tsx +0 -53
- package/dist/templates/web/ui-only/template/src/components/ui/badge.tsx +0 -36
- package/dist/templates/web/ui-only/template/src/components/ui/theme-toggle.tsx +0 -34
- package/dist/templates/web/ui-only/template/src/lib/env.ts +0 -49
- package/dist/templates/web/ui-only/template/src/lib/utils.ts +0 -140
- package/dist/templates/web/ui-only/template/src/test/setup.ts +0 -79
- package/dist/templates/web/ui-only/template/tailwind.config.js +0 -77
- package/dist/templates/web/ui-only/template/tsconfig.json +0 -33
- package/dist/templates/web/ui-only/template/vitest.config.ts +0 -17
- package/dist/templates/web/ui-only/template.backup/.env.example +0 -15
- package/dist/templates/web/ui-only/template.backup.20250817/.env.example +0 -15
- package/dist/templates/web/ui-package-test/template/package.json +0 -42
- package/dist/templates/web/ui-package-test/template/src/app/page.tsx +0 -106
- package/dist/templates/web/ui-package-test/template/tsconfig.json +0 -41
- /package/{dist/templates/web/ui-auth-payments → src/templates/web/ui-auth-payments-audio}/template/middleware.ts +0 -0
- /package/{dist/templates/web/ui-auth-payments → src/templates/web/ui-auth-payments-audio}/template/src/app/dashboard/layout.tsx +0 -0
- /package/{dist/templates/web/ui-auth-payments → src/templates/web/ui-auth-payments-audio}/template/src/app/dashboard/page.tsx +0 -0
- /package/{dist/templates/web/ui-auth-payments → src/templates/web/ui-auth-payments-audio}/template/src/components/client/auth-status.tsx +0 -0
- /package/{dist/templates/web/ui-auth-payments → src/templates/web/ui-auth-payments-audio}/template/src/lib/actions/auth.ts +0 -0
- /package/{dist/templates/web/base → src/templates/web/ui-auth-payments-audio}/template/src/lib/auth-server.ts +0 -0
|
@@ -1,42 +0,0 @@
|
|
|
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
|
-
}
|
|
@@ -1,33 +0,0 @@
|
|
|
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
|
-
import { Footer } from '@/components/shared/footer'
|
|
7
|
-
|
|
8
|
-
const inter = Inter({ subsets: ['latin'] })
|
|
9
|
-
|
|
10
|
-
export const metadata: Metadata = {
|
|
11
|
-
title: '{{titleCaseName}}',
|
|
12
|
-
description: '{{description}}',
|
|
13
|
-
}
|
|
14
|
-
|
|
15
|
-
export default function RootLayout({
|
|
16
|
-
children,
|
|
17
|
-
}: {
|
|
18
|
-
children: React.ReactNode
|
|
19
|
-
}) {
|
|
20
|
-
return (
|
|
21
|
-
<html lang="en" suppressHydrationWarning>
|
|
22
|
-
<body className={`${inter.className} min-h-screen flex flex-col`}>
|
|
23
|
-
<AppProviders>
|
|
24
|
-
<Header />
|
|
25
|
-
<main className="flex-1">
|
|
26
|
-
{children}
|
|
27
|
-
</main>
|
|
28
|
-
<Footer />
|
|
29
|
-
</AppProviders>
|
|
30
|
-
</body>
|
|
31
|
-
</html>
|
|
32
|
-
)
|
|
33
|
-
}
|
|
@@ -1,20 +0,0 @@
|
|
|
1
|
-
import { Card } from '@digilogiclabs/saas-factory-ui'
|
|
2
|
-
import { Loader2 } from 'lucide-react'
|
|
3
|
-
|
|
4
|
-
export default function Loading() {
|
|
5
|
-
return (
|
|
6
|
-
<div className="min-h-screen bg-gray-50 dark:bg-gray-900 flex items-center justify-center p-4">
|
|
7
|
-
<Card className="w-full max-w-md p-8 text-center">
|
|
8
|
-
<div className="flex flex-col items-center">
|
|
9
|
-
<Loader2 className="h-8 w-8 animate-spin text-blue-600 dark:text-blue-400 mb-4" />
|
|
10
|
-
<h2 className="text-lg font-medium text-gray-900 dark:text-white mb-2">
|
|
11
|
-
Loading
|
|
12
|
-
</h2>
|
|
13
|
-
<p className="text-sm text-gray-600 dark:text-gray-300">
|
|
14
|
-
Please wait while we load your content...
|
|
15
|
-
</p>
|
|
16
|
-
</div>
|
|
17
|
-
</Card>
|
|
18
|
-
</div>
|
|
19
|
-
)
|
|
20
|
-
}
|
|
@@ -1,38 +0,0 @@
|
|
|
1
|
-
import { Card } from '@digilogiclabs/saas-factory-ui'
|
|
2
|
-
|
|
3
|
-
export default function LoginLoading() {
|
|
4
|
-
return (
|
|
5
|
-
<div className="flex items-center justify-center min-h-screen bg-gray-100 dark:bg-gray-900">
|
|
6
|
-
<Card className="w-full max-w-md p-8">
|
|
7
|
-
<div className="animate-pulse space-y-6">
|
|
8
|
-
{/* Title skeleton */}
|
|
9
|
-
<div className="h-8 bg-gray-200 dark:bg-gray-700 rounded-md mx-auto w-32"></div>
|
|
10
|
-
|
|
11
|
-
{/* Form skeleton */}
|
|
12
|
-
<div className="space-y-4">
|
|
13
|
-
{/* Email field */}
|
|
14
|
-
<div>
|
|
15
|
-
<div className="h-4 bg-gray-200 dark:bg-gray-700 rounded w-16 mb-2"></div>
|
|
16
|
-
<div className="h-10 bg-gray-200 dark:bg-gray-700 rounded"></div>
|
|
17
|
-
</div>
|
|
18
|
-
|
|
19
|
-
{/* Password field */}
|
|
20
|
-
<div>
|
|
21
|
-
<div className="h-4 bg-gray-200 dark:bg-gray-700 rounded w-20 mb-2"></div>
|
|
22
|
-
<div className="h-10 bg-gray-200 dark:bg-gray-700 rounded"></div>
|
|
23
|
-
</div>
|
|
24
|
-
|
|
25
|
-
{/* Sign in button */}
|
|
26
|
-
<div className="h-10 bg-blue-200 dark:bg-blue-800 rounded"></div>
|
|
27
|
-
|
|
28
|
-
{/* OAuth button */}
|
|
29
|
-
<div className="h-10 bg-gray-200 dark:bg-gray-700 rounded"></div>
|
|
30
|
-
</div>
|
|
31
|
-
|
|
32
|
-
{/* Sign up link */}
|
|
33
|
-
<div className="h-4 bg-gray-200 dark:bg-gray-700 rounded w-48 mx-auto"></div>
|
|
34
|
-
</div>
|
|
35
|
-
</Card>
|
|
36
|
-
</div>
|
|
37
|
-
)
|
|
38
|
-
}
|
|
@@ -1,109 +0,0 @@
|
|
|
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'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
|
-
|
|
@@ -1,143 +0,0 @@
|
|
|
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 + Payments 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 and payments integration.
|
|
61
|
-
</p>
|
|
62
|
-
<div className="flex flex-col sm:flex-row gap-4 justify-center">
|
|
63
|
-
<Link href="/checkout">
|
|
64
|
-
<Button size="lg" className="text-lg px-8">
|
|
65
|
-
View Pricing
|
|
66
|
-
<ArrowRight className="ml-2 h-5 w-5" />
|
|
67
|
-
</Button>
|
|
68
|
-
</Link>
|
|
69
|
-
<Button variant="outline" size="lg" className="text-lg px-8">
|
|
70
|
-
Learn More
|
|
71
|
-
</Button>
|
|
72
|
-
</div>
|
|
73
|
-
</div>
|
|
74
|
-
|
|
75
|
-
{/* Component Showcase */}
|
|
76
|
-
<div className="grid md:grid-cols-4 gap-8 mb-16">
|
|
77
|
-
<Card className="text-center p-6">
|
|
78
|
-
<div className="mx-auto w-12 h-12 bg-blue-100 dark:bg-blue-900 rounded-lg flex items-center justify-center mb-4">
|
|
79
|
-
<Zap className="h-6 w-6 text-blue-600 dark:text-blue-400" />
|
|
80
|
-
</div>
|
|
81
|
-
<h3 className="text-xl font-semibold mb-2">UI Package Components</h3>
|
|
82
|
-
<p className="text-gray-600 dark:text-gray-300">
|
|
83
|
-
Button and Card components from @digilogiclabs/saas-factory-ui
|
|
84
|
-
</p>
|
|
85
|
-
</Card>
|
|
86
|
-
|
|
87
|
-
<Card className="text-center p-6">
|
|
88
|
-
<div className="mx-auto w-12 h-12 bg-green-100 dark:bg-green-900 rounded-lg flex items-center justify-center mb-4">
|
|
89
|
-
<Shield className="h-6 w-6 text-green-600 dark:text-green-400" />
|
|
90
|
-
</div>
|
|
91
|
-
<h3 className="text-xl font-semibold mb-2">Authentication</h3>
|
|
92
|
-
<p className="text-gray-600 dark:text-gray-300">
|
|
93
|
-
Secure user authentication with @digilogiclabs/saas-factory-auth
|
|
94
|
-
</p>
|
|
95
|
-
</Card>
|
|
96
|
-
|
|
97
|
-
<Card className="text-center p-6">
|
|
98
|
-
<div className="mx-auto w-12 h-12 bg-purple-100 dark:bg-purple-900 rounded-lg flex items-center justify-center mb-4">
|
|
99
|
-
<Rocket className="h-6 w-6 text-purple-600 dark:text-purple-400" />
|
|
100
|
-
</div>
|
|
101
|
-
<h3 className="text-xl font-semibold mb-2">TypeScript Ready</h3>
|
|
102
|
-
<p className="text-gray-600 dark:text-gray-300">
|
|
103
|
-
Full type safety with enhanced component definitions
|
|
104
|
-
</p>
|
|
105
|
-
</Card>
|
|
106
|
-
|
|
107
|
-
<Card className="text-center p-6">
|
|
108
|
-
<div className="mx-auto w-12 h-12 bg-orange-100 dark:bg-orange-900 rounded-lg flex items-center justify-center mb-4">
|
|
109
|
-
<svg className="h-6 w-6 text-orange-600 dark:text-orange-400" fill="none" stroke="currentColor" viewBox="0 0 24 24">
|
|
110
|
-
<path strokeLinecap="round" strokeLinejoin="round" strokeWidth={2} d="M3 10h18M7 15h1m4 0h1m-7 4h12a3 3 0 003-3V8a3 3 0 00-3-3H6a3 3 0 00-3 3v8a3 3 0 003 3z" />
|
|
111
|
-
</svg>
|
|
112
|
-
</div>
|
|
113
|
-
<h3 className="text-xl font-semibold mb-2">Payments Integration</h3>
|
|
114
|
-
<p className="text-gray-600 dark:text-gray-300">
|
|
115
|
-
Complete payment processing with @digilogiclabs/saas-factory-payments
|
|
116
|
-
</p>
|
|
117
|
-
</Card>
|
|
118
|
-
</div>
|
|
119
|
-
|
|
120
|
-
{/* Button Variants Showcase */}
|
|
121
|
-
<Card className="max-w-4xl mx-auto p-8">
|
|
122
|
-
<div className="text-center mb-6">
|
|
123
|
-
<h2 className="text-2xl font-bold mb-2">Full SaaS Package Integration</h2>
|
|
124
|
-
<p className="text-gray-600 dark:text-gray-300">
|
|
125
|
-
Complete integration of UI, Auth, and Payments packages
|
|
126
|
-
</p>
|
|
127
|
-
</div>
|
|
128
|
-
<div className="flex flex-wrap justify-center gap-4 mb-6">
|
|
129
|
-
<Button>Default Button</Button>
|
|
130
|
-
<Button variant="secondary">Secondary Button</Button>
|
|
131
|
-
<Button variant="outline">Outline Button</Button>
|
|
132
|
-
<Button disabled>Disabled Button</Button>
|
|
133
|
-
</div>
|
|
134
|
-
<div className="text-center">
|
|
135
|
-
<p className="text-sm text-gray-500">
|
|
136
|
-
All components from @digilogiclabs/saas-factory-ui v0.7.3 + auth v0.4.4 + payments
|
|
137
|
-
</p>
|
|
138
|
-
</div>
|
|
139
|
-
</Card>
|
|
140
|
-
</div>
|
|
141
|
-
</main>
|
|
142
|
-
)
|
|
143
|
-
}
|
|
@@ -1,50 +0,0 @@
|
|
|
1
|
-
import { Card } from '@digilogiclabs/saas-factory-ui'
|
|
2
|
-
|
|
3
|
-
export default function SignupLoading() {
|
|
4
|
-
return (
|
|
5
|
-
<div className="flex items-center justify-center min-h-screen bg-gray-100 dark:bg-gray-900">
|
|
6
|
-
<Card className="w-full max-w-md p-8">
|
|
7
|
-
<div className="animate-pulse space-y-6">
|
|
8
|
-
{/* Title skeleton */}
|
|
9
|
-
<div className="h-8 bg-gray-200 dark:bg-gray-700 rounded-md mx-auto w-32"></div>
|
|
10
|
-
|
|
11
|
-
{/* Form skeleton */}
|
|
12
|
-
<div className="space-y-4">
|
|
13
|
-
{/* Name field */}
|
|
14
|
-
<div>
|
|
15
|
-
<div className="h-4 bg-gray-200 dark:bg-gray-700 rounded w-12 mb-2"></div>
|
|
16
|
-
<div className="h-10 bg-gray-200 dark:bg-gray-700 rounded"></div>
|
|
17
|
-
</div>
|
|
18
|
-
|
|
19
|
-
{/* Email field */}
|
|
20
|
-
<div>
|
|
21
|
-
<div className="h-4 bg-gray-200 dark:bg-gray-700 rounded w-16 mb-2"></div>
|
|
22
|
-
<div className="h-10 bg-gray-200 dark:bg-gray-700 rounded"></div>
|
|
23
|
-
</div>
|
|
24
|
-
|
|
25
|
-
{/* Password field */}
|
|
26
|
-
<div>
|
|
27
|
-
<div className="h-4 bg-gray-200 dark:bg-gray-700 rounded w-20 mb-2"></div>
|
|
28
|
-
<div className="h-10 bg-gray-200 dark:bg-gray-700 rounded"></div>
|
|
29
|
-
</div>
|
|
30
|
-
|
|
31
|
-
{/* Confirm password field */}
|
|
32
|
-
<div>
|
|
33
|
-
<div className="h-4 bg-gray-200 dark:bg-gray-700 rounded w-32 mb-2"></div>
|
|
34
|
-
<div className="h-10 bg-gray-200 dark:bg-gray-700 rounded"></div>
|
|
35
|
-
</div>
|
|
36
|
-
|
|
37
|
-
{/* Sign up button */}
|
|
38
|
-
<div className="h-10 bg-blue-200 dark:bg-blue-800 rounded"></div>
|
|
39
|
-
|
|
40
|
-
{/* OAuth button */}
|
|
41
|
-
<div className="h-10 bg-gray-200 dark:bg-gray-700 rounded"></div>
|
|
42
|
-
</div>
|
|
43
|
-
|
|
44
|
-
{/* Sign in link */}
|
|
45
|
-
<div className="h-4 bg-gray-200 dark:bg-gray-700 rounded w-44 mx-auto"></div>
|
|
46
|
-
</div>
|
|
47
|
-
</Card>
|
|
48
|
-
</div>
|
|
49
|
-
)
|
|
50
|
-
}
|
|
@@ -1,128 +0,0 @@
|
|
|
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
|
-
|
package/dist/templates/web/ui-auth-payments/template/src/components/__tests__/example.test.tsx
DELETED
|
@@ -1,49 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Example test file demonstrating testing patterns for SaaS Factory components
|
|
3
|
-
*
|
|
4
|
-
* This is optional and serves as a reference for testing your components.
|
|
5
|
-
* You can delete this file if you don't need example tests.
|
|
6
|
-
*/
|
|
7
|
-
|
|
8
|
-
import { render, screen } from '@testing-library/react'
|
|
9
|
-
import { Button } from '@digilogiclabs/saas-factory-ui'
|
|
10
|
-
|
|
11
|
-
// Example: Testing UI components
|
|
12
|
-
describe('UI Components', () => {
|
|
13
|
-
it('renders button with correct text', () => {
|
|
14
|
-
render(<Button>Click me</Button>)
|
|
15
|
-
expect(screen.getByRole('button', { name: /click me/i })).toBeInTheDocument()
|
|
16
|
-
})
|
|
17
|
-
|
|
18
|
-
it('button can be disabled', () => {
|
|
19
|
-
render(<Button disabled>Disabled button</Button>)
|
|
20
|
-
expect(screen.getByRole('button')).toBeDisabled()
|
|
21
|
-
})
|
|
22
|
-
})
|
|
23
|
-
|
|
24
|
-
// Example: Testing custom components
|
|
25
|
-
function MockComponent({ title }: { title: string }) {
|
|
26
|
-
return <h1>{title}</h1>
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
describe('Custom Components', () => {
|
|
30
|
-
it('renders with correct title', () => {
|
|
31
|
-
render(<MockComponent title="Test Title" />)
|
|
32
|
-
expect(screen.getByRole('heading', { level: 1 })).toHaveTextContent('Test Title')
|
|
33
|
-
})
|
|
34
|
-
})
|
|
35
|
-
|
|
36
|
-
// Example: Testing utilities
|
|
37
|
-
function formatCurrency(amount: number): string {
|
|
38
|
-
return new Intl.NumberFormat('en-US', {
|
|
39
|
-
style: 'currency',
|
|
40
|
-
currency: 'USD',
|
|
41
|
-
}).format(amount)
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
describe('Utilities', () => {
|
|
45
|
-
it('formats currency correctly', () => {
|
|
46
|
-
expect(formatCurrency(1000)).toBe('$1,000.00')
|
|
47
|
-
expect(formatCurrency(0)).toBe('$0.00')
|
|
48
|
-
})
|
|
49
|
-
})
|