@digilogiclabs/create-saas-app 1.5.1 → 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/ui-auth-payments/template/package-lock.json +12240 -0
- 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/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/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/tsconfig.tsbuildinfo +1 -0
- 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 -53
- 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 -53
- 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,63 +0,0 @@
|
|
|
1
|
-
'use client';
|
|
2
|
-
|
|
3
|
-
import React, { useState } from 'react';
|
|
4
|
-
import { Button, Card, Input, Label } from '@digilogiclabs/saas-factory-ui';
|
|
5
|
-
|
|
6
|
-
export default function LoginPage() {
|
|
7
|
-
const [email, setEmail] = useState('');
|
|
8
|
-
const [password, setPassword] = useState('');
|
|
9
|
-
|
|
10
|
-
const handleLogin = async (e: React.FormEvent) => {
|
|
11
|
-
e.preventDefault();
|
|
12
|
-
alert('Login functionality requires @digilogiclabs/saas-factory-auth package');
|
|
13
|
-
console.log('Login values:', { email, password });
|
|
14
|
-
};
|
|
15
|
-
|
|
16
|
-
const handleGoogleLogin = async () => {
|
|
17
|
-
alert('Google login functionality requires @digilogiclabs/saas-factory-auth package');
|
|
18
|
-
};
|
|
19
|
-
|
|
20
|
-
return (
|
|
21
|
-
<div className="flex items-center justify-center min-h-screen bg-gray-100">
|
|
22
|
-
<Card className="w-full max-w-md p-8">
|
|
23
|
-
<h1 className="text-2xl font-bold text-center mb-6">Sign In</h1>
|
|
24
|
-
<form onSubmit={handleLogin} className="space-y-4">
|
|
25
|
-
<div>
|
|
26
|
-
<Label htmlFor="email">Email</Label>
|
|
27
|
-
<Input
|
|
28
|
-
id="email"
|
|
29
|
-
type="email"
|
|
30
|
-
value={email}
|
|
31
|
-
onChange={(e) => setEmail(e.target.value)}
|
|
32
|
-
placeholder="Enter your email"
|
|
33
|
-
required
|
|
34
|
-
/>
|
|
35
|
-
</div>
|
|
36
|
-
<div>
|
|
37
|
-
<Label htmlFor="password">Password</Label>
|
|
38
|
-
<Input
|
|
39
|
-
id="password"
|
|
40
|
-
type="password"
|
|
41
|
-
value={password}
|
|
42
|
-
onChange={(e) => setPassword(e.target.value)}
|
|
43
|
-
placeholder="Enter your password"
|
|
44
|
-
required
|
|
45
|
-
/>
|
|
46
|
-
</div>
|
|
47
|
-
<Button type="submit" className="w-full">
|
|
48
|
-
Sign In
|
|
49
|
-
</Button>
|
|
50
|
-
<Button
|
|
51
|
-
type="button"
|
|
52
|
-
variant="outline"
|
|
53
|
-
className="w-full"
|
|
54
|
-
onClick={handleGoogleLogin}
|
|
55
|
-
>
|
|
56
|
-
Sign in with Google
|
|
57
|
-
</Button>
|
|
58
|
-
</form>
|
|
59
|
-
</Card>
|
|
60
|
-
</div>
|
|
61
|
-
);
|
|
62
|
-
}
|
|
63
|
-
|
|
@@ -1,91 +0,0 @@
|
|
|
1
|
-
'use client'
|
|
2
|
-
|
|
3
|
-
import { Button, Card } from '@digilogiclabs/saas-factory-ui'
|
|
4
|
-
import { ArrowRight, Zap, Shield, Rocket, CheckCircle } from 'lucide-react'
|
|
5
|
-
import Link from 'next/link'
|
|
6
|
-
|
|
7
|
-
export default function Home() {
|
|
8
|
-
return (
|
|
9
|
-
<main className="min-h-screen bg-gradient-to-br from-blue-50 to-indigo-100 dark:from-gray-900 dark:to-gray-800">
|
|
10
|
-
<div className="container mx-auto px-4 py-16">
|
|
11
|
-
{/* Hero Section */}
|
|
12
|
-
<div className="text-center mb-16">
|
|
13
|
-
<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">
|
|
14
|
-
<CheckCircle className="w-4 h-4 mr-2" />
|
|
15
|
-
UI Package v0.7.3 Integrated Successfully
|
|
16
|
-
</div>
|
|
17
|
-
<h1 className="text-4xl md:text-6xl font-bold text-gray-900 dark:text-white mb-6">
|
|
18
|
-
Welcome to{' '}
|
|
19
|
-
<span className="text-blue-600 dark:text-blue-400">{{titleCaseName}}</span>
|
|
20
|
-
</h1>
|
|
21
|
-
<p className="text-xl text-gray-600 dark:text-gray-300 mb-8 max-w-2xl mx-auto">
|
|
22
|
-
{{description}}. This template uses the stable SaaS Factory UI package v0.7.3.
|
|
23
|
-
</p>
|
|
24
|
-
<div className="flex flex-col sm:flex-row gap-4 justify-center">
|
|
25
|
-
<Button size="lg" className="text-lg px-8">
|
|
26
|
-
Get Started
|
|
27
|
-
<ArrowRight className="ml-2 h-5 w-5" />
|
|
28
|
-
</Button>
|
|
29
|
-
<Button variant="outline" size="lg" className="text-lg px-8">
|
|
30
|
-
Learn More
|
|
31
|
-
</Button>
|
|
32
|
-
</div>
|
|
33
|
-
</div>
|
|
34
|
-
|
|
35
|
-
{/* Component Showcase */}
|
|
36
|
-
<div className="grid md:grid-cols-3 gap-8 mb-16">
|
|
37
|
-
<Card className="text-center p-6">
|
|
38
|
-
<div className="mx-auto w-12 h-12 bg-blue-100 dark:bg-blue-900 rounded-lg flex items-center justify-center mb-4">
|
|
39
|
-
<Zap className="h-6 w-6 text-blue-600 dark:text-blue-400" />
|
|
40
|
-
</div>
|
|
41
|
-
<h3 className="text-xl font-semibold mb-2">UI Package Components</h3>
|
|
42
|
-
<p className="text-gray-600 dark:text-gray-300">
|
|
43
|
-
Button and Card components from @digilogiclabs/saas-factory-ui
|
|
44
|
-
</p>
|
|
45
|
-
</Card>
|
|
46
|
-
|
|
47
|
-
<Card className="text-center p-6">
|
|
48
|
-
<div className="mx-auto w-12 h-12 bg-green-100 dark:bg-green-900 rounded-lg flex items-center justify-center mb-4">
|
|
49
|
-
<Shield className="h-6 w-6 text-green-600 dark:text-green-400" />
|
|
50
|
-
</div>
|
|
51
|
-
<h3 className="text-xl font-semibold mb-2">Hybrid Architecture</h3>
|
|
52
|
-
<p className="text-gray-600 dark:text-gray-300">
|
|
53
|
-
Clean web build with no React Native contamination
|
|
54
|
-
</p>
|
|
55
|
-
</Card>
|
|
56
|
-
|
|
57
|
-
<Card className="text-center p-6">
|
|
58
|
-
<div className="mx-auto w-12 h-12 bg-purple-100 dark:bg-purple-900 rounded-lg flex items-center justify-center mb-4">
|
|
59
|
-
<Rocket className="h-6 w-6 text-purple-600 dark:text-purple-400" />
|
|
60
|
-
</div>
|
|
61
|
-
<h3 className="text-xl font-semibold mb-2">TypeScript Ready</h3>
|
|
62
|
-
<p className="text-gray-600 dark:text-gray-300">
|
|
63
|
-
Full type safety with enhanced component definitions
|
|
64
|
-
</p>
|
|
65
|
-
</Card>
|
|
66
|
-
</div>
|
|
67
|
-
|
|
68
|
-
{/* Button Variants Showcase */}
|
|
69
|
-
<Card className="max-w-4xl mx-auto p-8">
|
|
70
|
-
<div className="text-center mb-6">
|
|
71
|
-
<h2 className="text-2xl font-bold mb-2">UI Package Component Showcase</h2>
|
|
72
|
-
<p className="text-gray-600 dark:text-gray-300">
|
|
73
|
-
Testing Button variants from the stable UI package
|
|
74
|
-
</p>
|
|
75
|
-
</div>
|
|
76
|
-
<div className="flex flex-wrap justify-center gap-4 mb-6">
|
|
77
|
-
<Button>Default Button</Button>
|
|
78
|
-
<Button variant="secondary">Secondary Button</Button>
|
|
79
|
-
<Button variant="outline">Outline Button</Button>
|
|
80
|
-
<Button disabled>Disabled Button</Button>
|
|
81
|
-
</div>
|
|
82
|
-
<div className="text-center">
|
|
83
|
-
<p className="text-sm text-gray-500">
|
|
84
|
-
All components imported from @digilogiclabs/saas-factory-ui v0.7.3
|
|
85
|
-
</p>
|
|
86
|
-
</div>
|
|
87
|
-
</Card>
|
|
88
|
-
</div>
|
|
89
|
-
</main>
|
|
90
|
-
)
|
|
91
|
-
}
|
|
@@ -1,79 +0,0 @@
|
|
|
1
|
-
'use client';
|
|
2
|
-
|
|
3
|
-
import React, { useState } from 'react';
|
|
4
|
-
import { Button, Card, Input, Label } from '@digilogiclabs/saas-factory-ui';
|
|
5
|
-
|
|
6
|
-
export default function SignupPage() {
|
|
7
|
-
const [email, setEmail] = useState('');
|
|
8
|
-
const [password, setPassword] = useState('');
|
|
9
|
-
const [confirmPassword, setConfirmPassword] = useState('');
|
|
10
|
-
|
|
11
|
-
const handleSignup = async (e: React.FormEvent) => {
|
|
12
|
-
e.preventDefault();
|
|
13
|
-
if (password !== confirmPassword) {
|
|
14
|
-
alert('Passwords do not match');
|
|
15
|
-
return;
|
|
16
|
-
}
|
|
17
|
-
alert('Signup functionality requires @digilogiclabs/saas-factory-auth package');
|
|
18
|
-
console.log('Signup values:', { email, password });
|
|
19
|
-
};
|
|
20
|
-
|
|
21
|
-
const handleGoogleSignup = async () => {
|
|
22
|
-
alert('Google signup functionality requires @digilogiclabs/saas-factory-auth package');
|
|
23
|
-
};
|
|
24
|
-
|
|
25
|
-
return (
|
|
26
|
-
<div className="flex items-center justify-center min-h-screen bg-gray-100">
|
|
27
|
-
<Card className="w-full max-w-md p-8">
|
|
28
|
-
<h1 className="text-2xl font-bold text-center mb-6">Sign Up</h1>
|
|
29
|
-
<form onSubmit={handleSignup} className="space-y-4">
|
|
30
|
-
<div>
|
|
31
|
-
<Label htmlFor="email">Email</Label>
|
|
32
|
-
<Input
|
|
33
|
-
id="email"
|
|
34
|
-
type="email"
|
|
35
|
-
value={email}
|
|
36
|
-
onChange={(e) => setEmail(e.target.value)}
|
|
37
|
-
placeholder="Enter your email"
|
|
38
|
-
required
|
|
39
|
-
/>
|
|
40
|
-
</div>
|
|
41
|
-
<div>
|
|
42
|
-
<Label htmlFor="password">Password</Label>
|
|
43
|
-
<Input
|
|
44
|
-
id="password"
|
|
45
|
-
type="password"
|
|
46
|
-
value={password}
|
|
47
|
-
onChange={(e) => setPassword(e.target.value)}
|
|
48
|
-
placeholder="Enter your password"
|
|
49
|
-
required
|
|
50
|
-
/>
|
|
51
|
-
</div>
|
|
52
|
-
<div>
|
|
53
|
-
<Label htmlFor="confirmPassword">Confirm Password</Label>
|
|
54
|
-
<Input
|
|
55
|
-
id="confirmPassword"
|
|
56
|
-
type="password"
|
|
57
|
-
value={confirmPassword}
|
|
58
|
-
onChange={(e) => setConfirmPassword(e.target.value)}
|
|
59
|
-
placeholder="Confirm your password"
|
|
60
|
-
required
|
|
61
|
-
/>
|
|
62
|
-
</div>
|
|
63
|
-
<Button type="submit" className="w-full">
|
|
64
|
-
Sign Up
|
|
65
|
-
</Button>
|
|
66
|
-
<Button
|
|
67
|
-
type="button"
|
|
68
|
-
variant="outline"
|
|
69
|
-
className="w-full"
|
|
70
|
-
onClick={handleGoogleSignup}
|
|
71
|
-
>
|
|
72
|
-
Sign up with Google
|
|
73
|
-
</Button>
|
|
74
|
-
</form>
|
|
75
|
-
</Card>
|
|
76
|
-
</div>
|
|
77
|
-
);
|
|
78
|
-
}
|
|
79
|
-
|
|
@@ -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
|
-
})
|
|
@@ -1,26 +0,0 @@
|
|
|
1
|
-
'use client'
|
|
2
|
-
|
|
3
|
-
import React from 'react'
|
|
4
|
-
import { ThemeProvider } from 'next-themes'
|
|
5
|
-
import { AppThemeProvider } from './theme-provider'
|
|
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="{{defaultTheme}}"
|
|
16
|
-
enableSystem
|
|
17
|
-
disableTransitionOnChange
|
|
18
|
-
storageKey="{{packageName}}-theme"
|
|
19
|
-
>
|
|
20
|
-
<AppThemeProvider themeColor="{{themeColor}}">
|
|
21
|
-
{children}
|
|
22
|
-
</AppThemeProvider>
|
|
23
|
-
</ThemeProvider>
|
|
24
|
-
)
|
|
25
|
-
}
|
|
26
|
-
|
|
@@ -1,94 +0,0 @@
|
|
|
1
|
-
'use client'
|
|
2
|
-
|
|
3
|
-
import React, { createContext, useContext, useEffect } from 'react'
|
|
4
|
-
|
|
5
|
-
interface ThemeContextType {
|
|
6
|
-
themeColor: string
|
|
7
|
-
}
|
|
8
|
-
|
|
9
|
-
const ThemeContext = createContext<ThemeContextType | undefined>(undefined)
|
|
10
|
-
|
|
11
|
-
interface AppThemeProviderProps {
|
|
12
|
-
children: React.ReactNode
|
|
13
|
-
themeColor: string
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
const THEME_COLORS = {
|
|
17
|
-
blue: {
|
|
18
|
-
primary: '221.2 83.2% 53.3%',
|
|
19
|
-
primaryForeground: '210 40% 98%',
|
|
20
|
-
secondary: '210 40% 96%',
|
|
21
|
-
accent: '210 40% 96%',
|
|
22
|
-
ring: '221.2 83.2% 53.3%',
|
|
23
|
-
},
|
|
24
|
-
green: {
|
|
25
|
-
primary: '142.1 76.2% 36.3%',
|
|
26
|
-
primaryForeground: '355.7 100% 97.3%',
|
|
27
|
-
secondary: '138.5 76.2% 96.7%',
|
|
28
|
-
accent: '138.5 76.2% 96.7%',
|
|
29
|
-
ring: '142.1 76.2% 36.3%',
|
|
30
|
-
},
|
|
31
|
-
purple: {
|
|
32
|
-
primary: '262.1 83.3% 57.8%',
|
|
33
|
-
primaryForeground: '210 40% 98%',
|
|
34
|
-
secondary: '270 3.18% 96.5%',
|
|
35
|
-
accent: '270 3.18% 96.5%',
|
|
36
|
-
ring: '262.1 83.3% 57.8%',
|
|
37
|
-
},
|
|
38
|
-
orange: {
|
|
39
|
-
primary: '24.6 95% 53.1%',
|
|
40
|
-
primaryForeground: '60 9.1% 97.8%',
|
|
41
|
-
secondary: '60 4.8% 95.9%',
|
|
42
|
-
accent: '60 4.8% 95.9%',
|
|
43
|
-
ring: '24.6 95% 53.1%',
|
|
44
|
-
},
|
|
45
|
-
red: {
|
|
46
|
-
primary: '0 72.2% 50.6%',
|
|
47
|
-
primaryForeground: '0 85.7% 97.3%',
|
|
48
|
-
secondary: '0 0% 96.3%',
|
|
49
|
-
accent: '0 0% 96.3%',
|
|
50
|
-
ring: '0 72.2% 50.6%',
|
|
51
|
-
},
|
|
52
|
-
slate: {
|
|
53
|
-
primary: '215 27.9% 16.9%',
|
|
54
|
-
primaryForeground: '0 0% 98%',
|
|
55
|
-
secondary: '210 40% 96%',
|
|
56
|
-
accent: '210 40% 96%',
|
|
57
|
-
ring: '215 27.9% 16.9%',
|
|
58
|
-
},
|
|
59
|
-
}
|
|
60
|
-
|
|
61
|
-
export function AppThemeProvider({ children, themeColor }: AppThemeProviderProps) {
|
|
62
|
-
useEffect(() => {
|
|
63
|
-
const colorScheme = THEME_COLORS[themeColor as keyof typeof THEME_COLORS] || THEME_COLORS.blue
|
|
64
|
-
|
|
65
|
-
// Apply theme colors to CSS custom properties
|
|
66
|
-
const root = document.documentElement
|
|
67
|
-
root.style.setProperty('--primary', colorScheme.primary)
|
|
68
|
-
root.style.setProperty('--primary-foreground', colorScheme.primaryForeground)
|
|
69
|
-
root.style.setProperty('--secondary', colorScheme.secondary)
|
|
70
|
-
root.style.setProperty('--accent', colorScheme.accent)
|
|
71
|
-
root.style.setProperty('--ring', colorScheme.ring)
|
|
72
|
-
|
|
73
|
-
// Store theme color preference
|
|
74
|
-
localStorage.setItem('{{packageName}}-theme-color', themeColor)
|
|
75
|
-
}, [themeColor])
|
|
76
|
-
|
|
77
|
-
const contextValue: ThemeContextType = {
|
|
78
|
-
themeColor,
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
return (
|
|
82
|
-
<ThemeContext.Provider value={contextValue}>
|
|
83
|
-
{children}
|
|
84
|
-
</ThemeContext.Provider>
|
|
85
|
-
)
|
|
86
|
-
}
|
|
87
|
-
|
|
88
|
-
export function useAppTheme() {
|
|
89
|
-
const context = useContext(ThemeContext)
|
|
90
|
-
if (context === undefined) {
|
|
91
|
-
throw new Error('useAppTheme must be used within a AppThemeProvider')
|
|
92
|
-
}
|
|
93
|
-
return context
|
|
94
|
-
}
|
|
@@ -1,36 +0,0 @@
|
|
|
1
|
-
'use client'
|
|
2
|
-
|
|
3
|
-
import React from 'react'
|
|
4
|
-
|
|
5
|
-
interface FooterProps {
|
|
6
|
-
className?: string
|
|
7
|
-
}
|
|
8
|
-
|
|
9
|
-
export function Footer({ className = '' }: FooterProps) {
|
|
10
|
-
return (
|
|
11
|
-
<footer className={`border-t bg-background py-4 ${className}`}>
|
|
12
|
-
<div className="container mx-auto px-4">
|
|
13
|
-
<div className="flex flex-col sm:flex-row justify-between items-center gap-4 text-sm text-muted-foreground">
|
|
14
|
-
<div className="flex items-center gap-2">
|
|
15
|
-
<span>© {new Date().getFullYear()} {{titleCaseName}}</span>
|
|
16
|
-
</div>
|
|
17
|
-
|
|
18
|
-
<div className="flex items-center gap-2 text-xs">
|
|
19
|
-
<span>Generated with</span>
|
|
20
|
-
<a
|
|
21
|
-
href="https://docs.digilogiclabs.com"
|
|
22
|
-
target="_blank"
|
|
23
|
-
rel="noopener noreferrer"
|
|
24
|
-
className="hover:text-foreground transition-colors"
|
|
25
|
-
>
|
|
26
|
-
Digi Logic Labs
|
|
27
|
-
</a>
|
|
28
|
-
<span className="text-muted-foreground/60">
|
|
29
|
-
• UI v{{uiVersion}} • {{generatedDate}}
|
|
30
|
-
</span>
|
|
31
|
-
</div>
|
|
32
|
-
</div>
|
|
33
|
-
</div>
|
|
34
|
-
</footer>
|
|
35
|
-
)
|
|
36
|
-
}
|
|
@@ -1,53 +0,0 @@
|
|
|
1
|
-
'use client';
|
|
2
|
-
|
|
3
|
-
import React from 'react';
|
|
4
|
-
import Link from 'next/link';
|
|
5
|
-
import { LogOut } from 'lucide-react';
|
|
6
|
-
import { ThemeToggle } from '../ui/theme-toggle';
|
|
7
|
-
|
|
8
|
-
export function Header() {
|
|
9
|
-
const user = null; // Placeholder for auth state
|
|
10
|
-
|
|
11
|
-
const handleSignOut = () => {
|
|
12
|
-
alert('Sign out functionality requires @digilogiclabs/saas-factory-auth package');
|
|
13
|
-
};
|
|
14
|
-
|
|
15
|
-
return (
|
|
16
|
-
<header className="bg-white dark:bg-gray-800 shadow-md">
|
|
17
|
-
<div className="container mx-auto px-4 py-4 flex justify-between items-center">
|
|
18
|
-
<Link href="/" className="text-2xl font-bold text-gray-900 dark:text-white">
|
|
19
|
-
{{titleCaseName}}
|
|
20
|
-
</Link>
|
|
21
|
-
<nav className="flex items-center gap-4">
|
|
22
|
-
<ThemeToggle />
|
|
23
|
-
{user ? (
|
|
24
|
-
<>
|
|
25
|
-
<Link href="/dashboard" className="text-gray-600 dark:text-gray-300 hover:text-gray-900 dark:hover:text-white">
|
|
26
|
-
Dashboard
|
|
27
|
-
</Link>
|
|
28
|
-
<button
|
|
29
|
-
onClick={handleSignOut}
|
|
30
|
-
className="p-2 text-gray-600 dark:text-gray-300 hover:text-gray-900 dark:hover:text-white"
|
|
31
|
-
>
|
|
32
|
-
<LogOut className="h-5 w-5" />
|
|
33
|
-
</button>
|
|
34
|
-
</>
|
|
35
|
-
) : (
|
|
36
|
-
<>
|
|
37
|
-
<Link href="/login" className="text-gray-600 dark:text-gray-300 hover:text-gray-900 dark:hover:text-white">
|
|
38
|
-
Login
|
|
39
|
-
</Link>
|
|
40
|
-
<Link
|
|
41
|
-
href="/signup"
|
|
42
|
-
className="px-4 py-2 bg-blue-600 text-white rounded hover:bg-blue-700"
|
|
43
|
-
>
|
|
44
|
-
Sign Up
|
|
45
|
-
</Link>
|
|
46
|
-
</>
|
|
47
|
-
)}
|
|
48
|
-
</nav>
|
|
49
|
-
</div>
|
|
50
|
-
</header>
|
|
51
|
-
);
|
|
52
|
-
}
|
|
53
|
-
|
|
@@ -1,36 +0,0 @@
|
|
|
1
|
-
import * as React from "react"
|
|
2
|
-
import { cva, type VariantProps } from "class-variance-authority"
|
|
3
|
-
import { cn } from "@/lib/utils"
|
|
4
|
-
|
|
5
|
-
const badgeVariants = cva(
|
|
6
|
-
"inline-flex items-center rounded-full border px-2.5 py-0.5 text-xs font-semibold transition-colors focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2",
|
|
7
|
-
{
|
|
8
|
-
variants: {
|
|
9
|
-
variant: {
|
|
10
|
-
default:
|
|
11
|
-
"border-transparent bg-primary text-primary-foreground hover:bg-primary/80",
|
|
12
|
-
secondary:
|
|
13
|
-
"border-transparent bg-secondary text-secondary-foreground hover:bg-secondary/80",
|
|
14
|
-
destructive:
|
|
15
|
-
"border-transparent bg-destructive text-destructive-foreground hover:bg-destructive/80",
|
|
16
|
-
outline: "text-foreground",
|
|
17
|
-
},
|
|
18
|
-
},
|
|
19
|
-
defaultVariants: {
|
|
20
|
-
variant: "default",
|
|
21
|
-
},
|
|
22
|
-
}
|
|
23
|
-
)
|
|
24
|
-
|
|
25
|
-
export interface BadgeProps
|
|
26
|
-
extends React.HTMLAttributes<HTMLDivElement>,
|
|
27
|
-
VariantProps<typeof badgeVariants> {}
|
|
28
|
-
|
|
29
|
-
function Badge({ className, variant, ...props }: BadgeProps) {
|
|
30
|
-
return (
|
|
31
|
-
<div className={cn(badgeVariants({ variant }), className)} {...props} />
|
|
32
|
-
)
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
export { Badge, badgeVariants }
|
|
36
|
-
|
|
@@ -1,34 +0,0 @@
|
|
|
1
|
-
'use client'
|
|
2
|
-
|
|
3
|
-
import * as React from "react"
|
|
4
|
-
import { Moon, Sun } from "lucide-react"
|
|
5
|
-
import { useTheme } from "next-themes"
|
|
6
|
-
|
|
7
|
-
import { Button } from "@digilogiclabs/saas-factory-ui"
|
|
8
|
-
|
|
9
|
-
export function ThemeToggle() {
|
|
10
|
-
const { theme, setTheme } = useTheme()
|
|
11
|
-
|
|
12
|
-
const toggleTheme = () => {
|
|
13
|
-
if (theme === 'light') {
|
|
14
|
-
setTheme('dark')
|
|
15
|
-
} else if (theme === 'dark') {
|
|
16
|
-
setTheme('system')
|
|
17
|
-
} else {
|
|
18
|
-
setTheme('light')
|
|
19
|
-
}
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
return (
|
|
23
|
-
<Button
|
|
24
|
-
variant="outline"
|
|
25
|
-
size="icon"
|
|
26
|
-
onClick={toggleTheme}
|
|
27
|
-
className="h-9 w-9"
|
|
28
|
-
>
|
|
29
|
-
<Sun className="h-4 w-4 rotate-0 scale-100 transition-all dark:-rotate-90 dark:scale-0" />
|
|
30
|
-
<Moon className="absolute h-4 w-4 rotate-90 scale-0 transition-all dark:rotate-0 dark:scale-100" />
|
|
31
|
-
<span className="sr-only">Toggle theme</span>
|
|
32
|
-
</Button>
|
|
33
|
-
)
|
|
34
|
-
}
|