mirror of
https://github.com/lucide-icons/lucide.git
synced 2025-12-16 17:27:43 +01:00
* Fixed import of toKebabCase helper function * Added utils package * utils * Make utils package work in build * Add lucide-shared * Transpile solid with esbuild * Fix resolve modules * Cleanup * Format files * Fix properties plugins function * Fix properties plugins in lucide package * Revert remove resolve plugin and cleanup * Update snapshots * Revert icon changes --------- Co-authored-by: Rohan <rohancrrm@gmail.com>
60 lines
1.2 KiB
JavaScript
60 lines
1.2 KiB
JavaScript
import plugins from '@lucide/rollup-plugins';
|
|
import dts from 'rollup-plugin-dts';
|
|
import pkg from './package.json' assert { type: 'json' };
|
|
|
|
const outputFileName = pkg.name;
|
|
const outputDir = 'dist';
|
|
const inputs = ['src/lucide-static.ts'];
|
|
const bundles = [
|
|
{
|
|
format: 'cjs',
|
|
inputs,
|
|
outputDir,
|
|
},
|
|
{
|
|
format: 'esm',
|
|
inputs,
|
|
outputDir,
|
|
preserveModules: true,
|
|
},
|
|
];
|
|
|
|
const configs = bundles
|
|
.map(({ inputs, outputDir, format, minify, preserveModules }) =>
|
|
inputs.map((input) => ({
|
|
input,
|
|
plugins: plugins({ pkg, minify }),
|
|
output: {
|
|
name: outputFileName,
|
|
...(preserveModules
|
|
? {
|
|
dir: `${outputDir}/${format}`,
|
|
}
|
|
: {
|
|
file: `${outputDir}/${format}/${outputFileName}${minify ? '.min' : ''}.js`,
|
|
}),
|
|
format,
|
|
sourcemap: true,
|
|
preserveModules,
|
|
},
|
|
})),
|
|
)
|
|
.flat();
|
|
|
|
const typesFileConfig = {
|
|
input: inputs[0],
|
|
output: [
|
|
{
|
|
file: `${outputDir}/${outputFileName}.d.ts`,
|
|
format: 'esm',
|
|
},
|
|
],
|
|
plugins: [
|
|
dts({
|
|
include: ['src'],
|
|
}),
|
|
],
|
|
};
|
|
|
|
export default [...configs, typesFileConfig];
|