feat: add cjs support

pull/666/head
Kia Ishii 3 years ago
parent 38af838da6
commit 2785c214c3

@ -9,7 +9,8 @@
"exports": { "exports": {
".": { ".": {
"types": "./types/index.d.ts", "types": "./types/index.d.ts",
"import": "./dist/node/index.js" "import": "./dist/node/index.js",
"require": "./dist/node-cjs/index.cjs"
}, },
"./dist/client/*": "./dist/client/*" "./dist/client/*": "./dist/client/*"
}, },
@ -45,7 +46,7 @@
"dev": "rimraf dist && run-s dev-shared dev-start", "dev": "rimraf dist && run-s dev-shared dev-start",
"dev-start": "run-p dev-client dev-node dev-watch", "dev-start": "run-p dev-client dev-node dev-watch",
"dev-client": "tsc -w -p src/client", "dev-client": "tsc -w -p src/client",
"dev-node": "pnpm run build-node -w", "dev-node": "DEV=true pnpm run build-node -w",
"dev-shared": "node scripts/copyShared", "dev-shared": "node scripts/copyShared",
"dev-watch": "node scripts/watchAndCopy", "dev-watch": "node scripts/watchAndCopy",
"build": "run-s build-prepare build-client build-node", "build": "run-s build-prepare build-client build-node",

@ -1,4 +1,4 @@
import { defineConfig } from 'rollup' import { RollupOptions, defineConfig } from 'rollup'
import { promises as fs } from 'fs' import { promises as fs } from 'fs'
import { nodeResolve } from '@rollup/plugin-node-resolve' import { nodeResolve } from '@rollup/plugin-node-resolve'
import commonjs from '@rollup/plugin-commonjs' import commonjs from '@rollup/plugin-commonjs'
@ -11,24 +11,15 @@ import { resolve } from 'path'
import { fileURLToPath } from 'url' import { fileURLToPath } from 'url'
import pkg from './package.json' import pkg from './package.json'
const DEV = !!process.env.DEV
const PROD = !DEV
const ROOT = fileURLToPath(import.meta.url) const ROOT = fileURLToPath(import.meta.url)
const r = (p: string) => resolve(ROOT, '..', p) const r = (p: string) => resolve(ROOT, '..', p)
const external = [ const external = [...Object.keys(pkg.dependencies), 'buffer', 'punycode']
...Object.keys(pkg.dependencies),
'buffer',
'punycode'
]
export default defineConfig([ const plugins = [
{
input: [r('src/node/index.ts'), r('src/node/cli.ts')],
output: {
format: 'esm',
dir: r('dist/node')
},
external,
plugins: [
alias({ alias({
entries: { entries: {
'readable-stream': 'stream' 'readable-stream': 'stream'
@ -42,24 +33,50 @@ export default defineConfig([
}), }),
commonjs(), commonjs(),
nodeResolve(), nodeResolve(),
esbuild({ esbuild({ target: 'node14' }),
target: 'node14'
}),
json() json()
], ]
const esmBuild: RollupOptions = {
input: [r('src/node/index.ts'), r('src/node/cli.ts')],
output: {
format: 'esm',
entryFileNames: `[name].js`,
chunkFileNames: 'serve-[hash].js',
dir: r('dist/node')
},
external,
plugins,
onwarn(warning, warn) { onwarn(warning, warn) {
if (warning.code !== 'EVAL') warn(warning) if (warning.code !== 'EVAL') warn(warning)
} }
}
const cjsBuild: RollupOptions = {
input: [r('src/node/index.ts'), r('src/node/cli.ts')],
output: {
format: 'cjs',
dir: r('dist/node-cjs'),
entryFileNames: `[name].cjs`,
chunkFileNames: 'serve-[hash].cjs'
}, },
{ external,
plugins,
onwarn(warning, warn) {
if (warning.code !== 'EVAL') warn(warning)
}
}
const nodeTypes: RollupOptions = {
input: r('src/node/index.ts'), input: r('src/node/index.ts'),
output: { output: {
format: 'esm', format: 'esm',
file: 'dist/node/index.d.ts' file: 'dist/node/index.d.ts'
}, },
plugins: [dts()] plugins: [dts()]
}, }
{
const clientTypes: RollupOptions = {
input: r('dist/client-types/index.d.ts'), input: r('dist/client-types/index.d.ts'),
output: { output: {
format: 'esm', format: 'esm',
@ -70,9 +87,23 @@ export default defineConfig([
{ {
name: 'cleanup', name: 'cleanup',
async closeBundle() { async closeBundle() {
if (PROD) {
await fs.rm(r('dist/client-types'), { recursive: true }) await fs.rm(r('dist/client-types'), { recursive: true })
} }
} }
]
} }
]) ]
}
const config = defineConfig([])
config.push(esmBuild)
if (PROD) {
config.push(cjsBuild)
}
config.push(nodeTypes)
config.push(clientTypes)
export default config

Loading…
Cancel
Save