From e7d38ab1c45b9d17f182f89d0c129932e2f994eb Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Arnaud=20Barr=C3=A9?= Date: Thu, 23 May 2024 17:59:16 +0200 Subject: [PATCH] docs: deprecate server.hot (#16741) --- docs/guide/api-plugin.md | 17 +++++++---------- packages/vite/src/node/plugin.ts | 2 +- packages/vite/src/node/server/index.ts | 2 +- 3 files changed, 9 insertions(+), 12 deletions(-) diff --git a/docs/guide/api-plugin.md b/docs/guide/api-plugin.md index b06982b4b89fc2..852a6e408cfb37 100644 --- a/docs/guide/api-plugin.md +++ b/docs/guide/api-plugin.md @@ -428,8 +428,7 @@ Vite plugins can also provide hooks that serve Vite-specific purposes. These hoo ```js handleHotUpdate({ server, modules, timestamp }) { - // Also use `server.ws.send` to support Vite <5.1 if needed - server.hot.send({ type: 'full-reload' }) + server.ws.send({ type: 'full-reload' }) // Invalidate modules manually const invalidatedModules = new Set() for (const mod of modules) { @@ -448,8 +447,7 @@ Vite plugins can also provide hooks that serve Vite-specific purposes. These hoo ```js handleHotUpdate({ server }) { - // Also use `server.ws.send` to support Vite <5.1 if needed - server.hot.send({ + server.ws.send({ type: 'custom', event: 'special-update', data: {} @@ -556,7 +554,7 @@ Since Vite 2.9, we provide some utilities for plugins to help handle the communi ### Server to Client -On the plugin side, we could use `server.hot.send` (since Vite 5.1) or `server.ws.send` to broadcast events to all the clients: +On the plugin side, we could use `server.ws.send` to broadcast events to the client: ```js // vite.config.js @@ -565,9 +563,8 @@ export default defineConfig({ { // ... configureServer(server) { - // Example: wait for a client to connect before sending a message - server.hot.on('connection', () => { - server.hot.send('my:greetings', { msg: 'hello' }) + server.ws.on('connection', () => { + server.ws.send('my:greetings', { msg: 'hello' }) }) }, }, @@ -603,7 +600,7 @@ if (import.meta.hot) { } ``` -Then use `server.hot.on` (since Vite 5.1) or `server.ws.on` and listen to the events on the server side: +Then use `server.ws.on` and listen to the events on the server side: ```js // vite.config.js @@ -612,7 +609,7 @@ export default defineConfig({ { // ... configureServer(server) { - server.hot.on('my:from-client', (data, client) => { + server.ws.on('my:from-client', (data, client) => { console.log('Message from client:', data.msg) // Hey! // reply only to the client (if needed) client.send('my:ack', { msg: 'Hi! I got your message!' }) diff --git a/packages/vite/src/node/plugin.ts b/packages/vite/src/node/plugin.ts index bf6eb069067bdc..8ef2f228115477 100644 --- a/packages/vite/src/node/plugin.ts +++ b/packages/vite/src/node/plugin.ts @@ -130,7 +130,7 @@ export interface Plugin extends RollupPlugin { * the descriptors. * * - The hook can also return an empty array and then perform custom updates - * by sending a custom hmr payload via server.hot.send(). + * by sending a custom hmr payload via server.ws.send(). * * - If the hook doesn't return a value, the hmr update will be performed as * normal. diff --git a/packages/vite/src/node/server/index.ts b/packages/vite/src/node/server/index.ts index 964b8e37a85000..2616cfe58aba4c 100644 --- a/packages/vite/src/node/server/index.ts +++ b/packages/vite/src/node/server/index.ts @@ -242,7 +242,6 @@ export interface ViteDevServer { watcher: FSWatcher /** * web socket server with `send(payload)` method - * @deprecated use `hot` instead */ ws: WebSocketServer /** @@ -250,6 +249,7 @@ export interface ViteDevServer { * * Always sends a message to at least a WebSocket client. Any third party can * add a channel to the broadcaster to process messages + * @deprecated will be replaced with the environment api in v6. */ hot: HMRBroadcaster /**