Getting Started
Este contenido aún no está disponible en tu idioma.
- 
Install the package Ventana de terminal npm i @capgo/capacitor-live-reloadVentana de terminal pnpm add @capgo/capacitor-live-reloadVentana de terminal yarn add @capgo/capacitor-live-reloadVentana de terminal bun add @capgo/capacitor-live-reload
- 
Sync with native projects Ventana de terminal npx cap syncVentana de terminal pnpm cap syncVentana de terminal yarn cap syncVentana de terminal bunx cap sync
Setup
Configure your Vite dev server to work with live reload. You need to:
- Disable the built-in HMR client
- Forward reload events over a dedicated WebSocket endpoint
Usage
import { LiveReload } from '@capgo/capacitor-live-reload';
// Configure the dev serverawait LiveReload.configureServer({  url: 'http://localhost:5173',  websocketPath: '/capgo-livereload',  autoReconnect: true,  reconnectInterval: 2000});
// Connect to the dev serverawait LiveReload.connect();
// Listen for reload eventsLiveReload.addListener('reloadEvent', (event) => {  console.log('Reload event:', event);  if (event.type === 'full-reload') {    console.log('Full page reload triggered');  } else if (event.type === 'file-update') {    console.log('File updated:', event.file);  }});
// Listen for connection status changesLiveReload.addListener('statusChange', (status) => {  console.log('Connection status:', status.connected);  console.log('Server URL:', status.url);});API Reference
configureServer(options)
Store remote dev server settings for subsequent connections.
const status = await LiveReload.configureServer({  url: 'http://192.168.1.100:5173',  websocketPath: '/capgo-livereload',  headers: {    'Authorization': 'Bearer token'  },  autoReconnect: true,  reconnectInterval: 2000});Parameters:
- url(string): Base URL for the dev server (e.g.,- http://dev.local:5173)
- websocketPath(string, optional): WebSocket path override (default:- /ws)
- headers(Record<string, string>, optional): Extra headers for WebSocket connection
- autoReconnect(boolean, optional): Auto-reconnect on disconnect (default:- true)
- reconnectInterval(number, optional): Delay between reconnect attempts in ms (default:- 2000)
Returns: LiveReloadStatus with connection info
connect()
Establish a WebSocket connection if one is not already active.
const status = await LiveReload.connect();console.log('Connected:', status.connected);Returns: Current connection status
disconnect()
Close the current WebSocket connection and disable auto reconnect.
await LiveReload.disconnect();getStatus()
Get the current connection status.
const status = await LiveReload.getStatus();console.log('Connected:', status.connected);console.log('URL:', status.url);reload()
Manually trigger a full reload of the Capacitor WebView.
await LiveReload.reload();reloadFile(options)
Reload a single file/module (falls back to full reload if not supported).
await LiveReload.reloadFile({  path: '/src/components/MyComponent.tsx',  hash: 'abc123'});addListener(‘reloadEvent’, callback)
Listen to incoming reload events from the server.
const handle = await LiveReload.addListener('reloadEvent', (event) => {  switch (event.type) {    case 'full-reload':      console.log('Full reload requested');      break;    case 'file-update':      console.log('File updated:', event.file?.path);      break;    case 'error':      console.error('Error:', event.message);      break;  }});
// Remove listener when doneawait handle.remove();addListener(‘statusChange’, callback)
Listen to socket status changes.
await LiveReload.addListener('statusChange', (status) => {  console.log(status.connected ? 'Connected' : 'Disconnected');});removeAllListeners()
Remove all registered listeners.
await LiveReload.removeAllListeners();Complete Example
import { LiveReload } from '@capgo/capacitor-live-reload';
export class DevServer {  private connected = false;
  async initialize() {    // Only enable in development    if (process.env.NODE_ENV !== 'development') {      return;    }
    try {      // Configure server      await LiveReload.configureServer({        url: 'http://192.168.1.100:5173',        websocketPath: '/capgo-livereload',        autoReconnect: true,        reconnectInterval: 3000      });
      // Set up listeners before connecting      await LiveReload.addListener('reloadEvent', this.handleReloadEvent.bind(this));      await LiveReload.addListener('statusChange', this.handleStatusChange.bind(this));
      // Connect      await LiveReload.connect();    } catch (error) {      console.error('Failed to initialize live reload:', error);    }  }
  private handleReloadEvent(event: any) {    console.log('Reload event received:', event.type);
    switch (event.type) {      case 'full-reload':        this.performFullReload();        break;      case 'file-update':        this.handleFileUpdate(event.file);        break;      case 'error':        console.error('Server error:', event.message);        break;      case 'connected':        console.log('Server connected');        break;      case 'disconnected':        console.log('Server disconnected');        break;    }  }
  private handleStatusChange(status: any) {    this.connected = status.connected;    console.log(`Live reload ${status.connected ? 'connected' : 'disconnected'}`);  }
  private performFullReload() {    console.log('Performing full page reload...');    window.location.reload();  }
  private handleFileUpdate(file: any) {    console.log('File updated:', file?.path);    // HMR will handle this automatically in most cases  }
  async disconnect() {    await LiveReload.disconnect();    await LiveReload.removeAllListeners();    this.connected = false;  }
  isConnected(): boolean {    return this.connected;  }}Vite Configuration Example
Configure your Vite server to work with the live reload plugin:
import { defineConfig } from 'vite';
export default defineConfig({  server: {    host: '0.0.0.0', // Allow connections from network    port: 5173,    hmr: {      // Custom WebSocket path for live reload      path: '/capgo-livereload',    }  }});Best Practices
- 
Only use in development if (import.meta.env.DEV) {await LiveReload.configureServer({url: 'http://localhost:5173',websocketPath: '/capgo-livereload'});await LiveReload.connect();}
- 
Use your local IP for mobile testing const devServerUrl = process.env.VITE_DEV_SERVER_URL || 'http://192.168.1.100:5173';await LiveReload.configureServer({ url: devServerUrl });
- 
Handle connection errors gracefully try {await LiveReload.connect();} catch (error) {console.warn('Could not connect to dev server, using production build');}
- 
Clean up on app exit window.addEventListener('beforeunload', async () => {await LiveReload.disconnect();});
- 
Show connection status in UI LiveReload.addListener('statusChange', (status) => {// Show indicator in dev buildsupdateDevIndicator(status.connected);});
Platform Notes
iOS
- Works with iOS 11.0+
- Ensure dev server is accessible from your device’s network
- May need to configure firewall to allow connections
Android
- Works with Android 5.0 (API 21)+
- Use adb reversefor localhost connections:Terminal window adb reverse tcp:5173 tcp:5173
Web
- Full support for web platform
- Direct WebSocket connection to Vite dev server
Troubleshooting
Connection fails:
- Verify dev server is running
- Check that device and computer are on same network
- Ensure firewall allows connections on the port
- Use IP address instead of localhost for mobile devices
Slow reload:
- Check network speed
- Reduce reconnect interval
- Optimize Vite build configuration
WebSocket errors:
- Verify websocketPath matches Vite config
- Check for port conflicts
- Ensure headers are correct if using authentication