mirror of
https://github.com/tabler/tabler-icons.git
synced 2025-09-03 10:53:47 +02:00
rollup config improvements
This commit is contained in:
@@ -2,7 +2,7 @@ import { visualizer } from 'rollup-plugin-visualizer'
|
|||||||
import license from 'rollup-plugin-license'
|
import license from 'rollup-plugin-license'
|
||||||
import esbuild from 'rollup-plugin-esbuild'
|
import esbuild from 'rollup-plugin-esbuild'
|
||||||
|
|
||||||
export const getRollupPlugins = (pkg, minify) => {
|
const getRollupPlugins = (pkg, minify) => {
|
||||||
return [
|
return [
|
||||||
esbuild({
|
esbuild({
|
||||||
minify
|
minify
|
||||||
@@ -19,3 +19,29 @@ See the LICENSE file in the root directory of this source tree.`
|
|||||||
})
|
})
|
||||||
].filter(Boolean)
|
].filter(Boolean)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export const getRollupConfig = (pkg, outputFileName, bundles, globals) => {
|
||||||
|
return bundles
|
||||||
|
.map(({ inputs, format, minify, preserveModules, outputDir = 'dist', extension = 'js' }) =>
|
||||||
|
inputs.map(input => ({
|
||||||
|
input,
|
||||||
|
plugins: getRollupPlugins(pkg, minify),
|
||||||
|
external: Object.keys(globals),
|
||||||
|
output: {
|
||||||
|
name: pkg.name,
|
||||||
|
...(preserveModules
|
||||||
|
? {
|
||||||
|
dir: `${outputDir}/${format}`,
|
||||||
|
}
|
||||||
|
: {
|
||||||
|
file: `${outputDir}/${format}/${outputFileName}${minify ? '.min' : ''}.${extension}`,
|
||||||
|
}),
|
||||||
|
format,
|
||||||
|
sourcemap: true,
|
||||||
|
preserveModules,
|
||||||
|
globals,
|
||||||
|
},
|
||||||
|
})),
|
||||||
|
)
|
||||||
|
.flat();
|
||||||
|
}
|
||||||
|
@@ -1,64 +1,33 @@
|
|||||||
import fs from 'fs'
|
import fs from 'fs'
|
||||||
import { getRollupPlugins } from '../../.build/rollup-plugins.mjs'
|
import { getRollupConfig } from '../../.build/rollup-plugins.mjs'
|
||||||
import dts from "rollup-plugin-dts";
|
import dts from "rollup-plugin-dts";
|
||||||
|
|
||||||
const pkg = JSON.parse(fs.readFileSync('package.json', 'utf-8'))
|
const pkg = JSON.parse(fs.readFileSync('package.json', 'utf-8'))
|
||||||
|
|
||||||
const packageName = '@tabler/icons-preact';
|
|
||||||
const outputFileName = 'tabler-icons-preact';
|
const outputFileName = 'tabler-icons-preact';
|
||||||
const outputDir = 'dist';
|
|
||||||
const inputs = ['./src/tabler-icons-preact.ts'];
|
const inputs = ['./src/tabler-icons-preact.ts'];
|
||||||
const bundles = [
|
const bundles = [
|
||||||
{
|
{
|
||||||
format: 'umd',
|
format: 'umd',
|
||||||
inputs,
|
inputs,
|
||||||
outputDir,
|
|
||||||
minify: true,
|
minify: true,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
format: 'umd',
|
format: 'umd',
|
||||||
inputs,
|
inputs,
|
||||||
outputDir,
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
format: 'cjs',
|
format: 'cjs',
|
||||||
inputs,
|
inputs,
|
||||||
outputDir,
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
format: 'esm',
|
format: 'esm',
|
||||||
inputs,
|
inputs,
|
||||||
outputDir,
|
|
||||||
preserveModules: true,
|
preserveModules: true,
|
||||||
|
extension: 'mjs',
|
||||||
},
|
},
|
||||||
];
|
];
|
||||||
|
|
||||||
const configs = bundles
|
|
||||||
.map(({ inputs, outputDir, format, minify, preserveModules }) =>
|
|
||||||
inputs.map(input => ({
|
|
||||||
input,
|
|
||||||
plugins: getRollupPlugins(pkg, minify),
|
|
||||||
external: ['preact'],
|
|
||||||
output: {
|
|
||||||
name: packageName,
|
|
||||||
...(preserveModules
|
|
||||||
? {
|
|
||||||
dir: `${outputDir}/${format}`,
|
|
||||||
}
|
|
||||||
: {
|
|
||||||
file: `${outputDir}/${format}/${outputFileName}${minify ? '.min' : ''}.js`,
|
|
||||||
}),
|
|
||||||
preserveModules,
|
|
||||||
format,
|
|
||||||
sourcemap: true,
|
|
||||||
globals: {
|
|
||||||
preact: 'preact'
|
|
||||||
},
|
|
||||||
},
|
|
||||||
})),
|
|
||||||
)
|
|
||||||
.flat();
|
|
||||||
|
|
||||||
export default [
|
export default [
|
||||||
{
|
{
|
||||||
input: inputs[0],
|
input: inputs[0],
|
||||||
@@ -67,5 +36,7 @@ export default [
|
|||||||
}],
|
}],
|
||||||
plugins: [dts()],
|
plugins: [dts()],
|
||||||
},
|
},
|
||||||
...configs
|
...getRollupConfig(pkg, outputFileName, bundles, {
|
||||||
|
preact: 'preact'
|
||||||
|
})
|
||||||
];
|
];
|
||||||
|
@@ -1,54 +1,24 @@
|
|||||||
import fs from 'fs'
|
import fs from 'fs'
|
||||||
import { getRollupPlugins } from '../../.build/rollup-plugins.mjs'
|
import { getRollupConfig } from '../../.build/rollup-plugins.mjs'
|
||||||
import dts from "rollup-plugin-dts";
|
import dts from "rollup-plugin-dts";
|
||||||
|
|
||||||
const pkg = JSON.parse(fs.readFileSync('package.json', 'utf-8'))
|
const pkg = JSON.parse(fs.readFileSync('package.json', 'utf-8'))
|
||||||
|
|
||||||
const packageName = '@tabler/icons-react-native';
|
|
||||||
const outputFileName = 'tabler-icons-react-native';
|
const outputFileName = 'tabler-icons-react-native';
|
||||||
const outputDir = 'dist';
|
|
||||||
const inputs = ['./src/tabler-icons-react-native.ts'];
|
const inputs = ['./src/tabler-icons-react-native.ts'];
|
||||||
const bundles = [
|
const bundles = [
|
||||||
{
|
{
|
||||||
format: 'cjs',
|
format: 'cjs',
|
||||||
inputs,
|
inputs,
|
||||||
outputDir,
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
format: 'esm',
|
format: 'esm',
|
||||||
inputs,
|
inputs,
|
||||||
outputDir,
|
|
||||||
preserveModules: true,
|
preserveModules: true,
|
||||||
|
extension: 'mjs',
|
||||||
},
|
},
|
||||||
];
|
];
|
||||||
|
|
||||||
const configs = bundles
|
|
||||||
.map(({ inputs, outputDir, format, minify, preserveModules }) =>
|
|
||||||
inputs.map(input => ({
|
|
||||||
input,
|
|
||||||
plugins: getRollupPlugins(pkg, minify),
|
|
||||||
external: ['react', 'react-native-svg'],
|
|
||||||
output: {
|
|
||||||
name: packageName,
|
|
||||||
...(preserveModules
|
|
||||||
? {
|
|
||||||
dir: `${outputDir}/${format}`,
|
|
||||||
}
|
|
||||||
: {
|
|
||||||
file: `${outputDir}/${format}/${outputFileName}${minify ? '.min' : ''}.js`,
|
|
||||||
}),
|
|
||||||
format,
|
|
||||||
sourcemap: true,
|
|
||||||
preserveModules,
|
|
||||||
globals: {
|
|
||||||
react: 'react',
|
|
||||||
'react-native-svg': 'react-native-svg',
|
|
||||||
},
|
|
||||||
},
|
|
||||||
})),
|
|
||||||
)
|
|
||||||
.flat();
|
|
||||||
|
|
||||||
export default [
|
export default [
|
||||||
{
|
{
|
||||||
input: inputs[0],
|
input: inputs[0],
|
||||||
@@ -57,5 +27,8 @@ export default [
|
|||||||
}],
|
}],
|
||||||
plugins: [dts()],
|
plugins: [dts()],
|
||||||
},
|
},
|
||||||
...configs
|
...getRollupConfig(pkg, outputFileName, bundles, {
|
||||||
|
react: 'react',
|
||||||
|
'react-native-svg': 'react-native-svg',
|
||||||
|
})
|
||||||
];
|
];
|
||||||
|
@@ -1,64 +1,33 @@
|
|||||||
import fs from 'fs'
|
import fs from 'fs'
|
||||||
import { getRollupPlugins } from '../../.build/rollup-plugins.mjs'
|
import { getRollupConfig } from '../../.build/rollup-plugins.mjs'
|
||||||
import dts from "rollup-plugin-dts";
|
import dts from "rollup-plugin-dts";
|
||||||
|
|
||||||
const pkg = JSON.parse(fs.readFileSync('package.json', 'utf-8'))
|
const pkg = JSON.parse(fs.readFileSync('package.json', 'utf-8'))
|
||||||
|
|
||||||
const packageName = '@tabler/icons-react';
|
|
||||||
const outputFileName = 'tabler-icons-react';
|
const outputFileName = 'tabler-icons-react';
|
||||||
const outputDir = 'dist';
|
|
||||||
const inputs = ['./src/tabler-icons-react.ts'];
|
const inputs = ['./src/tabler-icons-react.ts'];
|
||||||
const bundles = [
|
const bundles = [
|
||||||
{
|
{
|
||||||
format: 'umd',
|
format: 'umd',
|
||||||
inputs,
|
inputs,
|
||||||
outputDir,
|
|
||||||
minify: true,
|
minify: true,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
format: 'umd',
|
format: 'umd',
|
||||||
inputs,
|
inputs,
|
||||||
outputDir,
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
format: 'cjs',
|
format: 'cjs',
|
||||||
inputs,
|
inputs,
|
||||||
outputDir,
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
format: 'esm',
|
format: 'esm',
|
||||||
inputs,
|
inputs,
|
||||||
outputDir,
|
|
||||||
preserveModules: true,
|
preserveModules: true,
|
||||||
|
extension: 'mjs',
|
||||||
},
|
},
|
||||||
];
|
];
|
||||||
|
|
||||||
const configs = bundles
|
|
||||||
.map(({ inputs, outputDir, format, minify, preserveModules }) =>
|
|
||||||
inputs.map(input => ({
|
|
||||||
input,
|
|
||||||
plugins: getRollupPlugins(pkg, minify),
|
|
||||||
external: ['react'],
|
|
||||||
output: {
|
|
||||||
name: packageName,
|
|
||||||
...(preserveModules
|
|
||||||
? {
|
|
||||||
dir: `${outputDir}/${format}`,
|
|
||||||
}
|
|
||||||
: {
|
|
||||||
file: `${outputDir}/${format}/${outputFileName}${minify ? '.min' : ''}.js`,
|
|
||||||
}),
|
|
||||||
format,
|
|
||||||
sourcemap: true,
|
|
||||||
preserveModules,
|
|
||||||
globals: {
|
|
||||||
react: 'react'
|
|
||||||
},
|
|
||||||
},
|
|
||||||
})),
|
|
||||||
)
|
|
||||||
.flat();
|
|
||||||
|
|
||||||
export default [
|
export default [
|
||||||
{
|
{
|
||||||
input: inputs[0],
|
input: inputs[0],
|
||||||
@@ -67,5 +36,7 @@ export default [
|
|||||||
}],
|
}],
|
||||||
plugins: [dts()],
|
plugins: [dts()],
|
||||||
},
|
},
|
||||||
...configs
|
...getRollupConfig(pkg, outputFileName, bundles, {
|
||||||
|
react: 'react'
|
||||||
|
})
|
||||||
];
|
];
|
||||||
|
@@ -1,65 +1,33 @@
|
|||||||
import fs from 'fs'
|
import fs from 'fs'
|
||||||
import { getRollupPlugins } from '../../.build/rollup-plugins.mjs'
|
import { getRollupConfig } from '../../.build/rollup-plugins.mjs'
|
||||||
import dts from "rollup-plugin-dts";
|
import dts from "rollup-plugin-dts";
|
||||||
|
|
||||||
const pkg = JSON.parse(fs.readFileSync('package.json', 'utf-8'))
|
const pkg = JSON.parse(fs.readFileSync('package.json', 'utf-8'))
|
||||||
|
|
||||||
const packageName = '@tabler/icons-solidjs';
|
|
||||||
const outputFileName = 'tabler-icons-solidjs';
|
const outputFileName = 'tabler-icons-solidjs';
|
||||||
const outputDir = 'dist';
|
|
||||||
const inputs = ['./src/tabler-icons-solidjs.ts'];
|
const inputs = ['./src/tabler-icons-solidjs.ts'];
|
||||||
const bundles = [
|
const bundles = [
|
||||||
{
|
{
|
||||||
format: 'umd',
|
format: 'umd',
|
||||||
inputs,
|
inputs,
|
||||||
outputDir,
|
|
||||||
minify: true,
|
minify: true,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
format: 'umd',
|
format: 'umd',
|
||||||
inputs,
|
inputs,
|
||||||
outputDir,
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
format: 'cjs',
|
format: 'cjs',
|
||||||
inputs,
|
inputs,
|
||||||
outputDir,
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
format: 'esm',
|
format: 'esm',
|
||||||
inputs,
|
inputs,
|
||||||
outputDir,
|
|
||||||
preserveModules: true,
|
preserveModules: true,
|
||||||
|
extension: 'mjs',
|
||||||
},
|
},
|
||||||
];
|
];
|
||||||
|
|
||||||
const configs = bundles
|
|
||||||
.map(({ inputs, outputDir, format, minify, preserveModules }) =>
|
|
||||||
inputs.map(input => ({
|
|
||||||
input,
|
|
||||||
plugins: getRollupPlugins(pkg, minify),
|
|
||||||
external: ['solid-js', 'solid-js/h'],
|
|
||||||
output: {
|
|
||||||
name: packageName,
|
|
||||||
...(preserveModules
|
|
||||||
? {
|
|
||||||
dir: `${outputDir}/${format}`,
|
|
||||||
}
|
|
||||||
: {
|
|
||||||
file: `${outputDir}/${format}/${outputFileName}${minify ? '.min' : ''}.js`,
|
|
||||||
}),
|
|
||||||
preserveModules,
|
|
||||||
format,
|
|
||||||
sourcemap: true,
|
|
||||||
globals: {
|
|
||||||
'solid-js': 'solid-js',
|
|
||||||
'solid-js/h': 'solid-js/h',
|
|
||||||
},
|
|
||||||
},
|
|
||||||
})),
|
|
||||||
)
|
|
||||||
.flat();
|
|
||||||
|
|
||||||
export default [
|
export default [
|
||||||
{
|
{
|
||||||
input: inputs[0],
|
input: inputs[0],
|
||||||
@@ -68,5 +36,8 @@ export default [
|
|||||||
}],
|
}],
|
||||||
plugins: [dts()],
|
plugins: [dts()],
|
||||||
},
|
},
|
||||||
...configs
|
...getRollupConfig(pkg, outputFileName, bundles, {
|
||||||
|
'solid-js': 'solid-js',
|
||||||
|
'solid-js/h': 'solid-js/h',
|
||||||
|
})
|
||||||
];
|
];
|
||||||
|
@@ -1,64 +1,33 @@
|
|||||||
import fs from 'fs'
|
import fs from 'fs'
|
||||||
import { getRollupPlugins } from '../../.build/rollup-plugins.mjs'
|
import { getRollupConfig } from '../../.build/rollup-plugins.mjs'
|
||||||
import dts from "rollup-plugin-dts";
|
import dts from "rollup-plugin-dts";
|
||||||
|
|
||||||
const pkg = JSON.parse(fs.readFileSync('package.json', 'utf-8'))
|
const pkg = JSON.parse(fs.readFileSync('package.json', 'utf-8'))
|
||||||
|
|
||||||
const packageName = '@tabler/icons-vue';
|
|
||||||
const outputFileName = 'tabler-icons-vue';
|
const outputFileName = 'tabler-icons-vue';
|
||||||
const outputDir = 'dist';
|
|
||||||
const inputs = ['./src/tabler-icons-vue.ts'];
|
const inputs = ['./src/tabler-icons-vue.ts'];
|
||||||
const bundles = [
|
const bundles = [
|
||||||
{
|
{
|
||||||
format: 'umd',
|
format: 'umd',
|
||||||
inputs,
|
inputs,
|
||||||
outputDir,
|
|
||||||
minify: true,
|
minify: true,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
format: 'umd',
|
format: 'umd',
|
||||||
inputs,
|
inputs,
|
||||||
outputDir,
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
format: 'cjs',
|
format: 'cjs',
|
||||||
inputs,
|
inputs,
|
||||||
outputDir,
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
format: 'esm',
|
format: 'esm',
|
||||||
inputs,
|
inputs,
|
||||||
outputDir,
|
|
||||||
preserveModules: true,
|
preserveModules: true,
|
||||||
|
extension: 'mjs',
|
||||||
},
|
},
|
||||||
];
|
];
|
||||||
|
|
||||||
const configs = bundles
|
|
||||||
.map(({ inputs, outputDir, format, minify, preserveModules }) =>
|
|
||||||
inputs.map(input => ({
|
|
||||||
input,
|
|
||||||
plugins: getRollupPlugins(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 [
|
export default [
|
||||||
{
|
{
|
||||||
input: inputs[0],
|
input: inputs[0],
|
||||||
@@ -73,5 +42,7 @@ export default [
|
|||||||
})
|
})
|
||||||
],
|
],
|
||||||
},
|
},
|
||||||
...configs
|
...getRollupConfig(pkg, outputFileName, bundles, {
|
||||||
|
vue: 'vue',
|
||||||
|
})
|
||||||
];
|
];
|
||||||
|
Reference in New Issue
Block a user