mirror of
https://github.com/lucide-icons/lucide.git
synced 2025-12-23 05:39:23 +01:00
* extract workflow * Add aliases build * Setup types building for aliases * Add types generation for aliases * Finish React Aliases * Finish aliases for lucide-react * setup aliases preact * Fix aliases in preact * Add aliases preact * Add aliases lucide-react-native * Fix solid js build * update lock file * Improve solid for solid start * update import * update import * lucide solid fix types generation * Fix lucide sold * Fix svelte aliases * update lockfile * Fix imports * Fix solid js issues * Add aliases to the vue packages * Fix lucide react native * Test alpha versions lucide-vue, lucide-vue-next, lucide-svelte
78 lines
1.5 KiB
JavaScript
78 lines
1.5 KiB
JavaScript
import plugins, { replace } from '@lucide/rollup-plugins';
|
|
import pkg from './package.json' assert { type: 'json' };
|
|
|
|
const packageName = 'LucideVue';
|
|
const outputFileName = 'lucide-vue';
|
|
const outputDir = 'dist';
|
|
const inputs = ['src/lucide-vue.ts'];
|
|
const bundles = [
|
|
{
|
|
format: 'umd',
|
|
inputs,
|
|
outputDir,
|
|
minify: true,
|
|
},
|
|
{
|
|
format: 'umd',
|
|
inputs,
|
|
outputDir,
|
|
},
|
|
{
|
|
format: 'cjs',
|
|
inputs,
|
|
outputDir,
|
|
},
|
|
{
|
|
format: 'es',
|
|
inputs,
|
|
outputDir,
|
|
},
|
|
{
|
|
format: 'esm',
|
|
inputs,
|
|
outputDir,
|
|
preserveModules: true,
|
|
},
|
|
];
|
|
|
|
const configs = bundles
|
|
.map(({ inputs, outputDir, format, minify, preserveModules }) =>
|
|
inputs.map(input => ({
|
|
input,
|
|
plugins: [
|
|
// This for aliases, only for esm
|
|
...(
|
|
format !== 'esm' ? [
|
|
replace({
|
|
"export * from './aliases';": '',
|
|
"export * as icons from './icons';": '',
|
|
delimiters: ['', ''],
|
|
preventAssignment: false,
|
|
}),
|
|
] : []
|
|
),
|
|
...plugins(pkg, minify)
|
|
],
|
|
external: ['vue'],
|
|
output: {
|
|
name: packageName,
|
|
...(preserveModules
|
|
? {
|
|
dir: `${outputDir}/${format}`,
|
|
}
|
|
: {
|
|
file: `${outputDir}/${format}/${outputFileName}${minify ? '.min' : ''}.js`,
|
|
}),
|
|
format,
|
|
preserveModules,
|
|
sourcemap: true,
|
|
globals: {
|
|
vue: 'vue',
|
|
},
|
|
},
|
|
})),
|
|
)
|
|
.flat();
|
|
|
|
export default configs;
|