@silvenon/vite-plugin-devtools-json
v1.0.1
Published
Vite plugin for generating `com.chrome.devtools.json` on the fly in the devserver.
Downloads
204
Maintainers
Readme
Vite Plugin for DevTools Project Settings (devtools.json)
[!NOTE] This is a fork of the official vite-plugin-devtools-json. The primary purpose of forking it is to keep it up to date.
Vite plugin for generating the Chrome DevTools project settings file on-the-fly in the devserver.
This enables seamless integration with the new Chrome DevTools features
Installation
npm install -D @silvenon/vite-plugin-devtools-jsonUsage
Add it to your Vite config
import {defineConfig} from 'vite';
import devtoolsJson from '@silvenon/vite-plugin-devtools-json';
export default defineConfig({
plugins: [
devtoolsJson(),
// ...
]
});While the plugin can generate a UUID and save it in vite cache, you can also specify it in the options like in the following:
plugins: [
devtoolsJson({ uuid: "6ec0bd7f-11c0-43da-975e-2a8ad9ebae0b" }),
// ...
]Options
| Name | Type | Default | Description |
|------|------|---------|-------------|
| projectRoot | string | config.root | Absolute path that will be reported to DevTools. Useful for monorepos or when the Vite root is not the desired folder. |
| normalizeForWindowsContainer | boolean | true | Convert Linux paths to UNC form so Chrome on Windows (WSL / Docker Desktop) can mount them (e.g. via WSL or Docker Desktop). Pass false to disable. Alias: normalizeForChrome (deprecated)_ |
| uuid | string | auto-generated | Fixed UUID if you prefer to control it yourself. |
Example with all options:
import { defineConfig } from 'vite';
import devtoolsJson from '@silvenon/vite-plugin-devtools-json';
export default defineConfig({
plugins: [
devtoolsJson({
projectRoot: '/absolute/path/to/project',
normalizeForWindowsContainer: true,
uuid: '6ec0bd7f-11c0-43da-975e-2a8ad9ebae0b'
})
]
});The /.well-known/appspecific/com.chrome.devtools.json endpoint will serve the
project settings as JSON with the following structure
{
"workspace": {
"root": "/path/to/project/root",
"uuid": "6ec0bd7f-11c0-43da-975e-2a8ad9ebae0b"
}
}where root is the absolute path to your {projectRoot} folder, and uuid is
a random v4 UUID, generated the first time that you start the Vite devserver
with the plugin installed (it is henceforth cached in the Vite cache folder).
Checkout bmeurer/automatic-workspace-folders-vanilla for a trivial example project illustrating how to use the plugin in practice.
License
The code is under MIT License.
