@digilogiclabs/create-saas-app 2.8.1 → 2.9.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 (74) hide show
  1. package/dist/.tsbuildinfo +1 -1
  2. package/dist/generators/template-generator.js +8 -8
  3. package/dist/generators/template-generator.js.map +1 -1
  4. package/dist/templates/shared/quality/web/src/__tests__/accessibility.test.tsx +3 -3
  5. package/dist/templates/web/ai-platform/template/src/app/page.tsx +207 -207
  6. package/dist/templates/web/base/template/src/app/dashboard/page.tsx +6 -43
  7. package/dist/templates/web/base/template/src/app/page.tsx +2 -2
  8. package/dist/templates/web/ui-auth/template/src/app/dev-setup/page.tsx +800 -800
  9. package/dist/templates/web/ui-auth/template/src/app/login/page.tsx +109 -109
  10. package/dist/templates/web/ui-auth/template/src/app/page.tsx +3 -3
  11. package/dist/templates/web/ui-auth/template/src/app/signup/page.tsx +128 -128
  12. package/dist/templates/web/ui-auth-ai/template/src/app/globals.css +35 -40
  13. package/dist/templates/web/ui-auth-ai/template/src/app/layout.tsx +1 -0
  14. package/dist/templates/web/ui-auth-payments/template/src/app/checkout/page.tsx +3 -3
  15. package/dist/templates/web/ui-auth-payments/template/src/app/dashboard/page.tsx +10 -49
  16. package/dist/templates/web/ui-auth-payments/template/src/app/dev-setup/page.tsx +800 -800
  17. package/dist/templates/web/ui-auth-payments/template/src/app/login/page.tsx +109 -109
  18. package/dist/templates/web/ui-auth-payments/template/src/app/page.tsx +350 -350
  19. package/dist/templates/web/ui-auth-payments/template/src/app/setup/page.tsx +506 -506
  20. package/dist/templates/web/ui-auth-payments/template/src/app/signup/page.tsx +128 -128
  21. package/dist/templates/web/ui-auth-payments/template/src/components/client/login-form.tsx +143 -143
  22. package/dist/templates/web/ui-auth-payments/template/src/components/client/signup-form.tsx +184 -184
  23. package/dist/templates/web/ui-auth-payments-ai/template/src/app/billing/page.tsx +143 -233
  24. package/dist/templates/web/ui-auth-payments-ai/template/src/app/dashboard/page.tsx +10 -50
  25. package/dist/templates/web/ui-auth-payments-ai/template/src/app/dev-setup/page.tsx +800 -800
  26. package/dist/templates/web/ui-auth-payments-ai/template/src/app/onboarding/page.tsx +325 -364
  27. package/dist/templates/web/ui-auth-payments-ai/template/src/app/page.tsx +1 -1
  28. package/dist/templates/web/ui-auth-payments-ai/template/src/app/settings/page.tsx +389 -532
  29. package/dist/templates/web/ui-auth-payments-ai/template/src/app/setup/page.tsx +644 -644
  30. package/dist/templates/web/ui-auth-payments-ai/template/src/components/client/login-form.tsx +119 -163
  31. package/dist/templates/web/ui-auth-payments-ai/template/src/components/client/signup-form.tsx +158 -201
  32. package/dist/templates/web/ui-auth-payments-audio/template/src/app/dashboard/page.tsx +10 -51
  33. package/dist/templates/web/ui-auth-payments-audio/template/src/app/page.tsx +402 -403
  34. package/dist/templates/web/ui-auth-payments-audio/template/src/components/client/login-form.tsx +143 -143
  35. package/dist/templates/web/ui-auth-payments-audio/template/src/components/client/signup-form.tsx +184 -184
  36. package/dist/templates/web/ui-auth-payments-video/template/src/app/login/page.tsx +1 -1
  37. package/dist/templates/web/ui-auth-payments-video/template/src/app/page.tsx +3 -7
  38. package/dist/templates/web/ui-auth-payments-video/template/src/app/signup/page.tsx +1 -1
  39. package/package.json +1 -1
  40. package/src/templates/shared/quality/web/src/__tests__/accessibility.test.tsx +3 -3
  41. package/src/templates/web/ai-platform/template/src/app/page.tsx +207 -207
  42. package/src/templates/web/base/template/src/app/dashboard/page.tsx +6 -43
  43. package/src/templates/web/base/template/src/app/page.tsx +2 -2
  44. package/src/templates/web/ui-auth/template/src/app/dev-setup/page.tsx +800 -800
  45. package/src/templates/web/ui-auth/template/src/app/login/page.tsx +109 -109
  46. package/src/templates/web/ui-auth/template/src/app/page.tsx +3 -3
  47. package/src/templates/web/ui-auth/template/src/app/signup/page.tsx +128 -128
  48. package/src/templates/web/ui-auth-ai/template/src/app/globals.css +35 -40
  49. package/src/templates/web/ui-auth-ai/template/src/app/layout.tsx +1 -0
  50. package/src/templates/web/ui-auth-payments/template/src/app/checkout/page.tsx +3 -3
  51. package/src/templates/web/ui-auth-payments/template/src/app/dashboard/page.tsx +10 -49
  52. package/src/templates/web/ui-auth-payments/template/src/app/dev-setup/page.tsx +800 -800
  53. package/src/templates/web/ui-auth-payments/template/src/app/login/page.tsx +109 -109
  54. package/src/templates/web/ui-auth-payments/template/src/app/page.tsx +350 -350
  55. package/src/templates/web/ui-auth-payments/template/src/app/setup/page.tsx +506 -506
  56. package/src/templates/web/ui-auth-payments/template/src/app/signup/page.tsx +128 -128
  57. package/src/templates/web/ui-auth-payments/template/src/components/client/login-form.tsx +143 -143
  58. package/src/templates/web/ui-auth-payments/template/src/components/client/signup-form.tsx +184 -184
  59. package/src/templates/web/ui-auth-payments-ai/template/src/app/billing/page.tsx +143 -233
  60. package/src/templates/web/ui-auth-payments-ai/template/src/app/dashboard/page.tsx +10 -50
  61. package/src/templates/web/ui-auth-payments-ai/template/src/app/dev-setup/page.tsx +800 -800
  62. package/src/templates/web/ui-auth-payments-ai/template/src/app/onboarding/page.tsx +325 -364
  63. package/src/templates/web/ui-auth-payments-ai/template/src/app/page.tsx +1 -1
  64. package/src/templates/web/ui-auth-payments-ai/template/src/app/settings/page.tsx +389 -532
  65. package/src/templates/web/ui-auth-payments-ai/template/src/app/setup/page.tsx +644 -644
  66. package/src/templates/web/ui-auth-payments-ai/template/src/components/client/login-form.tsx +119 -163
  67. package/src/templates/web/ui-auth-payments-ai/template/src/components/client/signup-form.tsx +158 -201
  68. package/src/templates/web/ui-auth-payments-audio/template/src/app/dashboard/page.tsx +10 -51
  69. package/src/templates/web/ui-auth-payments-audio/template/src/app/page.tsx +402 -403
  70. package/src/templates/web/ui-auth-payments-audio/template/src/components/client/login-form.tsx +143 -143
  71. package/src/templates/web/ui-auth-payments-audio/template/src/components/client/signup-form.tsx +184 -184
  72. package/src/templates/web/ui-auth-payments-video/template/src/app/login/page.tsx +1 -1
  73. package/src/templates/web/ui-auth-payments-video/template/src/app/page.tsx +3 -7
  74. package/src/templates/web/ui-auth-payments-video/template/src/app/signup/page.tsx +1 -1
