This repository has been archived by the owner on Mar 18, 2023. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgatsby-node.js
114 lines (102 loc) · 2.53 KB
/
gatsby-node.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
const fs = require("fs").promises;
const { optimize: optimizeSVG } = require("svgo");
const svgoOptions = {
multipass: true,
floatPrecision: 2,
plugins: [
// Default
"removeDoctype",
"removeXMLProcInst",
"removeComments",
"removeMetadata",
"removeEditorsNSData",
"cleanupAttrs",
"mergeStyles",
"inlineStyles",
"minifyStyles",
"cleanupIDs",
"removeUselessDefs",
"cleanupNumericValues",
"convertColors",
"removeUnknownsAndDefaults",
"removeNonInheritableGroupAttrs",
"removeUselessStrokeAndFill",
// "removeViewBox",
"cleanupEnableBackground",
"removeHiddenElems",
"removeEmptyText",
"convertShapeToPath",
"convertEllipseToCircle",
"moveElemsAttrsToGroup",
"moveGroupAttrsToElems",
"collapseGroups",
"convertPathData",
"convertTransform",
"removeEmptyAttrs",
"removeEmptyContainers",
"mergePaths",
"removeUnusedNS",
"sortDefsChildren",
"removeTitle",
"removeDesc",
// Custom
"removeXMLNS",
],
};
exports.createSchemaCustomization = ({ actions: { createTypes } }) => {
createTypes(`
type SvgContent {
data: String!
width: Int
height: Int
}
type Svg implements Node @childOf(types: ["File"], mimeTypes: ["image/svg+xml"]) {
content: SvgContent
}`);
};
exports.onCreateNode = function({ node, actions, createNodeId }) {
const { createNode, createParentChildLink } = actions;
if (node.extension !== "svg") return;
const svgNode = {
id: createNodeId(`${node.id} >> Svg`),
children: [],
parent: node.id,
internal: {
contentDigest: `${node.internal.contentDigest}`,
type: `Svg`,
},
};
createNode(svgNode);
createParentChildLink({ parent: node, child: svgNode });
};
exports.createResolvers = (
{ createResolvers, getNodeAndSavePathDependency },
pluginOptions
) => {
createResolvers({
Svg: {
content: {
async resolve(node, _fieldArgs, context) {
const { absolutePath } = getNodeAndSavePathDependency(
node.parent,
context.path
);
const svg = await fs.readFile(absolutePath);
if (!svg) return null;
try {
const {
data,
info: { width, height },
} = optimizeSVG(svg, {
...(pluginOptions.svgo || svgoOptions),
path: absolutePath,
});
return { data, width, height };
} catch (err) {
return null;
}
},
},
},
});
};