Skip to content

Commit

Permalink
feat: add support for kirby serve w/ HMR plugin (#18)
Browse files Browse the repository at this point in the history
* feat: add support for `kirby serve` w/ HMR plugin

* feat: allow HMR refresh, abort only on HMR reload

* feat: rename module entry to _index.mjs

makes it clearer that module entries are an internal, dev-only feature

* docs: update examples to include serve script

* feat: reload on PHP change in serve mode

* feat: live-reload via CLI arg, CLI help, refactor

* fix: only call server.close() if still listening

* fix: set server.origin to serve assets in dev mode

depends on vuejs/vue#12732

* fix: always pass array to vite-full-reload-plugin

ElMassimo/vite-plugin-full-reload#9

* feat: specify port via cli instead of kirbyup conf

* refactor: update reload-plugin, remove workaround

* feat: make sure index.dev.mjs is gone after build

* feat: set index.dev.mjs location with --out-dir

* docs: update README for serve command

* docs: capitalize "panel"

* refactor: inline getViteConfig() type

* fix: only handle SIGINT, implemented like vite
  • Loading branch information
jonaskuske authored Aug 15, 2022
1 parent f2be3f0 commit 0d152b2
Show file tree
Hide file tree
Showing 11 changed files with 534 additions and 293 deletions.
1 change: 1 addition & 0 deletions .prettierignore
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
*
55 changes: 34 additions & 21 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ The fastest and leanest way to bundle your Kirby Panel plugins. No configuration

- 🍂 Lightweight, robust and tested
- ⚡️ Fast compilation with Vite/esbuild
- 🔍 Watch mode
- 🔄 Hot Module Replacement and Watch mode
- \*️⃣ `kirbyup.import` to [auto-import blocks & fields](#auto-import-blocks-and-fields)
- 🎒 [PostCSS support](#postcss)
- 🧭 [Path resolve aliases](#path-resolve-aliases)
Expand Down Expand Up @@ -36,7 +36,7 @@ If you want to use kirbyup right away, there is no need to install it. Simply ca
```json
{
"scripts": {
"dev": "npx -y kirbyup src/index.js --watch",
"dev": "npx -y kirbyup serve src/index.js",
"build": "npx -y kirbyup src/index.js"
}
}
Expand All @@ -55,7 +55,7 @@ Example package configuration:
```json
{
"scripts": {
"dev": "kirbyup src/index.js --watch",
"dev": "kirbyup serve src/index.js",
"build": "kirbyup src/index.js"
},
"devDependencies": {
Expand All @@ -70,31 +70,21 @@ Global installation is supported as well, but not recommended.

### Development

Rebuild the Panel plugin on any file changes:
Start a development server for the Panel plugin:

```bash
kirbyup src/index.js --watch
kirbyup serve src/index.js
```

You can also specify the directories to be watched. By default, if no path is specified, kirbyup watches the directory specified by the input file (`src` for the example above).

```bash
kirbyup src/index.js --watch src
```

You can specify more than a single directory:

```bash
kirbyup src/index.js --watch src --watch libs
```
This creates `./index.dev.mjs`, telling Kirby to load the development version of the plugin from the dev server started by `kirbyup serve`, enhanced by features like hot module replacement and auto-reload.

### Production

```bash
kirbyup src/index.js
```

The final panel plugin will be bundled, minified, and written into the current directory as `./index.js`.
The final panel plugin will be bundled, minified, and written into the current directory as `./index.js` and `./index.css`.

## Built-in Features

Expand Down Expand Up @@ -222,15 +212,38 @@ For a complete list of options, take a look at the [Vite configuration options](

## Options

> Inspect all available options with `kirbyup --help`.
> Inspect all available options with `kirbyup --help` and `kirbyup serve --help`.
### `kirbyup <input>`

### `--out-dir`
##### `--out-dir <dir>`

The output directory to save the processed code into. Defaults to the current working directory.

### `--watch`
##### `--watch [path]`

Enables watch mode. If no path is specified, kirbyup watches the folder of the input file. Repeat `--watch` for multiple paths.

### `kirbyup serve <input>`

##### `--port <port>`

The port for the development server to run on. Defaults to `5177`.

##### `--out-dir <dir>`

The output directory where the plugin file read by Kirby is saved. Defaults to the project root.

##### `--watch <path>`

Specifies additional files that should be watched for changes, with changes causing the page to reload. Repeat `--watch` for multiple paths.

> 💡 By default, kirbyup will watch all PHP files (`./**/*.php`) in the plugin directory and reload the page if it detects changes. Using `--watch` to set your own path overrides this setting, so you need to add the PHP glob explicitly if you want to keep the behavior: `--watch ./my/files/* --watch ./**/*.php`
##### `--no-watch`

Disables the default behavior of watching all PHP files for changes.

Sets the watch mode. If no path is specified, kirbyup watches the folder of the input file. Repeat `--watch` for multiple paths.

## Credits

Expand Down
2 changes: 1 addition & 1 deletion examples/eslint-and-prettier/package.json
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
{
"private": true,
"scripts": {
"dev": "kirbyup src/index.js --watch",
"dev": "kirbyup serve src/index.js",
"build": "kirbyup src/index.js",
"lint": "eslint \"src/**/*.{js,vue}\"",
"lint:fix": "npm run lint -- --fix",
Expand Down
2 changes: 1 addition & 1 deletion examples/tailwindcss/package.json
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
{
"private": true,
"scripts": {
"dev": "kirbyup src/index.js --watch",
"dev": "kirbyup serve src/index.js",
"build": "kirbyup src/index.js"
},
"devDependencies": {
Expand Down
4 changes: 3 additions & 1 deletion package.json
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
{
"name": "kirbyup",
"version": "1.3.2",
"packageManager": "pnpm@7.6.0",
"packageManager": "pnpm@7.8.0",
"description": "Zero-config bundler for Kirby Panel plugins",
"author": {
"name": "Johann Schopplich",
Expand Down Expand Up @@ -74,6 +74,7 @@
"cac": "^6.7.12",
"chokidar": "^3.5.3",
"consola": "^2.15.3",
"detect-package-manager": "^2.0.1",
"magic-string": "^0.26.2",
"pathe": "^0.3.3",
"perfect-debounce": "^0.1.3",
Expand All @@ -85,6 +86,7 @@
"sass": "^1.54.1",
"unconfig": "^0.3.5",
"vite": "^3.0.4",
"vite-plugin-full-reload": "^1.0.4",
"vue": "^2.7.8"
},
"devDependencies": {
Expand Down
Loading

0 comments on commit 0d152b2

Please sign in to comment.