Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

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

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 or filename or glob Array.

Must be a relative path, which will be calculated based on the root.

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. If logger is passed, all logs will be input this option




transformOptions
import('esbuild').TransformOptions
Options of esbuild.transform()




watch
import('chokidar').WatchOptions
Options of chokidar.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'],
})
```