@seed-design/figma 0.2.1 → 0.2.4

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 (47) hide show
  1. package/lib/codegen/index.cjs +294 -62
  2. package/lib/codegen/index.d.ts +460 -68
  3. package/lib/codegen/index.d.ts.map +1 -1
  4. package/lib/codegen/index.js +294 -62
  5. package/lib/codegen/targets/react/index.cjs +856 -242
  6. package/lib/codegen/targets/react/index.d.ts.map +1 -1
  7. package/lib/codegen/targets/react/index.js +856 -242
  8. package/lib/index.cjs +285 -60
  9. package/lib/index.js +285 -60
  10. package/package.json +2 -2
  11. package/src/codegen/component-properties.ts +82 -6
  12. package/src/codegen/core/jsx.ts +14 -2
  13. package/src/codegen/targets/react/component/handlers/checkbox.ts +7 -0
  14. package/src/codegen/targets/react/component/handlers/checkmark.ts +29 -0
  15. package/src/codegen/targets/react/component/handlers/chip.ts +5 -2
  16. package/src/codegen/targets/react/component/handlers/divider.ts +8 -2
  17. package/src/codegen/targets/react/component/handlers/help-bubble.ts +2 -0
  18. package/src/codegen/targets/react/component/handlers/list-item.ts +155 -0
  19. package/src/codegen/targets/react/component/handlers/radio-group.ts +31 -0
  20. package/src/codegen/targets/react/component/handlers/radio-mark.ts +27 -0
  21. package/src/codegen/targets/react/component/handlers/switch.ts +7 -0
  22. package/src/codegen/targets/react/component/handlers/tabs.ts +288 -5
  23. package/src/codegen/targets/react/component/index.ts +12 -2
  24. package/src/entities/data/__generated__/component-sets/checkbox.d.ts +9 -2
  25. package/src/entities/data/__generated__/component-sets/checkbox.mjs +9 -2
  26. package/src/entities/data/__generated__/component-sets/checkmark.d.ts +13 -6
  27. package/src/entities/data/__generated__/component-sets/checkmark.mjs +13 -6
  28. package/src/entities/data/__generated__/component-sets/divider.d.ts +2 -2
  29. package/src/entities/data/__generated__/component-sets/divider.mjs +2 -2
  30. package/src/entities/data/__generated__/component-sets/help-bubble.d.ts +3 -0
  31. package/src/entities/data/__generated__/component-sets/help-bubble.mjs +3 -0
  32. package/src/entities/data/__generated__/component-sets/index.d.ts +2 -0
  33. package/src/entities/data/__generated__/component-sets/index.mjs +2 -0
  34. package/src/entities/data/__generated__/component-sets/list-header.d.ts +24 -0
  35. package/src/entities/data/__generated__/component-sets/list-header.mjs +24 -0
  36. package/src/entities/data/__generated__/component-sets/list-item.d.ts +152 -0
  37. package/src/entities/data/__generated__/component-sets/list-item.mjs +152 -0
  38. package/src/entities/data/__generated__/component-sets/radio-mark.d.ts +7 -0
  39. package/src/entities/data/__generated__/component-sets/radio-mark.mjs +7 -0
  40. package/src/entities/data/__generated__/component-sets/radio.d.ts +14 -0
  41. package/src/entities/data/__generated__/component-sets/radio.mjs +14 -0
  42. package/src/entities/data/__generated__/component-sets/switch.d.ts +10 -3
  43. package/src/entities/data/__generated__/component-sets/switch.mjs +10 -3
  44. package/src/entities/data/__generated__/component-sets/tabs.d.ts +1 -1
  45. package/src/entities/data/__generated__/component-sets/tabs.mjs +1 -1
  46. package/src/entities/data/__generated__/component-sets/inline-banner.d.ts +0 -40
  47. package/src/entities/data/__generated__/component-sets/inline-banner.mjs +0 -40
@@ -1,14 +1,297 @@
1
1
  import { createLocalSnippetHelper } from "../../element-factories";
