svelte.sk-auth/rollup.config.js
Dan6erbond 735cc261fb
[ENHANCEMENT] Hybrid ESM & CJS Builds (#32)
* 👷 Create an ESM build with Rollup by renaming output files with `.esm`

* 📌 Reinstall `sk-auth` in app
2021-05-26 13:50:36 +02:00

58 lines
1.2 KiB
JavaScript

import multiInput from "rollup-plugin-multi-input";
import packageJson from "./package.json";
import esbuild from "rollup-plugin-esbuild";
import typescript from "@rollup/plugin-typescript";
const globals = {
...packageJson.dependencies,
...packageJson.devDependencies,
};
/** @type {import('rollup').RollupOptions} */
const baseConfig = {
input: ["src/**/*.ts"],
output: {
dir: "dist",
sourcemap: true,
},
plugins: [
esbuild(),
typescript({
emitDeclarationOnly: true,
sourceMap: false,
}),
],
external: [
...Object.keys(globals),
"@sveltejs/kit/assets/runtime/app/navigation",
"@sveltejs/kit/assets/runtime/app/stores",
],
};
/** @type {Array.<import('rollup').RollupOptions>} */
export default [
{
...baseConfig,
output: {
...baseConfig.output,
format: "cjs",
},
plugins: [...baseConfig.plugins, multiInput()],
},
{
...baseConfig,
output: {
...baseConfig.output,
format: "esm",
},
plugins: [
...baseConfig.plugins,
multiInput({
/** @param {string} output */
transformOutputPath: (output) =>
`${output.split(".").slice(0, -1).join(".")}.esm.${output.split(".").slice(-1)}`,
}),
],
},
];