@seed-design/figma 0.0.2
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/lib/index.cjs +13918 -0
- package/lib/index.d.ts +63 -0
- package/lib/index.js +13916 -0
- package/package.json +44 -0
- package/src/color.ts +78 -0
- package/src/component/index.ts +1688 -0
- package/src/component/properties.ts +20 -0
- package/src/component/type-helper.ts +29 -0
- package/src/component/type.ts +318 -0
- package/src/data/__generated__/component-sets/action-button.d.ts +59 -0
- package/src/data/__generated__/component-sets/action-button.mjs +59 -0
- package/src/data/__generated__/component-sets/action-chip.d.ts +57 -0
- package/src/data/__generated__/component-sets/action-chip.mjs +57 -0
- package/src/data/__generated__/component-sets/action-sheet.d.ts +40 -0
- package/src/data/__generated__/component-sets/action-sheet.mjs +40 -0
- package/src/data/__generated__/component-sets/avatar-stack.d.ts +32 -0
- package/src/data/__generated__/component-sets/avatar-stack.mjs +32 -0
- package/src/data/__generated__/component-sets/avatar.d.ts +25 -0
- package/src/data/__generated__/component-sets/avatar.mjs +25 -0
- package/src/data/__generated__/component-sets/badge.d.ts +41 -0
- package/src/data/__generated__/component-sets/badge.mjs +41 -0
- package/src/data/__generated__/component-sets/bottom-navigation-global.d.ts +20 -0
- package/src/data/__generated__/component-sets/bottom-navigation-global.mjs +20 -0
- package/src/data/__generated__/component-sets/bottom-navigation-kr.d.ts +13 -0
- package/src/data/__generated__/component-sets/bottom-navigation-kr.mjs +13 -0
- package/src/data/__generated__/component-sets/bottom-sheet.d.ts +14 -0
- package/src/data/__generated__/component-sets/bottom-sheet.mjs +14 -0
- package/src/data/__generated__/component-sets/callout.d.ts +57 -0
- package/src/data/__generated__/component-sets/callout.mjs +57 -0
- package/src/data/__generated__/component-sets/checkbox.d.ts +44 -0
- package/src/data/__generated__/component-sets/checkbox.mjs +44 -0
- package/src/data/__generated__/component-sets/chip-tablist.d.ts +24 -0
- package/src/data/__generated__/component-sets/chip-tablist.mjs +24 -0
- package/src/data/__generated__/component-sets/control-chip.d.ts +60 -0
- package/src/data/__generated__/component-sets/control-chip.mjs +60 -0
- package/src/data/__generated__/component-sets/divider.d.ts +13 -0
- package/src/data/__generated__/component-sets/divider.mjs +13 -0
- package/src/data/__generated__/component-sets/error-state.d.ts +32 -0
- package/src/data/__generated__/component-sets/error-state.mjs +32 -0
- package/src/data/__generated__/component-sets/extended-action-sheet.d.ts +32 -0
- package/src/data/__generated__/component-sets/extended-action-sheet.mjs +32 -0
- package/src/data/__generated__/component-sets/extended-floating-action-button.d.ts +34 -0
- package/src/data/__generated__/component-sets/extended-floating-action-button.mjs +34 -0
- package/src/data/__generated__/component-sets/floating-action-button.d.ts +17 -0
- package/src/data/__generated__/component-sets/floating-action-button.mjs +17 -0
- package/src/data/__generated__/component-sets/help-bubble.d.ts +39 -0
- package/src/data/__generated__/component-sets/help-bubble.mjs +39 -0
- package/src/data/__generated__/component-sets/identity-placeholder.d.ts +13 -0
- package/src/data/__generated__/component-sets/identity-placeholder.mjs +13 -0
- package/src/data/__generated__/component-sets/index.d.ts +47 -0
- package/src/data/__generated__/component-sets/index.mjs +47 -0
- package/src/data/__generated__/component-sets/inline-banner.d.ts +40 -0
- package/src/data/__generated__/component-sets/inline-banner.mjs +40 -0
- package/src/data/__generated__/component-sets/main-tab-navigation-global.d.ts +26 -0
- package/src/data/__generated__/component-sets/main-tab-navigation-global.mjs +26 -0
- package/src/data/__generated__/component-sets/main-tab-navigation-kr.d.ts +23 -0
- package/src/data/__generated__/component-sets/main-tab-navigation-kr.mjs +23 -0
- package/src/data/__generated__/component-sets/manner-temp-badge.d.ts +17 -0
- package/src/data/__generated__/component-sets/manner-temp-badge.mjs +17 -0
- package/src/data/__generated__/component-sets/manner-temp-bar.d.ts +23 -0
- package/src/data/__generated__/component-sets/manner-temp-bar.mjs +23 -0
- package/src/data/__generated__/component-sets/manner-temp.d.ts +17 -0
- package/src/data/__generated__/component-sets/manner-temp.mjs +17 -0
- package/src/data/__generated__/component-sets/multiline-text-field.d.ts +68 -0
- package/src/data/__generated__/component-sets/multiline-text-field.mjs +68 -0
- package/src/data/__generated__/component-sets/progress-circle.d.ts +31 -0
- package/src/data/__generated__/component-sets/progress-circle.mjs +31 -0
- package/src/data/__generated__/component-sets/radio.d.ts +27 -0
- package/src/data/__generated__/component-sets/radio.mjs +27 -0
- package/src/data/__generated__/component-sets/range-slider.d.ts +31 -0
- package/src/data/__generated__/component-sets/range-slider.mjs +31 -0
- package/src/data/__generated__/component-sets/reaction-button.d.ts +39 -0
- package/src/data/__generated__/component-sets/reaction-button.mjs +39 -0
- package/src/data/__generated__/component-sets/segmented-control.d.ts +23 -0
- package/src/data/__generated__/component-sets/segmented-control.mjs +23 -0
- package/src/data/__generated__/component-sets/select-box.d.ts +31 -0
- package/src/data/__generated__/component-sets/select-box.mjs +31 -0
- package/src/data/__generated__/component-sets/skeleton.d.ts +15 -0
- package/src/data/__generated__/component-sets/skeleton.mjs +15 -0
- package/src/data/__generated__/component-sets/slider.d.ts +31 -0
- package/src/data/__generated__/component-sets/slider.mjs +31 -0
- package/src/data/__generated__/component-sets/snackbar.d.ts +23 -0
- package/src/data/__generated__/component-sets/snackbar.mjs +23 -0
- package/src/data/__generated__/component-sets/standard-navigation.d.ts +23 -0
- package/src/data/__generated__/component-sets/standard-navigation.mjs +23 -0
- package/src/data/__generated__/component-sets/switch.d.ts +25 -0
- package/src/data/__generated__/component-sets/switch.mjs +25 -0
- package/src/data/__generated__/component-sets/tablist.d.ts +29 -0
- package/src/data/__generated__/component-sets/tablist.mjs +29 -0
- package/src/data/__generated__/component-sets/template-bottom-fixed-bar.d.ts +42 -0
- package/src/data/__generated__/component-sets/template-bottom-fixed-bar.mjs +42 -0
- package/src/data/__generated__/component-sets/template-button-group.d.ts +51 -0
- package/src/data/__generated__/component-sets/template-button-group.mjs +51 -0
- package/src/data/__generated__/component-sets/template-chip-group.d.ts +26 -0
- package/src/data/__generated__/component-sets/template-chip-group.mjs +26 -0
- package/src/data/__generated__/component-sets/template-select-box-group.d.ts +24 -0
- package/src/data/__generated__/component-sets/template-select-box-group.mjs +24 -0
- package/src/data/__generated__/component-sets/template-top-navigation.d.ts +25 -0
- package/src/data/__generated__/component-sets/template-top-navigation.mjs +25 -0
- package/src/data/__generated__/component-sets/text-button.d.ts +45 -0
- package/src/data/__generated__/component-sets/text-button.mjs +45 -0
- package/src/data/__generated__/component-sets/text-field.d.ts +100 -0
- package/src/data/__generated__/component-sets/text-field.mjs +100 -0
- package/src/data/__generated__/component-sets/toggle-button.d.ts +50 -0
- package/src/data/__generated__/component-sets/toggle-button.mjs +50 -0
- package/src/data/icons.ts +2774 -0
- package/src/data/styles.ts +142 -0
- package/src/data/variables.ts +7772 -0
- package/src/generate-code.ts +213 -0
- package/src/icon.ts +46 -0
- package/src/index.ts +3 -0
- package/src/jsx.ts +104 -0
- package/src/layout.ts +289 -0
- package/src/node-util.ts +49 -0
- package/src/normalizer/from-plugin.ts +345 -0
- package/src/normalizer/from-rest.ts +178 -0
- package/src/normalizer/types.ts +94 -0
- package/src/sizing.ts +58 -0
- package/src/text.ts +20 -0
- package/src/util.ts +17 -0
- package/src/variable.ts +66 -0
package/package.json
ADDED
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@seed-design/figma",
|
|
3
|
+
"version": "0.0.2",
|
|
4
|
+
"repository": {
|
|
5
|
+
"type": "git",
|
|
6
|
+
"url": "git+https://github.com/daangn/seed-design.git",
|
|
7
|
+
"directory": "packages/figma"
|
|
8
|
+
},
|
|
9
|
+
"author": "Asher <asher@daangn.com>",
|
|
10
|
+
"license": "MIT",
|
|
11
|
+
"type": "module",
|
|
12
|
+
"exports": {
|
|
13
|
+
".": {
|
|
14
|
+
"types": "./lib/index.d.ts",
|
|
15
|
+
"import": "./lib/index.js",
|
|
16
|
+
"require": "./lib/index.cjs"
|
|
17
|
+
}
|
|
18
|
+
},
|
|
19
|
+
"main": "./lib/index.cjs",
|
|
20
|
+
"sideEffects": false,
|
|
21
|
+
"files": [
|
|
22
|
+
"lib",
|
|
23
|
+
"src"
|
|
24
|
+
],
|
|
25
|
+
"scripts": {
|
|
26
|
+
"clean": "rm -rf lib",
|
|
27
|
+
"build": "bunchee",
|
|
28
|
+
"lint:publish": "bun publint"
|
|
29
|
+
},
|
|
30
|
+
"dependencies": {
|
|
31
|
+
"@create-figma-plugin/utilities": "^3.0.2",
|
|
32
|
+
"@seed-design/css": "0.0.10",
|
|
33
|
+
"change-case": "^5.2.0",
|
|
34
|
+
"ts-pattern": "^5.2.0"
|
|
35
|
+
},
|
|
36
|
+
"devDependencies": {
|
|
37
|
+
"@figma/plugin-typings": "^1.108.0",
|
|
38
|
+
"@seed-design/figma-extractor": "^0.0.3",
|
|
39
|
+
"typescript": "^5.4.5"
|
|
40
|
+
},
|
|
41
|
+
"publishConfig": {
|
|
42
|
+
"access": "public"
|
|
43
|
+
}
|
|
44
|
+
}
|
package/src/color.ts
ADDED
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
import type { NormalizedFrameNode, NormalizedTextNode } from "./normalizer/types";
|
|
2
|
+
import { getColorVariableName } from "./variable";
|
|
3
|
+
|
|
4
|
+
export function createBackgroundProps(
|
|
5
|
+
node: Pick<NormalizedFrameNode, "fills" | "boundVariables">,
|
|
6
|
+
): Partial<Record<"background", string | undefined>> {
|
|
7
|
+
const fills = node.fills;
|
|
8
|
+
if (fills.length === 0) {
|
|
9
|
+
return {};
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
const fill = fills[0];
|
|
13
|
+
if (!fill || ("visible" in fill && !fill.visible) || fill.type !== "SOLID") {
|
|
14
|
+
return {};
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
if (node.boundVariables?.fills?.length === 1) {
|
|
18
|
+
return {
|
|
19
|
+
background: getColorVariableName(node.boundVariables.fills[0]!.id),
|
|
20
|
+
};
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
const color = fill.color;
|
|
24
|
+
return {
|
|
25
|
+
background: `rgba(${color.r * 255}, ${color.g * 255}, ${color.b * 255}, ${fill.opacity})`,
|
|
26
|
+
};
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
export function createColorProps(
|
|
30
|
+
node: Pick<NormalizedTextNode, "fills" | "boundVariables">,
|
|
31
|
+
): Partial<Record<"color", string | undefined>> {
|
|
32
|
+
const fills = node.fills;
|
|
33
|
+
if (fills.length === 0) {
|
|
34
|
+
return {};
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
const fill = fills[0];
|
|
38
|
+
if (!fill || ("visible" in fill && !fill.visible) || fill.type !== "SOLID") {
|
|
39
|
+
return {};
|
|
40
|
+
}
|
|
41
|
+
if (node.boundVariables?.fills?.length === 1) {
|
|
42
|
+
return {
|
|
43
|
+
color: getColorVariableName(node.boundVariables.fills[0]!.id),
|
|
44
|
+
};
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
const color = fill.color;
|
|
48
|
+
return {
|
|
49
|
+
color: `rgba(${color.r * 255}, ${color.g * 255}, ${color.b * 255}, ${fill.opacity})`,
|
|
50
|
+
};
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
export function createBorderProps(
|
|
54
|
+
node: Pick<NormalizedFrameNode, "strokeWeight" | "strokes" | "boundVariables">,
|
|
55
|
+
): Partial<Record<"borderWidth" | "borderColor", string | number | undefined>> {
|
|
56
|
+
const strokes = node.strokes;
|
|
57
|
+
if (strokes === undefined || strokes.length === 0) {
|
|
58
|
+
return {};
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
const stroke = strokes[0];
|
|
62
|
+
if (!stroke || ("visible" in stroke && !stroke.visible) || stroke.type !== "SOLID") {
|
|
63
|
+
return {};
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
if (node.boundVariables?.strokes?.length === 1) {
|
|
67
|
+
return {
|
|
68
|
+
borderWidth: node.strokeWeight as number,
|
|
69
|
+
borderColor: getColorVariableName(node.boundVariables.strokes[0]!.id),
|
|
70
|
+
};
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
const color = stroke.color;
|
|
74
|
+
return {
|
|
75
|
+
borderWidth: node.strokeWeight as number,
|
|
76
|
+
borderColor: `rgba(${color.r * 255}, ${color.g * 255}, ${color.b * 255}, ${stroke.opacity})`,
|
|
77
|
+
};
|
|
78
|
+
}
|