diff --git a/app/yarn.lock b/app/yarn.lock index e6697f8..7cf96fa 100644 --- a/app/yarn.lock +++ b/app/yarn.lock @@ -3436,13 +3436,13 @@ simple-swizzle@^0.2.2: is-arrayish "^0.3.1" "sk-auth@file:..": - version "0.3.5" + version "0.3.6" dependencies: cookie "^0.4.1" jsonwebtoken "^8.5.1" "sk-auth@file:../": - version "0.3.5" + version "0.3.6" dependencies: cookie "^0.4.1" jsonwebtoken "^8.5.1" diff --git a/client/package.json b/client/package.json index 71a6308..6e2c6a4 100644 --- a/client/package.json +++ b/client/package.json @@ -1,5 +1,6 @@ { "internal": true, "main": "../dist/client/index.js", + "module": "../dist/client/index.esm.js", "types": "../dist/client/index.d.ts" } diff --git a/package.json b/package.json index dc17dd3..d013fd1 100644 --- a/package.json +++ b/package.json @@ -3,6 +3,7 @@ "version": "0.3.7", "description": "Authentication library for use with SvelteKit featuring built-in OAuth providers and zero restriction customization!", "main": "dist/index.js", + "module": "dist/index.esm.js", "types": "dist/index.d.ts", "exports": { ".": "./dist/index.js", diff --git a/providers/package.json b/providers/package.json index b3e90a0..86496b9 100644 --- a/providers/package.json +++ b/providers/package.json @@ -1,5 +1,6 @@ { "internal": true, "main": "../dist/providers/index.js", + "module": "../dist/providers/index.esm.js", "types": "../dist/providers/index.d.ts" } diff --git a/rollup.config.js b/rollup.config.js index 01d69cc..cc1c2ed 100644 --- a/rollup.config.js +++ b/rollup.config.js @@ -8,26 +8,50 @@ const globals = { ...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.} */ export default [ { - input: ["src/**/*.ts"], + ...baseConfig, output: { - dir: "dist", - sourcemap: true, + ...baseConfig.output, format: "cjs", }, + plugins: [...baseConfig.plugins, multiInput()], + }, + { + ...baseConfig, + output: { + ...baseConfig.output, + format: "esm", + }, plugins: [ - esbuild(), - multiInput(), - typescript({ - emitDeclarationOnly: true, - sourceMap: false, + ...baseConfig.plugins, + multiInput({ + /** @param {string} output */ + transformOutputPath: (output) => + `${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", - ], }, ];