Eventos
Copie una pestaña de configuración con los pasos de instalación y la guía de markdown completa para este complemento.
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.
Configuración del escuchador de eventos
Sección titulada “Configuración del escuchador de eventos”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 listenerconst listener = await CapacitorUpdater.addListener('eventName', (event) => { // Handle the event});
// Remove the listener when no longer neededlistener.remove();
// Remove all listenersawait CapacitorUpdater.removeAllListeners();Se dispara durante el proceso de descarga del paquete. Proporciona información de progreso de descarga.
Copiar a portapapelesdownload
Sección titulada “download”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
noNeedUpdate
Sección titulada “noNeedUpdate”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
updateAvailable
Sección titulada “updateAvailable”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
downloadComplete
Sección titulada “downloadComplete”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
majorAvailable
Sección titulada “majorAvailable”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
updateFailed
Sección titulada “updateFailed”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
downloadFailed
Sección titulada “downloadFailed”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
appReloaded
Sección titulada “appReloaded”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
appReady
Sección titulada “appReady”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 actualstatus: string - El estado listo
Objeto BundleInfo
Sección titulada “Objeto BundleInfo”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
Ejemplo: Flujo de actualización completo
Sección titulada “Ejemplo: Flujo de actualización completo”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 }}Prácticas recomendadas
Sección titulada “Prácticas recomendadas”-
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. -
Manejar fallas con graciaImplementar un manejo de errores adecuado para las fallas de descarga y actualización.
-
Proporcionar retroalimentación al usuarioUtilice el evento de progreso de descarga para mostrar el progreso de la actualización a los usuarios.
-
Limpieza de oyentes: Elimine los oyentes de eventos cuando ya no sean necesarios para prevenir fugas de memoria.
-
Escenarios de actualización: Pruebe varios escenarios de actualización, incluidas las fallas, los reversiones y las actualizaciones importantes.
Sigue adelante desde Eventos
Sección titulada “Sigue adelante desde Eventos”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