mirror of
https://github.com/Mibew/simple-icons.git
synced 2024-11-16 02:14:12 +03:00
2d3485b8c1
* Use getter for 'svg' instead of 'path' in packaged javascript version of icons * Use variable to avoid calling `escape` twice * Convert title to HTML friendly in build script * Update tests * Only friendly title for SVG content * Add equality test for SVG contents * Add missing import * Test using icons template * Fix lint error * Fix lint error in utils * Read files synchronicly in tests * Remove done from tests, make them pass * Remove uneeded imports * Remove replacements in tests * Update with changes in develop * Drop uneeded requirement * Space between requirements * Simplify encoding utility * Fix syntax error * Apply @ericcornelissen's suggestions * Apply @ericcornelissen's suggestions
69 lines
1.9 KiB
JavaScript
69 lines
1.9 KiB
JavaScript
/**
|
||
* @fileoverview
|
||
* Some common utilities for scripts.
|
||
*/
|
||
|
||
module.exports = {
|
||
/**
|
||
* Get the slug/filename for an icon.
|
||
* @param {Object} icon The icon data as it appears in _data/simple-icons.json
|
||
*/
|
||
getIconSlug: (icon) => icon.slug || module.exports.titleToSlug(icon.title),
|
||
|
||
/**
|
||
* Extract the path from an icon SVG content.
|
||
* @param {Object} svg The icon SVG content
|
||
**/
|
||
svgToPath: (svg) => svg.match(/<path\s+d="([^"]*)/)[1],
|
||
|
||
/**
|
||
* Converts a brand title into a slug/filename.
|
||
* @param {String} title The title to convert
|
||
*/
|
||
titleToSlug: (title) =>
|
||
title
|
||
.toLowerCase()
|
||
.replace(/\+/g, 'plus')
|
||
.replace(/\./g, 'dot')
|
||
.replace(/&/g, 'and')
|
||
.replace(/đ/g, 'd')
|
||
.replace(/ħ/g, 'h')
|
||
.replace(/ı/g, 'i')
|
||
.replace(/ĸ/g, 'k')
|
||
.replace(/ŀ/g, 'l')
|
||
.replace(/ł/g, 'l')
|
||
.replace(/ß/g, 'ss')
|
||
.replace(/ŧ/g, 't')
|
||
.normalize('NFD')
|
||
.replace(/[^a-z0-9]/g, ''),
|
||
|
||
/**
|
||
* Converts a brand title in HTML/SVG friendly format into a brand title (as
|
||
* it is seen in simple-icons.json)
|
||
* @param {String} htmlFriendlyTitle The title to convert
|
||
*/
|
||
htmlFriendlyToTitle: (htmlFriendlyTitle) =>
|
||
htmlFriendlyTitle
|
||
.replace(/&#([0-9]+);/g, (_, num) => String.fromCharCode(parseInt(num)))
|
||
.replace(
|
||
/&(quot|amp|lt|gt);/g,
|
||
(_, ref) => ({ quot: '"', amp: '&', lt: '<', gt: '>' }[ref]),
|
||
),
|
||
|
||
/**
|
||
* Converts a brand title (as it is seen in simple-icons.json) into a brand
|
||
* title in HTML/SVG friendly format.
|
||
* @param {String} brandTitle The title to convert
|
||
*/
|
||
titleToHtmlFriendly: (brandTitle) =>
|
||
brandTitle
|
||
.replace(/&/g, '&')
|
||
.replace(/"/g, '"')
|
||
.replace(/</g, '<')
|
||
.replace(/>/g, '>')
|
||
.replace(/./g, (char) => {
|
||
const charCode = char.charCodeAt(0);
|
||
return charCode > 127 ? `&#${charCode};` : char;
|
||
}),
|
||
};
|