2
+ import type {
3
+ ChipProperties,
4
+ ChipTabsTriggerProperties,
5
+ TabsChipWrapperProperties,
6
+ TabsLineTriggerFillProperties,
7
+ TabsLineTriggerHugProperties,
8
+ TabsLineWrapperProperties,
9
+ TabsProperties,
10
+ } from "@/codegen/component-properties";
11
+ import { defineComponentHandler } from "@/codegen/core";
12
+ import * as metadata from "@/entities/data/__generated__/component-sets";
13
+ import { camelCase } from "change-case";
14
+ import type { ComponentHandlerDeps } from "../deps.interface";
15
+ import { handleSizeProp } from "../size";
16
+ import { match } from "ts-pattern";
17
+ import { findAllInstances } from "@/utils/figma-node";
2
18
 
3
19
  const { createLocalSnippetElement: createTabsLocalSnippetElement } =
4
20
  createLocalSnippetHelper("tabs");
5
21
 
6
- const TABS_UNDERLINE_HUG_ITEM_KEY = "946cc52671ac3f46e20a8ff12fcc1c7f618da675";
7
- const TABS_UNDERLINE_FILL_ITEM_KEY = "78039b6b86852b685a6e93e9b6743b9e577cd7db";
8
-
9
22
  const { createLocalSnippetElement: createChipTabsLocalSnippetElement } =
10
23
  createLocalSnippetHelper("chip-tabs");
11
24
 
