2018-08-27 00:23:57 +03:00
|
|
|
#!/usr/bin/env node
|
|
|
|
/**
|
|
|
|
* @fileoverview
|
|
|
|
* Compiles our icons into static .js files that can be imported in the browser
|
2021-02-08 19:14:31 +03:00
|
|
|
* and are tree-shakeable. The static .js files go in icons/{filename}.js. Also
|
|
|
|
* generates an index.js that exports all icons by title, but is not
|
|
|
|
* tree-shakeable
|
2018-08-27 00:23:57 +03:00
|
|
|
*/
|
|
|
|
|
2021-10-25 22:13:10 +03:00
|
|
|
const fs = require('fs');
|
|
|
|
const path = require('path');
|
|
|
|
const util = require('util');
|
|
|
|
const { minify } = require('uglify-js');
|
2019-07-14 22:05:38 +03:00
|
|
|
|
2021-10-25 22:13:10 +03:00
|
|
|
const UTF8 = 'utf8';
|
2019-08-15 14:23:35 +03:00
|
|
|
|
2021-10-25 22:13:10 +03:00
|
|
|
const rootDir = path.resolve(__dirname, '..', '..');
|
|
|
|
const dataFile = path.resolve(rootDir, '_data', 'simple-icons.json');
|
|
|
|
const indexFile = path.resolve(rootDir, 'index.js');
|
|
|
|
const iconsDir = path.resolve(rootDir, 'icons');
|
2021-10-29 02:16:34 +03:00
|
|
|
const iconsJsFile = path.resolve(rootDir, 'icons.js');
|
|
|
|
const iconsMjsFile = path.resolve(rootDir, 'icons.mjs');
|
|
|
|
const iconsDtsFile = path.resolve(rootDir, 'icons.d.ts');
|
2019-08-15 14:23:35 +03:00
|
|
|
|
2021-10-25 22:13:10 +03:00
|
|
|
const templatesDir = path.resolve(__dirname, 'templates');
|
|
|
|
const indexTemplateFile = path.resolve(templatesDir, 'index.js');
|
|
|
|
const iconObjectTemplateFile = path.resolve(templatesDir, 'icon-object.js');
|
2019-08-15 14:23:35 +03:00
|
|
|
|
|
|
|
const indexTemplate = fs.readFileSync(indexTemplateFile, UTF8);
|
|
|
|
const iconObjectTemplate = fs.readFileSync(iconObjectTemplateFile, UTF8);
|
2018-08-27 00:23:57 +03:00
|
|
|
|
2019-07-14 22:05:38 +03:00
|
|
|
const data = require(dataFile);
|
2021-11-08 13:55:47 +03:00
|
|
|
const {
|
|
|
|
getIconSlug,
|
|
|
|
svgToPath,
|
|
|
|
titleToHtmlFriendly,
|
|
|
|
slugToVariableName,
|
|
|
|
} = require('../utils.js');
|
2018-08-27 00:23:57 +03:00
|
|
|
|
2019-07-14 18:07:24 +03:00
|
|
|
// Local helper functions
|
2021-10-25 22:13:10 +03:00
|
|
|
const escape = (value) => {
|
2020-07-28 13:33:40 +03:00
|
|
|
return value.replace(/(?<!\\)'/g, "\\'");
|
2021-10-25 22:13:10 +03:00
|
|
|
};
|
|
|
|
const iconToKeyValue = (icon) => {
|
2021-05-25 19:40:11 +03:00
|
|
|
return `'${icon.slug}':${iconToObject(icon)}`;
|
2021-10-25 22:13:10 +03:00
|
|
|
};
|
|
|
|
const licenseToObject = (license) => {
|
2021-03-02 15:01:31 +03:00
|
|
|
if (license === undefined) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (license.url === undefined) {
|
2021-04-15 19:33:25 +03:00
|
|
|
license.url = `https://spdx.org/licenses/${license.type}`;
|
2021-03-02 15:01:31 +03:00
|
|
|
}
|
|
|
|
return license;
|
2021-10-25 22:13:10 +03:00
|
|
|
};
|
|
|
|
const iconToObject = (icon) => {
|
|
|
|
return util.format(
|
|
|
|
iconObjectTemplate,
|
2019-08-15 14:23:35 +03:00
|
|
|
escape(icon.title),
|
|
|
|
escape(icon.slug),
|
2021-11-06 18:03:37 +03:00
|
|
|
escape(titleToHtmlFriendly(icon.title)),
|
|
|
|
escape(icon.path),
|
2019-08-15 14:23:35 +03:00
|
|
|
escape(icon.source),
|
2021-03-02 15:01:31 +03:00
|
|
|
escape(icon.hex),
|
2021-03-26 12:33:04 +03:00
|
|
|
icon.guidelines ? `'${escape(icon.guidelines)}'` : undefined,
|
2021-03-02 15:01:31 +03:00
|
|
|
licenseToObject(icon.license),
|
2019-08-15 14:23:35 +03:00
|
|
|
);
|
2021-10-25 22:13:10 +03:00
|
|
|
};
|
2021-10-29 02:16:34 +03:00
|
|
|
const writeJs = (filepath, rawJavaScript) => {
|
2021-02-08 19:14:31 +03:00
|
|
|
const { error, code } = minify(rawJavaScript);
|
|
|
|
if (error) {
|
|
|
|
console.error(error);
|
|
|
|
process.exit(1);
|
|
|
|
} else {
|
|
|
|
fs.writeFileSync(filepath, code);
|
|
|
|
}
|
2021-10-25 22:13:10 +03:00
|
|
|
};
|
2021-10-29 02:16:34 +03:00
|
|
|
const writeTs = (filepath, rawTypeScript) => {
|
|
|
|
fs.writeFileSync(filepath, rawTypeScript);
|
|
|
|
};
|
2019-07-14 18:07:24 +03:00
|
|
|
|
|
|
|
// 'main'
|
2021-10-29 02:16:34 +03:00
|
|
|
const iconsBarrelMjs = [];
|
|
|
|
const iconsBarrelJs = [];
|
|
|
|
const iconsBarrelDts = [];
|
2019-07-14 18:07:24 +03:00
|
|
|
const icons = [];
|
2021-10-25 22:13:10 +03:00
|
|
|
data.icons.forEach((icon) => {
|
2021-02-22 16:15:37 +03:00
|
|
|
const filename = getIconSlug(icon);
|
2021-02-08 19:14:31 +03:00
|
|
|
const svgFilepath = path.resolve(iconsDir, `${filename}.svg`);
|
|
|
|
icon.svg = fs.readFileSync(svgFilepath, UTF8).replace(/\r?\n/, '');
|
2021-11-06 18:03:37 +03:00
|
|
|
icon.path = svgToPath(icon.svg);
|
2021-02-08 19:14:31 +03:00
|
|
|
icon.slug = filename;
|
|
|
|
icons.push(icon);
|
2019-08-15 14:23:35 +03:00
|
|
|
|
2021-10-29 02:16:34 +03:00
|
|
|
const iconObject = iconToObject(icon);
|
|
|
|
|
2021-02-08 19:14:31 +03:00
|
|
|
// write the static .js file for the icon
|
|
|
|
const jsFilepath = path.resolve(iconsDir, `${filename}.js`);
|
2021-10-29 02:16:34 +03:00
|
|
|
writeJs(jsFilepath, `module.exports=${iconObject};`);
|
|
|
|
|
|
|
|
const dtsFilepath = path.resolve(iconsDir, `${filename}.d.ts`);
|
|
|
|
writeTs(
|
|
|
|
dtsFilepath,
|
|
|
|
'declare const i:import("../alias").I;export default i;',
|
|
|
|
);
|
|
|
|
|
|
|
|
// add object to the barrel file
|
|
|
|
const iconExportName = slugToVariableName(icon.slug);
|
|
|
|
iconsBarrelJs.push(`${iconExportName}:${iconObject},`);
|
|
|
|
iconsBarrelMjs.push(`export const ${iconExportName}=${iconObject}`);
|
|
|
|
iconsBarrelDts.push(`export const ${iconExportName}:I;`);
|
2018-08-27 00:23:57 +03:00
|
|
|
});
|
|
|
|
|
|
|
|
// write our generic index.js
|
2021-10-25 22:13:10 +03:00
|
|
|
const rawIndexJs = util.format(
|
|
|
|
indexTemplate,
|
|
|
|
icons.map(iconToKeyValue).join(','),
|
|
|
|
);
|
2021-10-29 02:16:34 +03:00
|
|
|
writeJs(indexFile, rawIndexJs);
|
|
|
|
|
|
|
|
// write our file containing the exports of all icons in CommonJS ...
|
|
|
|
const rawIconsJs = `module.exports={${iconsBarrelJs.join('')}};`;
|
|
|
|
writeJs(iconsJsFile, rawIconsJs);
|
|
|
|
// and ESM
|
|
|
|
const rawIconsMjs = iconsBarrelMjs.join('');
|
|
|
|
writeJs(iconsMjsFile, rawIconsMjs);
|
|
|
|
// and create a type declaration file
|
|
|
|
const rawIconsDts = `import {I} from "./alias";${iconsBarrelDts.join('')}`;
|
|
|
|
writeTs(iconsDtsFile, rawIconsDts);
|