Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/caoxiemeihao/vite-electron-plugin
High-performance, esbuild-based Vite Electron plugin
https://github.com/caoxiemeihao/vite-electron-plugin
electron esbuild plugin vite
Last synced: 3 months ago
JSON representation
High-performance, esbuild-based Vite Electron plugin
- Host: GitHub
- URL: https://github.com/caoxiemeihao/vite-electron-plugin
- Owner: caoxiemeihao
- License: mit
- Created: 2022-09-24T09:24:28.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2023-12-03T12:08:53.000Z (about 1 year ago)
- Last Synced: 2024-05-02T05:08:20.654Z (9 months ago)
- Topics: electron, esbuild, plugin, vite
- Language: TypeScript
- Homepage:
- Size: 316 KB
- Stars: 53
- Watchers: 1
- Forks: 7
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# vite-electron-plugin
High-performance, esbuild-based Vite Electron plugin
[![NPM version](https://img.shields.io/npm/v/vite-electron-plugin.svg)](https://npmjs.com/package/vite-electron-plugin)
[![NPM Downloads](https://img.shields.io/npm/dm/vite-electron-plugin.svg)](https://npmjs.com/package/vite-electron-plugin)- 🚀 High-performance (Not Bundle, based on esbuild)
- 🎯 Support Plugin (Like Vite's plugin)
- 🌱 What you see is what you get
- 🔥 Hot restart## Quick Setup
1. Add dependency to project
```sh
npm i -D vite-electron-plugin
```2. Add `vite-electron-plugin` into `vite.config.ts`
```js
import electron from 'vite-electron-plugin'export default {
plugins: [
electron({
include: [
// The Electron source codes directory
'electron',
],
}),
],
}
```3. Create `electron/main.ts` and type the following code
```js
import { app, BrowserWindow } from 'electron'app.whenReady().then(() => {
const win = new BrowserWindow()if (process.env.VITE_DEV_SERVER_URL) {
win.loadURL(process.env.VITE_DEV_SERVER_URL)
} else {
win.loadFile('dist/index.html')
}
})
```4. Add entry into `package.json`
```diff
{
+ "main": "dist-electron/main.js"
}
```## [Examples](https://github.com/electron-vite/vite-electron-plugin/tree/main/examples)
- [quick-start](https://github.com/electron-vite/vite-electron-plugin/tree/main/examples/quick-start)
## Recommend Structure
Let's use the official [template-vanilla-ts](https://github.com/vitejs/vite/tree/main/packages/create-vite/template-vanilla-ts) created based on `create vite` as an example
```diff
+ ├─┬ electron
+ │ └── main.ts
├─┬ src
│ ├── main.ts
│ ├── style.css
│ └── vite-env.d.ts
├── .gitignore
├── favicon.svg
├── index.html
├── package.json
├── tsconfig.json
+ └── vite.config.ts
```
## Conventions- Any file ending with `reload.ext` *(e.g. `foo.reload.js`, `preload.ts`)* after an update,
will trigger a reload of the Electron-Renderer process, instead of an entire Electron App restart.
**Which is useful when updating Preload-Scripts.**## Configuration
###### `electron(config: Configuration)`
Key
Type
Description
Required
Default
include
Array
directory
orfilename
orglob
Array.
Must be a relative path, which will be calculated based on theroot
.
If it is an absolute path, it can only be a subpath of root.
Otherwise it will cause the output file path to be calculated incorrectly.
✅
root
string
process.cwd()
outDir
string
Output Directory.
dist-electron
api
Record<string, any>
Useful if you want to pass some payload to the plugin.
plugins
Plugin[]
See the Plugin API.
logger
{ [type: string], (...message: string[]) => void }
Custom log. Iflogger
is passed, all logs will be input this option
transformOptions
import('esbuild').TransformOptions
Options ofesbuild.transform()
watch
import('chokidar').WatchOptions
Options ofchokidar.watch()
## Plugin API
> The design of plugin is similar to [Vite's plugin](https://vitejs.dev/guide/api-plugin.html). But simpler, only 4 hooks in total.
#### `configResolved`
- **Type**: `(config: ResolvedConfig) => void | Promise`
- **Kind**: `async`, `sequential`You can freely modify the `config` argument in ths hooks or use.
#### `onwatch` serve only
- **Type**: `(envet: 'add' | 'change' | 'addDir' | 'unlink' | 'unlinkDir', path: string) => void`
- **Kind**: `async`, `parallel`Triggered by `include` file changes. You can emit some files in this hooks. Even restart the Electron App.
#### `transform`
- **Type**: `(args: { filename: string, code: string, done: () => void }) => string | import('esbuild').TransformResult | void | Promise`
- **Kind**: `async`, `sequential`Triggered by changes in `extensions` files in include.
#### `ondone`
- **Type**: `(args: { filename: string, distname: string }) => void`
- **Kind**: `async`, `parallel`Triggered when `transform()` ends or a file in `extensions` is removed.
## Builtin Plugin
```ts
import path from 'node:path'
import electron from 'vite-electron-plugin'
import {
alias,
copy,
dest,
esmodule,
customStart,
loadViteEnv,
} from 'vite-electron-plugin/plugin'export default {
plugins: [
electron({
plugins: [
alias([
// `replacement` is recommented to use absolute path,
// it will be automatically calculated as relative path.
{ find: '@', replacement: path.join(__dirname, 'src') },
]),copy([
// filename, glob
{ from: 'foo/*.ext', to: 'dest' },
]),// Dynamic change the build dist path.
dest((_from, to) => to?.replace('dist-electron', 'dist-other')),customStart(({ startup }) => {
// If you want to control the launch of Electron App yourself.
startup()
}),// Support use ESM npm-package in Electron-Main.
esmodule({
// e.g. `execa`, `node-fetch`, `got`, etc.
include: ['execa', 'node-fetch', 'got'],
}),// https://vitejs.dev/guide/env-and-mode.html#env-files
// Support use `import.meta.env.VITE_SOME_KEY` in Electron-Main
loadViteEnv(),
],
}),
],
}
```## JavaScript API
```ts
import {
type Configuration,
type ResolvedConfig,
type Plugin,
build,
watch,
startup,
defineConfig,
default as electron,
} from 'vite-electron-plugin'
```**Example**
```js
// dev
watch({
include: [
// The Electron source codes directory
'electron',
],
plugins: [
{
name: 'plugin-electron-startup',
ondone() {
// Startup Electron App
startup()
},
},
],
})// build
build({
include: ['electron'],
})
```