mirror of
https://github.com/lucide-icons/lucide.git
synced 2025-12-15 21:47:43 +01:00
* Add useIconComponent, lucide-react * Add concept useIconComponent * add useIconComponents to packages * Add icon component * Add icon component * Add tests for react packages * Reset changes in icons * Add types * Add support for Icon components in Lucide Vue Next * update tests * Update tests * Enable Svelte component * Fix lucide-react-native tests * Update Solid package * update snapshots * Add docs * add docs * Update tests * Formatting * Formatting * Update package lock * Remove `useIconComponent` * Update guides * Update exports preact and solid package * Formatting * Format createIcons.ts * Add lucide lab repo link in docs
104 lines
2.7 KiB
JavaScript
Executable File
104 lines
2.7 KiB
JavaScript
Executable File
#!/usr/bin/env node
|
|
import fs from 'fs';
|
|
import path from 'path';
|
|
import getArgumentOptions from 'minimist';
|
|
|
|
import renderIconsObject from './render/renderIconsObject.mjs';
|
|
import generateIconFiles from './building/generateIconFiles.mjs';
|
|
import generateExportsFile from './building/generateExportsFile.mjs';
|
|
|
|
import { readSvgDirectory, getCurrentDirPath } from '../../scripts/helpers.mjs';
|
|
import generateAliasesFile from './building/generateAliasesFile.mjs';
|
|
import getIconMetaData from './utils/getIconMetaData.mjs';
|
|
import generateDynamicImports from './building/generateDynamicImports.mjs';
|
|
|
|
const cliArguments = getArgumentOptions(process.argv.slice(2));
|
|
|
|
const currentDir = getCurrentDirPath(import.meta.url);
|
|
|
|
const ICONS_DIR = path.resolve(currentDir, '../../icons');
|
|
const OUTPUT_DIR = path.resolve(process.cwd(), cliArguments.output || '../build');
|
|
|
|
if (!fs.existsSync(OUTPUT_DIR)) {
|
|
fs.mkdirSync(OUTPUT_DIR);
|
|
}
|
|
|
|
const {
|
|
renderUniqueKey = false,
|
|
templateSrc,
|
|
silent = false,
|
|
iconFileExtension = '.js',
|
|
importImportFileExtension = '',
|
|
exportFileName = 'index.js',
|
|
withAliases = false,
|
|
aliasNamesOnly = false,
|
|
withDynamicImports = false,
|
|
separateAliasesFile = false,
|
|
aliasesFileExtension = '.js',
|
|
aliasImportFileExtension = '',
|
|
pretty = true,
|
|
} = cliArguments;
|
|
|
|
async function buildIcons() {
|
|
if (templateSrc == null) {
|
|
throw new Error('No `templateSrc` argument given.');
|
|
}
|
|
|
|
const svgFiles = readSvgDirectory(ICONS_DIR);
|
|
|
|
const icons = renderIconsObject(svgFiles, ICONS_DIR, renderUniqueKey);
|
|
|
|
const { default: iconFileTemplate } = await import(path.resolve(process.cwd(), templateSrc));
|
|
|
|
const iconMetaData = await getIconMetaData(ICONS_DIR);
|
|
|
|
// Generates iconsNodes files for each icon
|
|
generateIconFiles({
|
|
iconNodes: icons,
|
|
outputDirectory: OUTPUT_DIR,
|
|
template: iconFileTemplate,
|
|
showLog: !silent,
|
|
iconFileExtension,
|
|
pretty: JSON.parse(pretty),
|
|
iconsDir: ICONS_DIR,
|
|
iconMetaData,
|
|
});
|
|
|
|
if (withAliases) {
|
|
await generateAliasesFile({
|
|
iconNodes: icons,
|
|
iconMetaData,
|
|
aliasNamesOnly,
|
|
iconFileExtension,
|
|
outputDirectory: OUTPUT_DIR,
|
|
fileExtension: aliasesFileExtension,
|
|
aliasImportFileExtension,
|
|
separateAliasesFile,
|
|
showLog: !silent,
|
|
});
|
|
}
|
|
|
|
if (withDynamicImports) {
|
|
generateDynamicImports({
|
|
iconNodes: icons,
|
|
outputDirectory: OUTPUT_DIR,
|
|
fileExtension: aliasesFileExtension,
|
|
showLog: !silent,
|
|
});
|
|
}
|
|
|
|
// Generates entry files for the compiler filled with icons exports
|
|
generateExportsFile(
|
|
path.join(OUTPUT_DIR, 'icons', exportFileName),
|
|
path.join(OUTPUT_DIR, 'icons'),
|
|
icons,
|
|
importImportFileExtension,
|
|
);
|
|
}
|
|
|
|
try {
|
|
buildIcons();
|
|
} catch (error) {
|
|
console.error(error);
|
|
}
|