@cyberalien/svg-utils 1.0.6 → 1.0.8
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/components/helpers/filenames/types.js +1 -1
- package/lib/components/helpers/ts/react.d.ts +9 -0
- package/lib/components/helpers/ts/react.js +20 -0
- package/lib/components/helpers/ts/wrapper.js +1 -1
- package/lib/components/jsx.d.ts +13 -0
- package/lib/components/jsx.js +118 -0
- package/lib/components/raw.js +2 -2
- package/lib/components/svelte.js +12 -6
- package/lib/components/types/component.d.ts +1 -0
- package/lib/components/vue-func.js +9 -4
- package/lib/components/vue.js +9 -4
- package/package.json +1 -1
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { getUniqueHash } from "../../../helpers/hash/unique.js";
|
|
2
|
-
import { getGeneratedComponentFilename } from "../../export/filename.js";
|
|
3
2
|
import { getGeneratedAssetFilename } from "./asset.js";
|
|
3
|
+
import { getGeneratedComponentFilename } from "../../export/filename.js";
|
|
4
4
|
|
|
5
5
|
/**
|
|
6
6
|
* Generate component types filename based on options
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { GeneratedAssetFile } from "../../types/component.js";
|
|
2
|
+
import { FactoryIconData } from "../../types/data.js";
|
|
3
|
+
import { ComponentFactoryOptions } from "../../types/options.js";
|
|
4
|
+
import { FactoryComponentProps } from "../props/types.js";
|
|
5
|
+
/**
|
|
6
|
+
* Add React component types
|
|
7
|
+
*/
|
|
8
|
+
declare const addReactComponentTypes: (data: FactoryIconData, options: ComponentFactoryOptions, assets: GeneratedAssetFile[], props: FactoryComponentProps) => string;
|
|
9
|
+
export { addReactComponentTypes };
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { addComponentTypes } from "./wrapper.js";
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* Add React component types
|
|
5
|
+
*/
|
|
6
|
+
const addReactComponentTypes = addComponentTypes.bind(null, `import type { ForwardRefExoticComponent, SVGProps } from 'react';
|
|
7
|
+
|
|
8
|
+
interface IconProps {
|
|
9
|
+
/* PROPS */
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
const Component: ForwardRefExoticComponent<
|
|
13
|
+
Omit<SVGProps<SVGSVGElement>, 'viewBox' | 'width' | 'height' | 'xmlns'> & IconProps
|
|
14
|
+
>;
|
|
15
|
+
|
|
16
|
+
export { type IconProps };
|
|
17
|
+
export default Component;
|
|
18
|
+
`);
|
|
19
|
+
|
|
20
|
+
export { addReactComponentTypes };
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { FactoryGeneratedComponent } from "./types/component.js";
|
|
2
|
+
import { FactoryIconData } from "./types/data.js";
|
|
3
|
+
import { ComponentFactoryOptions } from "./types/options.js";
|
|
4
|
+
interface Options extends ComponentFactoryOptions {
|
|
5
|
+
jsx: 'react';
|
|
6
|
+
fallbackPackage?: string;
|
|
7
|
+
ts?: boolean;
|
|
8
|
+
}
|
|
9
|
+
/**
|
|
10
|
+
* Create functional Vue component code
|
|
11
|
+
*/
|
|
12
|
+
declare function createJSXComponent(data: FactoryIconData, options: Options): FactoryGeneratedComponent;
|
|
13
|
+
export { createJSXComponent };
|
|
@@ -0,0 +1,118 @@
|
|
|
1
|
+
import { getComponentSizeValues } from "./helpers/content/size.js";
|
|
2
|
+
import { stringifyFactoryIconContent } from "./helpers/content/stringify.js";
|
|
3
|
+
import { stringifyIconViewBox } from "../svg/viewbox/value.js";
|
|
4
|
+
import { createFactoryImports } from "./helpers/imports/create.js";
|
|
5
|
+
import { generateCSSFilesForComponent } from "./helpers/css/generate.js";
|
|
6
|
+
import { addSizeFunctionAsset } from "./helpers/functions/size.js";
|
|
7
|
+
import { stringifyFactoryPropsAsJSON } from "./helpers/props/object.js";
|
|
8
|
+
import { stringifyFactoryImports } from "./helpers/imports/stringify.js";
|
|
9
|
+
import { makeSquareViewBox } from "../svg/viewbox/square.js";
|
|
10
|
+
import { getUsedFactoryProps, stringifyFactoryPropTypes } from "./helpers/props/ts.js";
|
|
11
|
+
import { minifyViewBox } from "../svg/viewbox/minify.js";
|
|
12
|
+
import { getViewBoxRatio } from "./helpers/content/ratio.js";
|
|
13
|
+
import { addReactComponentTypes } from "./helpers/ts/react.js";
|
|
14
|
+
|
|
15
|
+
/**
|
|
16
|
+
* Create functional Vue component code
|
|
17
|
+
*/
|
|
18
|
+
function createJSXComponent(data, options) {
|
|
19
|
+
const useTS = options.ts ?? false;
|
|
20
|
+
const assets = [];
|
|
21
|
+
const imports = createFactoryImports();
|
|
22
|
+
const dependencies = /* @__PURE__ */ new Set();
|
|
23
|
+
const importPackage = "react";
|
|
24
|
+
const createElement = "createElement";
|
|
25
|
+
const fallbackPackage = options.fallbackPackage || null;
|
|
26
|
+
const hasFallback = !!(fallbackPackage && data.fallback);
|
|
27
|
+
if (hasFallback) {
|
|
28
|
+
imports.named[fallbackPackage] = new Set(["Icon"]);
|
|
29
|
+
dependencies.add(fallbackPackage);
|
|
30
|
+
}
|
|
31
|
+
const reactNamedImports = new Set([createElement]);
|
|
32
|
+
imports.named[importPackage] = reactNamedImports;
|
|
33
|
+
const style = generateCSSFilesForComponent(data.icon, imports, assets, options);
|
|
34
|
+
const isEmbeddedCSS = options.cssMode === "embed";
|
|
35
|
+
let hasFixedSize = !!options.width && !!options.height;
|
|
36
|
+
const viewBox = data.viewBox;
|
|
37
|
+
const hasComputedViewbox = options.square && !hasFixedSize && viewBox.width !== viewBox.height;
|
|
38
|
+
const isStringViewBox = !hasFallback;
|
|
39
|
+
const hasComputedRatio = hasComputedViewbox && isStringViewBox;
|
|
40
|
+
if (!hasComputedViewbox && (options.width || options.height)) hasFixedSize = true;
|
|
41
|
+
const componentExternalCode = [];
|
|
42
|
+
const componentInternalCode = [];
|
|
43
|
+
const props = {};
|
|
44
|
+
if (!hasFallback) props.xmlns = "http://www.w3.org/2000/svg";
|
|
45
|
+
props.props = {
|
|
46
|
+
value: "props",
|
|
47
|
+
template: "...props,"
|
|
48
|
+
};
|
|
49
|
+
const getViewBox = (viewBox$1) => isStringViewBox ? `'${stringifyIconViewBox(viewBox$1)}'` : JSON.stringify(minifyViewBox(viewBox$1));
|
|
50
|
+
if (hasComputedViewbox) {
|
|
51
|
+
componentExternalCode.push(`const baseViewBox = ${getViewBox(viewBox)};`, `const squareViewBox = ${getViewBox(makeSquareViewBox(viewBox))};`);
|
|
52
|
+
componentInternalCode.push(`const viewBox = useMemo(() => square ? squareViewBox : baseViewBox, [square]);`);
|
|
53
|
+
} else componentExternalCode.push(`const viewBox = ${getViewBox(viewBox)};`);
|
|
54
|
+
const ratioValue = getViewBoxRatio(viewBox);
|
|
55
|
+
if (hasComputedRatio) componentInternalCode.push(`const ratio = useMemo(() => square ? 1 : ${ratioValue}, [square]);`);
|
|
56
|
+
if (hasFixedSize) {
|
|
57
|
+
const sizeProps = getComponentSizeValues(options, data.viewBox);
|
|
58
|
+
if (!sizeProps) throw new Error("Fixed size expected, but could not be determined");
|
|
59
|
+
props.width = sizeProps.width;
|
|
60
|
+
props.height = sizeProps.height;
|
|
61
|
+
} else if (hasFallback) {
|
|
62
|
+
props.width = {
|
|
63
|
+
type: "string",
|
|
64
|
+
value: "width",
|
|
65
|
+
template: "width,"
|
|
66
|
+
};
|
|
67
|
+
props.height = {
|
|
68
|
+
type: "string",
|
|
69
|
+
value: "height",
|
|
70
|
+
template: "height,"
|
|
71
|
+
};
|
|
72
|
+
} else {
|
|
73
|
+
const getSizeProps = addSizeFunctionAsset(imports, assets, options);
|
|
74
|
+
componentInternalCode.push(`const size = useMemo(() => ${getSizeProps}(width, height, ${hasComputedRatio ? "ratio" : ratioValue}), [width, height${hasComputedRatio ? ", ratio" : ""}]);`);
|
|
75
|
+
reactNamedImports.add("useMemo");
|
|
76
|
+
props.width = {
|
|
77
|
+
type: "string",
|
|
78
|
+
value: "width",
|
|
79
|
+
template: "...size,"
|
|
80
|
+
};
|
|
81
|
+
props.height = {
|
|
82
|
+
type: "string",
|
|
83
|
+
value: "height",
|
|
84
|
+
template: ""
|
|
85
|
+
};
|
|
86
|
+
}
|
|
87
|
+
if (options.square) props.square = { type: "boolean" };
|
|
88
|
+
props.viewBox = {
|
|
89
|
+
value: "viewBox",
|
|
90
|
+
template: "viewBox,"
|
|
91
|
+
};
|
|
92
|
+
props.content = {
|
|
93
|
+
value: stringifyFactoryIconContent(data.icon, options, isEmbeddedCSS ? style : void 0),
|
|
94
|
+
template: hasFallback ? void 0 : "dangerouslySetInnerHTML: {__html: {value}},"
|
|
95
|
+
};
|
|
96
|
+
if (hasFallback && data.fallback) props.fallback = data.fallback;
|
|
97
|
+
componentInternalCode.push(`return ${createElement}(${hasFallback ? "Icon" : "'svg'"}, {
|
|
98
|
+
\t\t${stringifyFactoryPropsAsJSON(props, "\n ")}
|
|
99
|
+
\t});`);
|
|
100
|
+
const beforeFunction = componentExternalCode.length ? componentExternalCode.join("\n") + "\n\n" : "";
|
|
101
|
+
const usedProps = getUsedFactoryProps(props);
|
|
102
|
+
const propsDestricturing = usedProps.length ? `{${[...usedProps, "...props"].join(", ")}}` : "props";
|
|
103
|
+
const componentFunction = `function Component${useTS ? `<{\n${stringifyFactoryPropTypes(props)}\n}>` : ""}(${propsDestricturing}) {
|
|
104
|
+
\t${componentInternalCode.join("\n ")}
|
|
105
|
+
}
|
|
106
|
+
`;
|
|
107
|
+
const content = `${stringifyFactoryImports(imports)}\n${beforeFunction}${componentFunction}\nexport default Component;\n`;
|
|
108
|
+
const types = addReactComponentTypes(data, options, assets, props);
|
|
109
|
+
return {
|
|
110
|
+
assets,
|
|
111
|
+
content,
|
|
112
|
+
style: isEmbeddedCSS ? void 0 : style,
|
|
113
|
+
types,
|
|
114
|
+
dependencies: dependencies.size ? dependencies : void 0
|
|
115
|
+
};
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
export { createJSXComponent };
|
package/lib/components/raw.js
CHANGED
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
import { getComponentSizeValues } from "./helpers/content/size.js";
|
|
2
2
|
import { stringifyFactoryIconContent } from "./helpers/content/stringify.js";
|
|
3
|
-
import { getGeneratedComponentTypesFilename } from "./helpers/filenames/types.js";
|
|
4
3
|
import { stringifyIconViewBox } from "../svg/viewbox/value.js";
|
|
5
4
|
import { createFactoryImports } from "./helpers/imports/create.js";
|
|
6
5
|
import { generateCSSFilesForComponent } from "./helpers/css/generate.js";
|
|
7
|
-
import { stringifyFactoryImports } from "./helpers/imports/stringify.js";
|
|
8
6
|
import { factoryPropTemplate, stringifyFactoryProps } from "./helpers/props/stringify.js";
|
|
7
|
+
import { stringifyFactoryImports } from "./helpers/imports/stringify.js";
|
|
8
|
+
import { getGeneratedComponentTypesFilename } from "./helpers/filenames/types.js";
|
|
9
9
|
|
|
10
10
|
/**
|
|
11
11
|
* Create raw component code
|
package/lib/components/svelte.js
CHANGED
|
@@ -3,14 +3,14 @@ import { stringifyFactoryIconContent } from "./helpers/content/stringify.js";
|
|
|
3
3
|
import { stringifyIconViewBox } from "../svg/viewbox/value.js";
|
|
4
4
|
import { createFactoryImports } from "./helpers/imports/create.js";
|
|
5
5
|
import { generateCSSFilesForComponent } from "./helpers/css/generate.js";
|
|
6
|
-
import { stringifyFactoryImports } from "./helpers/imports/stringify.js";
|
|
7
|
-
import { stringifyFactoryProps } from "./helpers/props/stringify.js";
|
|
8
6
|
import { addSizeFunctionAsset } from "./helpers/functions/size.js";
|
|
7
|
+
import { stringifyFactoryProps } from "./helpers/props/stringify.js";
|
|
8
|
+
import { stringifyFactoryImports } from "./helpers/imports/stringify.js";
|
|
9
9
|
import { makeSquareViewBox } from "../svg/viewbox/square.js";
|
|
10
10
|
import { getUsedFactoryProps, stringifyFactoryPropTypes } from "./helpers/props/ts.js";
|
|
11
|
-
import { addSvelteComponentTypes } from "./helpers/ts/svelte.js";
|
|
12
11
|
import { minifyViewBox } from "../svg/viewbox/minify.js";
|
|
13
12
|
import { getViewBoxRatio } from "./helpers/content/ratio.js";
|
|
13
|
+
import { addSvelteComponentTypes } from "./helpers/ts/svelte.js";
|
|
14
14
|
|
|
15
15
|
/**
|
|
16
16
|
* Create Svelte component code
|
|
@@ -19,8 +19,12 @@ function createSvelteComponent(data, options) {
|
|
|
19
19
|
const useTS = options.ts ?? false;
|
|
20
20
|
const assets = [];
|
|
21
21
|
const imports = createFactoryImports();
|
|
22
|
+
const dependencies = /* @__PURE__ */ new Set();
|
|
22
23
|
const hasFallback = !!data.fallback;
|
|
23
|
-
if (hasFallback)
|
|
24
|
+
if (hasFallback) {
|
|
25
|
+
imports.default["@iconify/css-svelte"] = "Icon";
|
|
26
|
+
dependencies.add("@iconify/css-svelte");
|
|
27
|
+
}
|
|
24
28
|
const styleContent = generateCSSFilesForComponent(data.icon, imports, assets, {
|
|
25
29
|
...options,
|
|
26
30
|
componentType: "svelte"
|
|
@@ -82,7 +86,8 @@ function createSvelteComponent(data, options) {
|
|
|
82
86
|
template: hasFallback ? `content={content} fallback="${data.fallback}"` : ""
|
|
83
87
|
};
|
|
84
88
|
const usedProps = getUsedFactoryProps(props);
|
|
85
|
-
|
|
89
|
+
const propsDestricturing = usedProps.length ? `{${[...usedProps, "...props"].join(", ")}}` : "props";
|
|
90
|
+
componentCode.unshift(`let ${propsDestricturing}${useTS ? ": Props" : ""} = $props();\n`);
|
|
86
91
|
if (useTS) componentCode.unshift(`interface Props {\n${stringifyFactoryPropTypes(props)}\n};\n`);
|
|
87
92
|
const tag = hasFallback ? "Icon" : "svg";
|
|
88
93
|
const template = `<${tag} ${stringifyFactoryProps(props, "{prop}={{value}}")} {...props}>${innerHTML}</${tag}>`;
|
|
@@ -99,7 +104,8 @@ ${template}
|
|
|
99
104
|
assets,
|
|
100
105
|
content,
|
|
101
106
|
style,
|
|
102
|
-
types
|
|
107
|
+
types,
|
|
108
|
+
dependencies: dependencies.size ? dependencies : void 0
|
|
103
109
|
};
|
|
104
110
|
}
|
|
105
111
|
|
|
@@ -3,14 +3,14 @@ import { stringifyFactoryIconContent } from "./helpers/content/stringify.js";
|
|
|
3
3
|
import { stringifyIconViewBox } from "../svg/viewbox/value.js";
|
|
4
4
|
import { createFactoryImports } from "./helpers/imports/create.js";
|
|
5
5
|
import { generateCSSFilesForComponent } from "./helpers/css/generate.js";
|
|
6
|
-
import { stringifyFactoryImports } from "./helpers/imports/stringify.js";
|
|
7
6
|
import { addSizeFunctionAsset } from "./helpers/functions/size.js";
|
|
7
|
+
import { stringifyFactoryPropsAsJSON } from "./helpers/props/object.js";
|
|
8
|
+
import { stringifyFactoryImports } from "./helpers/imports/stringify.js";
|
|
8
9
|
import { makeSquareViewBox } from "../svg/viewbox/square.js";
|
|
9
10
|
import { getUsedFactoryProps } from "./helpers/props/ts.js";
|
|
10
11
|
import { minifyViewBox } from "../svg/viewbox/minify.js";
|
|
11
12
|
import { getViewBoxRatio } from "./helpers/content/ratio.js";
|
|
12
13
|
import { addVueComponentTypes } from "./helpers/ts/vue.js";
|
|
13
|
-
import { stringifyFactoryPropsAsJSON } from "./helpers/props/object.js";
|
|
14
14
|
|
|
15
15
|
/**
|
|
16
16
|
* Create functional Vue component code
|
|
@@ -18,8 +18,12 @@ import { stringifyFactoryPropsAsJSON } from "./helpers/props/object.js";
|
|
|
18
18
|
function createVueFunctionalComponent(data, options) {
|
|
19
19
|
const assets = [];
|
|
20
20
|
const imports = createFactoryImports();
|
|
21
|
+
const dependencies = /* @__PURE__ */ new Set();
|
|
21
22
|
const hasFallback = !!data.fallback;
|
|
22
|
-
if (hasFallback)
|
|
23
|
+
if (hasFallback) {
|
|
24
|
+
imports.named["@iconify/css-vue"] = new Set(["Icon"]);
|
|
25
|
+
dependencies.add("@iconify/css-vue");
|
|
26
|
+
}
|
|
23
27
|
const vueNamedImports = new Set(["defineComponent", "h"]);
|
|
24
28
|
imports.named["vue"] = vueNamedImports;
|
|
25
29
|
const style = generateCSSFilesForComponent(data.icon, imports, assets, options);
|
|
@@ -94,7 +98,8 @@ function createVueFunctionalComponent(data, options) {
|
|
|
94
98
|
assets,
|
|
95
99
|
content: `${stringifyFactoryImports(imports)}\n${componentFunction}\nexport default Component;\n`,
|
|
96
100
|
style: isEmbeddedCSS ? void 0 : style,
|
|
97
|
-
types
|
|
101
|
+
types,
|
|
102
|
+
dependencies: dependencies.size ? dependencies : void 0
|
|
98
103
|
};
|
|
99
104
|
}
|
|
100
105
|
|
package/lib/components/vue.js
CHANGED
|
@@ -3,9 +3,9 @@ import { stringifyFactoryIconContent } from "./helpers/content/stringify.js";
|
|
|
3
3
|
import { stringifyIconViewBox } from "../svg/viewbox/value.js";
|
|
4
4
|
import { createFactoryImports } from "./helpers/imports/create.js";
|
|
5
5
|
import { generateCSSFilesForComponent } from "./helpers/css/generate.js";
|
|
6
|
-
import { stringifyFactoryImports } from "./helpers/imports/stringify.js";
|
|
7
|
-
import { stringifyFactoryProps } from "./helpers/props/stringify.js";
|
|
8
6
|
import { addSizeFunctionAsset } from "./helpers/functions/size.js";
|
|
7
|
+
import { stringifyFactoryProps } from "./helpers/props/stringify.js";
|
|
8
|
+
import { stringifyFactoryImports } from "./helpers/imports/stringify.js";
|
|
9
9
|
import { makeSquareViewBox } from "../svg/viewbox/square.js";
|
|
10
10
|
import { getUsedFactoryProps, stringifyFactoryPropTypes } from "./helpers/props/ts.js";
|
|
11
11
|
import { minifyViewBox } from "../svg/viewbox/minify.js";
|
|
@@ -19,8 +19,12 @@ function createVueComponent(data, options) {
|
|
|
19
19
|
const useTS = options.ts ?? false;
|
|
20
20
|
const assets = [];
|
|
21
21
|
const imports = createFactoryImports();
|
|
22
|
+
const dependencies = /* @__PURE__ */ new Set();
|
|
22
23
|
const hasFallback = !!data.fallback;
|
|
23
|
-
if (hasFallback)
|
|
24
|
+
if (hasFallback) {
|
|
25
|
+
imports.named["@iconify/css-vue"] = new Set(["Icon"]);
|
|
26
|
+
dependencies.add("@iconify/css-vue");
|
|
27
|
+
}
|
|
24
28
|
const vueNamedImports = /* @__PURE__ */ new Set();
|
|
25
29
|
imports.named["vue"] = vueNamedImports;
|
|
26
30
|
const styleContent = generateCSSFilesForComponent(data.icon, imports, assets, options);
|
|
@@ -98,7 +102,8 @@ ${template}
|
|
|
98
102
|
assets,
|
|
99
103
|
content,
|
|
100
104
|
style,
|
|
101
|
-
types
|
|
105
|
+
types,
|
|
106
|
+
dependencies: dependencies.size ? dependencies : void 0
|
|
102
107
|
};
|
|
103
108
|
}
|
|
104
109
|
|
package/package.json
CHANGED
|
@@ -3,7 +3,7 @@
|
|
|
3
3
|
"type": "module",
|
|
4
4
|
"description": "Common functions for working with SVG used by various packages.",
|
|
5
5
|
"author": "Vjacheslav Trushkin",
|
|
6
|
-
"version": "1.0.
|
|
6
|
+
"version": "1.0.8",
|
|
7
7
|
"license": "MIT",
|
|
8
8
|
"bugs": "https://github.com/cyberalien/svg-utils/issues",
|
|
9
9
|
"homepage": "https://cyberalien.dev/",
|