Aller directement au contenu

Événements

GitHub

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.

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 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();

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

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

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é

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

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

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

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

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

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
}

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

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
}
}
  1. 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.

  2. Gérer les échecs avec éléganceImplémenter un traitement d'erreur approprié pour les échecs de téléchargement et de mise à jour.

  3. Fournir des feedbacks à l'utilisateurUtilisez l'événement de progression de téléchargement pour afficher la progression de mise à jour aux utilisateurs.

  4. Nettoyer les écouteursSupprimer les écouteurs d'événements lorsque ceux-ci ne sont plus nécessaires pour prévenir les fuites de mémoire.

  5. Tester les scénarios de mise à jourTester divers scénarios de mise à jour, y compris les échecs, les rollbacks et les mises à jour majeures.

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.