👷 Create an ESM build with Rollup by renaming output files with .esm

This commit is contained in:
RaviAnand Mohabir 2021-05-26 11:24:16 +02:00
parent 87a817ed1d
commit ca90a1dab2
4 changed files with 40 additions and 13 deletions

View File

@ -1,5 +1,6 @@
{ {
"internal": true, "internal": true,
"main": "../dist/client/index.js", "main": "../dist/client/index.js",
"module": "../dist/client/index.esm.js",
"types": "../dist/client/index.d.ts" "types": "../dist/client/index.d.ts"
} }

View File

@ -3,6 +3,7 @@
"version": "0.3.6", "version": "0.3.6",
"description": "Authentication library for use with SvelteKit featuring built-in OAuth providers and zero restriction customization!", "description": "Authentication library for use with SvelteKit featuring built-in OAuth providers and zero restriction customization!",
"main": "dist/index.js", "main": "dist/index.js",
"module": "dist/index.esm.js",
"types": "dist/index.d.ts", "types": "dist/index.d.ts",
"exports": { "exports": {
".": "./dist/index.js", ".": "./dist/index.js",

View File

@ -1,5 +1,6 @@
{ {
"internal": true, "internal": true,
"main": "../dist/providers/index.js", "main": "../dist/providers/index.js",
"module": "../dist/providers/index.esm.js",
"types": "../dist/providers/index.d.ts" "types": "../dist/providers/index.d.ts"
} }

View File

@ -8,26 +8,50 @@ const globals = {
...packageJson.devDependencies, ...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 [ export default [
{ {
input: ["src/**/*.ts"], ...baseConfig,
output: { output: {
dir: "dist", ...baseConfig.output,
sourcemap: true,
format: "cjs", format: "cjs",
}, },
plugins: [...baseConfig.plugins, multiInput()],
},
{
...baseConfig,
output: {
...baseConfig.output,
format: "esm",
},
plugins: [ plugins: [
esbuild(), ...baseConfig.plugins,
multiInput(), multiInput({
typescript({ /** @param {string} output */
emitDeclarationOnly: true, transformOutputPath: (output) =>
sourceMap: false, `${output.split(".").slice(0, -1).join(".")}.esm.${output.split(".").slice(-1)}`,
}), }),
], ],
external: [
...Object.keys(globals),
"@sveltejs/kit/assets/runtime/app/navigation",
"@sveltejs/kit/assets/runtime/app/stores",
],
}, },
]; ];