@iconify/tools 2.2.2 → 2.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.
@@ -96,7 +96,9 @@ async function exportJSONPackage(iconSet, options) {
96
96
  if (data !== void 0) {
97
97
  await misc_writeJson.writeJSONFile(`${dir}/${jsonFilename}`, data);
98
98
  cjsImports.push(`const ${attr} = require('${relativeFile}');`);
99
- mjsImports.push(`import ${attr} from '${relativeFile}';`);
99
+ mjsImports.push(
100
+ `import ${attr} from '${relativeFile}' assert { type: 'json' };`
101
+ );
100
102
  packageJSONIconSet[attr] = attr + ".json";
101
103
  packageJSONExports[relativeFile] = relativeFile;
102
104
  } else {
@@ -94,7 +94,9 @@ async function exportJSONPackage(iconSet, options) {
94
94
  if (data !== void 0) {
95
95
  await writeJSONFile(`${dir}/${jsonFilename}`, data);
96
96
  cjsImports.push(`const ${attr} = require('${relativeFile}');`);
97
- mjsImports.push(`import ${attr} from '${relativeFile}';`);
97
+ mjsImports.push(
98
+ `import ${attr} from '${relativeFile}' assert { type: 'json' };`
99
+ );
98
100
  packageJSONIconSet[attr] = attr + ".json";
99
101
  packageJSONExports[relativeFile] = relativeFile;
100
102
  } else {
@@ -55,7 +55,8 @@ function getFigmaIconNodes(document, options) {
55
55
  switch (parentNodeType) {
56
56
  case "CANVAS":
57
57
  case "FRAME":
58
- case "GROUP": {
58
+ case "GROUP":
59
+ case "SECTION": {
59
60
  const parentItem = {
60
61
  ...node,
61
62
  type: parentNodeType
@@ -53,7 +53,8 @@ function getFigmaIconNodes(document, options) {
53
53
  switch (parentNodeType) {
54
54
  case "CANVAS":
55
55
  case "FRAME":
56
- case "GROUP": {
56
+ case "GROUP":
57
+ case "SECTION": {
57
58
  const parentItem = {
58
59
  ...node,
59
60
  type: parentNodeType
@@ -7,7 +7,7 @@ import '../../../icon-set/types.js';
7
7
  import '../../../svg/index.js';
8
8
  import '@iconify/utils/lib/icon-set/tree';
9
9
 
10
- type FigmaImportParentNodeType = 'CANVAS' | 'FRAME' | 'GROUP';
10
+ type FigmaImportParentNodeType = 'CANVAS' | 'FRAME' | 'GROUP' | 'SECTION';
11
11
  type FigmaImportIconNodeType = IconFigmaNode['type'];
12
12
  /**
13
13
  * Node information passed to callback
@@ -8,9 +8,13 @@ function scaleSVG(svg, scale) {
8
8
  const viewBox = svg.viewBox;
9
9
  const width = viewBox.width * scale;
10
10
  const height = viewBox.height * scale;
11
- const left = viewBox.left * scale;
12
- const top = viewBox.top * scale;
13
- const content = `<svg width="${width}" height="${height}" viewBox="${left} ${top} ${width} ${height}"><g transform="scale(${scale})">${svg.getBody()}</g></svg>`;
11
+ let shiftTransform = "";
12
+ let shiftTransformEnd = "";
13
+ if (viewBox.left !== 0 || viewBox.top !== 0) {
14
+ shiftTransform = `<g transform="translate(${0 - viewBox.left} ${0 - viewBox.top})">`;
15
+ shiftTransformEnd = "</g>";
16
+ }
17
+ const content = `<svg width="${width}" height="${height}" viewBox="0 0 ${width} ${height}"><g transform="scale(${scale})">${shiftTransform}${svg.getBody()}${shiftTransformEnd}</g></svg>`;
14
18
  svg.load(content);
15
19
  optimise_svgo.runSVGO(svg, {
16
20
  plugins: [
@@ -6,9 +6,13 @@ function scaleSVG(svg, scale) {
6
6
  const viewBox = svg.viewBox;
7
7
  const width = viewBox.width * scale;
8
8
  const height = viewBox.height * scale;
9
- const left = viewBox.left * scale;
10
- const top = viewBox.top * scale;
11
- const content = `<svg width="${width}" height="${height}" viewBox="${left} ${top} ${width} ${height}"><g transform="scale(${scale})">${svg.getBody()}</g></svg>`;
9
+ let shiftTransform = "";
10
+ let shiftTransformEnd = "";
11
+ if (viewBox.left !== 0 || viewBox.top !== 0) {
12
+ shiftTransform = `<g transform="translate(${0 - viewBox.left} ${0 - viewBox.top})">`;
13
+ shiftTransformEnd = "</g>";
14
+ }
15
+ const content = `<svg width="${width}" height="${height}" viewBox="0 0 ${width} ${height}"><g transform="scale(${scale})">${shiftTransform}${svg.getBody()}${shiftTransformEnd}</g></svg>`;
12
16
  svg.load(content);
13
17
  runSVGO(svg, {
14
18
  plugins: [
package/package.json CHANGED
@@ -3,7 +3,7 @@
3
3
  "type": "module",
4
4
  "description": "Collection of functions for cleaning up and parsing SVG for Iconify project",
5
5
  "author": "Vjacheslav Trushkin",
6
- "version": "2.2.2",
6
+ "version": "2.2.4",
7
7
  "license": "MIT",
8
8
  "bugs": "https://github.com/iconify/tools/issues",
9
9
  "homepage": "https://github.com/iconify/tools",