12
- const TABS_CHIP_ITEM_KEY = "95bf31a329f9e8bba0d9aa2299d1552f1d388148";
25
+ const LINE_TABS_WRAPPER_KEY = "e114161387f800d3668d0585bed1d109e4edcbe4";
26
+ const CHIP_TABS_WRAPPER_KEY = "d7cf2983c79c8394aaab0185af83a9d1b9d10ece";
27
+
28
+ export const createTabsHandler = (_ctx: ComponentHandlerDeps) => {
29
+ const lineHandler = createLineTabsHandler(_ctx);
30
+ const chipHandler = createChipTabsHandler(_ctx);
31
+
32
+ return defineComponentHandler<TabsProperties>(metadata.tabs.key, (node, traverse) => {
33
+ const props = node.componentProperties;
34
+
35
+ const elementNode = match(props.Variant.value)
36
+ .with("Line", () => {
37
+ const [wrapper] = findAllInstances<TabsLineWrapperProperties>({
38
+ node,
39
+ key: LINE_TABS_WRAPPER_KEY,
40
+ });
41
+
42
+ if (!wrapper) throw new Error("Line Tab wrapper not found");
43
+
44
+ return lineHandler.transform(wrapper, traverse);
45
+ })
46
+ .with("Chip", () => {
47
+ const [wrapper] = findAllInstances<TabsChipWrapperProperties>({
48
+ node,
49
+ key: CHIP_TABS_WRAPPER_KEY,
50
+ });
51
+
52
+ if (!wrapper) throw new Error("Chip Tab wrapper not found");
53
+
54
+ return chipHandler.transform(wrapper, traverse);
55
+ })
56
+ .exhaustive();
57
+
58
+ return elementNode;
59
+ });
60
+ };
61
+
62
+ /*
63
+ <TabsRoot defaultValue="2" triggerLayout="fill">
64
+ <TabsList>
65
+ <TabsTrigger value="1">라벨1</TabsTrigger>
66
+ <TabsTrigger value="2">라벨2</TabsTrigger>
67
+ <TabsTrigger value="3">라벨3</TabsTrigger>
68
+ </TabsList>
69
+ <TabsCarousel>
70
+ <TabsContent value="1">
71
+ <Content>Content 1</Content>
72
+ </TabsContent>
73
+ <TabsContent value="2">
74
+ <Content>Content 2</Content>
75
+ </TabsContent>
76
+ <TabsContent value="3">
77
+ <Content>Content 3</Content>
78
+ </TabsContent>
79
+ </TabsCarousel>
80
+ </TabsRoot>
81
+ */
82
+
83
+ const LINE_TABS_HUG_ITEM_KEY = "946cc52671ac3f46e20a8ff12fcc1c7f618da675";
84
+ const LINE_TABS_FILL_ITEM_KEY = "78039b6b86852b685a6e93e9b6743b9e577cd7db";
85
+
86
+ const createLineTabsHandler = (_ctx: ComponentHandlerDeps) => {
87
+ const hugHandler = createLineTriggerHugHandler(_ctx);
88
+ const fillHandler = createLineTriggerFillHandler(_ctx);
89
+
90
+ return defineComponentHandler<TabsLineWrapperProperties>(
91
+ LINE_TABS_WRAPPER_KEY,
92
+ (node, traverse) => {
93
+ const props = node.componentProperties;
94
+
95
+ const { triggers, defaultValue } = match(props.Layout.value)
96
+ .with("Hug", () => {
97
+ const nodes = findAllInstances<TabsLineTriggerHugProperties>({
98
+ node,
99
+ key: LINE_TABS_HUG_ITEM_KEY,
100
+ });
101
+
102
+ return {
103
+ triggers: nodes.map((node) => ({
104
+ elementNode: hugHandler.transform(node, traverse),
105
+ value: node.componentProperties["Label#4478:2"].value,
106
+ })),
107
+ defaultValue: nodes.find((node) => node.componentProperties.State.value === "Selected")
108
+ ?.componentProperties["Label#4478:2"].value,
109
+ };
110
+ })
111
+ .with("Fill", () => {
112
+ const nodes = findAllInstances<TabsLineTriggerFillProperties>({
113
+ node,
114
+ key: LINE_TABS_FILL_ITEM_KEY,
115
+ });
116
+
117
+ return {
118
+ triggers: nodes.map((node) => ({
119
+ elementNode: fillHandler.transform(node, traverse),
120
+ value: node.componentProperties["Label#4478:2"].value,
121
+ })),
122
+ defaultValue: nodes.find((node) => node.componentProperties.State.value === "Selected")
123
+ ?.componentProperties["Label#4478:2"].value,
124
+ };
125
+ })
126
+ .exhaustive();
127
+
128
+ const rootProps = {
129
+ triggerLayout: camelCase(props.Layout.value),
130
+ size: handleSizeProp(props.Size.value),
131
+ defaultValue,
132
+ };
133
+
134
+ const tabsCarousel = createTabsLocalSnippetElement(
135
+ "TabsCarousel",
136
+ undefined,
137
+ triggers.map(({ value }) => createTabsLocalSnippetElement("TabsContent", { value }, value)),
138
+ );
139
+
140
+ const tabsList = createTabsLocalSnippetElement(
141
+ "TabsList",
142
+ undefined,
143
+ triggers.map(({ elementNode }) => elementNode),
144
+ );
145
+
146
+ return createTabsLocalSnippetElement("TabsRoot", rootProps, [tabsList, tabsCarousel]);
147
+ },
148
+ );
149
+ };
150
+
151
+ const LINE_TRIGGER_HUG_KEY = "946cc52671ac3f46e20a8ff12fcc1c7f618da675";
152
+
153
+ const createLineTriggerHugHandler = (_ctx: ComponentHandlerDeps) =>
154
+ defineComponentHandler<TabsLineTriggerHugProperties>(
155
+ LINE_TRIGGER_HUG_KEY,
156
+ ({ componentProperties: props }) => {
157
+ const commonProps = {
158
+ value: props["Label#4478:2"].value,
159
+ ...(props.State.value === "Disabled" && {
160
+ disabled: true,
161
+ }),
162
+ ...(props["Has Notification#32892:0"].value && {
163
+ notification: true,
164
+ }),
165
+ };
166
+
167
+ return createTabsLocalSnippetElement("TabsTrigger", commonProps);
168
+ },
169
+ );
170
+
171
+ const LINE_TRIGGER_FILL_KEY = "78039b6b86852b685a6e93e9b6743b9e577cd7db";
172
+
173
+ const createLineTriggerFillHandler = (_ctx: ComponentHandlerDeps) =>
174
+ defineComponentHandler<TabsLineTriggerFillProperties>(
175
+ LINE_TRIGGER_FILL_KEY,
176
+ ({ componentProperties: props }) => {
177
+ const commonProps = {
178
+ value: props["Label#4478:2"].value,
179
+ ...(props.State.value === "Disabled" && {
180
+ disabled: true,
181
+ }),
182
+ ...(props["Has Notification#32904:13"].value && {
183
+ notification: true,
184
+ }),
185
+ };
186
+
187
+ return createTabsLocalSnippetElement("TabsTrigger", commonProps);
188
+ },
189
+ );
190
+
191
+ /*
192
+ <ChipTabsRoot
193
+ variant="neutralOutline"
194
+ defaultValue="1"
195
+ >
196
+ <ChipTabsList>
197
+ <ChipTabsTrigger value="1">라벨1</ChipTabsTrigger>
198
+ <ChipTabsTrigger value="2">라벨2</ChipTabsTrigger>
199
+ <ChipTabsTrigger value="3">라벨3</ChipTabsTrigger>
200
+ </ChipTabsList>
201
+ <ChipTabsCarousel>
202
+ <ChipTabsContent value="1">
203
+ <Content>Content 1</Content>
204
+ </ChipTabsContent>
205
+ <ChipTabsContent value="2">
206
+ <Content>Content 2</Content>
207
+ </ChipTabsContent>
208
+ <ChipTabsContent value="3">
209
+ <Content>Content 3</Content>
210
+ </ChipTabsContent>
211
+ </ChipTabsCarousel>
212
+ </ChipTabsRoot>
213
+ */
214
+
215
+ const createChipTabsHandler = (_ctx: ComponentHandlerDeps) => {
216
+ const triggerHandler = createChipTabsTriggerHandler(_ctx);
217
+
218
+ return defineComponentHandler<TabsChipWrapperProperties>(
219
+ CHIP_TABS_WRAPPER_KEY,
220
+ (node, traverse) => {
221
+ const props = node.componentProperties;
222
+
223
+ const nodes = findAllInstances<ChipTabsTriggerProperties>({ node, key: CHIP_TRIGGER_KEY });
224
+
225
+ const triggers = nodes.map((node) => {
226
+ // this is redundant; can this be better?
227
+ const [chip] = findAllInstances<ChipProperties>({ node, key: metadata.chip.key });
228
+ if (!chip) throw new Error("Chip not found in ChipTabsTrigger");
229
+
230
+ return {
231
+ elementNode: triggerHandler.transform(node, traverse),
232
+ value: chip.componentProperties["Label#7185:0"].value,
233
+ };
234
+ });
235
+
236
+ const selectedTrigger = nodes.find(
237
+ (node) => node.componentProperties.State.value === "Selected",
238
+ );
239
+ const [selectedChip] = selectedTrigger
240
+ ? findAllInstances<ChipProperties>({ node: selectedTrigger, key: metadata.chip.key })
241
+ : [undefined];
242
+ if (!selectedChip) throw new Error("Chip not found in ChipTabsTrigger");
243
+
244
+ const defaultValue = selectedChip.componentProperties["Label#7185:0"].value;
245
+
246
+ const variant = match(props.Variant.value)
247
+ .with("Outline", () => "neutralOutline")
248
+ .with("Solid", () => "neutralSolid")
249
+ .exhaustive();
250
+
251
+ const rootProps = {
252
+ size: handleSizeProp(props.Size.value),
253
+ variant,
254
+ defaultValue,
255
+ };
256
+
257
+ const tabsCarousel = createChipTabsLocalSnippetElement(
258
+ "ChipTabsCarousel",
259
+ { swipeable: false },
260
+ triggers.map(({ value }) =>
261
+ createChipTabsLocalSnippetElement("ChipTabsContent", { value }, value),
262
+ ),
263
+ );
264
+
265
+ const tabsList = createChipTabsLocalSnippetElement(
266
+ "ChipTabsList",
267
+ undefined,
268
+ triggers.map(({ elementNode }) => elementNode),
269
+ );
270
+
271
+ return createChipTabsLocalSnippetElement("ChipTabsRoot", rootProps, [tabsList, tabsCarousel]);
272
+ },
273
+ );
274
+ };
275
+
276
+ const CHIP_TRIGGER_KEY = "95bf31a329f9e8bba0d9aa2299d1552f1d388148";
277
+
278
+ const createChipTabsTriggerHandler = (_ctx: ComponentHandlerDeps) =>
279
+ defineComponentHandler<ChipTabsTriggerProperties>(CHIP_TRIGGER_KEY, (node) => {
280
+ const [chip] = findAllInstances<ChipProperties>({ node, key: metadata.chip.key });
281
+ if (!chip) throw new Error("Chip not found in ChipTabsTrigger");
282
+
283
+ const props = node.componentProperties;
284
+ const chipProps = chip.componentProperties;
285
+
286
+ const commonProps = {
287
+ value: chipProps["Label#7185:0"].value,
288
+ ...(chipProps.State.value === "Disabled" && {
289
+ disabled: true,
290
+ }),
291
+ ...(props["Has Notification"].value === "True" && {
292
+ notification: true,
293
+ }),
294
+ };
13
295
 
14
- // TODO: Implement the tabs handler
296
+ return createChipTabsLocalSnippetElement("ChipTabsTrigger", commonProps);
297
+ });
@@ -14,6 +14,7 @@ import { createBadgeHandler } from "./handlers/badge";
14
14
  import { createBottomSheetHandler } from "./handlers/bottom-sheet";
