@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,249 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @tekton-ui/core - Account/Profile Screen Template
|
|
3
|
+
* [SPEC-UI-002] [TAG-UI002-030] account.profile
|
|
4
|
+
*
|
|
5
|
+
* Design Reference: Claude.ai Profile Page (Claude Web 155.png)
|
|
6
|
+
* - 프로필 이미지 + 기본 정보
|
|
7
|
+
* - 편집 가능한 필드 명확히 표시
|
|
8
|
+
*/
|
|
9
|
+
/**
|
|
10
|
+
* Profile Component
|
|
11
|
+
* 프로필/내 계정 화면 컴포넌트
|
|
12
|
+
*
|
|
13
|
+
* Required Components: Avatar, Button, Input, Form, Card
|
|
14
|
+
*/
|
|
15
|
+
export const ProfileComponent = ({ slots, className, texts }) => {
|
|
16
|
+
const defaultTexts = {
|
|
17
|
+
title: texts?.title ?? '내 계정',
|
|
18
|
+
subtitle: texts?.subtitle ?? '프로필 정보를 관리하세요',
|
|
19
|
+
nameLabel: texts?.nameLabel ?? '이름',
|
|
20
|
+
emailLabel: texts?.emailLabel ?? '이메일',
|
|
21
|
+
saveButton: texts?.saveButton ?? '저장',
|
|
22
|
+
...texts,
|
|
23
|
+
};
|
|
24
|
+
return {
|
|
25
|
+
type: 'div',
|
|
26
|
+
props: {
|
|
27
|
+
className: `min-h-screen bg-[var(--tekton-bg-base)] ${className ?? ''}`,
|
|
28
|
+
},
|
|
29
|
+
children: [
|
|
30
|
+
{
|
|
31
|
+
type: 'div',
|
|
32
|
+
props: {
|
|
33
|
+
className: 'flex h-screen',
|
|
34
|
+
},
|
|
35
|
+
children: [
|
|
36
|
+
// Sidebar slot (optional)
|
|
37
|
+
slots?.sidebar,
|
|
38
|
+
// Main content
|
|
39
|
+
{
|
|
40
|
+
type: 'main',
|
|
41
|
+
props: {
|
|
42
|
+
className: 'flex-1 overflow-auto',
|
|
43
|
+
style: {
|
|
44
|
+
padding: 'var(--tekton-layout-padding-desktop)',
|
|
45
|
+
},
|
|
46
|
+
},
|
|
47
|
+
children: [
|
|
48
|
+
{
|
|
49
|
+
type: 'div',
|
|
50
|
+
props: {
|
|
51
|
+
className: 'max-w-2xl mx-auto',
|
|
52
|
+
},
|
|
53
|
+
children: [
|
|
54
|
+
// Header
|
|
55
|
+
{
|
|
56
|
+
type: 'div',
|
|
57
|
+
props: {
|
|
58
|
+
className: 'mb-8',
|
|
59
|
+
},
|
|
60
|
+
children: [
|
|
61
|
+
{
|
|
62
|
+
type: 'h1',
|
|
63
|
+
props: {
|
|
64
|
+
className: 'text-3xl font-semibold mb-2',
|
|
65
|
+
},
|
|
66
|
+
children: [defaultTexts.title],
|
|
67
|
+
},
|
|
68
|
+
{
|
|
69
|
+
type: 'p',
|
|
70
|
+
props: {
|
|
71
|
+
className: 'text-[var(--tekton-text-secondary)]',
|
|
72
|
+
},
|
|
73
|
+
children: [defaultTexts.subtitle],
|
|
74
|
+
},
|
|
75
|
+
],
|
|
76
|
+
},
|
|
77
|
+
// Profile card
|
|
78
|
+
{
|
|
79
|
+
type: 'Card',
|
|
80
|
+
props: {
|
|
81
|
+
className: 'p-6',
|
|
82
|
+
},
|
|
83
|
+
children: [
|
|
84
|
+
// Avatar section
|
|
85
|
+
{
|
|
86
|
+
type: 'div',
|
|
87
|
+
props: {
|
|
88
|
+
className: 'flex items-center gap-4 mb-6',
|
|
89
|
+
},
|
|
90
|
+
children: [
|
|
91
|
+
{
|
|
92
|
+
type: 'Avatar',
|
|
93
|
+
props: {
|
|
94
|
+
className: 'h-20 w-20',
|
|
95
|
+
},
|
|
96
|
+
},
|
|
97
|
+
{
|
|
98
|
+
type: 'Button',
|
|
99
|
+
props: {
|
|
100
|
+
variant: 'outline',
|
|
101
|
+
size: 'sm',
|
|
102
|
+
},
|
|
103
|
+
children: ['사진 변경'],
|
|
104
|
+
},
|
|
105
|
+
],
|
|
106
|
+
},
|
|
107
|
+
// Profile form
|
|
108
|
+
{
|
|
109
|
+
type: 'Form',
|
|
110
|
+
props: {
|
|
111
|
+
className: 'space-y-4',
|
|
112
|
+
},
|
|
113
|
+
children: [
|
|
114
|
+
// Name field
|
|
115
|
+
{
|
|
116
|
+
type: 'div',
|
|
117
|
+
props: {
|
|
118
|
+
className: 'space-y-2',
|
|
119
|
+
},
|
|
120
|
+
children: [
|
|
121
|
+
{
|
|
122
|
+
type: 'label',
|
|
123
|
+
props: {
|
|
124
|
+
className: 'text-sm font-medium',
|
|
125
|
+
},
|
|
126
|
+
children: [defaultTexts.nameLabel],
|
|
127
|
+
},
|
|
128
|
+
{
|
|
129
|
+
type: 'Input',
|
|
130
|
+
props: {
|
|
131
|
+
type: 'text',
|
|
132
|
+
placeholder: '홍길동',
|
|
133
|
+
},
|
|
134
|
+
},
|
|
135
|
+
],
|
|
136
|
+
},
|
|
137
|
+
// Email field
|
|
138
|
+
{
|
|
139
|
+
type: 'div',
|
|
140
|
+
props: {
|
|
141
|
+
className: 'space-y-2',
|
|
142
|
+
},
|
|
143
|
+
children: [
|
|
144
|
+
{
|
|
145
|
+
type: 'label',
|
|
146
|
+
props: {
|
|
147
|
+
className: 'text-sm font-medium',
|
|
148
|
+
},
|
|
149
|
+
children: [defaultTexts.emailLabel],
|
|
150
|
+
},
|
|
151
|
+
{
|
|
152
|
+
type: 'Input',
|
|
153
|
+
props: {
|
|
154
|
+
type: 'email',
|
|
155
|
+
placeholder: 'name@example.com',
|
|
156
|
+
},
|
|
157
|
+
},
|
|
158
|
+
],
|
|
159
|
+
},
|
|
160
|
+
// Content slot for additional fields
|
|
161
|
+
slots?.content,
|
|
162
|
+
// Save button
|
|
163
|
+
{
|
|
164
|
+
type: 'Button',
|
|
165
|
+
props: {
|
|
166
|
+
type: 'submit',
|
|
167
|
+
},
|
|
168
|
+
children: [defaultTexts.saveButton],
|
|
169
|
+
},
|
|
170
|
+
],
|
|
171
|
+
},
|
|
172
|
+
],
|
|
173
|
+
},
|
|
174
|
+
],
|
|
175
|
+
},
|
|
176
|
+
],
|
|
177
|
+
},
|
|
178
|
+
],
|
|
179
|
+
},
|
|
180
|
+
],
|
|
181
|
+
};
|
|
182
|
+
};
|
|
183
|
+
/**
|
|
184
|
+
* Account/Profile Screen Template
|
|
185
|
+
* 프로필/내 계정 화면 템플릿 정의
|
|
186
|
+
*/
|
|
187
|
+
export const profileTemplate = {
|
|
188
|
+
id: 'account.profile',
|
|
189
|
+
name: 'Account/Profile',
|
|
190
|
+
category: 'form',
|
|
191
|
+
description: 'User profile and account management screen with avatar, editable fields, and save functionality.',
|
|
192
|
+
skeleton: {
|
|
193
|
+
shell: 'shell.web.app',
|
|
194
|
+
page: 'page.form',
|
|
195
|
+
sections: [
|
|
196
|
+
{
|
|
197
|
+
id: 'avatar',
|
|
198
|
+
name: 'Profile Avatar',
|
|
199
|
+
required: true,
|
|
200
|
+
allowedComponents: ['Avatar', 'Button'],
|
|
201
|
+
},
|
|
202
|
+
{
|
|
203
|
+
id: 'form',
|
|
204
|
+
name: 'Profile Form',
|
|
205
|
+
required: true,
|
|
206
|
+
allowedComponents: ['Input', 'Form', 'Button'],
|
|
207
|
+
},
|
|
208
|
+
{
|
|
209
|
+
id: 'additional',
|
|
210
|
+
name: 'Additional Info',
|
|
211
|
+
required: false,
|
|
212
|
+
allowedComponents: ['Input', 'Textarea'],
|
|
213
|
+
},
|
|
214
|
+
],
|
|
215
|
+
},
|
|
216
|
+
customizable: {
|
|
217
|
+
texts: ['title', 'subtitle', 'nameLabel', 'emailLabel', 'saveButton'],
|
|
218
|
+
optional: ['profile_image_upload', 'additional_fields'],
|
|
219
|
+
slots: ['sidebar', 'content'],
|
|
220
|
+
},
|
|
221
|
+
requiredComponents: ['Avatar', 'Button', 'Input', 'Form', 'Card'],
|
|
222
|
+
layout: {
|
|
223
|
+
type: 'sidebar',
|
|
224
|
+
maxWidth: 'lg',
|
|
225
|
+
responsive: {
|
|
226
|
+
desktop: {
|
|
227
|
+
padding: 'atomic.spacing.64',
|
|
228
|
+
gap: 'atomic.spacing.32',
|
|
229
|
+
direction: 'column',
|
|
230
|
+
},
|
|
231
|
+
tablet: {
|
|
232
|
+
padding: 'atomic.spacing.32',
|
|
233
|
+
gap: 'atomic.spacing.24',
|
|
234
|
+
direction: 'column',
|
|
235
|
+
},
|
|
236
|
+
mobile: {
|
|
237
|
+
padding: 'atomic.spacing.16',
|
|
238
|
+
gap: 'atomic.spacing.16',
|
|
239
|
+
direction: 'column',
|
|
240
|
+
},
|
|
241
|
+
},
|
|
242
|
+
},
|
|
243
|
+
tokenBindings: {
|
|
244
|
+
backgroundColor: 'semantic.color.background.base',
|
|
245
|
+
textColor: 'semantic.color.text.primary',
|
|
246
|
+
},
|
|
247
|
+
Component: ProfileComponent,
|
|
248
|
+
};
|
|
249
|
+
//# sourceMappingURL=profile.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"profile.js","sourceRoot":"","sources":["../../../../src/screen-templates/templates/account/profile.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @tekton-ui/core - Forgot Password Screen Template
|
|
3
|
+
* [SPEC-UI-002] [TAG-UI002-026] auth.forgot-password
|
|
4
|
+
*
|
|
5
|
+
* Design Reference: Claude.ai / Reference Image (Lovable Web 335.png)
|
|
6
|
+
* - 간결한 설명 + 이메일 입력
|
|
7
|
+
* - 안내 메시지는 명확하고 친절하게
|
|
8
|
+
*/
|
|
9
|
+
import type { ScreenTemplate, ScreenTemplateProps } from '../../types.js';
|
|
10
|
+
import type { FC } from '../../types.js';
|
|
11
|
+
/**
|
|
12
|
+
* ForgotPassword Component
|
|
13
|
+
* 비밀번호 찾기 화면 컴포넌트
|
|
14
|
+
*
|
|
15
|
+
* Required Components: Button, Input, Form, Card, Label
|
|
16
|
+
*/
|
|
17
|
+
export declare const ForgotPasswordComponent: FC<ScreenTemplateProps>;
|
|
18
|
+
/**
|
|
19
|
+
* Forgot Password Screen Template
|
|
20
|
+
* 비밀번호 찾기 화면 템플릿 정의
|
|
21
|
+
*/
|
|
22
|
+
export declare const forgotPasswordTemplate: ScreenTemplate;
|
|
23
|
+
//# sourceMappingURL=forgot-password.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"forgot-password.d.ts","sourceRoot":"","sources":["../../../../src/screen-templates/templates/auth/forgot-password.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,uBAAuB,EAAE,EAAE,CAAC,mBAAmB,CA+H3D,CAAC;AAEF;;;GAGG;AACH,eAAO,MAAM,sBAAsB,EAAE,cAqEpC,CAAC"}
|
|
@@ -0,0 +1,203 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @tekton-ui/core - Forgot Password Screen Template
|
|
3
|
+
* [SPEC-UI-002] [TAG-UI002-026] auth.forgot-password
|
|
4
|
+
*
|
|
5
|
+
* Design Reference: Claude.ai / Reference Image (Lovable Web 335.png)
|
|
6
|
+
* - 간결한 설명 + 이메일 입력
|
|
7
|
+
* - 안내 메시지는 명확하고 친절하게
|
|
8
|
+
*/
|
|
9
|
+
/**
|
|
10
|
+
* ForgotPassword Component
|
|
11
|
+
* 비밀번호 찾기 화면 컴포넌트
|
|
12
|
+
*
|
|
13
|
+
* Required Components: Button, Input, Form, Card, Label
|
|
14
|
+
*/
|
|
15
|
+
export const ForgotPasswordComponent = ({ slots, className, texts }) => {
|
|
16
|
+
const defaultTexts = {
|
|
17
|
+
title: texts?.title ?? '비밀번호 재설정',
|
|
18
|
+
subtitle: texts?.subtitle ??
|
|
19
|
+
'가입하신 이메일 주소를 입력해주세요. 비밀번호 재설정 링크를 보내드립니다.',
|
|
20
|
+
emailLabel: texts?.emailLabel ?? '이메일',
|
|
21
|
+
sendButton: texts?.sendButton ?? '재설정 링크 보내기',
|
|
22
|
+
backToLogin: texts?.backToLogin ?? '로그인으로 돌아가기',
|
|
23
|
+
...texts,
|
|
24
|
+
};
|
|
25
|
+
return {
|
|
26
|
+
type: 'div',
|
|
27
|
+
props: {
|
|
28
|
+
className: `min-h-screen flex items-center justify-center bg-[var(--tekton-bg-base)] ${className ?? ''}`,
|
|
29
|
+
style: {
|
|
30
|
+
padding: 'var(--tekton-layout-padding-mobile)',
|
|
31
|
+
},
|
|
32
|
+
},
|
|
33
|
+
children: [
|
|
34
|
+
{
|
|
35
|
+
type: 'Card',
|
|
36
|
+
props: {
|
|
37
|
+
className: 'w-full max-w-md',
|
|
38
|
+
style: {
|
|
39
|
+
padding: 'var(--tekton-spacing-8)',
|
|
40
|
+
gap: 'var(--tekton-spacing-6)',
|
|
41
|
+
},
|
|
42
|
+
},
|
|
43
|
+
children: [
|
|
44
|
+
// Header slot
|
|
45
|
+
slots?.header ?? null,
|
|
46
|
+
// Title section
|
|
47
|
+
{
|
|
48
|
+
type: 'div',
|
|
49
|
+
props: {
|
|
50
|
+
className: 'space-y-2 text-center',
|
|
51
|
+
},
|
|
52
|
+
children: [
|
|
53
|
+
{
|
|
54
|
+
type: 'h1',
|
|
55
|
+
props: {
|
|
56
|
+
className: 'text-2xl font-semibold',
|
|
57
|
+
},
|
|
58
|
+
children: [defaultTexts.title],
|
|
59
|
+
},
|
|
60
|
+
{
|
|
61
|
+
type: 'p',
|
|
62
|
+
props: {
|
|
63
|
+
className: 'text-sm text-[var(--tekton-text-secondary)]',
|
|
64
|
+
},
|
|
65
|
+
children: [defaultTexts.subtitle],
|
|
66
|
+
},
|
|
67
|
+
],
|
|
68
|
+
},
|
|
69
|
+
// Form
|
|
70
|
+
{
|
|
71
|
+
type: 'Form',
|
|
72
|
+
props: {
|
|
73
|
+
className: 'space-y-4',
|
|
74
|
+
},
|
|
75
|
+
children: [
|
|
76
|
+
// Email field
|
|
77
|
+
{
|
|
78
|
+
type: 'div',
|
|
79
|
+
props: {
|
|
80
|
+
className: 'space-y-2',
|
|
81
|
+
},
|
|
82
|
+
children: [
|
|
83
|
+
{
|
|
84
|
+
type: 'Label',
|
|
85
|
+
props: {
|
|
86
|
+
htmlFor: 'email',
|
|
87
|
+
},
|
|
88
|
+
children: [defaultTexts.emailLabel],
|
|
89
|
+
},
|
|
90
|
+
{
|
|
91
|
+
type: 'Input',
|
|
92
|
+
props: {
|
|
93
|
+
id: 'email',
|
|
94
|
+
type: 'email',
|
|
95
|
+
placeholder: 'name@example.com',
|
|
96
|
+
required: true,
|
|
97
|
+
},
|
|
98
|
+
},
|
|
99
|
+
],
|
|
100
|
+
},
|
|
101
|
+
// Send button
|
|
102
|
+
{
|
|
103
|
+
type: 'Button',
|
|
104
|
+
props: {
|
|
105
|
+
type: 'submit',
|
|
106
|
+
className: 'w-full',
|
|
107
|
+
},
|
|
108
|
+
children: [defaultTexts.sendButton],
|
|
109
|
+
},
|
|
110
|
+
],
|
|
111
|
+
},
|
|
112
|
+
// Back to login link
|
|
113
|
+
{
|
|
114
|
+
type: 'div',
|
|
115
|
+
props: {
|
|
116
|
+
className: 'text-center',
|
|
117
|
+
},
|
|
118
|
+
children: [
|
|
119
|
+
{
|
|
120
|
+
type: 'a',
|
|
121
|
+
props: {
|
|
122
|
+
href: '/login',
|
|
123
|
+
className: 'text-sm text-[var(--tekton-text-link)] hover:underline',
|
|
124
|
+
},
|
|
125
|
+
children: [defaultTexts.backToLogin],
|
|
126
|
+
},
|
|
127
|
+
],
|
|
128
|
+
},
|
|
129
|
+
// Footer slot
|
|
130
|
+
slots?.footer ?? null,
|
|
131
|
+
],
|
|
132
|
+
},
|
|
133
|
+
],
|
|
134
|
+
};
|
|
135
|
+
};
|
|
136
|
+
/**
|
|
137
|
+
* Forgot Password Screen Template
|
|
138
|
+
* 비밀번호 찾기 화면 템플릿 정의
|
|
139
|
+
*/
|
|
140
|
+
export const forgotPasswordTemplate = {
|
|
141
|
+
id: 'auth.forgot-password',
|
|
142
|
+
name: 'Forgot Password',
|
|
143
|
+
category: 'auth',
|
|
144
|
+
description: 'Password reset screen with email input. Simple and clear instructions for users to reset their password.',
|
|
145
|
+
skeleton: {
|
|
146
|
+
shell: 'shell.web.app',
|
|
147
|
+
page: 'page.auth',
|
|
148
|
+
sections: [
|
|
149
|
+
{
|
|
150
|
+
id: 'logo',
|
|
151
|
+
name: 'Logo',
|
|
152
|
+
required: false,
|
|
153
|
+
allowedComponents: ['Logo', 'Image'],
|
|
154
|
+
},
|
|
155
|
+
{
|
|
156
|
+
id: 'form',
|
|
157
|
+
name: 'Reset Form',
|
|
158
|
+
required: true,
|
|
159
|
+
allowedComponents: ['Form', 'Input', 'Button', 'Label'],
|
|
160
|
+
},
|
|
161
|
+
{
|
|
162
|
+
id: 'footer',
|
|
163
|
+
name: 'Footer Links',
|
|
164
|
+
required: false,
|
|
165
|
+
allowedComponents: ['Link', 'Text'],
|
|
166
|
+
},
|
|
167
|
+
],
|
|
168
|
+
},
|
|
169
|
+
customizable: {
|
|
170
|
+
texts: ['title', 'subtitle', 'emailLabel', 'sendButton', 'backToLogin'],
|
|
171
|
+
optional: ['logo', 'help_text'],
|
|
172
|
+
slots: ['header', 'footer'],
|
|
173
|
+
},
|
|
174
|
+
requiredComponents: ['Button', 'Input', 'Form', 'Card', 'Label'],
|
|
175
|
+
layout: {
|
|
176
|
+
type: 'centered',
|
|
177
|
+
maxWidth: 'sm',
|
|
178
|
+
responsive: {
|
|
179
|
+
desktop: {
|
|
180
|
+
padding: 'atomic.spacing.64',
|
|
181
|
+
gap: 'atomic.spacing.32',
|
|
182
|
+
direction: 'column',
|
|
183
|
+
},
|
|
184
|
+
tablet: {
|
|
185
|
+
padding: 'atomic.spacing.32',
|
|
186
|
+
gap: 'atomic.spacing.24',
|
|
187
|
+
direction: 'column',
|
|
188
|
+
},
|
|
189
|
+
mobile: {
|
|
190
|
+
padding: 'atomic.spacing.16',
|
|
191
|
+
gap: 'atomic.spacing.16',
|
|
192
|
+
direction: 'column',
|
|
193
|
+
},
|
|
194
|
+
},
|
|
195
|
+
},
|
|
196
|
+
tokenBindings: {
|
|
197
|
+
backgroundColor: 'semantic.color.background.base',
|
|
198
|
+
textColor: 'semantic.color.text.primary',
|
|
199
|
+
linkColor: 'semantic.color.text.link',
|
|
200
|
+
},
|
|
201
|
+
Component: ForgotPasswordComponent,
|
|
202
|
+
};
|
|
203
|
+
//# sourceMappingURL=forgot-password.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"forgot-password.js","sourceRoot":"","sources":["../../../../src/screen-templates/templates/auth/forgot-password.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @tekton-ui/core - Auth Templates Export
|
|
3
|
+
* [SPEC-UI-002] Auth Screen Templates (4)
|
|
4
|
+
*/
|
|
5
|
+
export * from './login.js';
|
|
6
|
+
export * from './signup.js';
|
|
7
|
+
export * from './forgot-password.js';
|
|
8
|
+
export * from './verification.js';
|
|
9
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/screen-templates/templates/auth/index.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,cAAc,YAAY,CAAC;AAC3B,cAAc,aAAa,CAAC;AAC5B,cAAc,sBAAsB,CAAC;AACrC,cAAc,mBAAmB,CAAC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @tekton-ui/core - Auth Templates Export
|
|
3
|
+
* [SPEC-UI-002] Auth Screen Templates (4)
|
|
4
|
+
*/
|
|
5
|
+
export * from './login.js';
|
|
6
|
+
export * from './signup.js';
|
|
7
|
+
export * from './forgot-password.js';
|
|
8
|
+
export * from './verification.js';
|
|
9
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/screen-templates/templates/auth/index.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,cAAc,YAAY,CAAC;AAC3B,cAAc,aAAa,CAAC;AAC5B,cAAc,sBAAsB,CAAC;AACrC,cAAc,mBAAmB,CAAC"}
|
|
@@ -0,0 +1,24 @@
|
|
|
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
|
+
import type { ScreenTemplate, ScreenTemplateProps } from '../../types.js';
|
|
11
|
+
import type { FC } from '../../types.js';
|
|
12
|
+
/**
|
|
13
|
+
* Login Component
|
|
14
|
+
* 로그인 화면 컴포넌트
|
|
15
|
+
*
|
|
16
|
+
* Required Components: Button, Input, Form, Card, Label
|
|
17
|
+
*/
|
|
18
|
+
export declare const LoginComponent: FC<ScreenTemplateProps>;
|
|
19
|
+
/**
|
|
20
|
+
* Login Screen Template
|
|
21
|
+
* 로그인 화면 템플릿 정의
|
|
22
|
+
*/
|
|
23
|
+
export declare const loginTemplate: ScreenTemplate;
|
|
24
|
+
//# sourceMappingURL=login.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"login.d.ts","sourceRoot":"","sources":["../../../../src/screen-templates/templates/auth/login.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,cAAc,EAAE,EAAE,CAAC,mBAAmB,CAyKlD,CAAC;AAEF;;;GAGG;AACH,eAAO,MAAM,aAAa,EAAE,cA6E3B,CAAC"}
|