@marciocamello/react-sortable-tree
Version:
Drag-and-drop sortable component for nested data and hierarchies
91 lines (82 loc) • 2.07 kB
JavaScript
import path from 'path'
import babel from '@rollup/plugin-babel'
import nodeResolve from '@rollup/plugin-node-resolve'
import typescript from '@rollup/plugin-typescript'
import jsx from 'acorn-jsx'
import esbuild from 'rollup-plugin-esbuild'
import postcss from 'rollup-plugin-postcss'
import createBabelConfig from './babel.config.js'
const extensions = ['.js', '.ts', '.tsx']
const { root } = path.parse(process.cwd())
function external(id) {
return !id.startsWith('.') && !id.startsWith(root)
}
function getBabelOptions(targets) {
return {
...createBabelConfig({ env: (env) => env === 'build' }, targets),
extensions,
comments: false,
babelHelpers: 'bundled',
}
}
function getEsbuild(target) {
return esbuild({
minify: false,
target,
tsconfig: path.resolve('./tsconfig.json'),
})
}
function createDeclarationConfig(input, output) {
return {
input,
output: {
dir: output,
},
external,
acornInjectPlugins: [jsx()],
plugins: [
postcss({ extract: 'style.css' }),
typescript({
declaration: true,
emitDeclarationOnly: true,
outDir: output,
}),
],
}
}
function createESMConfig(input, output) {
return {
input,
output: [
{ file: `${output}.js`, format: 'esm' },
{ file: `${output}.mjs`, format: 'esm' },
],
external,
plugins: [
nodeResolve({ extensions }),
postcss({ extract: 'style.css' }),
getEsbuild('node16'),
],
}
}
function createCommonJSConfig(input, output) {
return {
input,
output: { file: output, format: 'cjs', exports: 'named' },
external,
acornInjectPlugins: [jsx()],
plugins: [
nodeResolve({ extensions }),
postcss({ extract: 'style.css' }),
typescript(),
babel(getBabelOptions({ chrome: 95 })),
],
}
}
export default function (args) {
return [
createDeclarationConfig('src/index.ts', 'dist'),
createCommonJSConfig('src/index.ts', 'dist/index.js'),
createESMConfig('src/index.ts', 'dist/esm/index'),
]
}