15
15
  import { createCalloutHandler } from "./handlers/callout";
16
16
  import { createCheckboxHandler } from "./handlers/checkbox";
17
+ import { createCheckmarkHandler } from "@/codegen/targets/react/component/handlers/checkmark";
17
18
  import { createChipHandler } from "./handlers/chip";
18
19
  import { createContextualFloatingButtonHandler } from "./handlers/contextual-floating-button";
19
20
  import { createDividerHandler } from "./handlers/divider";
@@ -21,20 +22,24 @@ import { createErrorStateHandler } from "./handlers/error-state";
21
22
  import { createFloatingActionButtonHandler } from "./handlers/floating-action-button";
22
23
  import { createHelpBubbleHandler } from "./handlers/help-bubble";
23
24
  import { createIdentityPlaceholderHandler } from "./handlers/identity-placeholder";
24
- import { createPageBannerHandler } from "./handlers/page-banner";
25
25
  import { createMannerTempBadgeHandler } from "./handlers/manner-temp-badge";
26
26
  import { createMannerTempHandler } from "./handlers/manner-temp";
27
27
  import { createMenuSheetHandler } from "./handlers/menu-sheet";
28
28
  import { createMultilineTextFieldHandler } from "./handlers/multiline-text-field";
29
+ import { createPageBannerHandler } from "./handlers/page-banner";
29
30
  import { createProgressCircleHandler } from "./handlers/progress-circle";
