@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.
Files changed (254) hide show
  1. package/README.md +758 -0
  2. package/dist/blueprint.d.ts +44 -0
  3. package/dist/blueprint.d.ts.map +1 -0
  4. package/dist/blueprint.js +163 -0
  5. package/dist/blueprint.js.map +1 -0
  6. package/dist/component-schemas.d.ts +78 -0
  7. package/dist/component-schemas.d.ts.map +1 -0
  8. package/dist/component-schemas.js +1037 -0
  9. package/dist/component-schemas.js.map +1 -0
  10. package/dist/css-generator.d.ts +42 -0
  11. package/dist/css-generator.d.ts.map +1 -0
  12. package/dist/css-generator.js +339 -0
  13. package/dist/css-generator.js.map +1 -0
  14. package/dist/icon-library.d.ts +109 -0
  15. package/dist/icon-library.d.ts.map +1 -0
  16. package/dist/icon-library.js +204 -0
  17. package/dist/icon-library.js.map +1 -0
  18. package/dist/index.d.ts +36 -0
  19. package/dist/index.d.ts.map +1 -0
  20. package/dist/index.js +51 -0
  21. package/dist/index.js.map +1 -0
  22. package/dist/layout-css-generator.d.ts +158 -0
  23. package/dist/layout-css-generator.d.ts.map +1 -0
  24. package/dist/layout-css-generator.js +901 -0
  25. package/dist/layout-css-generator.js.map +1 -0
  26. package/dist/layout-resolver.d.ts +92 -0
  27. package/dist/layout-resolver.d.ts.map +1 -0
  28. package/dist/layout-resolver.js +275 -0
  29. package/dist/layout-resolver.js.map +1 -0
  30. package/dist/layout-tokens/index.d.ts +16 -0
  31. package/dist/layout-tokens/index.d.ts.map +1 -0
  32. package/dist/layout-tokens/index.js +16 -0
  33. package/dist/layout-tokens/index.js.map +1 -0
  34. package/dist/layout-tokens/keyboard.d.ts +254 -0
  35. package/dist/layout-tokens/keyboard.d.ts.map +1 -0
  36. package/dist/layout-tokens/keyboard.js +407 -0
  37. package/dist/layout-tokens/keyboard.js.map +1 -0
  38. package/dist/layout-tokens/mobile-shells.d.ts +78 -0
  39. package/dist/layout-tokens/mobile-shells.d.ts.map +1 -0
  40. package/dist/layout-tokens/mobile-shells.js +635 -0
  41. package/dist/layout-tokens/mobile-shells.js.map +1 -0
  42. package/dist/layout-tokens/pages.d.ts +100 -0
  43. package/dist/layout-tokens/pages.d.ts.map +1 -0
  44. package/dist/layout-tokens/pages.js +576 -0
  45. package/dist/layout-tokens/pages.js.map +1 -0
  46. package/dist/layout-tokens/responsive.d.ts +109 -0
  47. package/dist/layout-tokens/responsive.d.ts.map +1 -0
  48. package/dist/layout-tokens/responsive.js +167 -0
  49. package/dist/layout-tokens/responsive.js.map +1 -0
  50. package/dist/layout-tokens/safe-area.d.ts +156 -0
  51. package/dist/layout-tokens/safe-area.d.ts.map +1 -0
  52. package/dist/layout-tokens/safe-area.js +316 -0
  53. package/dist/layout-tokens/safe-area.js.map +1 -0
  54. package/dist/layout-tokens/sections-advanced.d.ts +277 -0
  55. package/dist/layout-tokens/sections-advanced.d.ts.map +1 -0
  56. package/dist/layout-tokens/sections-advanced.js +593 -0
  57. package/dist/layout-tokens/sections-advanced.js.map +1 -0
  58. package/dist/layout-tokens/sections.d.ts +137 -0
  59. package/dist/layout-tokens/sections.d.ts.map +1 -0
  60. package/dist/layout-tokens/sections.js +694 -0
  61. package/dist/layout-tokens/sections.js.map +1 -0
  62. package/dist/layout-tokens/shells.d.ts +77 -0
  63. package/dist/layout-tokens/shells.d.ts.map +1 -0
  64. package/dist/layout-tokens/shells.js +408 -0
  65. package/dist/layout-tokens/shells.js.map +1 -0
  66. package/dist/layout-tokens/touch-target.d.ts +119 -0
  67. package/dist/layout-tokens/touch-target.d.ts.map +1 -0
  68. package/dist/layout-tokens/touch-target.js +156 -0
  69. package/dist/layout-tokens/touch-target.js.map +1 -0
  70. package/dist/layout-tokens/types.d.ts +632 -0
  71. package/dist/layout-tokens/types.d.ts.map +1 -0
  72. package/dist/layout-tokens/types.js +49 -0
  73. package/dist/layout-tokens/types.js.map +1 -0
  74. package/dist/layout-validation.d.ts +1547 -0
  75. package/dist/layout-validation.d.ts.map +1 -0
  76. package/dist/layout-validation.js +628 -0
  77. package/dist/layout-validation.js.map +1 -0
  78. package/dist/render.d.ts +23 -0
  79. package/dist/render.d.ts.map +1 -0
  80. package/dist/render.js +244 -0
  81. package/dist/render.js.map +1 -0
  82. package/dist/schema-validation.d.ts +208 -0
  83. package/dist/schema-validation.d.ts.map +1 -0
  84. package/dist/schema-validation.js +205 -0
  85. package/dist/schema-validation.js.map +1 -0
  86. package/dist/screen-generation/generators/css-in-js-generator.d.ts +82 -0
  87. package/dist/screen-generation/generators/css-in-js-generator.d.ts.map +1 -0
  88. package/dist/screen-generation/generators/css-in-js-generator.js +335 -0
  89. package/dist/screen-generation/generators/css-in-js-generator.js.map +1 -0
  90. package/dist/screen-generation/generators/index.d.ts +13 -0
  91. package/dist/screen-generation/generators/index.d.ts.map +1 -0
  92. package/dist/screen-generation/generators/index.js +32 -0
  93. package/dist/screen-generation/generators/index.js.map +1 -0
  94. package/dist/screen-generation/generators/react-generator.d.ts +100 -0
  95. package/dist/screen-generation/generators/react-generator.d.ts.map +1 -0
  96. package/dist/screen-generation/generators/react-generator.js +379 -0
  97. package/dist/screen-generation/generators/react-generator.js.map +1 -0
  98. package/dist/screen-generation/generators/tailwind-generator.d.ts +105 -0
  99. package/dist/screen-generation/generators/tailwind-generator.d.ts.map +1 -0
  100. package/dist/screen-generation/generators/tailwind-generator.js +355 -0
  101. package/dist/screen-generation/generators/tailwind-generator.js.map +1 -0
  102. package/dist/screen-generation/generators/types.d.ts +136 -0
  103. package/dist/screen-generation/generators/types.d.ts.map +1 -0
  104. package/dist/screen-generation/generators/types.js +18 -0
  105. package/dist/screen-generation/generators/types.js.map +1 -0
  106. package/dist/screen-generation/generators/utils.d.ts +187 -0
  107. package/dist/screen-generation/generators/utils.d.ts.map +1 -0
  108. package/dist/screen-generation/generators/utils.js +312 -0
  109. package/dist/screen-generation/generators/utils.js.map +1 -0
  110. package/dist/screen-generation/index.d.ts +14 -0
  111. package/dist/screen-generation/index.d.ts.map +1 -0
  112. package/dist/screen-generation/index.js +33 -0
  113. package/dist/screen-generation/index.js.map +1 -0
  114. package/dist/screen-generation/resolver/component-resolver.d.ts +157 -0
  115. package/dist/screen-generation/resolver/component-resolver.d.ts.map +1 -0
  116. package/dist/screen-generation/resolver/component-resolver.js +295 -0
  117. package/dist/screen-generation/resolver/component-resolver.js.map +1 -0
  118. package/dist/screen-generation/resolver/index.d.ts +10 -0
  119. package/dist/screen-generation/resolver/index.d.ts.map +1 -0
  120. package/dist/screen-generation/resolver/index.js +46 -0
  121. package/dist/screen-generation/resolver/index.js.map +1 -0
  122. package/dist/screen-generation/resolver/layout-resolver.d.ts +155 -0
  123. package/dist/screen-generation/resolver/layout-resolver.d.ts.map +1 -0
  124. package/dist/screen-generation/resolver/layout-resolver.js +193 -0
  125. package/dist/screen-generation/resolver/layout-resolver.js.map +1 -0
  126. package/dist/screen-generation/resolver/screen-resolver.d.ts +174 -0
  127. package/dist/screen-generation/resolver/screen-resolver.d.ts.map +1 -0
  128. package/dist/screen-generation/resolver/screen-resolver.js +373 -0
  129. package/dist/screen-generation/resolver/screen-resolver.js.map +1 -0
  130. package/dist/screen-generation/resolver/token-resolver.d.ts +170 -0
  131. package/dist/screen-generation/resolver/token-resolver.d.ts.map +1 -0
  132. package/dist/screen-generation/resolver/token-resolver.js +260 -0
  133. package/dist/screen-generation/resolver/token-resolver.js.map +1 -0
  134. package/dist/screen-generation/types.d.ts +116 -0
  135. package/dist/screen-generation/types.d.ts.map +1 -0
  136. package/dist/screen-generation/types.js +33 -0
  137. package/dist/screen-generation/types.js.map +1 -0
  138. package/dist/screen-generation/validators.d.ts +286 -0
  139. package/dist/screen-generation/validators.d.ts.map +1 -0
  140. package/dist/screen-generation/validators.js +323 -0
  141. package/dist/screen-generation/validators.js.map +1 -0
  142. package/dist/screen-templates/__tests__/registry.test.d.ts +6 -0
  143. package/dist/screen-templates/__tests__/registry.test.d.ts.map +1 -0
  144. package/dist/screen-templates/__tests__/registry.test.js +247 -0
  145. package/dist/screen-templates/__tests__/registry.test.js.map +1 -0
  146. package/dist/screen-templates/__tests__/templates.test.d.ts +6 -0
  147. package/dist/screen-templates/__tests__/templates.test.d.ts.map +1 -0
  148. package/dist/screen-templates/__tests__/templates.test.js +179 -0
  149. package/dist/screen-templates/__tests__/templates.test.js.map +1 -0
  150. package/dist/screen-templates/index.d.ts +39 -0
  151. package/dist/screen-templates/index.d.ts.map +1 -0
  152. package/dist/screen-templates/index.js +79 -0
  153. package/dist/screen-templates/index.js.map +1 -0
  154. package/dist/screen-templates/registry.d.ts +177 -0
  155. package/dist/screen-templates/registry.d.ts.map +1 -0
  156. package/dist/screen-templates/registry.js +274 -0
  157. package/dist/screen-templates/registry.js.map +1 -0
  158. package/dist/screen-templates/templates/account/index.d.ts +6 -0
  159. package/dist/screen-templates/templates/account/index.d.ts.map +1 -0
  160. package/dist/screen-templates/templates/account/index.js +6 -0
  161. package/dist/screen-templates/templates/account/index.js.map +1 -0
  162. package/dist/screen-templates/templates/account/profile.d.ts +23 -0
  163. package/dist/screen-templates/templates/account/profile.d.ts.map +1 -0
  164. package/dist/screen-templates/templates/account/profile.js +249 -0
  165. package/dist/screen-templates/templates/account/profile.js.map +1 -0
  166. package/dist/screen-templates/templates/auth/forgot-password.d.ts +23 -0
  167. package/dist/screen-templates/templates/auth/forgot-password.d.ts.map +1 -0
  168. package/dist/screen-templates/templates/auth/forgot-password.js +203 -0
  169. package/dist/screen-templates/templates/auth/forgot-password.js.map +1 -0
  170. package/dist/screen-templates/templates/auth/index.d.ts +9 -0
  171. package/dist/screen-templates/templates/auth/index.d.ts.map +1 -0
  172. package/dist/screen-templates/templates/auth/index.js +9 -0
  173. package/dist/screen-templates/templates/auth/index.js.map +1 -0
  174. package/dist/screen-templates/templates/auth/login.d.ts +24 -0
  175. package/dist/screen-templates/templates/auth/login.d.ts.map +1 -0
  176. package/dist/screen-templates/templates/auth/login.js +254 -0
  177. package/dist/screen-templates/templates/auth/login.js.map +1 -0
  178. package/dist/screen-templates/templates/auth/signup.d.ts +24 -0
  179. package/dist/screen-templates/templates/auth/signup.d.ts.map +1 -0
  180. package/dist/screen-templates/templates/auth/signup.js +315 -0
  181. package/dist/screen-templates/templates/auth/signup.js.map +1 -0
  182. package/dist/screen-templates/templates/auth/verification.d.ts +23 -0
  183. package/dist/screen-templates/templates/auth/verification.d.ts.map +1 -0
  184. package/dist/screen-templates/templates/auth/verification.js +239 -0
  185. package/dist/screen-templates/templates/auth/verification.js.map +1 -0
  186. package/dist/screen-templates/templates/feedback/confirmation.d.ts +9 -0
  187. package/dist/screen-templates/templates/feedback/confirmation.d.ts.map +1 -0
  188. package/dist/screen-templates/templates/feedback/confirmation.js +107 -0
  189. package/dist/screen-templates/templates/feedback/confirmation.js.map +1 -0
  190. package/dist/screen-templates/templates/feedback/empty.d.ts +9 -0
  191. package/dist/screen-templates/templates/feedback/empty.d.ts.map +1 -0
  192. package/dist/screen-templates/templates/feedback/empty.js +90 -0
  193. package/dist/screen-templates/templates/feedback/empty.js.map +1 -0
  194. package/dist/screen-templates/templates/feedback/error.d.ts +9 -0
  195. package/dist/screen-templates/templates/feedback/error.d.ts.map +1 -0
  196. package/dist/screen-templates/templates/feedback/error.js +99 -0
  197. package/dist/screen-templates/templates/feedback/error.js.map +1 -0
  198. package/dist/screen-templates/templates/feedback/index.d.ts +10 -0
  199. package/dist/screen-templates/templates/feedback/index.d.ts.map +1 -0
  200. package/dist/screen-templates/templates/feedback/index.js +10 -0
  201. package/dist/screen-templates/templates/feedback/index.js.map +1 -0
  202. package/dist/screen-templates/templates/feedback/loading.d.ts +9 -0
  203. package/dist/screen-templates/templates/feedback/loading.d.ts.map +1 -0
  204. package/dist/screen-templates/templates/feedback/loading.js +77 -0
  205. package/dist/screen-templates/templates/feedback/loading.js.map +1 -0
  206. package/dist/screen-templates/templates/feedback/success.d.ts +9 -0
  207. package/dist/screen-templates/templates/feedback/success.d.ts.map +1 -0
  208. package/dist/screen-templates/templates/feedback/success.js +99 -0
  209. package/dist/screen-templates/templates/feedback/success.js.map +1 -0
  210. package/dist/screen-templates/templates/home/index.d.ts +6 -0
  211. package/dist/screen-templates/templates/home/index.d.ts.map +1 -0
  212. package/dist/screen-templates/templates/home/index.js +6 -0
  213. package/dist/screen-templates/templates/home/index.js.map +1 -0
  214. package/dist/screen-templates/templates/home/landing.d.ts +24 -0
  215. package/dist/screen-templates/templates/home/landing.d.ts.map +1 -0
  216. package/dist/screen-templates/templates/home/landing.js +197 -0
  217. package/dist/screen-templates/templates/home/landing.js.map +1 -0
  218. package/dist/screen-templates/templates/settings/index.d.ts +6 -0
  219. package/dist/screen-templates/templates/settings/index.d.ts.map +1 -0
  220. package/dist/screen-templates/templates/settings/index.js +6 -0
  221. package/dist/screen-templates/templates/settings/index.js.map +1 -0
  222. package/dist/screen-templates/templates/settings/preferences.d.ts +24 -0
  223. package/dist/screen-templates/templates/settings/preferences.d.ts.map +1 -0
  224. package/dist/screen-templates/templates/settings/preferences.js +265 -0
  225. package/dist/screen-templates/templates/settings/preferences.js.map +1 -0
  226. package/dist/screen-templates/types.d.ts +229 -0
  227. package/dist/screen-templates/types.d.ts.map +1 -0
  228. package/dist/screen-templates/types.js +7 -0
  229. package/dist/screen-templates/types.js.map +1 -0
  230. package/dist/theme-v2.d.ts +228 -0
  231. package/dist/theme-v2.d.ts.map +1 -0
  232. package/dist/theme-v2.js +158 -0
  233. package/dist/theme-v2.js.map +1 -0
  234. package/dist/theme.d.ts +60 -0
  235. package/dist/theme.d.ts.map +1 -0
  236. package/dist/theme.js +76 -0
  237. package/dist/theme.js.map +1 -0
  238. package/dist/token-resolver.d.ts +69 -0
  239. package/dist/token-resolver.d.ts.map +1 -0
  240. package/dist/token-resolver.js +122 -0
  241. package/dist/token-resolver.js.map +1 -0
  242. package/dist/token-validation.d.ts +432 -0
  243. package/dist/token-validation.d.ts.map +1 -0
  244. package/dist/token-validation.js +140 -0
  245. package/dist/token-validation.js.map +1 -0
  246. package/dist/tokens.d.ts +158 -0
  247. package/dist/tokens.d.ts.map +1 -0
  248. package/dist/tokens.js +10 -0
  249. package/dist/tokens.js.map +1 -0
  250. package/dist/types.d.ts +77 -0
  251. package/dist/types.d.ts.map +1 -0
  252. package/dist/types.js +7 -0
  253. package/dist/types.js.map +1 -0
  254. 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":"AAAA;;;GAGG;AAOH,MAAM,CAAC,MAAM,qBAAqB,GAA4B,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,EAAE,EAAE;IACrF,MAAM,YAAY,GAAG;QACnB,KAAK,EAAE,KAAK,EAAE,KAAK,IAAI,IAAI;QAC3B,OAAO,EAAE,KAAK,EAAE,OAAO,IAAI,iBAAiB;QAC5C,aAAa,EAAE,KAAK,EAAE,aAAa,IAAI,IAAI;QAC3C,YAAY,EAAE,KAAK,EAAE,YAAY,IAAI,IAAI;QACzC,GAAG,KAAK;KACT,CAAC;IAEF,OAAO;QACL,IAAI,EAAE,QAAQ;QACd,KAAK,EAAE;YACL,IAAI,EAAE,IAAI;YACV,SAAS;SACV;QACD,QAAQ,EAAE;YACR;gBACE,IAAI,EAAE,KAAK;gBACX,KAAK,EAAE;oBACL,SAAS,EAAE,KAAK;iBACjB;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,KAAK;wBACX,KAAK,EAAE;4BACL,SAAS,EAAE,wBAAwB;yBACpC;wBACD,QAAQ,EAAE;4BACR;gCACE,IAAI,EAAE,QAAQ;gCACd,KAAK,EAAE;oCACL,OAAO,EAAE,SAAS;iCACnB;gCACD,QAAQ,EAAE,CAAC,YAAY,CAAC,YAAY,CAAC;6BACtC;4BACD;gCACE,IAAI,EAAE,QAAQ;gCACd,QAAQ,EAAE,CAAC,YAAY,CAAC,aAAa,CAAC;6BACvC;yBACF;qBACF;iBACF;aACF;SACF;KACwB,CAAC;AAC9B,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,oBAAoB,GAAmB;IAClD,EAAE,EAAE,uBAAuB;IAC3B,IAAI,EAAE,cAAc;IACpB,QAAQ,EAAE,UAAU;IACpB,WAAW,EAAE,0CAA0C;IACvD,QAAQ,EAAE;QACR,KAAK,EAAE,eAAe;QACtB,IAAI,EAAE,cAAc;QACpB,QAAQ,EAAE;YACR;gBACE,EAAE,EAAE,SAAS;gBACb,IAAI,EAAE,sBAAsB;gBAC5B,QAAQ,EAAE,IAAI;gBACd,iBAAiB,EAAE,CAAC,MAAM,CAAC;aAC5B;YACD;gBACE,EAAE,EAAE,SAAS;gBACb,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,eAAe,EAAE,cAAc,CAAC;QAC5D,QAAQ,EAAE,CAAC,cAAc,CAAC;QAC1B,KAAK,EAAE,EAAE;KACV;IACD,kBAAkB,EAAE,CAAC,QAAQ,EAAE,QAAQ,EAAE,aAAa,CAAC;IACvD,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,mCAAmC;KACrD;IACD,SAAS,EAAE,qBAAqB;CACjC,CAAC"}
@@ -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"}