electron-vite-react/configs/vite.renderer.ts

113 lines
2.8 KiB
TypeScript
Raw Normal View History

2021-11-01 19:30:15 +08:00
import { join } from 'path'
2022-01-17 09:45:09 +08:00
import { builtinModules } from 'module'
import { defineConfig, Plugin } from 'vite'
2021-11-01 10:06:07 +08:00
import react from '@vitejs/plugin-react'
import resolve from 'vite-plugin-resolve'
import pkg from '../package.json'
2021-11-01 10:06:07 +08:00
// https://vitejs.dev/config/
export default defineConfig({
2021-11-26 08:48:00 +08:00
mode: process.env.NODE_ENV,
2021-11-11 12:46:00 +08:00
root: join(__dirname, '../src/renderer'),
2021-11-15 19:14:50 +08:00
plugins: [
react(),
2022-01-17 09:45:09 +08:00
resolveElectron(),
2021-11-15 19:14:50 +08:00
],
2021-11-01 19:30:15 +08:00
base: './',
build: {
2021-11-08 19:17:39 +08:00
emptyOutDir: true,
2021-11-12 09:01:40 +08:00
outDir: '../../dist/renderer',
2021-11-01 19:30:15 +08:00
},
2021-12-14 14:19:59 +08:00
resolve: {
alias: {
'@': join(__dirname, '../src/renderer/src'),
'src': join(__dirname, '../src'),
},
},
2021-11-01 20:56:49 +08:00
server: {
host: pkg.env.HOST,
port: pkg.env.PORT,
},
optimizeDeps: {
exclude: ['electron'],
}
2021-11-01 10:06:07 +08:00
})
2022-01-17 09:45:09 +08:00
// ----------------- For use Electron, NodeJs in Renderer-process -----------------
export function resolveElectron(): Plugin[] {
const builtins = builtinModules.filter(t => !t.startsWith('_'))
return [
{
name: 'vite-plugin-electron-config',
config(config) {
if (!config.optimizeDeps) config.optimizeDeps = {}
if (!config.optimizeDeps.exclude) config.optimizeDeps.exclude = []
config.optimizeDeps.exclude.push('electron', ...builtins)
console.log(config.optimizeDeps.exclude)
},
},
// https://github.com/caoxiemeihao/vite-plugins/tree/main/packages/resolve#readme
resolve({
electron: electronExport(),
...builtinModulesExport(builtins),
// you can custom other module in here, need to make sure it's in `dependencies`
// 'electron-store': 'const Store = require("electron-store"); export defalut Store;'
})
]
function electronExport() {
return `
/**
* All exports module see https://www.electronjs.org -> API -> Renderer Process Modules
*/
const electron = require("electron");
const {
clipboard,
nativeImage,
shell,
contextBridge,
crashReporter,
ipcRenderer,
webFrame,
desktopCapturer,
deprecate,
} = electron;
export {
electron as default,
clipboard,
nativeImage,
shell,
contextBridge,
crashReporter,
ipcRenderer,
webFrame,
desktopCapturer,
deprecate,
}
`
}
function builtinModulesExport(modules: string[]) {
return modules.map((moduleId) => {
const nodeModule = require(moduleId)
const attrs = Object.keys(nodeModule)
const requireTpl = `const __builtinModule = require("${moduleId}");`
const exportDefault = `export default __builtinModule`
const exportTpl = attrs.map(attr => `export const ${attr} = __builtinModule.${attr}`).join(';\n') + ';'
const nodeModuleCode = `
${requireTpl}
${exportDefault}
${exportTpl}
`
return { [moduleId]: nodeModuleCode }
}).reduce((memo, item) => Object.assign(memo, item), {})
}
}