31
+ import { createRadioMarkHandler } from "@/codegen/targets/react/component/handlers/radio-mark";
32
+ import { createRadioGroupItemHandler } from "@/codegen/targets/react/component/handlers/radio-group";
30
33
  import { createReactionButtonHandler } from "./handlers/reaction-button";
31
34
  import { createSegmentedControlHandler } from "./handlers/segmented-control";
32
35
  import { createSelectBoxGroupHandler, createSelectBoxHandler } from "./handlers/select-box";
33
36
  import { createSkeletonHandler } from "./handlers/skeleton";
34
37
  import { createSnackbarHandler } from "./handlers/snackbar";
35
38
  import { createSwitchHandler } from "./handlers/switch";
39
+ import { createTabsHandler } from "@/codegen/targets/react/component/handlers/tabs";
36
40
  import { createTextFieldHandler } from "./handlers/text-field";
37
41
  import { createToggleButtonHandler } from "./handlers/toggle-button";
42
+ import { createListItemHandler } from "@/codegen/targets/react/component/handlers/list-item";
38
43
 
39
44
  export type { ComponentHandlerDeps };
40
45
  export type UnboundComponentHandler<T extends NormalizedInstanceNode["componentProperties"]> = (
@@ -59,6 +64,7 @@ export const unboundSeedComponentHandlers: Array<UnboundComponentHandler<any>> =
59
64
  createBottomSheetHandler,
60
65
  createCalloutHandler,
61
66
  createCheckboxHandler,
67
+ createCheckmarkHandler,
62
68
  createChipHandler,
63
69
  createContextualFloatingButtonHandler,
64
70
  createDividerHandler,
@@ -66,12 +72,15 @@ export const unboundSeedComponentHandlers: Array<UnboundComponentHandler<any>> =
66
72
  createFloatingActionButtonHandler,
67
73
  createHelpBubbleHandler,
68
74
  createIdentityPlaceholderHandler,
69
- createPageBannerHandler,
75
+ createListItemHandler,
70
76
  createMannerTempBadgeHandler,
71
77
  createMannerTempHandler,
72
78
  createMenuSheetHandler,
73
79
  createMultilineTextFieldHandler,
80
+ createPageBannerHandler,
74
81
  createProgressCircleHandler,
82
+ createRadioGroupItemHandler,
83
+ createRadioMarkHandler,
75
84
  createReactionButtonHandler,
76
85
  createSegmentedControlHandler,
77
86
  createSelectBoxGroupHandler,
@@ -79,6 +88,7 @@ export const unboundSeedComponentHandlers: Array<UnboundComponentHandler<any>> =
79
88
  createSkeletonHandler,
80
89
  createSnackbarHandler,
81
90
  createSwitchHandler,
91
+ createTabsHandler,
82
92
  createTextFieldHandler,
83
93
  createToggleButtonHandler,
84
94
  ];
