Événements
Copier un prompt de configuration avec les étapes d'installation et la guide markdown complète pour ce plugin.
Le plugin de mise à jour Capacitor fournit plusieurs événements que vous pouvez écouter pour surveiller le processus de mise à jour et répondre à différents états.
Configuration de l'écouteur d'événements
Section intitulée “Configuration de l'écouteur d'événements”Pour écouter les événements, utilisez le addListener méthode sur l'objet : CapacitorUpdater Copier dans le presse-papier
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();Section intitulée « Événements disponibles »
Section intitulée « téléchargement »Copier dans le presse-papier
CapacitorUpdater.addListener('download', (event) => { console.log(`Download progress: ${event.percent}%`); console.log('Bundle info:', event.bundle);});: nombre - Pourcentage de progression de téléchargement (0-100)
percent: BundleInfo - Informations sur le bundle téléchargébundleNote :
Déclenché lorsqu'une vérification de mise à jour détermine qu'aucune mise à jour n'est nécessaire.
CapacitorUpdater.addListener('noNeedUpdate', (event) => { console.log('App is up to date'); console.log('Current bundle:', event.bundle);});Données de l'événement :
bundle: BundleInfo - Informations sur le bundle actuel
updateAvailable
Section intitulée “mise à jour disponible”Déclenché lorsqu'une nouvelle mise à jour est disponible pour le téléchargement.
CapacitorUpdater.addListener('updateAvailable', (event) => { console.log('Update available'); console.log('New bundle:', event.bundle); // You can trigger a download here if needed});Données de l'événement :
bundle: BundleInfo - Informations sur le bundle de mise à jour disponible
downloadComplete
Section intitulée “downloadComplete”Déclenché lorsqu'un téléchargement de bundle est terminé avec succès.
CapacitorUpdater.addListener('downloadComplete', (event) => { console.log('Download completed'); console.log('Downloaded bundle:', event.bundle); // You might want to set this bundle as next});Données de l'événement :
bundle: BundleInfo - Informations sur le bundle téléchargé
majorAvailable
Section intitulée “majorAvailable”Déclenché lorsqu'une mise à jour majeure est disponible mais bloquée par les paramètres d'auto-mise à jour.
CapacitorUpdater.addListener('majorAvailable', (event) => { console.log('Major update available:', event.version); // Notify user about major update});Données de l'événement :
version: chaîne - Le numéro de version de la mise à jour majeure
updateFailed
Section intitulée “mise à jour échouée”Déclenché lorsqu'une mise à jour a échoué à s'installer à la prochaine démarrage de l'application.
CapacitorUpdater.addListener('updateFailed', (event) => { console.error('Update failed to install'); console.log('Failed bundle:', event.bundle); // Handle rollback or retry logic});Données de l'événement :
bundle: BundleInfo - Informations sur le bundle qui a échoué à s'installer
downloadFailed
Section intitulée “téléchargement échoué”Déclenché lorsqu'un téléchargement de bundle a échoué.
CapacitorUpdater.addListener('downloadFailed', (event) => { console.error('Download failed for version:', event.version); // Handle download retry logic});Données de l'événement :
version: string - La version qui a échoué à se télécharger
appReloaded
Section intitulée “application rechargée”Déclenché lorsque l'application a été rechargée.
CapacitorUpdater.addListener('appReloaded', () => { console.log('App has been reloaded'); // Perform any necessary reinitialization});Données de l'événement : Aucune
appReady
Section intitulée “appReady”Déclenché lorsque l'application est prête à être utilisée après une mise à jour.
CapacitorUpdater.addListener('appReady', (event) => { console.log('App is ready'); console.log('Current bundle:', event.bundle); console.log('Status:', event.status);});Données de l'événement :
bundle: Informations sur le bundle actuel -status: chaîne - L'état prêt
BundleInfo Object
Section intitulée “BundleInfo Object”Beaucoup d'événements incluent un BundleInfo objet avec les propriétés suivantes :
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}Où BundleStatus peut être :
'success'- Le bundle a été téléchargé avec succès'error'- Le téléchargement/ installation du bundle a échoué'pending'- Le bundle est en attente d'être défini comme le prochain'downloading'- Le bundle est actuellement en téléchargement
Exemple : Flux de mise à jour complet
Section intitulée “Exemple : Flux de mise à jour complet”Voici un exemple de gestion du flux de mise à jour complet avec des événements :
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 }}Meilleures Pratiques
Section intitulée « Meilleures Pratiques »-
Appeler toujours
notifyAppReady()Lors de l'utilisation de l'auto-mise à jour, appelez toujours cette méthode après l'initialisation de votre application pour prévenir le rollback. -
Gérer les échecs avec éléganceImplémenter un traitement d'erreur approprié pour les échecs de téléchargement et de mise à jour.
-
Fournir des feedbacks à l'utilisateurUtilisez l'événement de progression de téléchargement pour afficher la progression de mise à jour aux utilisateurs.
-
Nettoyer les écouteursSupprimer les écouteurs d'événements lorsque ceux-ci ne sont plus nécessaires pour prévenir les fuites de mémoire.
-
Tester les scénarios de mise à jourTester divers scénarios de mise à jour, y compris les échecs, les rollbacks et les mises à jour majeures.
Continuez de là des événements
Section intitulée « Continuez de là des événements »Si vous utilisez Événements pour planifier le travail de plugin natif, connectez-le avec En utilisant @capgo/capacitor-mise à jour pour la capacité native dans En utilisant @capgo/capacitor-mise à jour, Capgo Répertoire des plugins pour le flux de travail du produit dans Capgo Répertoire des plugins, Capacitor Plugins par Capgo pour le détail d'implémentation dans Capacitor Plugins par Capgo, Ajouter ou mettre à jour des plugins pour les détails d'implémentation dans l'ajout ou la mise à jour de plugins, et Alternatives de plugins d'entreprise Ionic pour le flux de travail du produit dans Alternatives de plugins d'entreprise Ionic.