Saltar al contenido

Eventos

El plugin de actualización Capacitor proporciona varios eventos a los que puedes suscribirte para supervisar el proceso de actualización y responder a diferentes estados.

Para escuchar eventos, utiliza el método en el objeto: addListener Copiar a portapapeles CapacitorUpdater Eventos disponibles

import { CapacitorUpdater } from '@capgo/capacitor-updater';
// Add a listener
const listener = await CapacitorUpdater.addListener('eventName', (event) => {
// Handle the event
});
// Remove the listener when no longer needed
listener.remove();
// Remove all listeners
await CapacitorUpdater.removeAllListeners();

Se dispara durante el proceso de descarga del paquete. Proporciona información de progreso de descarga.

Copiar a portapapeles

Se dispara durante el proceso de descarga del paquete. Proporciona información de progreso de descarga.

CapacitorUpdater.addListener('download', (event) => {
console.log(`Download progress: ${event.percent}%`);
console.log('Bundle info:', event.bundle);
});

Datos del evento:

  • percent: número - Porcentaje de progreso de descarga (0-100)
  • bundle: BundleInfo - Información sobre el paquete que se está descargando

Se dispara cuando una comprobación de actualizaciones determina que no es necesario actualizar.

CapacitorUpdater.addListener('noNeedUpdate', (event) => {
console.log('App is up to date');
console.log('Current bundle:', event.bundle);
});

Datos del evento:

  • bundle: BundleInfo - Información sobre el paquete actual

Se dispara cuando está disponible una nueva actualización para su descarga.

CapacitorUpdater.addListener('updateAvailable', (event) => {
console.log('Update available');
console.log('New bundle:', event.bundle);
// You can trigger a download here if needed
});

Datos del evento:

  • bundle: BundleInfo - Información sobre la actualización de paquete disponible

Se dispara cuando se ha completado con éxito la descarga de un paquete.

CapacitorUpdater.addListener('downloadComplete', (event) => {
console.log('Download completed');
console.log('Downloaded bundle:', event.bundle);
// You might want to set this bundle as next
});

Datos del evento:

  • bundle: BundleInfo - Información sobre el paquete descargado

Se dispara cuando está disponible una actualización importante pero está bloqueada por las configuraciones de actualización automática.

CapacitorUpdater.addListener('majorAvailable', (event) => {
console.log('Major update available:', event.version);
// Notify user about major update
});

Datos del evento:

  • version: string - La versión del número de la actualización principal

Se dispara cuando una actualización ha fallado para instalar en la próxima apertura de la aplicación.

CapacitorUpdater.addListener('updateFailed', (event) => {
console.error('Update failed to install');
console.log('Failed bundle:', event.bundle);
// Handle rollback or retry logic
});

Datos del evento:

  • bundle: BundleInfo - Información sobre el paquete que ha fallado para instalar

Se dispara cuando una descarga de paquetes ha fallado.

CapacitorUpdater.addListener('downloadFailed', (event) => {
console.error('Download failed for version:', event.version);
// Handle download retry logic
});

Datos del evento:

  • version: string - La versión que no pudo descargar

Se dispara cuando la aplicación ha sido recargada.

CapacitorUpdater.addListener('appReloaded', () => {
console.log('App has been reloaded');
// Perform any necessary reinitialization
});

Datos del evento: Ninguno

Se dispara cuando la aplicación está lista para usar después de una actualización.

CapacitorUpdater.addListener('appReady', (event) => {
console.log('App is ready');
console.log('Current bundle:', event.bundle);
console.log('Status:', event.status);
});

Datos del evento:

  • bundle: Información del paquete - Información sobre el paquete actual
  • status: string - El estado listo

Muchos eventos incluyen un BundleInfo objeto con las siguientes propiedades:

interface BundleInfo {
id: string; // Unique bundle identifier
version: string; // Bundle version
downloaded: string; // Download timestamp
checksum?: string; // Bundle checksum (if available)
status: BundleStatus; // Bundle status
}

¿Dónde? BundleStatus puede ser:

  • 'success' - Se ha descargado el paquete con éxito
  • 'error' - Se ha producido un error al descargar o instalar el paquete
  • 'pending' - El paquete está pendiente de configurarse como el siguiente
  • 'downloading' - El paquete está actualmente descargándose

Aquí hay un ejemplo de cómo manejar el flujo de actualización completo con eventos:

import { CapacitorUpdater } from '@capgo/capacitor-updater';
export class UpdateManager {
private listeners: any[] = [];
async setupListeners() {
// Listen for available updates
this.listeners.push(
await CapacitorUpdater.addListener('updateAvailable', async (event) => {
console.log('Update available:', event.bundle.version);
// Auto-download the update
await CapacitorUpdater.download({
url: event.bundle.url,
version: event.bundle.version
});
})
);
// Monitor download progress
this.listeners.push(
await CapacitorUpdater.addListener('download', (event) => {
console.log(`Downloading: ${event.percent}%`);
// Update UI progress bar
this.updateProgressBar(event.percent);
})
);
// Handle download completion
this.listeners.push(
await CapacitorUpdater.addListener('downloadComplete', async (event) => {
console.log('Download complete:', event.bundle.version);
// Set as next bundle
await CapacitorUpdater.next({ id: event.bundle.id });
})
);
// Handle failures
this.listeners.push(
await CapacitorUpdater.addListener('downloadFailed', (event) => {
console.error('Download failed:', event.version);
this.showError('Update download failed. Please try again later.');
})
);
this.listeners.push(
await CapacitorUpdater.addListener('updateFailed', (event) => {
console.error('Update installation failed:', event.bundle.version);
this.showError('Update installation failed. The app has been rolled back.');
})
);
// Handle app ready
this.listeners.push(
await CapacitorUpdater.addListener('appReady', async (event) => {
console.log('App ready with bundle:', event.bundle.version);
})
);
}
cleanup() {
// Remove all listeners when no longer needed
this.listeners.forEach(listener => listener.remove());
this.listeners = [];
}
private updateProgressBar(percent: number) {
// Update your UI progress bar
}
private showError(message: string) {
// Show error to user
}
}
  1. Siempre llamar notifyAppReady()Cuando se utiliza la actualización automática, siempre llame a este método después de que su aplicación se inicie para evitar el rollback.

  2. Manejar fallas con graciaImplementar un manejo de errores adecuado para las fallas de descarga y actualización.

  3. Proporcionar retroalimentación al usuarioUtilice el evento de progreso de descarga para mostrar el progreso de la actualización a los usuarios.

  4. Limpieza de oyentes: Elimine los oyentes de eventos cuando ya no sean necesarios para prevenir fugas de memoria.

  5. Escenarios de actualización: Pruebe varios escenarios de actualización, incluidas las fallas, los reversiones y las actualizaciones importantes.

Si estás utilizando Eventos para planificar el trabajo de plugins nativos, conecta con Usando @capgo/capacitor-actualizador para la capacidad nativa en Usando @capgo/capacitor-actualizador, Capgo Directorio de Plugin para el flujo de trabajo del producto en el directorio de plugins Capgo Capacitor Plugins por Capgo para el detalle de implementación en Capacitor Plugins por Capgo Agregar o actualizar plugins para el detalle de implementación en Agregar o actualizar plugins, y Alternativas de plugins de Ionic Enterprise para el flujo de trabajo del producto en Alternativas de plugins de Ionic Enterprise