Events
复制一个包含安装步骤和此插件的完整Markdown指南的设置提示.
Capgo 更新器插件(Capacitor)提供了几个事件,您可以监听这些事件来监控更新过程并响应不同状态。
事件监听器设置
标题为“事件监听器设置”要监听事件,请使用 addListener 方法在 CapacitorUpdater 对象上:
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();download
Section titled “下载”在 bundle 下载过程中触发。 提供下载进度信息。
CapacitorUpdater.addListener('download', (event) => { console.log(`Download progress: ${event.percent}%`); console.log('Bundle info:', event.bundle);});事件数据:
percent: number - 下载进度百分比 (0-100)bundle: BundleInfo - 下载的 bundle 信息
noNeedUpdate
Section titled “无需更新”当检查更新时确定无需更新时触发。
CapacitorUpdater.addListener('noNeedUpdate', (event) => { console.log('App is up to date'); console.log('Current bundle:', event.bundle);});事件数据:
bundle: BundleInfo - 当前捆绑包的信息
updateAvailable
标题:更新可用当有可下载的新更新时触发。
CapacitorUpdater.addListener('updateAvailable', (event) => { console.log('Update available'); console.log('New bundle:', event.bundle); // You can trigger a download here if needed});事件数据:
bundle: BundleInfo - 可下载的更新捆绑包的信息
downloadComplete
标题:下载完成当捆绑包下载成功时触发。
CapacitorUpdater.addListener('downloadComplete', (event) => { console.log('Download completed'); console.log('Downloaded bundle:', event.bundle); // You might want to set this bundle as next});事件数据:
bundle:
majorAvailable
BundleInfo - 下载的包信息Section titled “majorAvailable”
CapacitorUpdater.addListener('majorAvailable', (event) => { console.log('Major update available:', event.version); // Notify user about major update});Copy to clipboard
version事件数据:
updateFailed
主要更新通常需要用户确认或应用商店更新。使用此事件通知用户。Section titled “updateFailed”
CapacitorUpdater.addListener('updateFailed', (event) => { console.error('Update failed to install'); console.log('Failed bundle:', event.bundle); // Handle rollback or retry logic});事件数据:
bundle: BundleInfo - 安装失败的包信息
downloadFailed
下载失败下载包失败时触发
CapacitorUpdater.addListener('downloadFailed', (event) => { console.error('Download failed for version:', event.version); // Handle download retry logic});事件数据:
version: string - 下载失败的版本
appReloaded
应用重载应用已重载
CapacitorUpdater.addListener('appReloaded', () => { console.log('App has been reloaded'); // Perform any necessary reinitialization});事件数据: 无
appReady
应用就绪应用更新后,应用就绪事件将在此触发。
CapacitorUpdater.addListener('appReady', (event) => { console.log('App is ready'); console.log('Current bundle:', event.bundle); console.log('Status:', event.status);});事件数据:
bundle: BundleInfo - 当前捆绑包的信息status: string - 应用就绪状态
捆绑包信息对象
捆绑包信息对象许多事件包含一个 BundleInfo 具有以下属性的对象:
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 - 下载完成
'success'- 下载失败'error'- 等待下一个'pending'- 正在下载'downloading'示例:完整更新流程
标题:示例:完整更新流程
以下是处理完整更新流程事件的示例:__CAPGO_KEEP_0__
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 }}复制到剪贴板
最佳实践-
标题为“最佳实践”
notifyAppReady()始终调用:当使用自动更新时,始终在应用初始化后调用此方法以防止回滚. -
处理失败: 下载和更新失败时,实现适当的错误处理。
-
向用户提供反馈: 使用下载进度事件向用户展示更新进度。
-
清除监听器: 移除不再需要的事件监听器以防止内存泄漏。
-
测试更新场景: 测试各种更新场景,包括失败、回滚和重大更新。
如果您正在使用 事件 为了native插件的工作,连接它与 使用@capgo/capacitor-updater 对于native能力在使用@capgo/capacitor-updater, Capgo插件目录 对于产品工作流程在Capgo插件目录, Capacitor插件由Capgo 对于实现细节在Capacitor插件由Capgo, 添加或更新插件 对于实现细节在添加或更新插件,和 Ionic企业插件替代品 对于产品工作流程在Ionic企业插件替代品.