From 6ee6ba977c7c7249e3aa2fb436d19681e058c986 Mon Sep 17 00:00:00 2001 From: Johan Fagerberg Date: Sun, 26 Aug 2018 23:23:57 +0200 Subject: [PATCH] Add prepublish script (#942) * Add prepublish script Compiles icons into both static js files (icons/{filename}.js) and into a static index.js. The latter is not tree-shakeable. Closes #941, closes #751 * Add information on tree-shaking to README * Remove index.js after publishing * Change 'prepublish' to 'prepublishOnly' * Link to webpack in README * Simplify postpublish cleanup Thanks @ericcornelissen * Fix quote usage in prepublish.js * Fix quote usage in utils.js * Optimized file size of prepublish output * Improved readability of prepublish script --- README.md | 17 +++++++++++++++++ index.js | 18 ------------------ package.json | 4 +++- scripts/prepublish.js | 31 +++++++++++++++++++++++++++++++ scripts/utils.js | 14 ++++++++++++++ 5 files changed, 65 insertions(+), 19 deletions(-) delete mode 100644 index.js create mode 100755 scripts/prepublish.js create mode 100644 scripts/utils.js diff --git a/README.md b/README.md index 6c0ee8c0..87f6be27 100644 --- a/README.md +++ b/README.md @@ -47,6 +47,23 @@ console.log(simpleIcons['Google+']); */ ``` +Alternatively you can import the needed icons individually. +This is useful if you are e.g. compiling your code with [webpack](https://webpack.js.org/) and therefore have to be mindful of your package size: + +```js +const googleplus = require('simple-icons/icons/googleplus'); + +console.log(googleplus); +/* +{ + title: 'Google+', + hex: 'DC4E41', + source: 'https://developers.google.com/+/branding-guidelines', + svg: '...' +} +*/ +``` + ## Third Party Extensions ### WordPress diff --git a/index.js b/index.js deleted file mode 100644 index 9d40cefa..00000000 --- a/index.js +++ /dev/null @@ -1,18 +0,0 @@ -const dataFile = './_data/simple-icons.json'; -const data = require(dataFile); -const fs = require('fs'); - -const icons = {}; - -data.icons.forEach(i => { - const filename = i.title.toLowerCase() - .replace(/\+/g, "plus") - .replace(/^\./, "dot-") - .replace(/\.$/, "-dot") - .replace(/\./g, "-dot-") - .replace(/[ !’]/g, ''); - i.svg = fs.readFileSync(`${__dirname}/icons/${filename}.svg`, 'utf8'); - icons[i.title] = i -}); - -module.exports = icons; diff --git a/package.json b/package.json index a4e86bbe..bb9c86d1 100644 --- a/package.json +++ b/package.json @@ -23,6 +23,8 @@ }, "scripts": { "jsonlint": "jsonlint _data/simple-icons.json -q -V .jsonlintschema", - "svglint": "svglint icons/* --ci" + "svglint": "svglint icons/* --ci", + "prepublishOnly": "node scripts/prepublish.js", + "postpublish": "rm icons/*.js index.js" } } diff --git a/scripts/prepublish.js b/scripts/prepublish.js new file mode 100755 index 00000000..00c0e998 --- /dev/null +++ b/scripts/prepublish.js @@ -0,0 +1,31 @@ +#!/usr/bin/env node +/** + * @fileoverview + * Compiles our icons into static .js files that can be imported in the browser + * 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 + */ + +const dataFile = "../_data/simple-icons.json"; +const indexFile = `${__dirname}/../index.js`; +const iconsDir = `${__dirname}/../icons`; +const data = require(dataFile); +const fs = require("fs"); + +const { titleToFilename } = require("./utils"); + +const icons = {}; +data.icons.forEach(icon => { + const filename = titleToFilename(icon.title); + icon.svg = fs.readFileSync(`${iconsDir}/${filename}.svg`, "utf8"); + icons[icon.title] = icon; + // write the static .js file for the icon + fs.writeFileSync( + `${iconsDir}/${filename}.js`, + `module.exports=${JSON.stringify(icon)};` + ); +}); + +// write our generic index.js +fs.writeFileSync(indexFile, `module.exports=${JSON.stringify(icons)};`); diff --git a/scripts/utils.js b/scripts/utils.js new file mode 100644 index 00000000..9cd21c9e --- /dev/null +++ b/scripts/utils.js @@ -0,0 +1,14 @@ +module.exports = { + /** + * Converts a brand title into a filename (not a full path) + * @param {String} title The title to convert + */ + titleToFilename: title => ( + title.toLowerCase() + .replace(/\+/g, "plus") + .replace(/^\./, "dot-") + .replace(/\.$/, "-dot") + .replace(/\./g, "-dot-") + .replace(/[ !’]/g, "") + ) +}