diff --git a/preview/html/testpage.pug b/preview/html/testpage.pug
index 4844936..0d97d99 100644
--- a/preview/html/testpage.pug
+++ b/preview/html/testpage.pug
@@ -18,7 +18,7 @@ body
p.grid
each icon in icons
- i.si.si--color(class='si-' + icon.slug, title=icon.name)
+ i.si.si--color(class='si-' + icon.slug, title=icon.title)
p.paragraph
| An icon like #[i.si.si--color.si-github(title='Github')] inside a paragraph.
diff --git a/scripts/build-testpage.js b/scripts/build-testpage.js
index 6817fcb..b067356 100644
--- a/scripts/build-testpage.js
+++ b/scripts/build-testpage.js
@@ -7,7 +7,7 @@
import fs from 'node:fs';
import path from 'node:path';
import pug from 'pug';
-import * as icons from 'simple-icons/icons';
+import { getIconsData, titleToSlug } from 'simple-icons/sdk';
import { fileURLToPath } from 'node:url';
const __dirname = path.dirname(fileURLToPath(import.meta.url));
@@ -16,6 +16,12 @@ const ROOT_DIR = path.resolve(__dirname, '..');
const INPUT_FILE = path.join(ROOT_DIR, 'preview', 'html', 'testpage.pug');
const OUTPUT_FILE = path.join(ROOT_DIR, 'preview', 'testpage.html');
+const iconsData = await getIconsData();
+const icons = iconsData.map((icon) => ({
+ title: icon.title,
+ slug: icon.slug || titleToSlug(icon.title),
+}));
+
pug.renderFile(INPUT_FILE, { icons }, (renderError, html) => {
if (renderError) {
throw renderError;
diff --git a/scripts/build.js b/scripts/build.js
index 20176fa..2574e5d 100644
--- a/scripts/build.js
+++ b/scripts/build.js
@@ -10,6 +10,7 @@ import fsSync, { promises as fs } from 'node:fs';
import path from 'node:path';
import punycode from 'punycode/punycode.js';
import * as simpleIcons from 'simple-icons/icons';
+import { getIconsData, titleToSlug } from 'simple-icons/sdk';
import svg2ttf from 'svg2ttf';
import SVGPath from 'svgpath';
import ttf2eot from 'ttf2eot';
@@ -46,13 +47,19 @@ const cssDecodeUnicode = (value) => {
return value.replace('', '\\').replace(';', '').toLowerCase();
};
+const icons = await getIconsData();
+const iconKeys = icons.map((icon) => {
+ const slug = icon.slug ?? titleToSlug(icon.title);
+ return 'si' + slug.at(0).toUpperCase() + slug.slice(1);
+});
+
const buildSimpleIconsSvgFontFile = async () => {
const usedUnicodes = [];
const unicodeHexBySlug = [];
let startUnicode = 0xea01;
let glyphsContent = '';
- for (const si in simpleIcons) {
+ for (const key of iconKeys) {
const nextUnicode = punycode.ucs2.decode(
String.fromCodePoint(startUnicode++),
);
@@ -63,7 +70,7 @@ const buildSimpleIconsSvgFontFile = async () => {
throw Error(`Unicodes must be unique. Found '${unicodeString}' repeated`);
}
- const icon = simpleIcons[si];
+ const icon = simpleIcons[key];
const verticalTransformedPath = SVGPath(icon.path)
.translate(0, -24)
.scale(50, -50)