@guideveloper/design-assets 0.1.1

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 ADDED
@@ -0,0 +1,38 @@
1
+ # Design Asset Library
2
+
3
+ Source of truth for icons, illustrations, and animations. Generates React components, Storybook, metadata exports, and publishes as `@guideveloper/design-assets`.
4
+
5
+ ## Structure
6
+ - `assets/` raw assets + metadata
7
+ - `scripts/generateAssets.ts` scans assets and builds components, metadata, and stories
8
+ - `src/components` generated React components
9
+ - `src/metadata` generated metadata arrays
10
+ - `.storybook` Storybook config
11
+
12
+ ## Commands
13
+ - `npm run generate-assets` – generate components/stories/metadata from `assets`
14
+ - `npm run storybook` – run Storybook locally
15
+ - `npm run build-storybook` – build static Storybook
16
+ - `npm run build` – bundle library via tsup (ESM + CJS)
17
+
18
+ ## Workflow
19
+ 1. Add/update files under `assets/icons|illustrations|animations` (with matching `.json` metadata files).
20
+ 2. Run `npm install` then `npm run generate-assets`.
21
+ 3. Open Storybook (`npm run storybook`) to review.
22
+ 4. When you want a release, manually trigger the workflow (`.github/workflows/codegen-and-publish.yml`) which runs codegen, bumps the version, builds Storybook, builds the package, publishes Storybook to `gh-pages`, publishes to npm, and pushes the tagged release back to `master`.
23
+
24
+ ## Asset metadata format
25
+ - **Icon**: `assets/icons/name.svg` + `assets/icons/name.json` `{ name, tags?, description? }`
26
+ - **Illustration**: `assets/illustrations/name.svg|png` + `assets/illustrations/name.json` `{ name, category?, tags?, description? }`
27
+ - **Animation**: `assets/animations/name.json` (Lottie) + `assets/animations/name.meta.json` `{ name, frameRate?, loop?, tags?, description? }`
28
+
29
+ ## Publishing
30
+ Set secrets:
31
+ - `NPM_TOKEN` for npm publish
32
+ - Use default `GITHUB_TOKEN` for Storybook deploy to `gh-pages`
33
+
34
+ Package name: `@guideveloper/design-assets`
35
+
36
+ ### Manual release button
37
+ - GitHub Actions has a built-in “Run workflow” button for `Manual Codegen, Storybook, and Publish` (workflow dispatch only; no auto-runs on `master`).
38
+ - A lightweight front-end trigger lives at `scripts/run-manual-build.html` with a “Run workflow” button. Open the file in a browser, provide a GitHub token with `workflow` scope (and `repo`/`public_repo` as needed), choose the bump type, and optionally publish Storybook. It dispatches the workflow on `master`.
@@ -0,0 +1,61 @@
1
+ import * as react_jsx_runtime from 'react/jsx-runtime';
2
+ import React, { SVGProps } from 'react';
3
+ import Lottie from 'lottie-react';
4
+
5
+ declare const IconCheeseIcon2: (props: SVGProps<SVGSVGElement>) => react_jsx_runtime.JSX.Element;
6
+
7
+ declare const IconCheeseIcon: (props: SVGProps<SVGSVGElement>) => react_jsx_runtime.JSX.Element;
8
+
9
+ declare const IconSearch: (props: SVGProps<SVGSVGElement>) => react_jsx_runtime.JSX.Element;
10
+
11
+ declare const IllustrationRoosterHead: (props: SVGProps<SVGSVGElement>) => react_jsx_runtime.JSX.Element;
12
+
13
+ declare const IllustrationSunrise: (props: SVGProps<SVGSVGElement>) => react_jsx_runtime.JSX.Element;
14
+
15
+ declare const IllustrationSvgIcon: React.FC<React.ImgHTMLAttributes<HTMLImageElement>>;
16
+
17
+ declare const AnimationBounce: React.FC<{
18
+ loop?: boolean;
19
+ autoplay?: boolean;
20
+ className?: string;
21
+ } & Partial<React.ComponentProps<typeof Lottie>>>;
22
+
23
+ declare const icons: readonly [{
24
+ readonly name: "cheese-icon-2";
25
+ readonly tags: readonly ["food", "cheese", "icon"];
26
+ readonly description: "";
27
+ }, {
28
+ readonly name: "cheese-icon";
29
+ readonly tags: readonly ["food", "cheese", "icons"];
30
+ readonly description: "";
31
+ }, {
32
+ readonly name: "search";
33
+ readonly tags: readonly ["find", "magnify"];
34
+ readonly description: "Search icon";
35
+ }];
36
+ declare const illustrations: readonly [{
37
+ readonly name: "rooster-head";
38
+ readonly category: "Brand";
39
+ readonly tags: readonly ["rooster", "rooster head", "brand mark"];
40
+ }, {
41
+ readonly name: "sunrise";
42
+ readonly category: "nature";
43
+ readonly tags: readonly ["morning", "sun"];
44
+ readonly description: "Sunrise illustration";
45
+ }, {
46
+ readonly name: "svg-icon";
47
+ readonly category: "Icons";
48
+ readonly tags: readonly ["icon", "black", "line icon"];
49
+ }];
50
+ declare const animations: readonly [{
51
+ readonly name: "bounce";
52
+ readonly frameRate: 30;
53
+ readonly loop: true;
54
+ readonly tags: readonly ["motion", "loop"];
55
+ readonly description: "Simple bouncing ball animation";
56
+ }];
57
+ type IconMetadata = typeof icons[number];
58
+ type IllustrationMetadata = typeof illustrations[number];
59
+ type AnimationMetadata = typeof animations[number];
60
+
61
+ export { AnimationBounce, AnimationMetadata, IconCheeseIcon, IconCheeseIcon2, IconMetadata, IconSearch, IllustrationMetadata, IllustrationRoosterHead, IllustrationSunrise, IllustrationSvgIcon, animations, icons, illustrations };
@@ -0,0 +1,61 @@
1
+ import * as react_jsx_runtime from 'react/jsx-runtime';
2
+ import React, { SVGProps } from 'react';
3
+ import Lottie from 'lottie-react';
4
+
5
+ declare const IconCheeseIcon2: (props: SVGProps<SVGSVGElement>) => react_jsx_runtime.JSX.Element;
6
+
7
+ declare const IconCheeseIcon: (props: SVGProps<SVGSVGElement>) => react_jsx_runtime.JSX.Element;
8
+
9
+ declare const IconSearch: (props: SVGProps<SVGSVGElement>) => react_jsx_runtime.JSX.Element;
10
+
11
+ declare const IllustrationRoosterHead: (props: SVGProps<SVGSVGElement>) => react_jsx_runtime.JSX.Element;
12
+
13
+ declare const IllustrationSunrise: (props: SVGProps<SVGSVGElement>) => react_jsx_runtime.JSX.Element;
14
+
15
+ declare const IllustrationSvgIcon: React.FC<React.ImgHTMLAttributes<HTMLImageElement>>;
16
+
17
+ declare const AnimationBounce: React.FC<{
18
+ loop?: boolean;
19
+ autoplay?: boolean;
20
+ className?: string;
21
+ } & Partial<React.ComponentProps<typeof Lottie>>>;
22
+
23
+ declare const icons: readonly [{
24
+ readonly name: "cheese-icon-2";
25
+ readonly tags: readonly ["food", "cheese", "icon"];
26
+ readonly description: "";
27
+ }, {
28
+ readonly name: "cheese-icon";
29
+ readonly tags: readonly ["food", "cheese", "icons"];
30
+ readonly description: "";
31
+ }, {
32
+ readonly name: "search";
33
+ readonly tags: readonly ["find", "magnify"];
34
+ readonly description: "Search icon";
35
+ }];
36
+ declare const illustrations: readonly [{
37
+ readonly name: "rooster-head";
38
+ readonly category: "Brand";
39
+ readonly tags: readonly ["rooster", "rooster head", "brand mark"];
40
+ }, {
41
+ readonly name: "sunrise";
42
+ readonly category: "nature";
43
+ readonly tags: readonly ["morning", "sun"];
44
+ readonly description: "Sunrise illustration";
45
+ }, {
46
+ readonly name: "svg-icon";
47
+ readonly category: "Icons";
48
+ readonly tags: readonly ["icon", "black", "line icon"];
49
+ }];
50
+ declare const animations: readonly [{
51
+ readonly name: "bounce";
52
+ readonly frameRate: 30;
53
+ readonly loop: true;
54
+ readonly tags: readonly ["motion", "loop"];
55
+ readonly description: "Simple bouncing ball animation";
56
+ }];
57
+ type IconMetadata = typeof icons[number];
58
+ type IllustrationMetadata = typeof illustrations[number];
59
+ type AnimationMetadata = typeof animations[number];
60
+
61
+ export { AnimationBounce, AnimationMetadata, IconCheeseIcon, IconCheeseIcon2, IconMetadata, IconSearch, IllustrationMetadata, IllustrationRoosterHead, IllustrationSunrise, IllustrationSvgIcon, animations, icons, illustrations };
package/dist/index.js ADDED
@@ -0,0 +1,234 @@
1
+ 'use strict';
2
+
3
+ var jsxRuntime = require('react/jsx-runtime');
4
+ var Lottie = require('lottie-react');
5
+
6
+ function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
7
+
8
+ var Lottie__default = /*#__PURE__*/_interopDefault(Lottie);
9
+
10
+ // src/components/icons/IconCheeseIcon2.tsx
11
+ var IconCheeseIcon2 = (props) => /* @__PURE__ */ jsxRuntime.jsx("svg", { className: "w-6 h-6 text-gray-800 dark:text-white", "aria-hidden": "true", xmlns: "http://www.w3.org/2000/svg", width: "1em", height: "1em", fill: "none", viewBox: "0 0 24 24", role: "img", ...props, children: /* @__PURE__ */ jsxRuntime.jsx("path", { stroke: "currentColor", strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: 2, d: "m4 12 6.4267-4.65924c.6372.89667 1.8922 1.10897 2.7888.4718.8967-.63718 1.3493-1.69135.4681-2.80084C13.6373 4.95345 14.9106 4 15 4c.0894 0 5 1 5 8M4 12h16M4 12v8h16v-8M8 15h.01M12 17h.01M16 15h.01" }) });
12
+ var IconCheeseIcon = (props) => /* @__PURE__ */ jsxRuntime.jsx("svg", { className: "w-6 h-6 text-gray-800 dark:text-white", "aria-hidden": "true", xmlns: "http://www.w3.org/2000/svg", width: "1em", height: "1em", fill: "none", viewBox: "0 0 24 24", role: "img", ...props, children: /* @__PURE__ */ jsxRuntime.jsx("path", { stroke: "currentColor", strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: 2, d: "m4 12 6.4267-4.65924c.6372.89667 1.8922 1.10897 2.7888.4718.8967-.63718 1.3493-1.69135.4681-2.80084C13.6373 4.95345 14.9106 4 15 4c.0894 0 5 1 5 8M4 12h16M4 12v8h16v-8M8 15h.01M12 17h.01M16 15h.01" }) });
13
+ var IconSearch = (props) => /* @__PURE__ */ jsxRuntime.jsxs("svg", { width: "1em", height: "1em", viewBox: "0 0 24 24", fill: "none", xmlns: "http://www.w3.org/2000/svg", role: "img", ...props, children: [
14
+ /* @__PURE__ */ jsxRuntime.jsx("circle", { cx: 11, cy: 11, r: 7, stroke: "#111827", strokeWidth: 2 }),
15
+ /* @__PURE__ */ jsxRuntime.jsx("line", { x1: 16.6569, y1: 16, x2: 21, y2: 20.3431, stroke: "#111827", strokeWidth: 2, strokeLinecap: "round" })
16
+ ] });
17
+ var IllustrationRoosterHead = (props) => /* @__PURE__ */ jsxRuntime.jsxs("svg", { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 867 1124.67", "aria-hidden": "true", ...props, children: [
18
+ /* @__PURE__ */ jsxRuntime.jsx("polygon", { "data-name": "Fill-30", points: "337.77 386.66 124.23 58.15 0 562.59 337.77 386.66", fill: "#fcc42f", fillRule: "evenodd" }),
19
+ /* @__PURE__ */ jsxRuntime.jsx("polygon", { "data-name": "Fill-32", points: "0 562.59 334.51 381.65 379.87 837.6 0 562.59", fill: "#59b7b1", fillRule: "evenodd" }),
20
+ /* @__PURE__ */ jsxRuntime.jsx("polygon", { "data-name": "Fill-34", points: "334.51 381.64 548.64 183.63 730.92 460.06 538.21 725.26 334.51 381.64", fill: "#00a0dd", fillRule: "evenodd" }),
21
+ /* @__PURE__ */ jsxRuntime.jsx("polygon", { "data-name": "Fill-36", points: "334.51 381.64 408.42 1124.67 538.21 725.26 334.51 381.64", fill: "#fcc42f", fillRule: "evenodd" }),
22
+ /* @__PURE__ */ jsxRuntime.jsx("polygon", { "data-name": "Fill-38", points: "548.63 183.32 867 667.57 832.97 387.2 548.63 183.32", fill: "#266093", fillRule: "evenodd" }),
23
+ /* @__PURE__ */ jsxRuntime.jsx("polygon", { "data-name": "Fill-27", points: "200.38 175.32 124.22 58.16 353.72 0 200.38 175.32", fill: "#e54360", fillRule: "evenodd" }),
24
+ /* @__PURE__ */ jsxRuntime.jsx("polygon", { "data-name": "Fill-25", points: "111.52 109.77 6.37 144.63 90.69 194.9 111.52 109.77", fill: "#e1281d", fillRule: "evenodd" })
25
+ ] });
26
+ var IllustrationSunrise = (props) => /* @__PURE__ */ jsxRuntime.jsxs("svg", { width: 320, height: 200, viewBox: "0 0 320 200", fill: "none", xmlns: "http://www.w3.org/2000/svg", ...props, children: [
27
+ /* @__PURE__ */ jsxRuntime.jsx("rect", { width: 320, height: 200, fill: "#E0F2FE" }),
28
+ /* @__PURE__ */ jsxRuntime.jsx("circle", { cx: 160, cy: 120, r: 60, fill: "#FBBF24" }),
29
+ /* @__PURE__ */ jsxRuntime.jsx("rect", { x: 0, y: 140, width: 320, height: 60, fill: "#10B981" })
30
+ ] });
31
+ var IllustrationSvgIcon = (props) => /* @__PURE__ */ jsxRuntime.jsx("img", { src: "", alt: props.alt ?? "svg-icon illustration", ...props });
32
+ var animationData = {
33
+ "v": "5.7.4",
34
+ "fr": 30,
35
+ "ip": 0,
36
+ "op": 30,
37
+ "w": 200,
38
+ "h": 200,
39
+ "nm": "bounce",
40
+ "ddd": 0,
41
+ "assets": [],
42
+ "layers": [
43
+ {
44
+ "ddd": 0,
45
+ "ind": 1,
46
+ "ty": 4,
47
+ "nm": "Circle",
48
+ "sr": 1,
49
+ "ks": {
50
+ "o": {
51
+ "a": 0,
52
+ "k": 100
53
+ },
54
+ "r": {
55
+ "a": 0,
56
+ "k": 0
57
+ },
58
+ "p": {
59
+ "a": 1,
60
+ "k": [
61
+ {
62
+ "i": {
63
+ "x": 0.667,
64
+ "y": 1
65
+ },
66
+ "o": {
67
+ "x": 0.333,
68
+ "y": 0
69
+ },
70
+ "t": 0,
71
+ "s": [
72
+ 100,
73
+ 40,
74
+ 0
75
+ ]
76
+ },
77
+ {
78
+ "t": 30,
79
+ "s": [
80
+ 100,
81
+ 160,
82
+ 0
83
+ ]
84
+ }
85
+ ]
86
+ },
87
+ "a": {
88
+ "a": 0,
89
+ "k": [
90
+ 0,
91
+ 0,
92
+ 0
93
+ ]
94
+ },
95
+ "s": {
96
+ "a": 0,
97
+ "k": [
98
+ 100,
99
+ 100,
100
+ 100
101
+ ]
102
+ }
103
+ },
104
+ "shapes": [
105
+ {
106
+ "ty": "el",
107
+ "p": {
108
+ "a": 0,
109
+ "k": [
110
+ 0,
111
+ 0
112
+ ]
113
+ },
114
+ "s": {
115
+ "a": 0,
116
+ "k": [
117
+ 60,
118
+ 60
119
+ ]
120
+ },
121
+ "nm": "Ellipse Path"
122
+ },
123
+ {
124
+ "ty": "fl",
125
+ "c": {
126
+ "a": 0,
127
+ "k": [
128
+ 0.129,
129
+ 0.588,
130
+ 0.953,
131
+ 1
132
+ ]
133
+ },
134
+ "o": {
135
+ "a": 0,
136
+ "k": 100
137
+ },
138
+ "r": 1,
139
+ "nm": "Fill"
140
+ }
141
+ ],
142
+ "ip": 0,
143
+ "op": 30,
144
+ "st": 0
145
+ }
146
+ ]
147
+ };
148
+ var AnimationBounce = ({ loop = true, autoplay = true, ...rest }) => {
149
+ return /* @__PURE__ */ jsxRuntime.jsx(Lottie__default.default, { animationData, loop, autoplay, ...rest });
150
+ };
151
+
152
+ // src/metadata/index.ts
153
+ var icons = [
154
+ {
155
+ "name": "cheese-icon-2",
156
+ "tags": [
157
+ "food",
158
+ "cheese",
159
+ "icon"
160
+ ],
161
+ "description": ""
162
+ },
163
+ {
164
+ "name": "cheese-icon",
165
+ "tags": [
166
+ "food",
167
+ "cheese",
168
+ "icons"
169
+ ],
170
+ "description": ""
171
+ },
172
+ {
173
+ "name": "search",
174
+ "tags": [
175
+ "find",
176
+ "magnify"
177
+ ],
178
+ "description": "Search icon"
179
+ }
180
+ ];
181
+ var illustrations = [
182
+ {
183
+ "name": "rooster-head",
184
+ "category": "Brand",
185
+ "tags": [
186
+ "rooster",
187
+ "rooster head",
188
+ "brand mark"
189
+ ]
190
+ },
191
+ {
192
+ "name": "sunrise",
193
+ "category": "nature",
194
+ "tags": [
195
+ "morning",
196
+ "sun"
197
+ ],
198
+ "description": "Sunrise illustration"
199
+ },
200
+ {
201
+ "name": "svg-icon",
202
+ "category": "Icons",
203
+ "tags": [
204
+ "icon",
205
+ "black",
206
+ "line icon"
207
+ ]
208
+ }
209
+ ];
210
+ var animations = [
211
+ {
212
+ "name": "bounce",
213
+ "frameRate": 30,
214
+ "loop": true,
215
+ "tags": [
216
+ "motion",
217
+ "loop"
218
+ ],
219
+ "description": "Simple bouncing ball animation"
220
+ }
221
+ ];
222
+
223
+ exports.AnimationBounce = AnimationBounce;
224
+ exports.IconCheeseIcon = IconCheeseIcon;
225
+ exports.IconCheeseIcon2 = IconCheeseIcon2;
226
+ exports.IconSearch = IconSearch;
227
+ exports.IllustrationRoosterHead = IllustrationRoosterHead;
228
+ exports.IllustrationSunrise = IllustrationSunrise;
229
+ exports.IllustrationSvgIcon = IllustrationSvgIcon;
230
+ exports.animations = animations;
231
+ exports.icons = icons;
232
+ exports.illustrations = illustrations;
233
+ //# sourceMappingURL=out.js.map
234
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/components/icons/IconCheeseIcon2.tsx","../src/components/icons/IconCheeseIcon.tsx","../src/components/icons/IconSearch.tsx","../src/components/illustrations/IllustrationRoosterHead.tsx","../src/components/illustrations/IllustrationSunrise.tsx","../src/components/illustrations/IllustrationSvgIcon.tsx","../src/components/animations/AnimationBounce.tsx","../src/metadata/index.ts"],"names":["jsx","jsxs"],"mappings":"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","sourcesContent":["import type { SVGProps } from \"react\";\nconst IconCheeseIcon2 = (props: SVGProps<SVGSVGElement>) => <svg className=\"w-6 h-6 text-gray-800 dark:text-white\" aria-hidden=\"true\" xmlns=\"http://www.w3.org/2000/svg\" width=\"1em\" height=\"1em\" fill=\"none\" viewBox=\"0 0 24 24\" role=\"img\" {...props}><path stroke=\"currentColor\" strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"m4 12 6.4267-4.65924c.6372.89667 1.8922 1.10897 2.7888.4718.8967-.63718 1.3493-1.69135.4681-2.80084C13.6373 4.95345 14.9106 4 15 4c.0894 0 5 1 5 8M4 12h16M4 12v8h16v-8M8 15h.01M12 17h.01M16 15h.01\" /></svg>;\nexport { IconCheeseIcon2 };","import type { SVGProps } from \"react\";\nconst IconCheeseIcon = (props: SVGProps<SVGSVGElement>) => <svg className=\"w-6 h-6 text-gray-800 dark:text-white\" aria-hidden=\"true\" xmlns=\"http://www.w3.org/2000/svg\" width=\"1em\" height=\"1em\" fill=\"none\" viewBox=\"0 0 24 24\" role=\"img\" {...props}><path stroke=\"currentColor\" strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"m4 12 6.4267-4.65924c.6372.89667 1.8922 1.10897 2.7888.4718.8967-.63718 1.3493-1.69135.4681-2.80084C13.6373 4.95345 14.9106 4 15 4c.0894 0 5 1 5 8M4 12h16M4 12v8h16v-8M8 15h.01M12 17h.01M16 15h.01\" /></svg>;\nexport { IconCheeseIcon };","import type { SVGProps } from \"react\";\nconst IconSearch = (props: SVGProps<SVGSVGElement>) => <svg width=\"1em\" height=\"1em\" viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" role=\"img\" {...props}><circle cx={11} cy={11} r={7} stroke=\"#111827\" strokeWidth={2} /><line x1={16.6569} y1={16} x2={21} y2={20.3431} stroke=\"#111827\" strokeWidth={2} strokeLinecap=\"round\" /></svg>;\nexport { IconSearch };","import type { SVGProps } from \"react\";\nconst IllustrationRoosterHead = (props: SVGProps<SVGSVGElement>) => <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 867 1124.67\" aria-hidden=\"true\" {...props}><polygon data-name=\"Fill-30\" points=\"337.77 386.66 124.23 58.15 0 562.59 337.77 386.66\" fill=\"#fcc42f\" fillRule=\"evenodd\" /><polygon data-name=\"Fill-32\" points=\"0 562.59 334.51 381.65 379.87 837.6 0 562.59\" fill=\"#59b7b1\" fillRule=\"evenodd\" /><polygon data-name=\"Fill-34\" points=\"334.51 381.64 548.64 183.63 730.92 460.06 538.21 725.26 334.51 381.64\" fill=\"#00a0dd\" fillRule=\"evenodd\" /><polygon data-name=\"Fill-36\" points=\"334.51 381.64 408.42 1124.67 538.21 725.26 334.51 381.64\" fill=\"#fcc42f\" fillRule=\"evenodd\" /><polygon data-name=\"Fill-38\" points=\"548.63 183.32 867 667.57 832.97 387.2 548.63 183.32\" fill=\"#266093\" fillRule=\"evenodd\" /><polygon data-name=\"Fill-27\" points=\"200.38 175.32 124.22 58.16 353.72 0 200.38 175.32\" fill=\"#e54360\" fillRule=\"evenodd\" /><polygon data-name=\"Fill-25\" points=\"111.52 109.77 6.37 144.63 90.69 194.9 111.52 109.77\" fill=\"#e1281d\" fillRule=\"evenodd\" /></svg>;\nexport { IllustrationRoosterHead };","import type { SVGProps } from \"react\";\nconst IllustrationSunrise = (props: SVGProps<SVGSVGElement>) => <svg width={320} height={200} viewBox=\"0 0 320 200\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" {...props}><rect width={320} height={200} fill=\"#E0F2FE\" /><circle cx={160} cy={120} r={60} fill=\"#FBBF24\" /><rect x={0} y={140} width={320} height={60} fill=\"#10B981\" /></svg>;\nexport { IllustrationSunrise };","import React from 'react';\n\nconst IllustrationSvgIcon: React.FC<React.ImgHTMLAttributes<HTMLImageElement>> = (props) => (\n <img src=\"\" alt={props.alt ?? 'svg-icon illustration'} {...props} />\n);\n\nexport { IllustrationSvgIcon };\n","import React from 'react';\nimport Lottie from 'lottie-react';\n\nconst animationData = {\n \"v\": \"5.7.4\",\n \"fr\": 30,\n \"ip\": 0,\n \"op\": 30,\n \"w\": 200,\n \"h\": 200,\n \"nm\": \"bounce\",\n \"ddd\": 0,\n \"assets\": [],\n \"layers\": [\n {\n \"ddd\": 0,\n \"ind\": 1,\n \"ty\": 4,\n \"nm\": \"Circle\",\n \"sr\": 1,\n \"ks\": {\n \"o\": {\n \"a\": 0,\n \"k\": 100\n },\n \"r\": {\n \"a\": 0,\n \"k\": 0\n },\n \"p\": {\n \"a\": 1,\n \"k\": [\n {\n \"i\": {\n \"x\": 0.667,\n \"y\": 1\n },\n \"o\": {\n \"x\": 0.333,\n \"y\": 0\n },\n \"t\": 0,\n \"s\": [\n 100,\n 40,\n 0\n ]\n },\n {\n \"t\": 30,\n \"s\": [\n 100,\n 160,\n 0\n ]\n }\n ]\n },\n \"a\": {\n \"a\": 0,\n \"k\": [\n 0,\n 0,\n 0\n ]\n },\n \"s\": {\n \"a\": 0,\n \"k\": [\n 100,\n 100,\n 100\n ]\n }\n },\n \"shapes\": [\n {\n \"ty\": \"el\",\n \"p\": {\n \"a\": 0,\n \"k\": [\n 0,\n 0\n ]\n },\n \"s\": {\n \"a\": 0,\n \"k\": [\n 60,\n 60\n ]\n },\n \"nm\": \"Ellipse Path\"\n },\n {\n \"ty\": \"fl\",\n \"c\": {\n \"a\": 0,\n \"k\": [\n 0.129,\n 0.588,\n 0.953,\n 1\n ]\n },\n \"o\": {\n \"a\": 0,\n \"k\": 100\n },\n \"r\": 1,\n \"nm\": \"Fill\"\n }\n ],\n \"ip\": 0,\n \"op\": 30,\n \"st\": 0\n }\n ]\n} as const;\n\nconst AnimationBounce: React.FC<{ loop?: boolean; autoplay?: boolean; className?: string } & Partial<React.ComponentProps<typeof Lottie>>> = ({ loop = true, autoplay = true, ...rest }) => {\n return <Lottie animationData={animationData} loop={loop} autoplay={autoplay} {...rest} />;\n};\n\nexport { AnimationBounce };\n","// Auto-generated by scripts/generateAssets.ts\nexport const icons = [\n {\n \"name\": \"cheese-icon-2\",\n \"tags\": [\n \"food\",\n \"cheese\",\n \"icon\"\n ],\n \"description\": \"\"\n },\n {\n \"name\": \"cheese-icon\",\n \"tags\": [\n \"food\",\n \"cheese\",\n \"icons\"\n ],\n \"description\": \"\"\n },\n {\n \"name\": \"search\",\n \"tags\": [\n \"find\",\n \"magnify\"\n ],\n \"description\": \"Search icon\"\n }\n] as const;\nexport const illustrations = [\n {\n \"name\": \"rooster-head\",\n \"category\": \"Brand\",\n \"tags\": [\n \"rooster\",\n \"rooster head\",\n \"brand mark\"\n ]\n },\n {\n \"name\": \"sunrise\",\n \"category\": \"nature\",\n \"tags\": [\n \"morning\",\n \"sun\"\n ],\n \"description\": \"Sunrise illustration\"\n },\n {\n \"name\": \"svg-icon\",\n \"category\": \"Icons\",\n \"tags\": [\n \"icon\",\n \"black\",\n \"line icon\"\n ]\n }\n] as const;\nexport const animations = [\n {\n \"name\": \"bounce\",\n \"frameRate\": 30,\n \"loop\": true,\n \"tags\": [\n \"motion\",\n \"loop\"\n ],\n \"description\": \"Simple bouncing ball animation\"\n }\n] as const;\n\nexport type IconMetadata = typeof icons[number];\nexport type IllustrationMetadata = typeof illustrations[number];\nexport type AnimationMetadata = typeof animations[number];\n"]}
package/dist/index.mjs ADDED
@@ -0,0 +1,219 @@
1
+ import { jsx, jsxs } from 'react/jsx-runtime';
2
+ import Lottie from 'lottie-react';
3
+
4
+ // src/components/icons/IconCheeseIcon2.tsx
5
+ var IconCheeseIcon2 = (props) => /* @__PURE__ */ jsx("svg", { className: "w-6 h-6 text-gray-800 dark:text-white", "aria-hidden": "true", xmlns: "http://www.w3.org/2000/svg", width: "1em", height: "1em", fill: "none", viewBox: "0 0 24 24", role: "img", ...props, children: /* @__PURE__ */ jsx("path", { stroke: "currentColor", strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: 2, d: "m4 12 6.4267-4.65924c.6372.89667 1.8922 1.10897 2.7888.4718.8967-.63718 1.3493-1.69135.4681-2.80084C13.6373 4.95345 14.9106 4 15 4c.0894 0 5 1 5 8M4 12h16M4 12v8h16v-8M8 15h.01M12 17h.01M16 15h.01" }) });
6
+ var IconCheeseIcon = (props) => /* @__PURE__ */ jsx("svg", { className: "w-6 h-6 text-gray-800 dark:text-white", "aria-hidden": "true", xmlns: "http://www.w3.org/2000/svg", width: "1em", height: "1em", fill: "none", viewBox: "0 0 24 24", role: "img", ...props, children: /* @__PURE__ */ jsx("path", { stroke: "currentColor", strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: 2, d: "m4 12 6.4267-4.65924c.6372.89667 1.8922 1.10897 2.7888.4718.8967-.63718 1.3493-1.69135.4681-2.80084C13.6373 4.95345 14.9106 4 15 4c.0894 0 5 1 5 8M4 12h16M4 12v8h16v-8M8 15h.01M12 17h.01M16 15h.01" }) });
7
+ var IconSearch = (props) => /* @__PURE__ */ jsxs("svg", { width: "1em", height: "1em", viewBox: "0 0 24 24", fill: "none", xmlns: "http://www.w3.org/2000/svg", role: "img", ...props, children: [
8
+ /* @__PURE__ */ jsx("circle", { cx: 11, cy: 11, r: 7, stroke: "#111827", strokeWidth: 2 }),
9
+ /* @__PURE__ */ jsx("line", { x1: 16.6569, y1: 16, x2: 21, y2: 20.3431, stroke: "#111827", strokeWidth: 2, strokeLinecap: "round" })
10
+ ] });
11
+ var IllustrationRoosterHead = (props) => /* @__PURE__ */ jsxs("svg", { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 867 1124.67", "aria-hidden": "true", ...props, children: [
12
+ /* @__PURE__ */ jsx("polygon", { "data-name": "Fill-30", points: "337.77 386.66 124.23 58.15 0 562.59 337.77 386.66", fill: "#fcc42f", fillRule: "evenodd" }),
13
+ /* @__PURE__ */ jsx("polygon", { "data-name": "Fill-32", points: "0 562.59 334.51 381.65 379.87 837.6 0 562.59", fill: "#59b7b1", fillRule: "evenodd" }),
14
+ /* @__PURE__ */ jsx("polygon", { "data-name": "Fill-34", points: "334.51 381.64 548.64 183.63 730.92 460.06 538.21 725.26 334.51 381.64", fill: "#00a0dd", fillRule: "evenodd" }),
15
+ /* @__PURE__ */ jsx("polygon", { "data-name": "Fill-36", points: "334.51 381.64 408.42 1124.67 538.21 725.26 334.51 381.64", fill: "#fcc42f", fillRule: "evenodd" }),
16
+ /* @__PURE__ */ jsx("polygon", { "data-name": "Fill-38", points: "548.63 183.32 867 667.57 832.97 387.2 548.63 183.32", fill: "#266093", fillRule: "evenodd" }),
17
+ /* @__PURE__ */ jsx("polygon", { "data-name": "Fill-27", points: "200.38 175.32 124.22 58.16 353.72 0 200.38 175.32", fill: "#e54360", fillRule: "evenodd" }),
18
+ /* @__PURE__ */ jsx("polygon", { "data-name": "Fill-25", points: "111.52 109.77 6.37 144.63 90.69 194.9 111.52 109.77", fill: "#e1281d", fillRule: "evenodd" })
19
+ ] });
20
+ var IllustrationSunrise = (props) => /* @__PURE__ */ jsxs("svg", { width: 320, height: 200, viewBox: "0 0 320 200", fill: "none", xmlns: "http://www.w3.org/2000/svg", ...props, children: [
21
+ /* @__PURE__ */ jsx("rect", { width: 320, height: 200, fill: "#E0F2FE" }),
22
+ /* @__PURE__ */ jsx("circle", { cx: 160, cy: 120, r: 60, fill: "#FBBF24" }),
23
+ /* @__PURE__ */ jsx("rect", { x: 0, y: 140, width: 320, height: 60, fill: "#10B981" })
24
+ ] });
25
+ var IllustrationSvgIcon = (props) => /* @__PURE__ */ jsx("img", { src: "", alt: props.alt ?? "svg-icon illustration", ...props });
26
+ var animationData = {
27
+ "v": "5.7.4",
28
+ "fr": 30,
29
+ "ip": 0,
30
+ "op": 30,
31
+ "w": 200,
32
+ "h": 200,
33
+ "nm": "bounce",
34
+ "ddd": 0,
35
+ "assets": [],
36
+ "layers": [
37
+ {
38
+ "ddd": 0,
39
+ "ind": 1,
40
+ "ty": 4,
41
+ "nm": "Circle",
42
+ "sr": 1,
43
+ "ks": {
44
+ "o": {
45
+ "a": 0,
46
+ "k": 100
47
+ },
48
+ "r": {
49
+ "a": 0,
50
+ "k": 0
51
+ },
52
+ "p": {
53
+ "a": 1,
54
+ "k": [
55
+ {
56
+ "i": {
57
+ "x": 0.667,
58
+ "y": 1
59
+ },
60
+ "o": {
61
+ "x": 0.333,
62
+ "y": 0
63
+ },
64
+ "t": 0,
65
+ "s": [
66
+ 100,
67
+ 40,
68
+ 0
69
+ ]
70
+ },
71
+ {
72
+ "t": 30,
73
+ "s": [
74
+ 100,
75
+ 160,
76
+ 0
77
+ ]
78
+ }
79
+ ]
80
+ },
81
+ "a": {
82
+ "a": 0,
83
+ "k": [
84
+ 0,
85
+ 0,
86
+ 0
87
+ ]
88
+ },
89
+ "s": {
90
+ "a": 0,
91
+ "k": [
92
+ 100,
93
+ 100,
94
+ 100
95
+ ]
96
+ }
97
+ },
98
+ "shapes": [
99
+ {
100
+ "ty": "el",
101
+ "p": {
102
+ "a": 0,
103
+ "k": [
104
+ 0,
105
+ 0
106
+ ]
107
+ },
108
+ "s": {
109
+ "a": 0,
110
+ "k": [
111
+ 60,
112
+ 60
113
+ ]
114
+ },
115
+ "nm": "Ellipse Path"
116
+ },
117
+ {
118
+ "ty": "fl",
119
+ "c": {
120
+ "a": 0,
121
+ "k": [
122
+ 0.129,
123
+ 0.588,
124
+ 0.953,
125
+ 1
126
+ ]
127
+ },
128
+ "o": {
129
+ "a": 0,
130
+ "k": 100
131
+ },
132
+ "r": 1,
133
+ "nm": "Fill"
134
+ }
135
+ ],
136
+ "ip": 0,
137
+ "op": 30,
138
+ "st": 0
139
+ }
140
+ ]
141
+ };
142
+ var AnimationBounce = ({ loop = true, autoplay = true, ...rest }) => {
143
+ return /* @__PURE__ */ jsx(Lottie, { animationData, loop, autoplay, ...rest });
144
+ };
145
+
146
+ // src/metadata/index.ts
147
+ var icons = [
148
+ {
149
+ "name": "cheese-icon-2",
150
+ "tags": [
151
+ "food",
152
+ "cheese",
153
+ "icon"
154
+ ],
155
+ "description": ""
156
+ },
157
+ {
158
+ "name": "cheese-icon",
159
+ "tags": [
160
+ "food",
161
+ "cheese",
162
+ "icons"
163
+ ],
164
+ "description": ""
165
+ },
166
+ {
167
+ "name": "search",
168
+ "tags": [
169
+ "find",
170
+ "magnify"
171
+ ],
172
+ "description": "Search icon"
173
+ }
174
+ ];
175
+ var illustrations = [
176
+ {
177
+ "name": "rooster-head",
178
+ "category": "Brand",
179
+ "tags": [
180
+ "rooster",
181
+ "rooster head",
182
+ "brand mark"
183
+ ]
184
+ },
185
+ {
186
+ "name": "sunrise",
187
+ "category": "nature",
188
+ "tags": [
189
+ "morning",
190
+ "sun"
191
+ ],
192
+ "description": "Sunrise illustration"
193
+ },
194
+ {
195
+ "name": "svg-icon",
196
+ "category": "Icons",
197
+ "tags": [
198
+ "icon",
199
+ "black",
200
+ "line icon"
201
+ ]
202
+ }
203
+ ];
204
+ var animations = [
205
+ {
206
+ "name": "bounce",
207
+ "frameRate": 30,
208
+ "loop": true,
209
+ "tags": [
210
+ "motion",
211
+ "loop"
212
+ ],
213
+ "description": "Simple bouncing ball animation"
214
+ }
215
+ ];
216
+
217
+ export { AnimationBounce, IconCheeseIcon, IconCheeseIcon2, IconSearch, IllustrationRoosterHead, IllustrationSunrise, IllustrationSvgIcon, animations, icons, illustrations };
218
+ //# sourceMappingURL=out.js.map
219
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/components/icons/IconCheeseIcon2.tsx","../src/components/icons/IconCheeseIcon.tsx","../src/components/icons/IconSearch.tsx","../src/components/illustrations/IllustrationRoosterHead.tsx","../src/components/illustrations/IllustrationSunrise.tsx","../src/components/illustrations/IllustrationSvgIcon.tsx","../src/components/animations/AnimationBounce.tsx","../src/metadata/index.ts"],"names":["jsx","jsxs"],"mappings":"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","sourcesContent":["import type { SVGProps } from \"react\";\nconst IconCheeseIcon2 = (props: SVGProps<SVGSVGElement>) => <svg className=\"w-6 h-6 text-gray-800 dark:text-white\" aria-hidden=\"true\" xmlns=\"http://www.w3.org/2000/svg\" width=\"1em\" height=\"1em\" fill=\"none\" viewBox=\"0 0 24 24\" role=\"img\" {...props}><path stroke=\"currentColor\" strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"m4 12 6.4267-4.65924c.6372.89667 1.8922 1.10897 2.7888.4718.8967-.63718 1.3493-1.69135.4681-2.80084C13.6373 4.95345 14.9106 4 15 4c.0894 0 5 1 5 8M4 12h16M4 12v8h16v-8M8 15h.01M12 17h.01M16 15h.01\" /></svg>;\nexport { IconCheeseIcon2 };","import type { SVGProps } from \"react\";\nconst IconCheeseIcon = (props: SVGProps<SVGSVGElement>) => <svg className=\"w-6 h-6 text-gray-800 dark:text-white\" aria-hidden=\"true\" xmlns=\"http://www.w3.org/2000/svg\" width=\"1em\" height=\"1em\" fill=\"none\" viewBox=\"0 0 24 24\" role=\"img\" {...props}><path stroke=\"currentColor\" strokeLinecap=\"round\" strokeLinejoin=\"round\" strokeWidth={2} d=\"m4 12 6.4267-4.65924c.6372.89667 1.8922 1.10897 2.7888.4718.8967-.63718 1.3493-1.69135.4681-2.80084C13.6373 4.95345 14.9106 4 15 4c.0894 0 5 1 5 8M4 12h16M4 12v8h16v-8M8 15h.01M12 17h.01M16 15h.01\" /></svg>;\nexport { IconCheeseIcon };","import type { SVGProps } from \"react\";\nconst IconSearch = (props: SVGProps<SVGSVGElement>) => <svg width=\"1em\" height=\"1em\" viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" role=\"img\" {...props}><circle cx={11} cy={11} r={7} stroke=\"#111827\" strokeWidth={2} /><line x1={16.6569} y1={16} x2={21} y2={20.3431} stroke=\"#111827\" strokeWidth={2} strokeLinecap=\"round\" /></svg>;\nexport { IconSearch };","import type { SVGProps } from \"react\";\nconst IllustrationRoosterHead = (props: SVGProps<SVGSVGElement>) => <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 867 1124.67\" aria-hidden=\"true\" {...props}><polygon data-name=\"Fill-30\" points=\"337.77 386.66 124.23 58.15 0 562.59 337.77 386.66\" fill=\"#fcc42f\" fillRule=\"evenodd\" /><polygon data-name=\"Fill-32\" points=\"0 562.59 334.51 381.65 379.87 837.6 0 562.59\" fill=\"#59b7b1\" fillRule=\"evenodd\" /><polygon data-name=\"Fill-34\" points=\"334.51 381.64 548.64 183.63 730.92 460.06 538.21 725.26 334.51 381.64\" fill=\"#00a0dd\" fillRule=\"evenodd\" /><polygon data-name=\"Fill-36\" points=\"334.51 381.64 408.42 1124.67 538.21 725.26 334.51 381.64\" fill=\"#fcc42f\" fillRule=\"evenodd\" /><polygon data-name=\"Fill-38\" points=\"548.63 183.32 867 667.57 832.97 387.2 548.63 183.32\" fill=\"#266093\" fillRule=\"evenodd\" /><polygon data-name=\"Fill-27\" points=\"200.38 175.32 124.22 58.16 353.72 0 200.38 175.32\" fill=\"#e54360\" fillRule=\"evenodd\" /><polygon data-name=\"Fill-25\" points=\"111.52 109.77 6.37 144.63 90.69 194.9 111.52 109.77\" fill=\"#e1281d\" fillRule=\"evenodd\" /></svg>;\nexport { IllustrationRoosterHead };","import type { SVGProps } from \"react\";\nconst IllustrationSunrise = (props: SVGProps<SVGSVGElement>) => <svg width={320} height={200} viewBox=\"0 0 320 200\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" {...props}><rect width={320} height={200} fill=\"#E0F2FE\" /><circle cx={160} cy={120} r={60} fill=\"#FBBF24\" /><rect x={0} y={140} width={320} height={60} fill=\"#10B981\" /></svg>;\nexport { IllustrationSunrise };","import React from 'react';\n\nconst IllustrationSvgIcon: React.FC<React.ImgHTMLAttributes<HTMLImageElement>> = (props) => (\n <img src=\"\" alt={props.alt ?? 'svg-icon illustration'} {...props} />\n);\n\nexport { IllustrationSvgIcon };\n","import React from 'react';\nimport Lottie from 'lottie-react';\n\nconst animationData = {\n \"v\": \"5.7.4\",\n \"fr\": 30,\n \"ip\": 0,\n \"op\": 30,\n \"w\": 200,\n \"h\": 200,\n \"nm\": \"bounce\",\n \"ddd\": 0,\n \"assets\": [],\n \"layers\": [\n {\n \"ddd\": 0,\n \"ind\": 1,\n \"ty\": 4,\n \"nm\": \"Circle\",\n \"sr\": 1,\n \"ks\": {\n \"o\": {\n \"a\": 0,\n \"k\": 100\n },\n \"r\": {\n \"a\": 0,\n \"k\": 0\n },\n \"p\": {\n \"a\": 1,\n \"k\": [\n {\n \"i\": {\n \"x\": 0.667,\n \"y\": 1\n },\n \"o\": {\n \"x\": 0.333,\n \"y\": 0\n },\n \"t\": 0,\n \"s\": [\n 100,\n 40,\n 0\n ]\n },\n {\n \"t\": 30,\n \"s\": [\n 100,\n 160,\n 0\n ]\n }\n ]\n },\n \"a\": {\n \"a\": 0,\n \"k\": [\n 0,\n 0,\n 0\n ]\n },\n \"s\": {\n \"a\": 0,\n \"k\": [\n 100,\n 100,\n 100\n ]\n }\n },\n \"shapes\": [\n {\n \"ty\": \"el\",\n \"p\": {\n \"a\": 0,\n \"k\": [\n 0,\n 0\n ]\n },\n \"s\": {\n \"a\": 0,\n \"k\": [\n 60,\n 60\n ]\n },\n \"nm\": \"Ellipse Path\"\n },\n {\n \"ty\": \"fl\",\n \"c\": {\n \"a\": 0,\n \"k\": [\n 0.129,\n 0.588,\n 0.953,\n 1\n ]\n },\n \"o\": {\n \"a\": 0,\n \"k\": 100\n },\n \"r\": 1,\n \"nm\": \"Fill\"\n }\n ],\n \"ip\": 0,\n \"op\": 30,\n \"st\": 0\n }\n ]\n} as const;\n\nconst AnimationBounce: React.FC<{ loop?: boolean; autoplay?: boolean; className?: string } & Partial<React.ComponentProps<typeof Lottie>>> = ({ loop = true, autoplay = true, ...rest }) => {\n return <Lottie animationData={animationData} loop={loop} autoplay={autoplay} {...rest} />;\n};\n\nexport { AnimationBounce };\n","// Auto-generated by scripts/generateAssets.ts\nexport const icons = [\n {\n \"name\": \"cheese-icon-2\",\n \"tags\": [\n \"food\",\n \"cheese\",\n \"icon\"\n ],\n \"description\": \"\"\n },\n {\n \"name\": \"cheese-icon\",\n \"tags\": [\n \"food\",\n \"cheese\",\n \"icons\"\n ],\n \"description\": \"\"\n },\n {\n \"name\": \"search\",\n \"tags\": [\n \"find\",\n \"magnify\"\n ],\n \"description\": \"Search icon\"\n }\n] as const;\nexport const illustrations = [\n {\n \"name\": \"rooster-head\",\n \"category\": \"Brand\",\n \"tags\": [\n \"rooster\",\n \"rooster head\",\n \"brand mark\"\n ]\n },\n {\n \"name\": \"sunrise\",\n \"category\": \"nature\",\n \"tags\": [\n \"morning\",\n \"sun\"\n ],\n \"description\": \"Sunrise illustration\"\n },\n {\n \"name\": \"svg-icon\",\n \"category\": \"Icons\",\n \"tags\": [\n \"icon\",\n \"black\",\n \"line icon\"\n ]\n }\n] as const;\nexport const animations = [\n {\n \"name\": \"bounce\",\n \"frameRate\": 30,\n \"loop\": true,\n \"tags\": [\n \"motion\",\n \"loop\"\n ],\n \"description\": \"Simple bouncing ball animation\"\n }\n] as const;\n\nexport type IconMetadata = typeof icons[number];\nexport type IllustrationMetadata = typeof illustrations[number];\nexport type AnimationMetadata = typeof animations[number];\n"]}
package/package.json ADDED
@@ -0,0 +1,51 @@
1
+ {
2
+ "name": "@guideveloper/design-assets",
3
+ "version": "0.1.1",
4
+ "description": "Design Asset Factory library of generated components and metadata.",
5
+ "main": "dist/index.cjs.js",
6
+ "module": "dist/index.esm.js",
7
+ "types": "dist/index.d.ts",
8
+ "scripts": {
9
+ "dev": "storybook dev -p 6006",
10
+ "storybook": "storybook dev -p 6006",
11
+ "build-storybook": "storybook build",
12
+ "generate-assets": "tsx scripts/generateAssets.ts",
13
+ "build": "tsup src/index.ts --format esm,cjs --dts",
14
+ "lint": "eslint 'src/**/*.{ts,tsx}'",
15
+ "prepare": "npm run generate-assets"
16
+ },
17
+ "files": [
18
+ "dist",
19
+ "src/components",
20
+ "src/metadata",
21
+ "src/index.ts"
22
+ ],
23
+ "engines": {
24
+ "node": ">=18"
25
+ },
26
+ "dependencies": {
27
+ "@svgr/core": "^8.0.0",
28
+ "@svgr/plugin-jsx": "^8.0.0",
29
+ "lottie-react": "^2.4.0",
30
+ "react": "^18.2.0",
31
+ "react-dom": "^18.2.0"
32
+ },
33
+ "devDependencies": {
34
+ "@storybook/addon-essentials": "^8.6.14",
35
+ "@storybook/addon-links": "^8.6.14",
36
+ "@storybook/cli": "^8.0.0",
37
+ "@storybook/react": "^8.6.14",
38
+ "@storybook/react-vite": "^8.6.14",
39
+ "storybook": "^8.6.14",
40
+ "@types/node": "^20.10.0",
41
+ "@types/react": "^18.2.0",
42
+ "@types/react-dom": "^18.2.0",
43
+ "@vitejs/plugin-react": "^4.2.0",
44
+ "eslint": "^8.54.0",
45
+ "ts-node": "^10.9.1",
46
+ "tsup": "^7.2.0",
47
+ "tsx": "^4.7.0",
48
+ "typescript": "^5.2.0",
49
+ "vite": "^5.0.0"
50
+ }
51
+ }
@@ -0,0 +1,125 @@
1
+ import React from 'react';
2
+ import Lottie from 'lottie-react';
3
+
4
+ const animationData = {
5
+ "v": "5.7.4",
6
+ "fr": 30,
7
+ "ip": 0,
8
+ "op": 30,
9
+ "w": 200,
10
+ "h": 200,
11
+ "nm": "bounce",
12
+ "ddd": 0,
13
+ "assets": [],
14
+ "layers": [
15
+ {
16
+ "ddd": 0,
17
+ "ind": 1,
18
+ "ty": 4,
19
+ "nm": "Circle",
20
+ "sr": 1,
21
+ "ks": {
22
+ "o": {
23
+ "a": 0,
24
+ "k": 100
25
+ },
26
+ "r": {
27
+ "a": 0,
28
+ "k": 0
29
+ },
30
+ "p": {
31
+ "a": 1,
32
+ "k": [
33
+ {
34
+ "i": {
35
+ "x": 0.667,
36
+ "y": 1
37
+ },
38
+ "o": {
39
+ "x": 0.333,
40
+ "y": 0
41
+ },
42
+ "t": 0,
43
+ "s": [
44
+ 100,
45
+ 40,
46
+ 0
47
+ ]
48
+ },
49
+ {
50
+ "t": 30,
51
+ "s": [
52
+ 100,
53
+ 160,
54
+ 0
55
+ ]
56
+ }
57
+ ]
58
+ },
59
+ "a": {
60
+ "a": 0,
61
+ "k": [
62
+ 0,
63
+ 0,
64
+ 0
65
+ ]
66
+ },
67
+ "s": {
68
+ "a": 0,
69
+ "k": [
70
+ 100,
71
+ 100,
72
+ 100
73
+ ]
74
+ }
75
+ },
76
+ "shapes": [
77
+ {
78
+ "ty": "el",
79
+ "p": {
80
+ "a": 0,
81
+ "k": [
82
+ 0,
83
+ 0
84
+ ]
85
+ },
86
+ "s": {
87
+ "a": 0,
88
+ "k": [
89
+ 60,
90
+ 60
91
+ ]
92
+ },
93
+ "nm": "Ellipse Path"
94
+ },
95
+ {
96
+ "ty": "fl",
97
+ "c": {
98
+ "a": 0,
99
+ "k": [
100
+ 0.129,
101
+ 0.588,
102
+ 0.953,
103
+ 1
104
+ ]
105
+ },
106
+ "o": {
107
+ "a": 0,
108
+ "k": 100
109
+ },
110
+ "r": 1,
111
+ "nm": "Fill"
112
+ }
113
+ ],
114
+ "ip": 0,
115
+ "op": 30,
116
+ "st": 0
117
+ }
118
+ ]
119
+ } as const;
120
+
121
+ const AnimationBounce: React.FC<{ loop?: boolean; autoplay?: boolean; className?: string } & Partial<React.ComponentProps<typeof Lottie>>> = ({ loop = true, autoplay = true, ...rest }) => {
122
+ return <Lottie animationData={animationData} loop={loop} autoplay={autoplay} {...rest} />;
123
+ };
124
+
125
+ export { AnimationBounce };
@@ -0,0 +1,3 @@
1
+ import type { SVGProps } from "react";
2
+ const IconCheeseIcon = (props: SVGProps<SVGSVGElement>) => <svg className="w-6 h-6 text-gray-800 dark:text-white" aria-hidden="true" xmlns="http://www.w3.org/2000/svg" width="1em" height="1em" fill="none" viewBox="0 0 24 24" role="img" {...props}><path stroke="currentColor" strokeLinecap="round" strokeLinejoin="round" strokeWidth={2} d="m4 12 6.4267-4.65924c.6372.89667 1.8922 1.10897 2.7888.4718.8967-.63718 1.3493-1.69135.4681-2.80084C13.6373 4.95345 14.9106 4 15 4c.0894 0 5 1 5 8M4 12h16M4 12v8h16v-8M8 15h.01M12 17h.01M16 15h.01" /></svg>;
3
+ export { IconCheeseIcon };
@@ -0,0 +1,3 @@
1
+ import type { SVGProps } from "react";
2
+ const IconCheeseIcon2 = (props: SVGProps<SVGSVGElement>) => <svg className="w-6 h-6 text-gray-800 dark:text-white" aria-hidden="true" xmlns="http://www.w3.org/2000/svg" width="1em" height="1em" fill="none" viewBox="0 0 24 24" role="img" {...props}><path stroke="currentColor" strokeLinecap="round" strokeLinejoin="round" strokeWidth={2} d="m4 12 6.4267-4.65924c.6372.89667 1.8922 1.10897 2.7888.4718.8967-.63718 1.3493-1.69135.4681-2.80084C13.6373 4.95345 14.9106 4 15 4c.0894 0 5 1 5 8M4 12h16M4 12v8h16v-8M8 15h.01M12 17h.01M16 15h.01" /></svg>;
3
+ export { IconCheeseIcon2 };
@@ -0,0 +1,3 @@
1
+ import type { SVGProps } from "react";
2
+ const IconSearch = (props: SVGProps<SVGSVGElement>) => <svg width="1em" height="1em" viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg" role="img" {...props}><circle cx={11} cy={11} r={7} stroke="#111827" strokeWidth={2} /><line x1={16.6569} y1={16} x2={21} y2={20.3431} stroke="#111827" strokeWidth={2} strokeLinecap="round" /></svg>;
3
+ export { IconSearch };
@@ -0,0 +1,3 @@
1
+ import type { SVGProps } from "react";
2
+ const IllustrationRoosterHead = (props: SVGProps<SVGSVGElement>) => <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 867 1124.67" aria-hidden="true" {...props}><polygon data-name="Fill-30" points="337.77 386.66 124.23 58.15 0 562.59 337.77 386.66" fill="#fcc42f" fillRule="evenodd" /><polygon data-name="Fill-32" points="0 562.59 334.51 381.65 379.87 837.6 0 562.59" fill="#59b7b1" fillRule="evenodd" /><polygon data-name="Fill-34" points="334.51 381.64 548.64 183.63 730.92 460.06 538.21 725.26 334.51 381.64" fill="#00a0dd" fillRule="evenodd" /><polygon data-name="Fill-36" points="334.51 381.64 408.42 1124.67 538.21 725.26 334.51 381.64" fill="#fcc42f" fillRule="evenodd" /><polygon data-name="Fill-38" points="548.63 183.32 867 667.57 832.97 387.2 548.63 183.32" fill="#266093" fillRule="evenodd" /><polygon data-name="Fill-27" points="200.38 175.32 124.22 58.16 353.72 0 200.38 175.32" fill="#e54360" fillRule="evenodd" /><polygon data-name="Fill-25" points="111.52 109.77 6.37 144.63 90.69 194.9 111.52 109.77" fill="#e1281d" fillRule="evenodd" /></svg>;
3
+ export { IllustrationRoosterHead };
@@ -0,0 +1,3 @@
1
+ import type { SVGProps } from "react";
2
+ const IllustrationSunrise = (props: SVGProps<SVGSVGElement>) => <svg width={320} height={200} viewBox="0 0 320 200" fill="none" xmlns="http://www.w3.org/2000/svg" {...props}><rect width={320} height={200} fill="#E0F2FE" /><circle cx={160} cy={120} r={60} fill="#FBBF24" /><rect x={0} y={140} width={320} height={60} fill="#10B981" /></svg>;
3
+ export { IllustrationSunrise };
@@ -0,0 +1,7 @@
1
+ import React from 'react';
2
+
3
+ const IllustrationSvgIcon: React.FC<React.ImgHTMLAttributes<HTMLImageElement>> = (props) => (
4
+ <img src="" alt={props.alt ?? 'svg-icon illustration'} {...props} />
5
+ );
6
+
7
+ export { IllustrationSvgIcon };
@@ -0,0 +1,8 @@
1
+ // Auto-generated by scripts/generateAssets.ts
2
+ export { IconCheeseIcon2 } from './icons/IconCheeseIcon2';
3
+ export { IconCheeseIcon } from './icons/IconCheeseIcon';
4
+ export { IconSearch } from './icons/IconSearch';
5
+ export { IllustrationRoosterHead } from './illustrations/IllustrationRoosterHead';
6
+ export { IllustrationSunrise } from './illustrations/IllustrationSunrise';
7
+ export { IllustrationSvgIcon } from './illustrations/IllustrationSvgIcon';
8
+ export { AnimationBounce } from './animations/AnimationBounce';
package/src/index.ts ADDED
@@ -0,0 +1,2 @@
1
+ export * from './components';
2
+ export * from './metadata';
@@ -0,0 +1,74 @@
1
+ // Auto-generated by scripts/generateAssets.ts
2
+ export const icons = [
3
+ {
4
+ "name": "cheese-icon-2",
5
+ "tags": [
6
+ "food",
7
+ "cheese",
8
+ "icon"
9
+ ],
10
+ "description": ""
11
+ },
12
+ {
13
+ "name": "cheese-icon",
14
+ "tags": [
15
+ "food",
16
+ "cheese",
17
+ "icons"
18
+ ],
19
+ "description": ""
20
+ },
21
+ {
22
+ "name": "search",
23
+ "tags": [
24
+ "find",
25
+ "magnify"
26
+ ],
27
+ "description": "Search icon"
28
+ }
29
+ ] as const;
30
+ export const illustrations = [
31
+ {
32
+ "name": "rooster-head",
33
+ "category": "Brand",
34
+ "tags": [
35
+ "rooster",
36
+ "rooster head",
37
+ "brand mark"
38
+ ]
39
+ },
40
+ {
41
+ "name": "sunrise",
42
+ "category": "nature",
43
+ "tags": [
44
+ "morning",
45
+ "sun"
46
+ ],
47
+ "description": "Sunrise illustration"
48
+ },
49
+ {
50
+ "name": "svg-icon",
51
+ "category": "Icons",
52
+ "tags": [
53
+ "icon",
54
+ "black",
55
+ "line icon"
56
+ ]
57
+ }
58
+ ] as const;
59
+ export const animations = [
60
+ {
61
+ "name": "bounce",
62
+ "frameRate": 30,
63
+ "loop": true,
64
+ "tags": [
65
+ "motion",
66
+ "loop"
67
+ ],
68
+ "description": "Simple bouncing ball animation"
69
+ }
70
+ ] as const;
71
+
72
+ export type IconMetadata = typeof icons[number];
73
+ export type IllustrationMetadata = typeof illustrations[number];
74
+ export type AnimationMetadata = typeof animations[number];