Eventos
Copie un prompt de configuración con los pasos de instalación y la guía de markdown completa para este plugin.
El plugin de actualizador Capacitor proporciona varios eventos que puedes escuchar para monitorear el proceso de actualización y responder a diferentes estados.
Configuración de escucha de eventos
Sección titulada “Configuración de escucha de eventos”Para escuchar eventos, utiliza el método addListener en el objeto: CapacitorUpdater Copiar al portapapeles
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();Disponibles
Sección titulada “Eventos disponibles”download
Sección titulada “descargar”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 “no es necesario actualizar”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:
bundleBundleInfo - Información sobre el paquete actual
updateAvailable
Sección titulada “actualización disponible”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:
bundleBundleInfo - Información sobre el paquete de actualización disponible
downloadComplete
Sección titulada “descarga completa”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: Información del paquete - Información sobre el paquete descargado
majorAvailable
Sección titulada “majorAvailable”Se dispara cuando hay una actualización importante disponible 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 - El número de versión de la actualización importante
updateFailed
Sección titulada “updateFailed”Se dispara cuando una actualización ha fallado al 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__CAPGO_KEEP_0__ - Información sobre el paquete que no se instaló correctamente
downloadFailed
Sección titulada “downloadFailed”Se dispara cuando un paquete de descarga ha fallado.
CapacitorUpdater.addListener('downloadFailed', (event) => { console.error('Download failed for version:', event.version); // Handle download retry logic});Datos del evento:
version__CAPGO_KEEP_0__ - La versión que no se 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: No hay datos
appReady
Sección titulada “appReady”Se dispara cuando la aplicación está lista para su uso 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 actual - Información sobre el paquete actualstatus: cadena - El estado de lista
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}Donde BundleStatus puede ser:
'success'- Se ha descargado el paquete con éxito'error'- Se ha fallado la descarga del 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 llama
notifyAppReady(): Siempre llama a este método después de que tu aplicación se inicie para evitar el rollback. -
Maneje las fallas con gracia: Implemente un manejo de errores adecuado para fallas de descarga y actualización.
-
Proporcionar retroalimentación al usuario: Utilice el evento de progreso de descarga para mostrar el progreso de actualización a los usuarios.
-
Limpiar los oyentes: Elimine los oyentes de eventos cuando ya no sean necesarios para prevenir fugas de memoria.
-
Probar escenarios de actualización: Pruebe varios escenarios de actualización, incluidas fallas, retrocesos y actualizaciones importantes.
Sigue adelante desde Eventos
Sección titulada “Sigue adelante desde Eventos”Si está utilizando Eventos para planificar el trabajo de plugin nativo, conectarlo con Usando @capgo/capacitor-actualizador para la capacidad nativa en Usando @capgo/capacitor-actualizador, Capgo Directorio de Plugins para el flujo de trabajo del producto en Capgo Directorio de Plugins, 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.