@tekton-ui/core 0.2.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.
- package/README.md +758 -0
- package/dist/blueprint.d.ts +44 -0
- package/dist/blueprint.d.ts.map +1 -0
- package/dist/blueprint.js +163 -0
- package/dist/blueprint.js.map +1 -0
- package/dist/component-schemas.d.ts +78 -0
- package/dist/component-schemas.d.ts.map +1 -0
- package/dist/component-schemas.js +1037 -0
- package/dist/component-schemas.js.map +1 -0
- package/dist/css-generator.d.ts +42 -0
- package/dist/css-generator.d.ts.map +1 -0
- package/dist/css-generator.js +339 -0
- package/dist/css-generator.js.map +1 -0
- package/dist/icon-library.d.ts +109 -0
- package/dist/icon-library.d.ts.map +1 -0
- package/dist/icon-library.js +204 -0
- package/dist/icon-library.js.map +1 -0
- package/dist/index.d.ts +36 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +51 -0
- package/dist/index.js.map +1 -0
- package/dist/layout-css-generator.d.ts +158 -0
- package/dist/layout-css-generator.d.ts.map +1 -0
- package/dist/layout-css-generator.js +901 -0
- package/dist/layout-css-generator.js.map +1 -0
- package/dist/layout-resolver.d.ts +92 -0
- package/dist/layout-resolver.d.ts.map +1 -0
- package/dist/layout-resolver.js +275 -0
- package/dist/layout-resolver.js.map +1 -0
- package/dist/layout-tokens/index.d.ts +16 -0
- package/dist/layout-tokens/index.d.ts.map +1 -0
- package/dist/layout-tokens/index.js +16 -0
- package/dist/layout-tokens/index.js.map +1 -0
- package/dist/layout-tokens/keyboard.d.ts +254 -0
- package/dist/layout-tokens/keyboard.d.ts.map +1 -0
- package/dist/layout-tokens/keyboard.js +407 -0
- package/dist/layout-tokens/keyboard.js.map +1 -0
- package/dist/layout-tokens/mobile-shells.d.ts +78 -0
- package/dist/layout-tokens/mobile-shells.d.ts.map +1 -0
- package/dist/layout-tokens/mobile-shells.js +635 -0
- package/dist/layout-tokens/mobile-shells.js.map +1 -0
- package/dist/layout-tokens/pages.d.ts +100 -0
- package/dist/layout-tokens/pages.d.ts.map +1 -0
- package/dist/layout-tokens/pages.js +576 -0
- package/dist/layout-tokens/pages.js.map +1 -0
- package/dist/layout-tokens/responsive.d.ts +109 -0
- package/dist/layout-tokens/responsive.d.ts.map +1 -0
- package/dist/layout-tokens/responsive.js +167 -0
- package/dist/layout-tokens/responsive.js.map +1 -0
- package/dist/layout-tokens/safe-area.d.ts +156 -0
- package/dist/layout-tokens/safe-area.d.ts.map +1 -0
- package/dist/layout-tokens/safe-area.js +316 -0
- package/dist/layout-tokens/safe-area.js.map +1 -0
- package/dist/layout-tokens/sections-advanced.d.ts +277 -0
- package/dist/layout-tokens/sections-advanced.d.ts.map +1 -0
- package/dist/layout-tokens/sections-advanced.js +593 -0
- package/dist/layout-tokens/sections-advanced.js.map +1 -0
- package/dist/layout-tokens/sections.d.ts +137 -0
- package/dist/layout-tokens/sections.d.ts.map +1 -0
- package/dist/layout-tokens/sections.js +694 -0
- package/dist/layout-tokens/sections.js.map +1 -0
- package/dist/layout-tokens/shells.d.ts +77 -0
- package/dist/layout-tokens/shells.d.ts.map +1 -0
- package/dist/layout-tokens/shells.js +408 -0
- package/dist/layout-tokens/shells.js.map +1 -0
- package/dist/layout-tokens/touch-target.d.ts +119 -0
- package/dist/layout-tokens/touch-target.d.ts.map +1 -0
- package/dist/layout-tokens/touch-target.js +156 -0
- package/dist/layout-tokens/touch-target.js.map +1 -0
- package/dist/layout-tokens/types.d.ts +632 -0
- package/dist/layout-tokens/types.d.ts.map +1 -0
- package/dist/layout-tokens/types.js +49 -0
- package/dist/layout-tokens/types.js.map +1 -0
- package/dist/layout-validation.d.ts +1547 -0
- package/dist/layout-validation.d.ts.map +1 -0
- package/dist/layout-validation.js +628 -0
- package/dist/layout-validation.js.map +1 -0
- package/dist/render.d.ts +23 -0
- package/dist/render.d.ts.map +1 -0
- package/dist/render.js +244 -0
- package/dist/render.js.map +1 -0
- package/dist/schema-validation.d.ts +208 -0
- package/dist/schema-validation.d.ts.map +1 -0
- package/dist/schema-validation.js +205 -0
- package/dist/schema-validation.js.map +1 -0
- package/dist/screen-generation/generators/css-in-js-generator.d.ts +82 -0
- package/dist/screen-generation/generators/css-in-js-generator.d.ts.map +1 -0
- package/dist/screen-generation/generators/css-in-js-generator.js +335 -0
- package/dist/screen-generation/generators/css-in-js-generator.js.map +1 -0
- package/dist/screen-generation/generators/index.d.ts +13 -0
- package/dist/screen-generation/generators/index.d.ts.map +1 -0
- package/dist/screen-generation/generators/index.js +32 -0
- package/dist/screen-generation/generators/index.js.map +1 -0
- package/dist/screen-generation/generators/react-generator.d.ts +100 -0
- package/dist/screen-generation/generators/react-generator.d.ts.map +1 -0
- package/dist/screen-generation/generators/react-generator.js +379 -0
- package/dist/screen-generation/generators/react-generator.js.map +1 -0
- package/dist/screen-generation/generators/tailwind-generator.d.ts +105 -0
- package/dist/screen-generation/generators/tailwind-generator.d.ts.map +1 -0
- package/dist/screen-generation/generators/tailwind-generator.js +355 -0
- package/dist/screen-generation/generators/tailwind-generator.js.map +1 -0
- package/dist/screen-generation/generators/types.d.ts +136 -0
- package/dist/screen-generation/generators/types.d.ts.map +1 -0
- package/dist/screen-generation/generators/types.js +18 -0
- package/dist/screen-generation/generators/types.js.map +1 -0
- package/dist/screen-generation/generators/utils.d.ts +187 -0
- package/dist/screen-generation/generators/utils.d.ts.map +1 -0
- package/dist/screen-generation/generators/utils.js +312 -0
- package/dist/screen-generation/generators/utils.js.map +1 -0
- package/dist/screen-generation/index.d.ts +14 -0
- package/dist/screen-generation/index.d.ts.map +1 -0
- package/dist/screen-generation/index.js +33 -0
- package/dist/screen-generation/index.js.map +1 -0
- package/dist/screen-generation/resolver/component-resolver.d.ts +157 -0
- package/dist/screen-generation/resolver/component-resolver.d.ts.map +1 -0
- package/dist/screen-generation/resolver/component-resolver.js +295 -0
- package/dist/screen-generation/resolver/component-resolver.js.map +1 -0
- package/dist/screen-generation/resolver/index.d.ts +10 -0
- package/dist/screen-generation/resolver/index.d.ts.map +1 -0
- package/dist/screen-generation/resolver/index.js +46 -0
- package/dist/screen-generation/resolver/index.js.map +1 -0
- package/dist/screen-generation/resolver/layout-resolver.d.ts +155 -0
- package/dist/screen-generation/resolver/layout-resolver.d.ts.map +1 -0
- package/dist/screen-generation/resolver/layout-resolver.js +193 -0
- package/dist/screen-generation/resolver/layout-resolver.js.map +1 -0
- package/dist/screen-generation/resolver/screen-resolver.d.ts +174 -0
- package/dist/screen-generation/resolver/screen-resolver.d.ts.map +1 -0
- package/dist/screen-generation/resolver/screen-resolver.js +373 -0
- package/dist/screen-generation/resolver/screen-resolver.js.map +1 -0
- package/dist/screen-generation/resolver/token-resolver.d.ts +170 -0
- package/dist/screen-generation/resolver/token-resolver.d.ts.map +1 -0
- package/dist/screen-generation/resolver/token-resolver.js +260 -0
- package/dist/screen-generation/resolver/token-resolver.js.map +1 -0
- package/dist/screen-generation/types.d.ts +116 -0
- package/dist/screen-generation/types.d.ts.map +1 -0
- package/dist/screen-generation/types.js +33 -0
- package/dist/screen-generation/types.js.map +1 -0
- package/dist/screen-generation/validators.d.ts +286 -0
- package/dist/screen-generation/validators.d.ts.map +1 -0
- package/dist/screen-generation/validators.js +323 -0
- package/dist/screen-generation/validators.js.map +1 -0
- package/dist/screen-templates/__tests__/registry.test.d.ts +6 -0
- package/dist/screen-templates/__tests__/registry.test.d.ts.map +1 -0
- package/dist/screen-templates/__tests__/registry.test.js +247 -0
- package/dist/screen-templates/__tests__/registry.test.js.map +1 -0
- package/dist/screen-templates/__tests__/templates.test.d.ts +6 -0
- package/dist/screen-templates/__tests__/templates.test.d.ts.map +1 -0
- package/dist/screen-templates/__tests__/templates.test.js +179 -0
- package/dist/screen-templates/__tests__/templates.test.js.map +1 -0
- package/dist/screen-templates/index.d.ts +39 -0
- package/dist/screen-templates/index.d.ts.map +1 -0
- package/dist/screen-templates/index.js +79 -0
- package/dist/screen-templates/index.js.map +1 -0
- package/dist/screen-templates/registry.d.ts +177 -0
- package/dist/screen-templates/registry.d.ts.map +1 -0
- package/dist/screen-templates/registry.js +274 -0
- package/dist/screen-templates/registry.js.map +1 -0
- package/dist/screen-templates/templates/account/index.d.ts +6 -0
- package/dist/screen-templates/templates/account/index.d.ts.map +1 -0
- package/dist/screen-templates/templates/account/index.js +6 -0
- package/dist/screen-templates/templates/account/index.js.map +1 -0
- package/dist/screen-templates/templates/account/profile.d.ts +23 -0
- package/dist/screen-templates/templates/account/profile.d.ts.map +1 -0
- package/dist/screen-templates/templates/account/profile.js +249 -0
- package/dist/screen-templates/templates/account/profile.js.map +1 -0
- package/dist/screen-templates/templates/auth/forgot-password.d.ts +23 -0
- package/dist/screen-templates/templates/auth/forgot-password.d.ts.map +1 -0
- package/dist/screen-templates/templates/auth/forgot-password.js +203 -0
- package/dist/screen-templates/templates/auth/forgot-password.js.map +1 -0
- package/dist/screen-templates/templates/auth/index.d.ts +9 -0
- package/dist/screen-templates/templates/auth/index.d.ts.map +1 -0
- package/dist/screen-templates/templates/auth/index.js +9 -0
- package/dist/screen-templates/templates/auth/index.js.map +1 -0
- package/dist/screen-templates/templates/auth/login.d.ts +24 -0
- package/dist/screen-templates/templates/auth/login.d.ts.map +1 -0
- package/dist/screen-templates/templates/auth/login.js +254 -0
- package/dist/screen-templates/templates/auth/login.js.map +1 -0
- package/dist/screen-templates/templates/auth/signup.d.ts +24 -0
- package/dist/screen-templates/templates/auth/signup.d.ts.map +1 -0
- package/dist/screen-templates/templates/auth/signup.js +315 -0
- package/dist/screen-templates/templates/auth/signup.js.map +1 -0
- package/dist/screen-templates/templates/auth/verification.d.ts +23 -0
- package/dist/screen-templates/templates/auth/verification.d.ts.map +1 -0
- package/dist/screen-templates/templates/auth/verification.js +239 -0
- package/dist/screen-templates/templates/auth/verification.js.map +1 -0
- package/dist/screen-templates/templates/feedback/confirmation.d.ts +9 -0
- package/dist/screen-templates/templates/feedback/confirmation.d.ts.map +1 -0
- package/dist/screen-templates/templates/feedback/confirmation.js +107 -0
- package/dist/screen-templates/templates/feedback/confirmation.js.map +1 -0
- package/dist/screen-templates/templates/feedback/empty.d.ts +9 -0
- package/dist/screen-templates/templates/feedback/empty.d.ts.map +1 -0
- package/dist/screen-templates/templates/feedback/empty.js +90 -0
- package/dist/screen-templates/templates/feedback/empty.js.map +1 -0
- package/dist/screen-templates/templates/feedback/error.d.ts +9 -0
- package/dist/screen-templates/templates/feedback/error.d.ts.map +1 -0
- package/dist/screen-templates/templates/feedback/error.js +99 -0
- package/dist/screen-templates/templates/feedback/error.js.map +1 -0
- package/dist/screen-templates/templates/feedback/index.d.ts +10 -0
- package/dist/screen-templates/templates/feedback/index.d.ts.map +1 -0
- package/dist/screen-templates/templates/feedback/index.js +10 -0
- package/dist/screen-templates/templates/feedback/index.js.map +1 -0
- package/dist/screen-templates/templates/feedback/loading.d.ts +9 -0
- package/dist/screen-templates/templates/feedback/loading.d.ts.map +1 -0
- package/dist/screen-templates/templates/feedback/loading.js +77 -0
- package/dist/screen-templates/templates/feedback/loading.js.map +1 -0
- package/dist/screen-templates/templates/feedback/success.d.ts +9 -0
- package/dist/screen-templates/templates/feedback/success.d.ts.map +1 -0
- package/dist/screen-templates/templates/feedback/success.js +99 -0
- package/dist/screen-templates/templates/feedback/success.js.map +1 -0
- package/dist/screen-templates/templates/home/index.d.ts +6 -0
- package/dist/screen-templates/templates/home/index.d.ts.map +1 -0
- package/dist/screen-templates/templates/home/index.js +6 -0
- package/dist/screen-templates/templates/home/index.js.map +1 -0
- package/dist/screen-templates/templates/home/landing.d.ts +24 -0
- package/dist/screen-templates/templates/home/landing.d.ts.map +1 -0
- package/dist/screen-templates/templates/home/landing.js +197 -0
- package/dist/screen-templates/templates/home/landing.js.map +1 -0
- package/dist/screen-templates/templates/settings/index.d.ts +6 -0
- package/dist/screen-templates/templates/settings/index.d.ts.map +1 -0
- package/dist/screen-templates/templates/settings/index.js +6 -0
- package/dist/screen-templates/templates/settings/index.js.map +1 -0
- package/dist/screen-templates/templates/settings/preferences.d.ts +24 -0
- package/dist/screen-templates/templates/settings/preferences.d.ts.map +1 -0
- package/dist/screen-templates/templates/settings/preferences.js +265 -0
- package/dist/screen-templates/templates/settings/preferences.js.map +1 -0
- package/dist/screen-templates/types.d.ts +229 -0
- package/dist/screen-templates/types.d.ts.map +1 -0
- package/dist/screen-templates/types.js +7 -0
- package/dist/screen-templates/types.js.map +1 -0
- package/dist/theme-v2.d.ts +228 -0
- package/dist/theme-v2.d.ts.map +1 -0
- package/dist/theme-v2.js +158 -0
- package/dist/theme-v2.js.map +1 -0
- package/dist/theme.d.ts +60 -0
- package/dist/theme.d.ts.map +1 -0
- package/dist/theme.js +76 -0
- package/dist/theme.js.map +1 -0
- package/dist/token-resolver.d.ts +69 -0
- package/dist/token-resolver.d.ts.map +1 -0
- package/dist/token-resolver.js +122 -0
- package/dist/token-resolver.js.map +1 -0
- package/dist/token-validation.d.ts +432 -0
- package/dist/token-validation.d.ts.map +1 -0
- package/dist/token-validation.js +140 -0
- package/dist/token-validation.js.map +1 -0
- package/dist/tokens.d.ts +158 -0
- package/dist/tokens.d.ts.map +1 -0
- package/dist/tokens.js +10 -0
- package/dist/tokens.js.map +1 -0
- package/dist/types.d.ts +77 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +7 -0
- package/dist/types.js.map +1 -0
- package/package.json +53 -0
|
@@ -0,0 +1,254 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @tekton-ui/core - Login Screen Template
|
|
3
|
+
* [SPEC-UI-002] [TAG-UI002-024] auth.login
|
|
4
|
+
*
|
|
5
|
+
* Design Reference: Claude.ai Login Page
|
|
6
|
+
* - 중앙 정렬 카드 레이아웃
|
|
7
|
+
* - 명료함과 접근성 우선
|
|
8
|
+
* - 절제된 색상 사용
|
|
9
|
+
*/
|
|
10
|
+
/**
|
|
11
|
+
* Login Component
|
|
12
|
+
* 로그인 화면 컴포넌트
|
|
13
|
+
*
|
|
14
|
+
* Required Components: Button, Input, Form, Card, Label
|
|
15
|
+
*/
|
|
16
|
+
export const LoginComponent = ({ slots, className, texts }) => {
|
|
17
|
+
const defaultTexts = {
|
|
18
|
+
title: texts?.title ?? '로그인',
|
|
19
|
+
subtitle: texts?.subtitle ?? '계정에 로그인하세요',
|
|
20
|
+
emailLabel: texts?.emailLabel ?? '이메일',
|
|
21
|
+
passwordLabel: texts?.passwordLabel ?? '비밀번호',
|
|
22
|
+
loginButton: texts?.loginButton ?? '로그인',
|
|
23
|
+
forgotPassword: texts?.forgotPassword ?? '비밀번호를 잊으셨나요?',
|
|
24
|
+
signupLink: texts?.signupLink ?? '회원가입',
|
|
25
|
+
...texts,
|
|
26
|
+
};
|
|
27
|
+
return {
|
|
28
|
+
type: 'div',
|
|
29
|
+
props: {
|
|
30
|
+
className: `min-h-screen flex items-center justify-center bg-[var(--tekton-bg-base)] ${className ?? ''}`,
|
|
31
|
+
style: {
|
|
32
|
+
padding: 'var(--tekton-layout-padding-mobile)',
|
|
33
|
+
},
|
|
34
|
+
},
|
|
35
|
+
children: [
|
|
36
|
+
{
|
|
37
|
+
type: 'Card',
|
|
38
|
+
props: {
|
|
39
|
+
className: 'w-full max-w-md',
|
|
40
|
+
style: {
|
|
41
|
+
padding: 'var(--tekton-spacing-8)',
|
|
42
|
+
gap: 'var(--tekton-spacing-6)',
|
|
43
|
+
},
|
|
44
|
+
},
|
|
45
|
+
children: [
|
|
46
|
+
// Header slot
|
|
47
|
+
slots?.header ?? null,
|
|
48
|
+
// Title section
|
|
49
|
+
{
|
|
50
|
+
type: 'div',
|
|
51
|
+
props: {
|
|
52
|
+
className: 'space-y-2 text-center',
|
|
53
|
+
},
|
|
54
|
+
children: [
|
|
55
|
+
{
|
|
56
|
+
type: 'h1',
|
|
57
|
+
props: {
|
|
58
|
+
className: 'text-2xl font-semibold',
|
|
59
|
+
},
|
|
60
|
+
children: [defaultTexts.title],
|
|
61
|
+
},
|
|
62
|
+
{
|
|
63
|
+
type: 'p',
|
|
64
|
+
props: {
|
|
65
|
+
className: 'text-sm text-[var(--tekton-text-secondary)]',
|
|
66
|
+
},
|
|
67
|
+
children: [defaultTexts.subtitle],
|
|
68
|
+
},
|
|
69
|
+
],
|
|
70
|
+
},
|
|
71
|
+
// Form
|
|
72
|
+
{
|
|
73
|
+
type: 'Form',
|
|
74
|
+
props: {
|
|
75
|
+
className: 'space-y-4',
|
|
76
|
+
},
|
|
77
|
+
children: [
|
|
78
|
+
// Email field
|
|
79
|
+
{
|
|
80
|
+
type: 'div',
|
|
81
|
+
props: {
|
|
82
|
+
className: 'space-y-2',
|
|
83
|
+
},
|
|
84
|
+
children: [
|
|
85
|
+
{
|
|
86
|
+
type: 'Label',
|
|
87
|
+
props: {
|
|
88
|
+
htmlFor: 'email',
|
|
89
|
+
},
|
|
90
|
+
children: [defaultTexts.emailLabel],
|
|
91
|
+
},
|
|
92
|
+
{
|
|
93
|
+
type: 'Input',
|
|
94
|
+
props: {
|
|
95
|
+
id: 'email',
|
|
96
|
+
type: 'email',
|
|
97
|
+
placeholder: 'name@example.com',
|
|
98
|
+
required: true,
|
|
99
|
+
},
|
|
100
|
+
},
|
|
101
|
+
],
|
|
102
|
+
},
|
|
103
|
+
// Password field
|
|
104
|
+
{
|
|
105
|
+
type: 'div',
|
|
106
|
+
props: {
|
|
107
|
+
className: 'space-y-2',
|
|
108
|
+
},
|
|
109
|
+
children: [
|
|
110
|
+
{
|
|
111
|
+
type: 'Label',
|
|
112
|
+
props: {
|
|
113
|
+
htmlFor: 'password',
|
|
114
|
+
},
|
|
115
|
+
children: [defaultTexts.passwordLabel],
|
|
116
|
+
},
|
|
117
|
+
{
|
|
118
|
+
type: 'Input',
|
|
119
|
+
props: {
|
|
120
|
+
id: 'password',
|
|
121
|
+
type: 'password',
|
|
122
|
+
required: true,
|
|
123
|
+
},
|
|
124
|
+
},
|
|
125
|
+
],
|
|
126
|
+
},
|
|
127
|
+
// Login button
|
|
128
|
+
{
|
|
129
|
+
type: 'Button',
|
|
130
|
+
props: {
|
|
131
|
+
type: 'submit',
|
|
132
|
+
className: 'w-full',
|
|
133
|
+
},
|
|
134
|
+
children: [defaultTexts.loginButton],
|
|
135
|
+
},
|
|
136
|
+
],
|
|
137
|
+
},
|
|
138
|
+
// Footer links
|
|
139
|
+
{
|
|
140
|
+
type: 'div',
|
|
141
|
+
props: {
|
|
142
|
+
className: 'flex flex-col items-center gap-2 text-sm',
|
|
143
|
+
},
|
|
144
|
+
children: [
|
|
145
|
+
{
|
|
146
|
+
type: 'a',
|
|
147
|
+
props: {
|
|
148
|
+
href: '/forgot-password',
|
|
149
|
+
className: 'text-[var(--tekton-text-link)] hover:underline',
|
|
150
|
+
},
|
|
151
|
+
children: [defaultTexts.forgotPassword],
|
|
152
|
+
},
|
|
153
|
+
{
|
|
154
|
+
type: 'div',
|
|
155
|
+
props: {
|
|
156
|
+
className: 'text-[var(--tekton-text-secondary)]',
|
|
157
|
+
},
|
|
158
|
+
children: [
|
|
159
|
+
'계정이 없으신가요? ',
|
|
160
|
+
{
|
|
161
|
+
type: 'a',
|
|
162
|
+
props: {
|
|
163
|
+
href: '/signup',
|
|
164
|
+
className: 'text-[var(--tekton-text-link)] hover:underline',
|
|
165
|
+
},
|
|
166
|
+
children: [defaultTexts.signupLink],
|
|
167
|
+
},
|
|
168
|
+
],
|
|
169
|
+
},
|
|
170
|
+
],
|
|
171
|
+
},
|
|
172
|
+
// Footer slot
|
|
173
|
+
slots?.footer ?? null,
|
|
174
|
+
],
|
|
175
|
+
},
|
|
176
|
+
],
|
|
177
|
+
};
|
|
178
|
+
};
|
|
179
|
+
/**
|
|
180
|
+
* Login Screen Template
|
|
181
|
+
* 로그인 화면 템플릿 정의
|
|
182
|
+
*/
|
|
183
|
+
export const loginTemplate = {
|
|
184
|
+
id: 'auth.login',
|
|
185
|
+
name: 'Login',
|
|
186
|
+
category: 'auth',
|
|
187
|
+
description: 'User login screen with email/password authentication. Clean, centered layout following Claude.ai design principles.',
|
|
188
|
+
skeleton: {
|
|
189
|
+
shell: 'shell.web.app',
|
|
190
|
+
page: 'page.auth',
|
|
191
|
+
sections: [
|
|
192
|
+
{
|
|
193
|
+
id: 'logo',
|
|
194
|
+
name: 'Logo',
|
|
195
|
+
required: false,
|
|
196
|
+
allowedComponents: ['Logo', 'Image'],
|
|
197
|
+
},
|
|
198
|
+
{
|
|
199
|
+
id: 'form',
|
|
200
|
+
name: 'Login Form',
|
|
201
|
+
required: true,
|
|
202
|
+
allowedComponents: ['Form', 'Input', 'Button', 'Label'],
|
|
203
|
+
},
|
|
204
|
+
{
|
|
205
|
+
id: 'footer',
|
|
206
|
+
name: 'Footer Links',
|
|
207
|
+
required: false,
|
|
208
|
+
allowedComponents: ['Link', 'Text'],
|
|
209
|
+
},
|
|
210
|
+
],
|
|
211
|
+
},
|
|
212
|
+
customizable: {
|
|
213
|
+
texts: [
|
|
214
|
+
'title',
|
|
215
|
+
'subtitle',
|
|
216
|
+
'emailLabel',
|
|
217
|
+
'passwordLabel',
|
|
218
|
+
'loginButton',
|
|
219
|
+
'forgotPassword',
|
|
220
|
+
'signupLink',
|
|
221
|
+
],
|
|
222
|
+
optional: ['social_login', 'remember_me', 'logo'],
|
|
223
|
+
slots: ['header', 'footer'],
|
|
224
|
+
},
|
|
225
|
+
requiredComponents: ['Button', 'Input', 'Form', 'Card', 'Label'],
|
|
226
|
+
layout: {
|
|
227
|
+
type: 'centered',
|
|
228
|
+
maxWidth: 'sm',
|
|
229
|
+
responsive: {
|
|
230
|
+
desktop: {
|
|
231
|
+
padding: 'atomic.spacing.64',
|
|
232
|
+
gap: 'atomic.spacing.32',
|
|
233
|
+
direction: 'column',
|
|
234
|
+
},
|
|
235
|
+
tablet: {
|
|
236
|
+
padding: 'atomic.spacing.32',
|
|
237
|
+
gap: 'atomic.spacing.24',
|
|
238
|
+
direction: 'column',
|
|
239
|
+
},
|
|
240
|
+
mobile: {
|
|
241
|
+
padding: 'atomic.spacing.16',
|
|
242
|
+
gap: 'atomic.spacing.16',
|
|
243
|
+
direction: 'column',
|
|
244
|
+
},
|
|
245
|
+
},
|
|
246
|
+
},
|
|
247
|
+
tokenBindings: {
|
|
248
|
+
backgroundColor: 'semantic.color.background.base',
|
|
249
|
+
textColor: 'semantic.color.text.primary',
|
|
250
|
+
linkColor: 'semantic.color.text.link',
|
|
251
|
+
},
|
|
252
|
+
Component: LoginComponent,
|
|
253
|
+
};
|
|
254
|
+
//# sourceMappingURL=login.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"login.js","sourceRoot":"","sources":["../../../../src/screen-templates/templates/auth/login.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @tekton-ui/core - Signup Screen Template
|
|
3
|
+
* [SPEC-UI-002] [TAG-UI002-025] auth.signup
|
|
4
|
+
*
|
|
5
|
+
* Design Reference: Claude.ai Signup Page
|
|
6
|
+
* - auth.login과 동일한 레이아웃 구조
|
|
7
|
+
* - 추가 입력 필드 (이름, 비밀번호 확인)
|
|
8
|
+
* - 약관 동의 체크박스
|
|
9
|
+
*/
|
|
10
|
+
import type { ScreenTemplate, ScreenTemplateProps } from '../../types.js';
|
|
11
|
+
import type { FC } from '../../types.js';
|
|
12
|
+
/**
|
|
13
|
+
* Signup Component
|
|
14
|
+
* 회원가입 화면 컴포넌트
|
|
15
|
+
*
|
|
16
|
+
* Required Components: Button, Input, Form, Card, Label, Checkbox
|
|
17
|
+
*/
|
|
18
|
+
export declare const SignupComponent: FC<ScreenTemplateProps>;
|
|
19
|
+
/**
|
|
20
|
+
* Signup Screen Template
|
|
21
|
+
* 회원가입 화면 템플릿 정의
|
|
22
|
+
*/
|
|
23
|
+
export declare const signupTemplate: ScreenTemplate;
|
|
24
|
+
//# sourceMappingURL=signup.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"signup.d.ts","sourceRoot":"","sources":["../../../../src/screen-templates/templates/auth/signup.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAIH,OAAO,KAAK,EAAE,cAAc,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAC1E,OAAO,KAAK,EAAE,EAAE,EAAE,MAAM,gBAAgB,CAAC;AAEzC;;;;;GAKG;AACH,eAAO,MAAM,eAAe,EAAE,EAAE,CAAC,mBAAmB,CAuOnD,CAAC;AAEF;;;GAGG;AACH,eAAO,MAAM,cAAc,EAAE,cA+E5B,CAAC"}
|
|
@@ -0,0 +1,315 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @tekton-ui/core - Signup Screen Template
|
|
3
|
+
* [SPEC-UI-002] [TAG-UI002-025] auth.signup
|
|
4
|
+
*
|
|
5
|
+
* Design Reference: Claude.ai Signup Page
|
|
6
|
+
* - auth.login과 동일한 레이아웃 구조
|
|
7
|
+
* - 추가 입력 필드 (이름, 비밀번호 확인)
|
|
8
|
+
* - 약관 동의 체크박스
|
|
9
|
+
*/
|
|
10
|
+
/**
|
|
11
|
+
* Signup Component
|
|
12
|
+
* 회원가입 화면 컴포넌트
|
|
13
|
+
*
|
|
14
|
+
* Required Components: Button, Input, Form, Card, Label, Checkbox
|
|
15
|
+
*/
|
|
16
|
+
export const SignupComponent = ({ slots, className, texts }) => {
|
|
17
|
+
const defaultTexts = {
|
|
18
|
+
title: texts?.title ?? '회원가입',
|
|
19
|
+
subtitle: texts?.subtitle ?? '새 계정을 만드세요',
|
|
20
|
+
nameLabel: texts?.nameLabel ?? '이름',
|
|
21
|
+
emailLabel: texts?.emailLabel ?? '이메일',
|
|
22
|
+
passwordLabel: texts?.passwordLabel ?? '비밀번호',
|
|
23
|
+
confirmPasswordLabel: texts?.confirmPasswordLabel ?? '비밀번호 확인',
|
|
24
|
+
termsLabel: texts?.termsLabel ?? '이용약관 및 개인정보처리방침에 동의합니다',
|
|
25
|
+
signupButton: texts?.signupButton ?? '가입하기',
|
|
26
|
+
loginLink: texts?.loginLink ?? '로그인',
|
|
27
|
+
...texts,
|
|
28
|
+
};
|
|
29
|
+
return {
|
|
30
|
+
type: 'div',
|
|
31
|
+
props: {
|
|
32
|
+
className: `min-h-screen flex items-center justify-center bg-[var(--tekton-bg-base)] ${className ?? ''}`,
|
|
33
|
+
style: {
|
|
34
|
+
padding: 'var(--tekton-layout-padding-mobile)',
|
|
35
|
+
},
|
|
36
|
+
},
|
|
37
|
+
children: [
|
|
38
|
+
{
|
|
39
|
+
type: 'Card',
|
|
40
|
+
props: {
|
|
41
|
+
className: 'w-full max-w-md',
|
|
42
|
+
style: {
|
|
43
|
+
padding: 'var(--tekton-spacing-8)',
|
|
44
|
+
gap: 'var(--tekton-spacing-6)',
|
|
45
|
+
},
|
|
46
|
+
},
|
|
47
|
+
children: [
|
|
48
|
+
// Header slot
|
|
49
|
+
slots?.header ?? null,
|
|
50
|
+
// Title section
|
|
51
|
+
{
|
|
52
|
+
type: 'div',
|
|
53
|
+
props: {
|
|
54
|
+
className: 'space-y-2 text-center',
|
|
55
|
+
},
|
|
56
|
+
children: [
|
|
57
|
+
{
|
|
58
|
+
type: 'h1',
|
|
59
|
+
props: {
|
|
60
|
+
className: 'text-2xl font-semibold',
|
|
61
|
+
},
|
|
62
|
+
children: [defaultTexts.title],
|
|
63
|
+
},
|
|
64
|
+
{
|
|
65
|
+
type: 'p',
|
|
66
|
+
props: {
|
|
67
|
+
className: 'text-sm text-[var(--tekton-text-secondary)]',
|
|
68
|
+
},
|
|
69
|
+
children: [defaultTexts.subtitle],
|
|
70
|
+
},
|
|
71
|
+
],
|
|
72
|
+
},
|
|
73
|
+
// Form
|
|
74
|
+
{
|
|
75
|
+
type: 'Form',
|
|
76
|
+
props: {
|
|
77
|
+
className: 'space-y-4',
|
|
78
|
+
},
|
|
79
|
+
children: [
|
|
80
|
+
// Name field
|
|
81
|
+
{
|
|
82
|
+
type: 'div',
|
|
83
|
+
props: {
|
|
84
|
+
className: 'space-y-2',
|
|
85
|
+
},
|
|
86
|
+
children: [
|
|
87
|
+
{
|
|
88
|
+
type: 'Label',
|
|
89
|
+
props: {
|
|
90
|
+
htmlFor: 'name',
|
|
91
|
+
},
|
|
92
|
+
children: [defaultTexts.nameLabel],
|
|
93
|
+
},
|
|
94
|
+
{
|
|
95
|
+
type: 'Input',
|
|
96
|
+
props: {
|
|
97
|
+
id: 'name',
|
|
98
|
+
type: 'text',
|
|
99
|
+
placeholder: '홍길동',
|
|
100
|
+
required: true,
|
|
101
|
+
},
|
|
102
|
+
},
|
|
103
|
+
],
|
|
104
|
+
},
|
|
105
|
+
// Email field
|
|
106
|
+
{
|
|
107
|
+
type: 'div',
|
|
108
|
+
props: {
|
|
109
|
+
className: 'space-y-2',
|
|
110
|
+
},
|
|
111
|
+
children: [
|
|
112
|
+
{
|
|
113
|
+
type: 'Label',
|
|
114
|
+
props: {
|
|
115
|
+
htmlFor: 'email',
|
|
116
|
+
},
|
|
117
|
+
children: [defaultTexts.emailLabel],
|
|
118
|
+
},
|
|
119
|
+
{
|
|
120
|
+
type: 'Input',
|
|
121
|
+
props: {
|
|
122
|
+
id: 'email',
|
|
123
|
+
type: 'email',
|
|
124
|
+
placeholder: 'name@example.com',
|
|
125
|
+
required: true,
|
|
126
|
+
},
|
|
127
|
+
},
|
|
128
|
+
],
|
|
129
|
+
},
|
|
130
|
+
// Password field
|
|
131
|
+
{
|
|
132
|
+
type: 'div',
|
|
133
|
+
props: {
|
|
134
|
+
className: 'space-y-2',
|
|
135
|
+
},
|
|
136
|
+
children: [
|
|
137
|
+
{
|
|
138
|
+
type: 'Label',
|
|
139
|
+
props: {
|
|
140
|
+
htmlFor: 'password',
|
|
141
|
+
},
|
|
142
|
+
children: [defaultTexts.passwordLabel],
|
|
143
|
+
},
|
|
144
|
+
{
|
|
145
|
+
type: 'Input',
|
|
146
|
+
props: {
|
|
147
|
+
id: 'password',
|
|
148
|
+
type: 'password',
|
|
149
|
+
required: true,
|
|
150
|
+
},
|
|
151
|
+
},
|
|
152
|
+
],
|
|
153
|
+
},
|
|
154
|
+
// Confirm password field
|
|
155
|
+
{
|
|
156
|
+
type: 'div',
|
|
157
|
+
props: {
|
|
158
|
+
className: 'space-y-2',
|
|
159
|
+
},
|
|
160
|
+
children: [
|
|
161
|
+
{
|
|
162
|
+
type: 'Label',
|
|
163
|
+
props: {
|
|
164
|
+
htmlFor: 'confirm-password',
|
|
165
|
+
},
|
|
166
|
+
children: [defaultTexts.confirmPasswordLabel],
|
|
167
|
+
},
|
|
168
|
+
{
|
|
169
|
+
type: 'Input',
|
|
170
|
+
props: {
|
|
171
|
+
id: 'confirm-password',
|
|
172
|
+
type: 'password',
|
|
173
|
+
required: true,
|
|
174
|
+
},
|
|
175
|
+
},
|
|
176
|
+
],
|
|
177
|
+
},
|
|
178
|
+
// Terms checkbox
|
|
179
|
+
{
|
|
180
|
+
type: 'div',
|
|
181
|
+
props: {
|
|
182
|
+
className: 'flex items-center gap-2',
|
|
183
|
+
},
|
|
184
|
+
children: [
|
|
185
|
+
{
|
|
186
|
+
type: 'Checkbox',
|
|
187
|
+
props: {
|
|
188
|
+
id: 'terms',
|
|
189
|
+
required: true,
|
|
190
|
+
},
|
|
191
|
+
},
|
|
192
|
+
{
|
|
193
|
+
type: 'Label',
|
|
194
|
+
props: {
|
|
195
|
+
htmlFor: 'terms',
|
|
196
|
+
className: 'text-sm font-normal',
|
|
197
|
+
},
|
|
198
|
+
children: [defaultTexts.termsLabel],
|
|
199
|
+
},
|
|
200
|
+
],
|
|
201
|
+
},
|
|
202
|
+
// Signup button
|
|
203
|
+
{
|
|
204
|
+
type: 'Button',
|
|
205
|
+
props: {
|
|
206
|
+
type: 'submit',
|
|
207
|
+
className: 'w-full',
|
|
208
|
+
},
|
|
209
|
+
children: [defaultTexts.signupButton],
|
|
210
|
+
},
|
|
211
|
+
],
|
|
212
|
+
},
|
|
213
|
+
// Footer link
|
|
214
|
+
{
|
|
215
|
+
type: 'div',
|
|
216
|
+
props: {
|
|
217
|
+
className: 'text-center text-sm text-[var(--tekton-text-secondary)]',
|
|
218
|
+
},
|
|
219
|
+
children: [
|
|
220
|
+
'이미 계정이 있으신가요? ',
|
|
221
|
+
{
|
|
222
|
+
type: 'a',
|
|
223
|
+
props: {
|
|
224
|
+
href: '/login',
|
|
225
|
+
className: 'text-[var(--tekton-text-link)] hover:underline',
|
|
226
|
+
},
|
|
227
|
+
children: [defaultTexts.loginLink],
|
|
228
|
+
},
|
|
229
|
+
],
|
|
230
|
+
},
|
|
231
|
+
// Footer slot
|
|
232
|
+
slots?.footer ?? null,
|
|
233
|
+
],
|
|
234
|
+
},
|
|
235
|
+
],
|
|
236
|
+
};
|
|
237
|
+
};
|
|
238
|
+
/**
|
|
239
|
+
* Signup Screen Template
|
|
240
|
+
* 회원가입 화면 템플릿 정의
|
|
241
|
+
*/
|
|
242
|
+
export const signupTemplate = {
|
|
243
|
+
id: 'auth.signup',
|
|
244
|
+
name: 'Signup',
|
|
245
|
+
category: 'auth',
|
|
246
|
+
description: 'User signup screen with name, email, password, and terms agreement. Follows auth.login layout structure with additional fields.',
|
|
247
|
+
skeleton: {
|
|
248
|
+
shell: 'shell.web.app',
|
|
249
|
+
page: 'page.auth',
|
|
250
|
+
sections: [
|
|
251
|
+
{
|
|
252
|
+
id: 'logo',
|
|
253
|
+
name: 'Logo',
|
|
254
|
+
required: false,
|
|
255
|
+
allowedComponents: ['Logo', 'Image'],
|
|
256
|
+
},
|
|
257
|
+
{
|
|
258
|
+
id: 'form',
|
|
259
|
+
name: 'Signup Form',
|
|
260
|
+
required: true,
|
|
261
|
+
allowedComponents: ['Form', 'Input', 'Button', 'Label', 'Checkbox'],
|
|
262
|
+
},
|
|
263
|
+
{
|
|
264
|
+
id: 'footer',
|
|
265
|
+
name: 'Footer Links',
|
|
266
|
+
required: false,
|
|
267
|
+
allowedComponents: ['Link', 'Text'],
|
|
268
|
+
},
|
|
269
|
+
],
|
|
270
|
+
},
|
|
271
|
+
customizable: {
|
|
272
|
+
texts: [
|
|
273
|
+
'title',
|
|
274
|
+
'subtitle',
|
|
275
|
+
'nameLabel',
|
|
276
|
+
'emailLabel',
|
|
277
|
+
'passwordLabel',
|
|
278
|
+
'confirmPasswordLabel',
|
|
279
|
+
'termsLabel',
|
|
280
|
+
'signupButton',
|
|
281
|
+
'loginLink',
|
|
282
|
+
],
|
|
283
|
+
optional: ['social_signup', 'logo'],
|
|
284
|
+
slots: ['header', 'footer'],
|
|
285
|
+
},
|
|
286
|
+
requiredComponents: ['Button', 'Input', 'Form', 'Card', 'Label', 'Checkbox'],
|
|
287
|
+
layout: {
|
|
288
|
+
type: 'centered',
|
|
289
|
+
maxWidth: 'sm',
|
|
290
|
+
responsive: {
|
|
291
|
+
desktop: {
|
|
292
|
+
padding: 'atomic.spacing.64',
|
|
293
|
+
gap: 'atomic.spacing.32',
|
|
294
|
+
direction: 'column',
|
|
295
|
+
},
|
|
296
|
+
tablet: {
|
|
297
|
+
padding: 'atomic.spacing.32',
|
|
298
|
+
gap: 'atomic.spacing.24',
|
|
299
|
+
direction: 'column',
|
|
300
|
+
},
|
|
301
|
+
mobile: {
|
|
302
|
+
padding: 'atomic.spacing.16',
|
|
303
|
+
gap: 'atomic.spacing.16',
|
|
304
|
+
direction: 'column',
|
|
305
|
+
},
|
|
306
|
+
},
|
|
307
|
+
},
|
|
308
|
+
tokenBindings: {
|
|
309
|
+
backgroundColor: 'semantic.color.background.base',
|
|
310
|
+
textColor: 'semantic.color.text.primary',
|
|
311
|
+
linkColor: 'semantic.color.text.link',
|
|
312
|
+
},
|
|
313
|
+
Component: SignupComponent,
|
|
314
|
+
};
|
|
315
|
+
//# sourceMappingURL=signup.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"signup.js","sourceRoot":"","sources":["../../../../src/screen-templates/templates/auth/signup.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @tekton-ui/core - Email Verification Screen Template
|
|
3
|
+
* [SPEC-UI-002] [TAG-UI002-027] auth.verification
|
|
4
|
+
*
|
|
5
|
+
* Design Reference: Claude.ai Email Verification
|
|
6
|
+
* - 중앙 정렬 메시지
|
|
7
|
+
* - 명확한 다음 단계 안내
|
|
8
|
+
*/
|
|
9
|
+
import type { ScreenTemplate, ScreenTemplateProps } from '../../types.js';
|
|
10
|
+
import type { FC } from '../../types.js';
|
|
11
|
+
/**
|
|
12
|
+
* Verification Component
|
|
13
|
+
* 이메일 인증 화면 컴포넌트
|
|
14
|
+
*
|
|
15
|
+
* Required Components: Button, Card, Badge
|
|
16
|
+
*/
|
|
17
|
+
export declare const VerificationComponent: FC<ScreenTemplateProps>;
|
|
18
|
+
/**
|
|
19
|
+
* Email Verification Screen Template
|
|
20
|
+
* 이메일 인증 화면 템플릿 정의
|
|
21
|
+
*/
|
|
22
|
+
export declare const verificationTemplate: ScreenTemplate;
|
|
23
|
+
//# sourceMappingURL=verification.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"verification.d.ts","sourceRoot":"","sources":["../../../../src/screen-templates/templates/auth/verification.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAIH,OAAO,KAAK,EAAE,cAAc,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAC1E,OAAO,KAAK,EAAE,EAAE,EAAE,MAAM,gBAAgB,CAAC;AAEzC;;;;;GAKG;AACH,eAAO,MAAM,qBAAqB,EAAE,EAAE,CAAC,mBAAmB,CA4JzD,CAAC;AAEF;;;GAGG;AACH,eAAO,MAAM,oBAAoB,EAAE,cA8ElC,CAAC"}
|