@@ -1,109 +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/app-sdk';
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
-
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/app-sdk';
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');
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
+
@@ -41,7 +41,7 @@ export default function Home() {
41
41
  badge: {
42
42
  text: "🔒 Secure & Modern",
43
43
  variant: "secondary" as const,
44
- icon: CheckCircle
44
+ icon: <CheckCircle className="w-4 h-4" />
45
45
  },
46
46
  title: {
47
47
  text: `Welcome to ${projectName}`,
@@ -151,7 +151,7 @@ export default function Home() {
151
151
  {/* Component Showcase */}
152
152
  <NetworkAwareContent
153
153
  showOnSlow={
154
- <ResponsiveGrid columns={gridConfig.columns_1_sm2} gap="lg" className="mb-16">
154
+ <ResponsiveGrid columns={gridConfig.columns_1_sm2} gap={6} className="mb-16">
155
155
  <SwipeableCard
156
156
  rightActions={[
157
157
  {
@@ -202,7 +202,7 @@ export default function Home() {
202
202
  </ResponsiveGrid>
203
203
  }
204
204
  >
205
- <ResponsiveGrid columns={gridConfig.columns_1_sm2_md3} gap="lg" className="mb-16">
205
+ <ResponsiveGrid columns={gridConfig.columns_1_sm2_md3} gap={6} className="mb-16">
206
206
  <SwipeableCard
207
207
  rightActions={[
208
208
  {
@@ -1,128 +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/app-sdk';
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
-
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/app-sdk';
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');
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
+
@@ -1,40 +1,35 @@
1
- /* Import SaaS Factory UI styles */
2
- @import '@digilogiclabs/saas-factory-ui/dist/index.css';
3
-
4
- @tailwind base;
5
- @tailwind components;
6
- @tailwind utilities;
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
- --popover: 0 0% 100%;
15
- --popover-foreground: 222.2 84% 4.9%;
16
- --primary: 222.2 47.4% 11.2%;
17
- --primary-foreground: 210 40% 98%;
18
- --secondary: 210 40% 96%;
19
- --secondary-foreground: 222.2 47.4% 11.2%;
20
- --muted: 210 40% 96%;
21
- --muted-foreground: 215.4 16.3% 46.9%;
22
- --accent: 210 40% 96%;
23
- --accent-foreground: 222.2 47.4% 11.2%;
24
- --destructive: 0 84.2% 60.2%;
25
- --destructive-foreground: 210 40% 98%;
26
- --border: 214.3 31.8% 91.4%;
27
- --input: 214.3 31.8% 91.4%;
28
- --ring: 222.2 84% 4.9%;
29
- --radius: 0.5rem;
30
- }
31
- }
32
-
33
- @layer base {
34
- * {
35
- @apply border-border;
36
- }
37
- body {
38
- @apply bg-background text-foreground;
39
- }
40
- }
1
+ @import "tailwindcss";
2
+
3
+ @layer base {
4
+ :root {
5
+ --background: 0 0% 100%;
6
+ --foreground: 222.2 84% 4.9%;
7
+ --card: 0 0% 100%;
8
+ --card-foreground: 222.2 84% 4.9%;
9
+ --popover: 0 0% 100%;
10
+ --popover-foreground: 222.2 84% 4.9%;
11
+ --primary: 222.2 47.4% 11.2%;
12
+ --primary-foreground: 210 40% 98%;
13
+ --secondary: 210 40% 96%;
14
+ --secondary-foreground: 222.2 47.4% 11.2%;
15
+ --muted: 210 40% 96%;
16
+ --muted-foreground: 215.4 16.3% 46.9%;
17
+ --accent: 210 40% 96%;
18
+ --accent-foreground: 222.2 47.4% 11.2%;
19
+ --destructive: 0 84.2% 60.2%;
20
+ --destructive-foreground: 210 40% 98%;
21
+ --border: 214.3 31.8% 91.4%;
22
+ --input: 214.3 31.8% 91.4%;
23
+ --ring: 222.2 84% 4.9%;
24
+ --radius: 0.5rem;
25
+ }
26
+ }
27
+
28
+ @layer base {
29
+ * {
30
+ @apply border-border;
31
+ }
32
+ body {
33
+ @apply bg-background text-foreground;
34
+ }
35
+ }
@@ -1,5 +1,6 @@
1
1
  import type { Metadata } from 'next'
2
2
  import { Inter } from 'next/font/google'
3
+ import '@digilogiclabs/saas-factory-ui/dist/index.css'
3
4
  import './globals.css'
4
5
  {{#ai.enabled}}
5
6
  import { AIProvider } from '@digilogiclabs/saas-factory-ai/react'
@@ -113,7 +113,7 @@ export default function CheckoutPage() {
113
113
  {/* Subscription Plans */}
114
114
  <NetworkAwareContent
115
115
  showOnSlow={
116
- <ResponsiveGrid columns={gridConfig.columns_1_2} gap="lg" className="mb-8">
116
+ <ResponsiveGrid columns={gridConfig.columns_1_2} gap={6} className="mb-8">
117
117
  {plans.slice(0, 2).map((plan) => (
118
118
  <Card key={plan.id} className={`p-6 relative ${plan.popular ? 'ring-2 ring-blue-500' : ''}`}>
119
119
  {plan.popular && (
@@ -151,7 +151,7 @@ export default function CheckoutPage() {
151
151
  </ResponsiveGrid>
152
152
  }
153
153
  >
154
- <ResponsiveGrid columns={gridConfig.columns_1_3} gap="lg" className="mb-8">
154
+ <ResponsiveGrid columns={gridConfig.columns_1_3} gap={6} className="mb-8">
155
155
  {plans.map((plan) => (
156
156
  <SwipeableCard
157
157
  key={plan.id}
@@ -260,7 +260,7 @@ export default function CheckoutPage() {
260
260
  hapticFeedback={true}
261
261
  />
262
262
  </div>
263
- <ResponsiveGrid columns={gridConfig.columns_2} gap="md">
263
+ <ResponsiveGrid columns={gridConfig.columns_2} gap={4}>
264
264
  <div>
265
265
  <label className="block text-sm font-medium mb-2">Expiry Date</label>
266
266
  <TouchInput