@@ -12,6 +12,13 @@ export declare const metadata: {
12
12
  "Large"
13
13
  ]
14
14
  },
15
+ "Tone": {
16
+ "type": "VARIANT",
17
+ "variantOptions": [
18
+ "🚫[Deprecated]Brand",
19
+ "Neutral"
20
+ ]
21
+ },
15
22
  "Shape": {
16
23
  "type": "VARIANT",
17
24
  "variantOptions": [
@@ -22,8 +29,8 @@ export declare const metadata: {
22
29
  "Weight": {
23
30
  "type": "VARIANT",
24
31
  "variantOptions": [
25
- "Default",
26
- "Stronger"
32
+ "Bold",
33
+ "Regular"
27
34
  ]
28
35
  },
29
36
  "Selected": {
@@ -12,6 +12,13 @@ export const metadata = {
12
12
  "Large"
13
13
  ]
14
14
  },
15
+ "Tone": {
16
+ "type": "VARIANT",
17
+ "variantOptions": [
18
+ "🚫[Deprecated]Brand",
19
+ "Neutral"
20
+ ]
21
+ },
15
22
  "Shape": {
16
23
  "type": "VARIANT",
17
24
  "variantOptions": [
@@ -22,8 +29,8 @@ export const metadata = {
22
29
  "Weight": {
23
30
  "type": "VARIANT",
24
31
  "variantOptions": [
25
- "Default",
26
- "Stronger"
32
+ "Bold",
33
+ "Regular"
27
34
  ]
28
35
  },
29
36
  "Selected": {
@@ -2,18 +2,25 @@ export declare const metadata: {
2
2
  "name": "🟢 Checkmark",
3
3
  "key": "fae60fb392f55bde60de1dbccb2f453320068805",
4
4
  "componentPropertyDefinitions": {
5
- "Shape": {
5
+ "Size": {
6
6
  "type": "VARIANT",
7
7
  "variantOptions": [
8
- "Square",
9
- "Ghost"
8
+ "Medium",
9
+ "Large"
10
10
  ]
11
11
  },
12
- "Size": {
12
+ "Tone": {
13
13
  "type": "VARIANT",
14
14
  "variantOptions": [
15
- "Medium",
16
- "Large"
15
+ "🚫[Deprecated]Brand",
16
+ "Neutral"
17
+ ]
18
+ },
19
+ "Shape": {
20
+ "type": "VARIANT",
21
+ "variantOptions": [
22
+ "Square",
23
+ "Ghost"
17
24
  ]
18
25
  },
19
26
  "Selected": {
@@ -2,18 +2,25 @@ export const metadata = {
2
2
  "name": "🟢 Checkmark",
3
3
  "key": "fae60fb392f55bde60de1dbccb2f453320068805",
4
4
  "componentPropertyDefinitions": {
5
- "Shape": {
5
+ "Size": {
6
6
  "type": "VARIANT",
7
7
  "variantOptions": [
8
- "Square",
9
- "Ghost"
8
+ "Medium",
9
+ "Large"
10
10
  ]
11
11
  },
12
- "Size": {
12
+ "Tone": {
13
13
  "type": "VARIANT",
14
14
  "variantOptions": [
15
- "Medium",
16
- "Large"
15
+ "🚫[Deprecated]Brand",
16
+ "Neutral"
17
+ ]
18
+ },
19
+ "Shape": {
20
+ "type": "VARIANT",
21
+ "variantOptions": [
22
+ "Square",
23
+ "Ghost"
17
24
  ]
18
25
  },
19
26
  "Selected": {
@@ -8,8 +8,8 @@ export declare const metadata: {
8
8
  "Tone": {
9
9
  "type": "VARIANT",
10
10
  "variantOptions": [
11
- "Neutral",
12
- "Neutral Muted"
11
+ "Neutral Muted",
12
+ "Neutral Subtle"
13
13
  ]
14
14
  },
15
15
  "Orientation": {
@@ -8,8 +8,8 @@ export const metadata = {
8
8
  "Tone": {
9
9
  "type": "VARIANT",
10
10
  "variantOptions": [
11
- "Neutral",
12
- "Neutral Muted"
11
+ "Neutral Muted",
12
+ "Neutral Subtle"
13
13
  ]
14
14
  },
15
15
  "Orientation": {
@@ -2,6 +2,9 @@ export declare const metadata: {
2
2
  "name": "🟢 Help Bubble",
3
3
  "key": "804b327c091278a40d5891939eaed90bb2889659",
4
4
  "componentPropertyDefinitions": {
5
+ "Show Close Button#40538:0": {
6
+ "type": "BOOLEAN"
7
+ },
5
8
  "Show Description#62499:0": {
6
9
  "type": "BOOLEAN"
7
10
  },
@@ -2,6 +2,9 @@ export const metadata = {
2
2
  "name": "🟢 Help Bubble",
3
3
  "key": "804b327c091278a40d5891939eaed90bb2889659",
4
4
  "componentPropertyDefinitions": {
5
+ "Show Close Button#40538:0": {
6
+ "type": "BOOLEAN"
7
+ },
5
8
  "Show Description#62499:0": {
6
9
  "type": "BOOLEAN"
7
10
  },
@@ -21,6 +21,8 @@ export { metadata as contextualFloatingButton } from "./contextual-floating-butt
21
21
  export { metadata as divider } from "./divider";
22
22
  export { metadata as floatingActionButton } from "./floating-action-button";
23
23
  export { metadata as helpBubble } from "./help-bubble";
24
+ export { metadata as listHeader } from "./list-header";
25
+ export { metadata as listItem } from "./list-item";
24
26
  export { metadata as mainTabNavigationGlobal } from "./main-tab-navigation-global";
25
27
  export { metadata as mainTabNavigationKr } from "./main-tab-navigation-kr";
26
28
  export { metadata as mannerTemp } from "./manner-temp";
@@ -21,6 +21,8 @@ export { metadata as contextualFloatingButton } from "./contextual-floating-butt
21
21
  export { metadata as divider } from "./divider.mjs";
22
22
  export { metadata as floatingActionButton } from "./floating-action-button.mjs";
23
23
  export { metadata as helpBubble } from "./help-bubble.mjs";
24
+ export { metadata as listHeader } from "./list-header.mjs";
25
+ export { metadata as listItem } from "./list-item.mjs";
24
26
  export { metadata as mainTabNavigationGlobal } from "./main-tab-navigation-global.mjs";
25
27
  export { metadata as mainTabNavigationKr } from "./main-tab-navigation-kr.mjs";
26
28
  export { metadata as mannerTemp } from "./manner-temp.mjs";
@@ -0,0 +1,24 @@
1
+ export declare const metadata: {
2
+ "name": "🟢 List Header",
3
+ "key": "609f93ed0608ef0a6d9a351e47595ad631bae0fa",
4
+ "componentPropertyDefinitions": {
5
+ "Title#28588:0": {
6
+ "type": "TEXT"
7
+ },
8
+ "Suffix": {
9
+ "type": "VARIANT",
10
+ "variantOptions": [
11
+ "None",
12
+ "Button",
13
+ "Custom"
14
+ ]
15
+ },
16
+ "Title Weight": {
17
+ "type": "VARIANT",
18
+ "variantOptions": [
19
+ "Medium",
20
+ "Bold"
21
+ ]
22
+ }
23
+ }
24
+ };
@@ -0,0 +1,24 @@
1
+ export const metadata = {
2
+ "name": "🟢 List Header",
3
+ "key": "609f93ed0608ef0a6d9a351e47595ad631bae0fa",
4
+ "componentPropertyDefinitions": {
5
+ "Title#28588:0": {
6
+ "type": "TEXT"
7
+ },
8
+ "Suffix": {
9
+ "type": "VARIANT",
10
+ "variantOptions": [
11
+ "None",
12
+ "Button",
13
+ "Custom"
14
+ ]
15
+ },
16
+ "Title Weight": {
17
+ "type": "VARIANT",
18
+ "variantOptions": [
19
+ "Medium",
20
+ "Bold"
21
+ ]
22
+ }
23
+ }
24
+ };