export bundled icons from one entry point and add types (#6767)

* export all icons from a single file (#6189)

* fix: revert formatting, add exports to package.json

* feat: generate icons.js and add relevant exports field

* add minifyAndWrite

Co-authored-by: Eric Cornelissen <ericornelissen@gmail.com>

* fix: minifyAndWrite build

* add type: commonjs

Co-authored-by: Eric Cornelissen <ericornelissen@gmail.com>

* simplify exports

Co-authored-by: Eric Cornelissen <ericornelissen@gmail.com>

* add "require" in exports

* place objects directly in barrel file

* write exports minified

Co-authored-by: Eric Cornelissen <ericornelissen@gmail.com>

* fix formatting

Co-authored-by: Eric Cornelissen <ericornelissen@gmail.com>

* refactor slugToVariableName code into a function

* fix slugToVariableName

* change prefix to "si"

* move slugToVariableName to local helper functions

* unignore icons.js and icons.mjs

Co-authored-by: Eric Cornelissen <ericornelissen@gmail.com>

* feat: add types (#6580)

* feat: add types

* fix linting error

* export default from types/index.d.ts

* minify

* revert formatting changes

* revert formatting change

* change paths from types/index.d.ts to index.d.ts

* mark icons.get as deprecated

* move type alias to another file

* update readme

* update readme.md

Co-authored-by: Eric Cornelissen <ericornelissen@gmail.com>

* update typescript usage section

Co-authored-by: Eric Cornelissen <ericornelissen@gmail.com>

* fix conflicts

* Apply suggestions from code review

Co-authored-by: Eric Cornelissen <ericornelissen@gmail.com>

* add writeTs function

Co-authored-by: Eric Cornelissen <ericornelissen@gmail.com>
This commit is contained in:
Sachin Raja 2021-10-28 16:16:34 -07:00 committed by GitHub
parent dd0cc815a1
commit 1a77d28227
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
7 changed files with 105 additions and 11 deletions

3
.gitignore vendored
View File

@ -1,5 +1,8 @@
# Files generated by build script # Files generated by build script
/index.js /index.js
/icons.js
/icons.mjs
/icons.d.ts
# Ignore all files in the icons folder # Ignore all files in the icons folder
icons/* icons/*

View File

@ -9,3 +9,8 @@
!LICENSE.md !LICENSE.md
!VERSIONING.md !VERSIONING.md
!index.js !index.js
!index.d.ts
!icons.js
!icons.mjs
!icons.d.ts
!alias.d.ts

View File

@ -60,9 +60,17 @@ const icon = simpleIcons.Get('simpleicons');
``` ```
Alternatively you can import the needed icons individually, where `[ICON SLUG]` is replaced by a [slug]. Alternatively, you can also import all icons from a single file, where `[ICON SLUG]` is replaced by a capitalized [slug]. We highly recommend using a bundler that can tree shake such as [webpack](https://webpack.js.org/) to remove the unused icon code:
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: ```javascript
// Import a specific icon by its slug as:
// import { si[ICON SLUG] } from 'simple-icons/icons'
// For example:
// use import/esm to allow tree shaking
import { siSimpleicons } from 'simple-icons/icons'
```
You can also import the needed icons individually, where `[ICON SLUG]` is replaced by a [slug].
```javascript ```javascript
// Import a specific icon by its slug as: // Import a specific icon by its slug as:
// require('simple-icons/icons/[ICON SLUG]'); // require('simple-icons/icons/[ICON SLUG]');
@ -110,11 +118,7 @@ for (const iconSlug in simpleIcons) {
#### TypeScript Usage #### TypeScript Usage
There are also TypeScript type definitions for the Node package. To use them, simply run: Type definitions are bundled with the package.
```shell
npm install --save-dev @types/simple-icons
```
### PHP Usage ### PHP Usage

6
alias.d.ts vendored Normal file
View File

@ -0,0 +1,6 @@
import { SimpleIcon } from '.';
/**
* @internal
*/
export type I = SimpleIcon;

25
index.d.ts vendored Normal file
View File

@ -0,0 +1,25 @@
export interface SimpleIcon {
title: string;
slug: string;
svg: string;
path: string;
source: string;
hex: string;
guidelines?: string | undefined;
license?:
| {
type: string;
url: string;
}
| undefined;
}
declare const icons: Record<string, SimpleIcon> & {
/**
* @deprecated use .Get instead
*/
get(name: string): SimpleIcon;
Get(name: string): SimpleIcon;
};
export default icons;

View File

@ -7,7 +7,20 @@
"svg", "svg",
"icons" "icons"
], ],
"type": "commonjs",
"main": "index.js", "main": "index.js",
"types": "index.d.ts",
"exports": {
".": "./index.js",
"./icons": {
"module": "./icons.mjs",
"import": "./icons.mjs",
"require": "./icons.js",
"default": "./icons.js"
},
"./icons/*": "./icons/*.js"
},
"sideEffects": false,
"repository": { "repository": {
"type": "git", "type": "git",
"url": "git+ssh://git@github.com/simple-icons/simple-icons.git" "url": "git+ssh://git@github.com/simple-icons/simple-icons.git"
@ -37,7 +50,7 @@
}, },
"scripts": { "scripts": {
"build": "node scripts/build/package.js", "build": "node scripts/build/package.js",
"clean": "rimraf icons/*.js index.js", "clean": "rimraf icons/*.js icons/*.d.ts index.js icons.js icons.mjs icons.d.ts",
"format": "prettier --write .", "format": "prettier --write .",
"lint": "run-s our-lint jslint jsonlint svglint wslint", "lint": "run-s our-lint jslint jsonlint svglint wslint",
"our-lint": "node scripts/lint/ourlint.js", "our-lint": "node scripts/lint/ourlint.js",

View File

@ -18,6 +18,9 @@ const rootDir = path.resolve(__dirname, '..', '..');
const dataFile = path.resolve(rootDir, '_data', 'simple-icons.json'); const dataFile = path.resolve(rootDir, '_data', 'simple-icons.json');
const indexFile = path.resolve(rootDir, 'index.js'); const indexFile = path.resolve(rootDir, 'index.js');
const iconsDir = path.resolve(rootDir, 'icons'); const iconsDir = path.resolve(rootDir, 'icons');
const iconsJsFile = path.resolve(rootDir, 'icons.js');
const iconsMjsFile = path.resolve(rootDir, 'icons.mjs');
const iconsDtsFile = path.resolve(rootDir, 'icons.d.ts');
const templatesDir = path.resolve(__dirname, 'templates'); const templatesDir = path.resolve(__dirname, 'templates');
const indexTemplateFile = path.resolve(templatesDir, 'index.js'); const indexTemplateFile = path.resolve(templatesDir, 'index.js');
@ -58,7 +61,12 @@ const iconToObject = (icon) => {
licenseToObject(icon.license), licenseToObject(icon.license),
); );
}; };
const minifyAndWrite = (filepath, rawJavaScript) => { const slugToVariableName = (slug) => {
const slugFirstLetter = slug[0].toUpperCase();
const slugRest = slug.slice(1);
return `si${slugFirstLetter}${slugRest}`;
};
const writeJs = (filepath, rawJavaScript) => {
const { error, code } = minify(rawJavaScript); const { error, code } = minify(rawJavaScript);
if (error) { if (error) {
console.error(error); console.error(error);
@ -67,8 +75,14 @@ const minifyAndWrite = (filepath, rawJavaScript) => {
fs.writeFileSync(filepath, code); fs.writeFileSync(filepath, code);
} }
}; };
const writeTs = (filepath, rawTypeScript) => {
fs.writeFileSync(filepath, rawTypeScript);
};
// 'main' // 'main'
const iconsBarrelMjs = [];
const iconsBarrelJs = [];
const iconsBarrelDts = [];
const icons = []; const icons = [];
data.icons.forEach((icon) => { data.icons.forEach((icon) => {
const filename = getIconSlug(icon); const filename = getIconSlug(icon);
@ -77,9 +91,23 @@ data.icons.forEach((icon) => {
icon.slug = filename; icon.slug = filename;
icons.push(icon); icons.push(icon);
const iconObject = iconToObject(icon);
// write the static .js file for the icon // write the static .js file for the icon
const jsFilepath = path.resolve(iconsDir, `${filename}.js`); const jsFilepath = path.resolve(iconsDir, `${filename}.js`);
minifyAndWrite(jsFilepath, `module.exports=${iconToObject(icon)};`); 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;`);
}); });
// write our generic index.js // write our generic index.js
@ -87,4 +115,14 @@ const rawIndexJs = util.format(
indexTemplate, indexTemplate,
icons.map(iconToKeyValue).join(','), icons.map(iconToKeyValue).join(','),
); );
minifyAndWrite(indexFile, rawIndexJs); 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);