feat: build main, preload, react-ts

This commit is contained in:
草鞋没号 2021-11-01 19:30:15 +08:00
parent 7b92b312d6
commit 0fb526481d
2 changed files with 50 additions and 18 deletions

View File

@ -1,7 +1,13 @@
import { join } from 'path'
import { defineConfig } from 'vite'
import react from '@vitejs/plugin-react'
// https://vitejs.dev/config/
export default defineConfig({
plugins: [react()]
plugins: [react()],
base: './',
build: {
minify: false,
outDir: join(process.cwd(), 'dist/react-ts'),
},
})

View File

@ -1,8 +1,11 @@
import { join } from 'path'
import { join, relative } from 'path'
import { readdirSync } from 'fs'
import { OutputOptions, rollup, RollupOptions, RollupOutput } from 'rollup'
import { OutputOptions, rollup, RollupOptions, RollupOutput, RollupError } from 'rollup'
import { build as viteBuild2 } from 'vite'
import { optionsFactory } from './rollup.config'
export type BuildResult = [RollupError | null, RollupOutput | null]
const TAG = '[build.ts]'
function mainOptions() {
@ -26,10 +29,32 @@ function preloadOptions() {
})
}
async function doBuild(options: RollupOptions): Promise<[Error | null, RollupOutput | null]> {
// build main、preload
async function rollupBuild(options: RollupOptions): Promise<BuildResult> {
try {
const build = await rollup(options)
const output = await build.write(options.output as OutputOptions)
const optOutput = (options.output || {}) as OutputOptions
const output = await build.write(optOutput)
output.output.forEach(out => {
const relativePath = relative(__dirname, optOutput.dir as string)
console.log(TAG, `Build successful - ${join(relativePath, out.fileName)}`)
})
return [null, output]
} catch (error: any) {
console.error(TAG, 'Build failed:\n', error)
return [error, null]
}
}
// build react-ts
async function buildReactTs(): Promise<BuildResult> {
try {
const output = await viteBuild2({
root: join(__dirname, '../react-ts'),
configFile: join(__dirname, '../react-ts/vite.config.ts'),
}) as RollupOutput
return [null, output]
} catch (error: any) {
@ -37,16 +62,17 @@ async function doBuild(options: RollupOptions): Promise<[Error | null, RollupOut
}
}
// build
[mainOptions(), preloadOptions()].forEach(options => {
doBuild(options)
.then(([err, output]) => {
if (err) {
console.error(err)
process.exit(1)
}
output?.output.forEach(out => {
console.log(TAG, `Build successed -- ${(out as any).facadeModuleId}`)
})
})
})
; (async () => {
console.log(TAG, 'Build with rollup.')
try {
await Promise.all([
rollupBuild(mainOptions()),
rollupBuild(preloadOptions()),
])
await buildReactTs()
} catch (error) {
console.error(TAG, error)
process.exit(1)
}
})();