@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,239 @@
|
|
|
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
|
+
/**
|
|
10
|
+
* Verification Component
|
|
11
|
+
* 이메일 인증 화면 컴포넌트
|
|
12
|
+
*
|
|
13
|
+
* Required Components: Button, Card, Badge
|
|
14
|
+
*/
|
|
15
|
+
export const VerificationComponent = ({ slots, className, texts }) => {
|
|
16
|
+
const defaultTexts = {
|
|
17
|
+
title: texts?.title ?? '이메일 인증',
|
|
18
|
+
subtitle: texts?.subtitle ?? '이메일로 인증 링크를 보내드렸습니다',
|
|
19
|
+
instruction: texts?.instruction ?? '받은 편지함을 확인하고 인증 링크를 클릭해주세요',
|
|
20
|
+
email: texts?.email ?? '',
|
|
21
|
+
resendButton: texts?.resendButton ?? '인증 메일 재전송',
|
|
22
|
+
continueButton: texts?.continueButton ?? '계속하기',
|
|
23
|
+
backToLogin: texts?.backToLogin ?? '로그인으로 돌아가기',
|
|
24
|
+
...texts,
|
|
25
|
+
};
|
|
26
|
+
return {
|
|
27
|
+
type: 'div',
|
|
28
|
+
props: {
|
|
29
|
+
className: `min-h-screen flex items-center justify-center bg-[var(--tekton-bg-base)] ${className ?? ''}`,
|
|
30
|
+
style: {
|
|
31
|
+
padding: 'var(--tekton-layout-padding-mobile)',
|
|
32
|
+
},
|
|
33
|
+
},
|
|
34
|
+
children: [
|
|
35
|
+
{
|
|
36
|
+
type: 'Card',
|
|
37
|
+
props: {
|
|
38
|
+
className: 'w-full max-w-md',
|
|
39
|
+
style: {
|
|
40
|
+
padding: 'var(--tekton-spacing-8)',
|
|
41
|
+
gap: 'var(--tekton-spacing-6)',
|
|
42
|
+
},
|
|
43
|
+
},
|
|
44
|
+
children: [
|
|
45
|
+
// Header slot
|
|
46
|
+
slots?.header ?? null,
|
|
47
|
+
// Icon/Badge (success indicator)
|
|
48
|
+
{
|
|
49
|
+
type: 'div',
|
|
50
|
+
props: {
|
|
51
|
+
className: 'flex justify-center',
|
|
52
|
+
},
|
|
53
|
+
children: [
|
|
54
|
+
{
|
|
55
|
+
type: 'Badge',
|
|
56
|
+
props: {
|
|
57
|
+
variant: 'outline',
|
|
58
|
+
className: 'px-4 py-2',
|
|
59
|
+
},
|
|
60
|
+
children: ['✓ 전송 완료'],
|
|
61
|
+
},
|
|
62
|
+
],
|
|
63
|
+
},
|
|
64
|
+
// Title section
|
|
65
|
+
{
|
|
66
|
+
type: 'div',
|
|
67
|
+
props: {
|
|
68
|
+
className: 'space-y-2 text-center',
|
|
69
|
+
},
|
|
70
|
+
children: [
|
|
71
|
+
{
|
|
72
|
+
type: 'h1',
|
|
73
|
+
props: {
|
|
74
|
+
className: 'text-2xl font-semibold',
|
|
75
|
+
},
|
|
76
|
+
children: [defaultTexts.title],
|
|
77
|
+
},
|
|
78
|
+
{
|
|
79
|
+
type: 'p',
|
|
80
|
+
props: {
|
|
81
|
+
className: 'text-sm text-[var(--tekton-text-secondary)]',
|
|
82
|
+
},
|
|
83
|
+
children: [defaultTexts.subtitle],
|
|
84
|
+
},
|
|
85
|
+
],
|
|
86
|
+
},
|
|
87
|
+
// Email display (if provided)
|
|
88
|
+
defaultTexts.email
|
|
89
|
+
? {
|
|
90
|
+
type: 'div',
|
|
91
|
+
props: {
|
|
92
|
+
className: 'text-center',
|
|
93
|
+
},
|
|
94
|
+
children: [
|
|
95
|
+
{
|
|
96
|
+
type: 'Badge',
|
|
97
|
+
props: {
|
|
98
|
+
variant: 'secondary',
|
|
99
|
+
},
|
|
100
|
+
children: [defaultTexts.email],
|
|
101
|
+
},
|
|
102
|
+
],
|
|
103
|
+
}
|
|
104
|
+
: null,
|
|
105
|
+
// Instructions
|
|
106
|
+
{
|
|
107
|
+
type: 'p',
|
|
108
|
+
props: {
|
|
109
|
+
className: 'text-sm text-center text-[var(--tekton-text-secondary)]',
|
|
110
|
+
},
|
|
111
|
+
children: [defaultTexts.instruction],
|
|
112
|
+
},
|
|
113
|
+
// Action buttons
|
|
114
|
+
{
|
|
115
|
+
type: 'div',
|
|
116
|
+
props: {
|
|
117
|
+
className: 'space-y-3',
|
|
118
|
+
},
|
|
119
|
+
children: [
|
|
120
|
+
// Continue button
|
|
121
|
+
{
|
|
122
|
+
type: 'Button',
|
|
123
|
+
props: {
|
|
124
|
+
className: 'w-full',
|
|
125
|
+
},
|
|
126
|
+
children: [defaultTexts.continueButton],
|
|
127
|
+
},
|
|
128
|
+
// Resend button
|
|
129
|
+
{
|
|
130
|
+
type: 'Button',
|
|
131
|
+
props: {
|
|
132
|
+
variant: 'outline',
|
|
133
|
+
className: 'w-full',
|
|
134
|
+
},
|
|
135
|
+
children: [defaultTexts.resendButton],
|
|
136
|
+
},
|
|
137
|
+
],
|
|
138
|
+
},
|
|
139
|
+
// Back to login link
|
|
140
|
+
{
|
|
141
|
+
type: 'div',
|
|
142
|
+
props: {
|
|
143
|
+
className: 'text-center',
|
|
144
|
+
},
|
|
145
|
+
children: [
|
|
146
|
+
{
|
|
147
|
+
type: 'a',
|
|
148
|
+
props: {
|
|
149
|
+
href: '/login',
|
|
150
|
+
className: 'text-sm text-[var(--tekton-text-link)] hover:underline',
|
|
151
|
+
},
|
|
152
|
+
children: [defaultTexts.backToLogin],
|
|
153
|
+
},
|
|
154
|
+
],
|
|
155
|
+
},
|
|
156
|
+
// Footer slot
|
|
157
|
+
slots?.footer ?? null,
|
|
158
|
+
],
|
|
159
|
+
},
|
|
160
|
+
],
|
|
161
|
+
};
|
|
162
|
+
};
|
|
163
|
+
/**
|
|
164
|
+
* Email Verification Screen Template
|
|
165
|
+
* 이메일 인증 화면 템플릿 정의
|
|
166
|
+
*/
|
|
167
|
+
export const verificationTemplate = {
|
|
168
|
+
id: 'auth.verification',
|
|
169
|
+
name: 'Email Verification',
|
|
170
|
+
category: 'auth',
|
|
171
|
+
description: 'Email verification screen with status message and action buttons. Clear next steps for users after signup.',
|
|
172
|
+
skeleton: {
|
|
173
|
+
shell: 'shell.web.app',
|
|
174
|
+
page: 'page.auth',
|
|
175
|
+
sections: [
|
|
176
|
+
{
|
|
177
|
+
id: 'status',
|
|
178
|
+
name: 'Status Message',
|
|
179
|
+
required: true,
|
|
180
|
+
allowedComponents: ['Badge', 'Text'],
|
|
181
|
+
},
|
|
182
|
+
{
|
|
183
|
+
id: 'actions',
|
|
184
|
+
name: 'Action Buttons',
|
|
185
|
+
required: true,
|
|
186
|
+
allowedComponents: ['Button'],
|
|
187
|
+
},
|
|
188
|
+
{
|
|
189
|
+
id: 'footer',
|
|
190
|
+
name: 'Footer Links',
|
|
191
|
+
required: false,
|
|
192
|
+
allowedComponents: ['Link', 'Text'],
|
|
193
|
+
},
|
|
194
|
+
],
|
|
195
|
+
},
|
|
196
|
+
customizable: {
|
|
197
|
+
texts: [
|
|
198
|
+
'title',
|
|
199
|
+
'subtitle',
|
|
200
|
+
'instruction',
|
|
201
|
+
'email',
|
|
202
|
+
'resendButton',
|
|
203
|
+
'continueButton',
|
|
204
|
+
'backToLogin',
|
|
205
|
+
],
|
|
206
|
+
optional: ['email_display', 'resend_timer'],
|
|
207
|
+
slots: ['header', 'footer'],
|
|
208
|
+
},
|
|
209
|
+
requiredComponents: ['Button', 'Card', 'Badge'],
|
|
210
|
+
layout: {
|
|
211
|
+
type: 'centered',
|
|
212
|
+
maxWidth: 'sm',
|
|
213
|
+
responsive: {
|
|
214
|
+
desktop: {
|
|
215
|
+
padding: 'atomic.spacing.64',
|
|
216
|
+
gap: 'atomic.spacing.32',
|
|
217
|
+
direction: 'column',
|
|
218
|
+
},
|
|
219
|
+
tablet: {
|
|
220
|
+
padding: 'atomic.spacing.32',
|
|
221
|
+
gap: 'atomic.spacing.24',
|
|
222
|
+
direction: 'column',
|
|
223
|
+
},
|
|
224
|
+
mobile: {
|
|
225
|
+
padding: 'atomic.spacing.16',
|
|
226
|
+
gap: 'atomic.spacing.16',
|
|
227
|
+
direction: 'column',
|
|
228
|
+
},
|
|
229
|
+
},
|
|
230
|
+
},
|
|
231
|
+
tokenBindings: {
|
|
232
|
+
backgroundColor: 'semantic.color.background.base',
|
|
233
|
+
textColor: 'semantic.color.text.primary',
|
|
234
|
+
linkColor: 'semantic.color.text.link',
|
|
235
|
+
successColor: 'semantic.color.success',
|
|
236
|
+
},
|
|
237
|
+
Component: VerificationComponent,
|
|
238
|
+
};
|
|
239
|
+
//# sourceMappingURL=verification.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"verification.js","sourceRoot":"","sources":["../../../../src/screen-templates/templates/auth/verification.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @tekton-ui/core - Confirmation Dialog Template
|
|
3
|
+
* [SPEC-UI-002] [TAG-UI002-034] feedback.confirmation
|
|
4
|
+
*/
|
|
5
|
+
import type { ScreenTemplate, ScreenTemplateProps } from '../../types.js';
|
|
6
|
+
import type { FC } from '../../types.js';
|
|
7
|
+
export declare const ConfirmationComponent: FC<ScreenTemplateProps>;
|
|
8
|
+
export declare const confirmationTemplate: ScreenTemplate;
|
|
9
|
+
//# sourceMappingURL=confirmation.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"confirmation.d.ts","sourceRoot":"","sources":["../../../../src/screen-templates/templates/feedback/confirmation.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAIH,OAAO,KAAK,EAAE,cAAc,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAC1E,OAAO,KAAK,EAAE,EAAE,EAAE,MAAM,gBAAgB,CAAC;AAEzC,eAAO,MAAM,qBAAqB,EAAE,EAAE,CAAC,mBAAmB,CA2DzD,CAAC;AAEF,eAAO,MAAM,oBAAoB,EAAE,cA0ClC,CAAC"}
|
|
@@ -0,0 +1,107 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @tekton-ui/core - Confirmation Dialog Template
|
|
3
|
+
* [SPEC-UI-002] [TAG-UI002-034] feedback.confirmation
|
|
4
|
+
*/
|
|
5
|
+
export const ConfirmationComponent = ({ className, texts }) => {
|
|
6
|
+
const defaultTexts = {
|
|
7
|
+
title: texts?.title ?? '확인',
|
|
8
|
+
message: texts?.message ?? '이 작업을 진행하시겠습니까?',
|
|
9
|
+
confirmButton: texts?.confirmButton ?? '확인',
|
|
10
|
+
cancelButton: texts?.cancelButton ?? '취소',
|
|
11
|
+
...texts,
|
|
12
|
+
};
|
|
13
|
+
return {
|
|
14
|
+
type: 'Dialog',
|
|
15
|
+
props: {
|
|
16
|
+
open: true,
|
|
17
|
+
className,
|
|
18
|
+
},
|
|
19
|
+
children: [
|
|
20
|
+
{
|
|
21
|
+
type: 'div',
|
|
22
|
+
props: {
|
|
23
|
+
className: 'p-6',
|
|
24
|
+
},
|
|
25
|
+
children: [
|
|
26
|
+
{
|
|
27
|
+
type: 'h2',
|
|
28
|
+
props: {
|
|
29
|
+
className: 'text-lg font-semibold mb-2',
|
|
30
|
+
},
|
|
31
|
+
children: [defaultTexts.title],
|
|
32
|
+
},
|
|
33
|
+
{
|
|
34
|
+
type: 'p',
|
|
35
|
+
props: {
|
|
36
|
+
className: 'text-sm text-[var(--tekton-text-secondary)] mb-4',
|
|
37
|
+
},
|
|
38
|
+
children: [defaultTexts.message],
|
|
39
|
+
},
|
|
40
|
+
{
|
|
41
|
+
type: 'div',
|
|
42
|
+
props: {
|
|
43
|
+
className: 'flex gap-2 justify-end',
|
|
44
|
+
},
|
|
45
|
+
children: [
|
|
46
|
+
{
|
|
47
|
+
type: 'Button',
|
|
48
|
+
props: {
|
|
49
|
+
variant: 'outline',
|
|
50
|
+
},
|
|
51
|
+
children: [defaultTexts.cancelButton],
|
|
52
|
+
},
|
|
53
|
+
{
|
|
54
|
+
type: 'Button',
|
|
55
|
+
children: [defaultTexts.confirmButton],
|
|
56
|
+
},
|
|
57
|
+
],
|
|
58
|
+
},
|
|
59
|
+
],
|
|
60
|
+
},
|
|
61
|
+
],
|
|
62
|
+
};
|
|
63
|
+
};
|
|
64
|
+
export const confirmationTemplate = {
|
|
65
|
+
id: 'feedback.confirmation',
|
|
66
|
+
name: 'Confirmation',
|
|
67
|
+
category: 'feedback',
|
|
68
|
+
description: 'Confirmation dialog with yes/no buttons.',
|
|
69
|
+
skeleton: {
|
|
70
|
+
shell: 'shell.web.app',
|
|
71
|
+
page: 'page.content',
|
|
72
|
+
sections: [
|
|
73
|
+
{
|
|
74
|
+
id: 'message',
|
|
75
|
+
name: 'Confirmation Message',
|
|
76
|
+
required: true,
|
|
77
|
+
allowedComponents: ['Text'],
|
|
78
|
+
},
|
|
79
|
+
{
|
|
80
|
+
id: 'actions',
|
|
81
|
+
name: 'Action Buttons',
|
|
82
|
+
required: true,
|
|
83
|
+
allowedComponents: ['Button'],
|
|
84
|
+
},
|
|
85
|
+
],
|
|
86
|
+
},
|
|
87
|
+
customizable: {
|
|
88
|
+
texts: ['title', 'message', 'confirmButton', 'cancelButton'],
|
|
89
|
+
optional: ['warning_icon'],
|
|
90
|
+
slots: [],
|
|
91
|
+
},
|
|
92
|
+
requiredComponents: ['Dialog', 'Button', 'AlertDialog'],
|
|
93
|
+
layout: {
|
|
94
|
+
type: 'centered',
|
|
95
|
+
maxWidth: 'sm',
|
|
96
|
+
responsive: {
|
|
97
|
+
desktop: { padding: 'atomic.spacing.32', gap: 'atomic.spacing.16', direction: 'column' },
|
|
98
|
+
tablet: { padding: 'atomic.spacing.24', gap: 'atomic.spacing.16', direction: 'column' },
|
|
99
|
+
mobile: { padding: 'atomic.spacing.16', gap: 'atomic.spacing.12', direction: 'column' },
|
|
100
|
+
},
|
|
101
|
+
},
|
|
102
|
+
tokenBindings: {
|
|
103
|
+
backgroundColor: 'semantic.color.background.surface',
|
|
104
|
+
},
|
|
105
|
+
Component: ConfirmationComponent,
|
|
106
|
+
};
|
|
107
|
+
//# sourceMappingURL=confirmation.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"confirmation.js","sourceRoot":"","sources":["../../../../src/screen-templates/templates/feedback/confirmation.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @tekton-ui/core - Empty State Screen Template
|
|
3
|
+
* [SPEC-UI-002] [TAG-UI002-033] feedback.empty
|
|
4
|
+
*/
|
|
5
|
+
import type { ScreenTemplate, ScreenTemplateProps } from '../../types.js';
|
|
6
|
+
import type { FC } from '../../types.js';
|
|
7
|
+
export declare const EmptyComponent: FC<ScreenTemplateProps>;
|
|
8
|
+
export declare const emptyTemplate: ScreenTemplate;
|
|
9
|
+
//# sourceMappingURL=empty.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"empty.d.ts","sourceRoot":"","sources":["../../../../src/screen-templates/templates/feedback/empty.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAIH,OAAO,KAAK,EAAE,cAAc,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAC1E,OAAO,KAAK,EAAE,EAAE,EAAE,MAAM,gBAAgB,CAAC;AAEzC,eAAO,MAAM,cAAc,EAAE,EAAE,CAAC,mBAAmB,CA0ClD,CAAC;AAEF,eAAO,MAAM,aAAa,EAAE,cA0C3B,CAAC"}
|
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @tekton-ui/core - Empty State Screen Template
|
|
3
|
+
* [SPEC-UI-002] [TAG-UI002-033] feedback.empty
|
|
4
|
+
*/
|
|
5
|
+
export const EmptyComponent = ({ className, texts }) => {
|
|
6
|
+
const defaultTexts = {
|
|
7
|
+
title: texts?.title ?? '아직 아무것도 없습니다',
|
|
8
|
+
message: texts?.message ?? '지금 바로 시작해보세요.',
|
|
9
|
+
ctaButton: texts?.ctaButton ?? '시작하기',
|
|
10
|
+
...texts,
|
|
11
|
+
};
|
|
12
|
+
return {
|
|
13
|
+
type: 'div',
|
|
14
|
+
props: {
|
|
15
|
+
className: `min-h-screen flex items-center justify-center bg-[var(--tekton-bg-base)] ${className ?? ''}`,
|
|
16
|
+
},
|
|
17
|
+
children: [
|
|
18
|
+
{
|
|
19
|
+
type: 'Card',
|
|
20
|
+
props: {
|
|
21
|
+
className: 'max-w-md p-8 text-center',
|
|
22
|
+
},
|
|
23
|
+
children: [
|
|
24
|
+
{
|
|
25
|
+
type: 'h2',
|
|
26
|
+
props: {
|
|
27
|
+
className: 'text-xl font-semibold mb-2',
|
|
28
|
+
},
|
|
29
|
+
children: [defaultTexts.title],
|
|
30
|
+
},
|
|
31
|
+
{
|
|
32
|
+
type: 'p',
|
|
33
|
+
props: {
|
|
34
|
+
className: 'text-sm text-[var(--tekton-text-secondary)] mb-4',
|
|
35
|
+
},
|
|
36
|
+
children: [defaultTexts.message],
|
|
37
|
+
},
|
|
38
|
+
{
|
|
39
|
+
type: 'Button',
|
|
40
|
+
children: [defaultTexts.ctaButton],
|
|
41
|
+
},
|
|
42
|
+
],
|
|
43
|
+
},
|
|
44
|
+
],
|
|
45
|
+
};
|
|
46
|
+
};
|
|
47
|
+
export const emptyTemplate = {
|
|
48
|
+
id: 'feedback.empty',
|
|
49
|
+
name: 'Empty State',
|
|
50
|
+
category: 'feedback',
|
|
51
|
+
description: 'Empty state screen with friendly message and CTA button.',
|
|
52
|
+
skeleton: {
|
|
53
|
+
shell: 'shell.web.app',
|
|
54
|
+
page: 'page.content',
|
|
55
|
+
sections: [
|
|
56
|
+
{
|
|
57
|
+
id: 'message',
|
|
58
|
+
name: 'Empty Message',
|
|
59
|
+
required: true,
|
|
60
|
+
allowedComponents: ['Text'],
|
|
61
|
+
},
|
|
62
|
+
{
|
|
63
|
+
id: 'cta',
|
|
64
|
+
name: 'Call to Action',
|
|
65
|
+
required: true,
|
|
66
|
+
allowedComponents: ['Button'],
|
|
67
|
+
},
|
|
68
|
+
],
|
|
69
|
+
},
|
|
70
|
+
customizable: {
|
|
71
|
+
texts: ['title', 'message', 'ctaButton'],
|
|
72
|
+
optional: ['illustration', 'help_link'],
|
|
73
|
+
slots: [],
|
|
74
|
+
},
|
|
75
|
+
requiredComponents: ['Button', 'Card'],
|
|
76
|
+
layout: {
|
|
77
|
+
type: 'centered',
|
|
78
|
+
maxWidth: 'md',
|
|
79
|
+
responsive: {
|
|
80
|
+
desktop: { padding: 'atomic.spacing.64', gap: 'atomic.spacing.32', direction: 'column' },
|
|
81
|
+
tablet: { padding: 'atomic.spacing.32', gap: 'atomic.spacing.24', direction: 'column' },
|
|
82
|
+
mobile: { padding: 'atomic.spacing.16', gap: 'atomic.spacing.16', direction: 'column' },
|
|
83
|
+
},
|
|
84
|
+
},
|
|
85
|
+
tokenBindings: {
|
|
86
|
+
backgroundColor: 'semantic.color.background.base',
|
|
87
|
+
},
|
|
88
|
+
Component: EmptyComponent,
|
|
89
|
+
};
|
|
90
|
+
//# sourceMappingURL=empty.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"empty.js","sourceRoot":"","sources":["../../../../src/screen-templates/templates/feedback/empty.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAOH,MAAM,CAAC,MAAM,cAAc,GAA4B,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,EAAE,EAAE;IAC9E,MAAM,YAAY,GAAG;QACnB,KAAK,EAAE,KAAK,EAAE,KAAK,IAAI,cAAc;QACrC,OAAO,EAAE,KAAK,EAAE,OAAO,IAAI,eAAe;QAC1C,SAAS,EAAE,KAAK,EAAE,SAAS,IAAI,MAAM;QACrC,GAAG,KAAK;KACT,CAAC;IAEF,OAAO;QACL,IAAI,EAAE,KAAK;QACX,KAAK,EAAE;YACL,SAAS,EAAE,4EAA4E,SAAS,IAAI,EAAE,EAAE;SACzG;QACD,QAAQ,EAAE;YACR;gBACE,IAAI,EAAE,MAAM;gBACZ,KAAK,EAAE;oBACL,SAAS,EAAE,0BAA0B;iBACtC;gBACD,QAAQ,EAAE;oBACR;wBACE,IAAI,EAAE,IAAI;wBACV,KAAK,EAAE;4BACL,SAAS,EAAE,4BAA4B;yBACxC;wBACD,QAAQ,EAAE,CAAC,YAAY,CAAC,KAAK,CAAC;qBAC/B;oBACD;wBACE,IAAI,EAAE,GAAG;wBACT,KAAK,EAAE;4BACL,SAAS,EAAE,kDAAkD;yBAC9D;wBACD,QAAQ,EAAE,CAAC,YAAY,CAAC,OAAO,CAAC;qBACjC;oBACD;wBACE,IAAI,EAAE,QAAQ;wBACd,QAAQ,EAAE,CAAC,YAAY,CAAC,SAAS,CAAC;qBACnC;iBACF;aACF;SACF;KACwB,CAAC;AAC9B,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,aAAa,GAAmB;IAC3C,EAAE,EAAE,gBAAgB;IACpB,IAAI,EAAE,aAAa;IACnB,QAAQ,EAAE,UAAU;IACpB,WAAW,EAAE,0DAA0D;IACvE,QAAQ,EAAE;QACR,KAAK,EAAE,eAAe;QACtB,IAAI,EAAE,cAAc;QACpB,QAAQ,EAAE;YACR;gBACE,EAAE,EAAE,SAAS;gBACb,IAAI,EAAE,eAAe;gBACrB,QAAQ,EAAE,IAAI;gBACd,iBAAiB,EAAE,CAAC,MAAM,CAAC;aAC5B;YACD;gBACE,EAAE,EAAE,KAAK;gBACT,IAAI,EAAE,gBAAgB;gBACtB,QAAQ,EAAE,IAAI;gBACd,iBAAiB,EAAE,CAAC,QAAQ,CAAC;aAC9B;SACF;KACF;IACD,YAAY,EAAE;QACZ,KAAK,EAAE,CAAC,OAAO,EAAE,SAAS,EAAE,WAAW,CAAC;QACxC,QAAQ,EAAE,CAAC,cAAc,EAAE,WAAW,CAAC;QACvC,KAAK,EAAE,EAAE;KACV;IACD,kBAAkB,EAAE,CAAC,QAAQ,EAAE,MAAM,CAAC;IACtC,MAAM,EAAE;QACN,IAAI,EAAE,UAAU;QAChB,QAAQ,EAAE,IAAI;QACd,UAAU,EAAE;YACV,OAAO,EAAE,EAAE,OAAO,EAAE,mBAAmB,EAAE,GAAG,EAAE,mBAAmB,EAAE,SAAS,EAAE,QAAQ,EAAE;YACxF,MAAM,EAAE,EAAE,OAAO,EAAE,mBAAmB,EAAE,GAAG,EAAE,mBAAmB,EAAE,SAAS,EAAE,QAAQ,EAAE;YACvF,MAAM,EAAE,EAAE,OAAO,EAAE,mBAAmB,EAAE,GAAG,EAAE,mBAAmB,EAAE,SAAS,EAAE,QAAQ,EAAE;SACxF;KACF;IACD,aAAa,EAAE;QACb,eAAe,EAAE,gCAAgC;KAClD;IACD,SAAS,EAAE,cAAc;CAC1B,CAAC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @tekton-ui/core - Error Screen Template
|
|
3
|
+
* [SPEC-UI-002] [TAG-UI002-032] feedback.error
|
|
4
|
+
*/
|
|
5
|
+
import type { ScreenTemplate, ScreenTemplateProps } from '../../types.js';
|
|
6
|
+
import type { FC } from '../../types.js';
|
|
7
|
+
export declare const ErrorComponent: FC<ScreenTemplateProps>;
|
|
8
|
+
export declare const errorTemplate: ScreenTemplate;
|
|
9
|
+
//# sourceMappingURL=error.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"error.d.ts","sourceRoot":"","sources":["../../../../src/screen-templates/templates/feedback/error.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAIH,OAAO,KAAK,EAAE,cAAc,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAC1E,OAAO,KAAK,EAAE,EAAE,EAAE,MAAM,gBAAgB,CAAC;AAEzC,eAAO,MAAM,cAAc,EAAE,EAAE,CAAC,mBAAmB,CAkDlD,CAAC;AAEF,eAAO,MAAM,aAAa,EAAE,cA2C3B,CAAC"}
|
|
@@ -0,0 +1,99 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @tekton-ui/core - Error Screen Template
|
|
3
|
+
* [SPEC-UI-002] [TAG-UI002-032] feedback.error
|
|
4
|
+
*/
|
|
5
|
+
export const ErrorComponent = ({ className, texts }) => {
|
|
6
|
+
const defaultTexts = {
|
|
7
|
+
title: texts?.title ?? '오류가 발생했습니다',
|
|
8
|
+
message: texts?.message ?? '요청을 처리하는 중 문제가 발생했습니다.',
|
|
9
|
+
retryButton: texts?.retryButton ?? '다시 시도',
|
|
10
|
+
...texts,
|
|
11
|
+
};
|
|
12
|
+
return {
|
|
13
|
+
type: 'div',
|
|
14
|
+
props: {
|
|
15
|
+
className: `min-h-screen flex items-center justify-center bg-[var(--tekton-bg-base)] ${className ?? ''}`,
|
|
16
|
+
},
|
|
17
|
+
children: [
|
|
18
|
+
{
|
|
19
|
+
type: 'Card',
|
|
20
|
+
props: {
|
|
21
|
+
className: 'max-w-md p-6 text-center',
|
|
22
|
+
},
|
|
23
|
+
children: [
|
|
24
|
+
{
|
|
25
|
+
type: 'Badge',
|
|
26
|
+
props: {
|
|
27
|
+
variant: 'destructive',
|
|
28
|
+
className: 'mb-4',
|
|
29
|
+
},
|
|
30
|
+
children: ['오류'],
|
|
31
|
+
},
|
|
32
|
+
{
|
|
33
|
+
type: 'h2',
|
|
34
|
+
props: {
|
|
35
|
+
className: 'text-xl font-semibold mb-2',
|
|
36
|
+
},
|
|
37
|
+
children: [defaultTexts.title],
|
|
38
|
+
},
|
|
39
|
+
{
|
|
40
|
+
type: 'p',
|
|
41
|
+
props: {
|
|
42
|
+
className: 'text-sm text-[var(--tekton-text-secondary)] mb-4',
|
|
43
|
+
},
|
|
44
|
+
children: [defaultTexts.message],
|
|
45
|
+
},
|
|
46
|
+
{
|
|
47
|
+
type: 'Button',
|
|
48
|
+
children: [defaultTexts.retryButton],
|
|
49
|
+
},
|
|
50
|
+
],
|
|
51
|
+
},
|
|
52
|
+
],
|
|
53
|
+
};
|
|
54
|
+
};
|
|
55
|
+
export const errorTemplate = {
|
|
56
|
+
id: 'feedback.error',
|
|
57
|
+
name: 'Error',
|
|
58
|
+
category: 'feedback',
|
|
59
|
+
description: 'Error state screen with message and retry button.',
|
|
60
|
+
skeleton: {
|
|
61
|
+
shell: 'shell.web.app',
|
|
62
|
+
page: 'page.content',
|
|
63
|
+
sections: [
|
|
64
|
+
{
|
|
65
|
+
id: 'message',
|
|
66
|
+
name: 'Error Message',
|
|
67
|
+
required: true,
|
|
68
|
+
allowedComponents: ['Badge', 'Text'],
|
|
69
|
+
},
|
|
70
|
+
{
|
|
71
|
+
id: 'actions',
|
|
72
|
+
name: 'Actions',
|
|
73
|
+
required: true,
|
|
74
|
+
allowedComponents: ['Button'],
|
|
75
|
+
},
|
|
76
|
+
],
|
|
77
|
+
},
|
|
78
|
+
customizable: {
|
|
79
|
+
texts: ['title', 'message', 'retryButton'],
|
|
80
|
+
optional: ['error_details', 'support_link'],
|
|
81
|
+
slots: [],
|
|
82
|
+
},
|
|
83
|
+
requiredComponents: ['Button', 'Card', 'Badge'],
|
|
84
|
+
layout: {
|
|
85
|
+
type: 'centered',
|
|
86
|
+
maxWidth: 'md',
|
|
87
|
+
responsive: {
|
|
88
|
+
desktop: { padding: 'atomic.spacing.64', gap: 'atomic.spacing.32', direction: 'column' },
|
|
89
|
+
tablet: { padding: 'atomic.spacing.32', gap: 'atomic.spacing.24', direction: 'column' },
|
|
90
|
+
mobile: { padding: 'atomic.spacing.16', gap: 'atomic.spacing.16', direction: 'column' },
|
|
91
|
+
},
|
|
92
|
+
},
|
|
93
|
+
tokenBindings: {
|
|
94
|
+
backgroundColor: 'semantic.color.background.base',
|
|
95
|
+
errorColor: 'semantic.color.error',
|
|
96
|
+
},
|
|
97
|
+
Component: ErrorComponent,
|
|
98
|
+
};
|
|
99
|
+
//# sourceMappingURL=error.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"error.js","sourceRoot":"","sources":["../../../../src/screen-templates/templates/feedback/error.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAOH,MAAM,CAAC,MAAM,cAAc,GAA4B,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,EAAE,EAAE;IAC9E,MAAM,YAAY,GAAG;QACnB,KAAK,EAAE,KAAK,EAAE,KAAK,IAAI,YAAY;QACnC,OAAO,EAAE,KAAK,EAAE,OAAO,IAAI,wBAAwB;QACnD,WAAW,EAAE,KAAK,EAAE,WAAW,IAAI,OAAO;QAC1C,GAAG,KAAK;KACT,CAAC;IAEF,OAAO;QACL,IAAI,EAAE,KAAK;QACX,KAAK,EAAE;YACL,SAAS,EAAE,4EAA4E,SAAS,IAAI,EAAE,EAAE;SACzG;QACD,QAAQ,EAAE;YACR;gBACE,IAAI,EAAE,MAAM;gBACZ,KAAK,EAAE;oBACL,SAAS,EAAE,0BAA0B;iBACtC;gBACD,QAAQ,EAAE;oBACR;wBACE,IAAI,EAAE,OAAO;wBACb,KAAK,EAAE;4BACL,OAAO,EAAE,aAAa;4BACtB,SAAS,EAAE,MAAM;yBAClB;wBACD,QAAQ,EAAE,CAAC,IAAI,CAAC;qBACjB;oBACD;wBACE,IAAI,EAAE,IAAI;wBACV,KAAK,EAAE;4BACL,SAAS,EAAE,4BAA4B;yBACxC;wBACD,QAAQ,EAAE,CAAC,YAAY,CAAC,KAAK,CAAC;qBAC/B;oBACD;wBACE,IAAI,EAAE,GAAG;wBACT,KAAK,EAAE;4BACL,SAAS,EAAE,kDAAkD;yBAC9D;wBACD,QAAQ,EAAE,CAAC,YAAY,CAAC,OAAO,CAAC;qBACjC;oBACD;wBACE,IAAI,EAAE,QAAQ;wBACd,QAAQ,EAAE,CAAC,YAAY,CAAC,WAAW,CAAC;qBACrC;iBACF;aACF;SACF;KACwB,CAAC;AAC9B,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,aAAa,GAAmB;IAC3C,EAAE,EAAE,gBAAgB;IACpB,IAAI,EAAE,OAAO;IACb,QAAQ,EAAE,UAAU;IACpB,WAAW,EAAE,mDAAmD;IAChE,QAAQ,EAAE;QACR,KAAK,EAAE,eAAe;QACtB,IAAI,EAAE,cAAc;QACpB,QAAQ,EAAE;YACR;gBACE,EAAE,EAAE,SAAS;gBACb,IAAI,EAAE,eAAe;gBACrB,QAAQ,EAAE,IAAI;gBACd,iBAAiB,EAAE,CAAC,OAAO,EAAE,MAAM,CAAC;aACrC;YACD;gBACE,EAAE,EAAE,SAAS;gBACb,IAAI,EAAE,SAAS;gBACf,QAAQ,EAAE,IAAI;gBACd,iBAAiB,EAAE,CAAC,QAAQ,CAAC;aAC9B;SACF;KACF;IACD,YAAY,EAAE;QACZ,KAAK,EAAE,CAAC,OAAO,EAAE,SAAS,EAAE,aAAa,CAAC;QAC1C,QAAQ,EAAE,CAAC,eAAe,EAAE,cAAc,CAAC;QAC3C,KAAK,EAAE,EAAE;KACV;IACD,kBAAkB,EAAE,CAAC,QAAQ,EAAE,MAAM,EAAE,OAAO,CAAC;IAC/C,MAAM,EAAE;QACN,IAAI,EAAE,UAAU;QAChB,QAAQ,EAAE,IAAI;QACd,UAAU,EAAE;YACV,OAAO,EAAE,EAAE,OAAO,EAAE,mBAAmB,EAAE,GAAG,EAAE,mBAAmB,EAAE,SAAS,EAAE,QAAQ,EAAE;YACxF,MAAM,EAAE,EAAE,OAAO,EAAE,mBAAmB,EAAE,GAAG,EAAE,mBAAmB,EAAE,SAAS,EAAE,QAAQ,EAAE;YACvF,MAAM,EAAE,EAAE,OAAO,EAAE,mBAAmB,EAAE,GAAG,EAAE,mBAAmB,EAAE,SAAS,EAAE,QAAQ,EAAE;SACxF;KACF;IACD,aAAa,EAAE;QACb,eAAe,EAAE,gCAAgC;QACjD,UAAU,EAAE,sBAAsB;KACnC;IACD,SAAS,EAAE,cAAc;CAC1B,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @tekton-ui/core - Feedback Templates Export
|
|
3
|
+
* [SPEC-UI-002] Feedback Screen Templates (5)
|
|
4
|
+
*/
|
|
5
|
+
export * from './loading.js';
|
|
6
|
+
export * from './error.js';
|
|
7
|
+
export * from './empty.js';
|
|
8
|
+
export * from './confirmation.js';
|
|
9
|
+
export * from './success.js';
|
|
10
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/screen-templates/templates/feedback/index.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,cAAc,cAAc,CAAC;AAC7B,cAAc,YAAY,CAAC;AAC3B,cAAc,YAAY,CAAC;AAC3B,cAAc,mBAAmB,CAAC;AAClC,cAAc,cAAc,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @tekton-ui/core - Feedback Templates Export
|
|
3
|
+
* [SPEC-UI-002] Feedback Screen Templates (5)
|
|
4
|
+
*/
|
|
5
|
+
export * from './loading.js';
|
|
6
|
+
export * from './error.js';
|
|
7
|
+
export * from './empty.js';
|
|
8
|
+
export * from './confirmation.js';
|
|
9
|
+
export * from './success.js';
|
|
10
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/screen-templates/templates/feedback/index.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,cAAc,cAAc,CAAC;AAC7B,cAAc,YAAY,CAAC;AAC3B,cAAc,YAAY,CAAC;AAC3B,cAAc,mBAAmB,CAAC;AAClC,cAAc,cAAc,CAAC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @tekton-ui/core - Loading Screen Template
|
|
3
|
+
* [SPEC-UI-002] [TAG-UI002-031] feedback.loading
|
|
4
|
+
*/
|
|
5
|
+
import type { ScreenTemplate, ScreenTemplateProps } from '../../types.js';
|
|
6
|
+
import type { FC } from '../../types.js';
|
|
7
|
+
export declare const LoadingComponent: FC<ScreenTemplateProps>;
|
|
8
|
+
export declare const loadingTemplate: ScreenTemplate;
|
|
9
|
+
//# sourceMappingURL=loading.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"loading.d.ts","sourceRoot":"","sources":["../../../../src/screen-templates/templates/feedback/loading.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAIH,OAAO,KAAK,EAAE,cAAc,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAC1E,OAAO,KAAK,EAAE,EAAE,EAAE,MAAM,gBAAgB,CAAC;AAEzC,eAAO,MAAM,gBAAgB,EAAE,EAAE,CAAC,mBAAmB,CAmCpD,CAAC;AAEF,eAAO,MAAM,eAAe,EAAE,cAoC7B,CAAC"}
|