@koishijs/client
Version:
Koishi Console Client
186 lines (177 loc) • 4.56 kB
text/typescript
import * as vite from 'vite'
import { RollupOutput } from 'rollup'
import { existsSync, promises as fs } from 'fs'
import { resolve } from 'path'
import { Context } from 'yakumo'
import vue from '@vitejs/plugin-vue'
import yaml from '@maikolib/vite-plugin-yaml'
declare module 'yakumo' {
interface PackageConfig {
client?: string
}
}
export async function build(root: string, config: vite.UserConfig = {}) {
if (!existsSync(root + '/client')) return
const outDir = root + '/dist'
if (existsSync(outDir)) {
await fs.rm(outDir, { recursive: true })
}
await fs.mkdir(root + '/dist', { recursive: true })
const results = await vite.build(vite.mergeConfig({
root,
build: {
write: false,
outDir: 'dist',
assetsDir: '',
minify: true,
emptyOutDir: true,
commonjsOptions: {
strictRequires: true,
},
lib: {
entry: root + '/client/index.ts',
fileName: 'index',
formats: ['es'],
},
rollupOptions: {
makeAbsoluteExternalsRelative: true,
external: [
'vue',
'vue-router',
'@vueuse/core',
'@koishijs/client',
],
output: {
format: 'iife',
},
},
},
plugins: [
vue(),
yaml(),
(await import('unocss/vite')).default({
presets: [
(await import('unocss/preset-mini')).default({
preflight: false,
}),
],
}),
],
css: {
preprocessorOptions: {
scss: {
api: 'modern-compiler',
},
},
},
resolve: {
alias: {
'vue-i18n': '@koishijs/client',
'@koishijs/components': '@koishijs/client',
},
},
define: {
'process.env.NODE_ENV': '"production"',
},
} as vite.InlineConfig, config)) as RollupOutput[]
for (const item of results[0].output) {
if (item.fileName === 'index.mjs') item.fileName = 'index.js'
const dest = root + '/dist/' + item.fileName
if (item.type === 'asset') {
await fs.writeFile(dest, item.source)
} else {
const result = await vite.transformWithEsbuild(item.code, dest, {
minifyWhitespace: true,
charset: 'utf8',
})
await fs.writeFile(dest, result.code)
}
}
}
export async function createServer(baseDir: string, config?: vite.InlineConfig) {
const root = resolve(__dirname, '../app')
return vite.createServer(vite.mergeConfig({
root,
base: '/vite/',
server: {
middlewareMode: true,
fs: {
allow: [
vite.searchForWorkspaceRoot(baseDir),
],
},
},
plugins: [
vue(),
yaml(),
(await import('unocss/vite')).default({
presets: [
(await import('unocss/preset-mini')).default({
preflight: false,
}),
],
}),
],
css: {
preprocessorOptions: {
scss: {
api: 'modern-compiler',
},
},
},
resolve: {
dedupe: ['vue', 'vue-demi', 'vue-router', 'element-plus', '@vueuse/core', '@popperjs/core', 'marked', 'xss'],
alias: {
// for backward compatibility
'../client.js': '@koishijs/client',
'../vue.js': 'vue',
'../vue-router.js': 'vue-router',
'../vueuse.js': '@vueuse/core',
},
},
optimizeDeps: {
include: [
'vue',
'vue-router',
'element-plus',
'@vueuse/core',
'@popperjs/core',
'marked',
'xss',
],
},
build: {
rollupOptions: {
input: root + '/index.html',
},
},
} as vite.InlineConfig, config))
}
export const inject = ['yakumo']
export function apply(ctx: Context) {
ctx.register('client', async () => {
const paths = ctx.yakumo.locate(ctx.yakumo.argv._)
for (const path of paths) {
const meta = ctx.yakumo.workspaces[path]
const deps = {
...meta.dependencies,
...meta.devDependencies,
...meta.peerDependencies,
...meta.optionalDependencies,
}
let config: vite.UserConfig = {}
if (meta.yakumo?.client) {
const filename = resolve(ctx.yakumo.cwd + path, meta.yakumo.client)
const exports = (await import(filename)).default
if (typeof exports === 'function') {
await exports()
continue
}
config = exports
} else if (!deps['@koishijs/client']) {
continue
}
await build(ctx.yakumo.cwd + path, config)
}
})
}