mirror of
https://github.com/tabler/tabler-icons.git
synced 2025-08-22 13:42:50 +02:00
Enhance icon sprite generation: add support for multiple sprite files and improve SVG handling (#1314)
This commit is contained in:
@@ -3,26 +3,36 @@ import { getAllIcons } from '../../.build/helpers.mjs'
|
|||||||
|
|
||||||
const icons = getAllIcons(true)
|
const icons = getAllIcons(true)
|
||||||
|
|
||||||
|
fs.mkdirSync('dist', { recursive: true })
|
||||||
|
|
||||||
const buildSprite = () => {
|
const buildSprite = () => {
|
||||||
let svgContent = ''
|
|
||||||
Object.entries(icons).forEach(([type, iconsInCategory]) => {
|
Object.entries(icons).forEach(([type, iconsInCategory]) => {
|
||||||
|
let svgContent = ''
|
||||||
|
console.log(`Building ${type} sprite...`)
|
||||||
|
|
||||||
iconsInCategory.forEach(icon => {
|
iconsInCategory.forEach(icon => {
|
||||||
|
|
||||||
|
console.log(`Adding ${icon.name}...`)
|
||||||
const svgFileContent = icon.content
|
const svgFileContent = icon.content
|
||||||
.replace(/<svg[^>]+>/g, '')
|
.replace(/<svg[^>]+>/g, '')
|
||||||
.replace(/<\/svg>/g, '')
|
.replace(/<\/svg>/g, '')
|
||||||
.replace(/\n+/g, '')
|
.replace(/\n+/g, '')
|
||||||
.replace(/>\s+</g, '><')
|
.replace(/>\s+</g, '><')
|
||||||
|
.replace('<path stroke="none" d="M0 0h24v24H0z" fill="none"/>', '')
|
||||||
.trim()
|
.trim()
|
||||||
|
|
||||||
svgContent += `<symbol id="tabler-${type == 'outline' ? '' : `${type}-`}${icon.name}" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round">${svgFileContent}</symbol>`
|
svgContent += `<symbol id="tabler-${type == 'outline' ? '' : `${type}-`}${icon.name}" viewBox="0 0 24 24" fill="${type == 'outline' ? 'none' : 'currentColor'}" stroke="${type == 'outline' ? 'currentColor' : 'none'}" stroke-width="2" stroke-linecap="round" stroke-linejoin="round">${svgFileContent}</symbol>`
|
||||||
})
|
})
|
||||||
|
|
||||||
|
let svg = `<svg xmlns="http://www.w3.org/2000/svg" id="tabler-icons${type == 'outline' ? '' : `-${type}`}"><defs>${svgContent}</defs></svg>`
|
||||||
|
|
||||||
|
fs.writeFileSync(`dist/tabler-sprite${type == 'outline' ? '' : `-${type}`}.svg`, svg)
|
||||||
|
|
||||||
|
if (type == 'outline') {
|
||||||
|
fs.writeFileSync(`dist/tabler-sprite-nostroke.svg`, svg.replace(/stroke-width="2"\s/g, ''))
|
||||||
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
let svg = `<svg xmlns="http://www.w3.org/2000/svg"><defs>${svgContent}</defs></svg>`
|
|
||||||
|
|
||||||
fs.mkdirSync('dist', { recursive: true })
|
|
||||||
fs.writeFileSync('dist/tabler-sprite.svg', svg)
|
|
||||||
fs.writeFileSync('dist/tabler-sprite-nostroke.svg', svg.replace(/stroke-width="2"\s/g, ''))
|
|
||||||
}
|
}
|
||||||
|
|
||||||
buildSprite()
|
buildSprite()
|
||||||
|
Reference in New Issue
Block a user