Passer à la navigation

@capgo/capacitor-kit-de-widgets

Kit de widgets et activités en direct pour les applications Capacitor, avec des modèles SVG ou des synchronisations d'état de widget natif complet.

@capgo/capacitor-widget-kit offre à une application Capacitor deux façons de contrôler les widgets et les activités en direct :

  • Activités de modèles SVG : définir les surfaces de WidgetKit en tant qu'SVG, passer des noms de fenêtres de la touche, exécuter les temporisations pause/jeu, muter l'état JSON et collecter les événements d'action dans l'application.
  • Sessions de widgets natifs complètes : garder l'interface utilisateur du widget entièrement en Swift/Kotlin/Java tandis que Capacitor possède l'état JSON partagé et les messages app-à-widget ou widget-à-app.

Utilisez les modèles SVG lorsque votre widget peut être rendu à partir de chaînes de résolution SVG. Utilisez les sessions de widgets natifs complètes lorsque le widget nécessite une interface utilisateur native personnalisée mais doit toujours démarrer, arrêter, synchroniser l'état ou demander à l'application de terminer le travail asynchrone.

Démonstration animée de WidgetKit montrant l'état et les contrôles du widget de modèle pilotés par Capacitor
Flux de modèle de widget
ModeMeilleur pourAPI principaux
Activité de modèle SVGActivités ou surfaces de widget qui rendent à partir de sortie SVGstartTemplateActivity, performTemplateAction, listTemplateEvents
Séance de widget native complèteWidgets rendus nativement qui nécessitent un état partagé et des tâches asynchronesstartWidgetSession, updateWidgetSession, sendWidgetMessage

Les deux modes peuvent coexister dans la même application. Par exemple, une application de workout peut utiliser une activité SVG Live pour des contrôles de cadence rapide/timer et une séance de widget native complète pour un widget d'écran d'accueil avec un affichage natif plus riche.

Les modèles SVG incluent les pièces nécessaires pour les surfaces de widget interactives :

  • frames variantes de SVG nommées telles que summary, timer, ou details.
  • frameMutations démarrez, arrêtez, reprenez, déclenchez, réinitialisez, arrêtez ou modifiez la durée du chronomètre.
  • timerMutations mettez à jour l'état JSON à l'aide de valeurs littérales, de modèles, de tampons, d'incréments, de déclencheurs ou d'opérations d'annulation.
  • patches associez les zones de tapage à des identifiants d'action.
  • hotspots permet à l'application de traiter les actions provenant des widgets ultérieurement.
  • listTemplateEvents Le runtime résout les marqueurs comme __CAPGO_KEEP_0__ et __CAPGO_KEEP_1__ avant que le pont natif ne retourne une surface pour le rendu.

Capacités du Pont Natif Complet {{state.title}}, {{timers.rest.remainingText}}Sous-titre « Capacités du Pont Natif Complet » {{meta.template.kind}} Les sessions de type complet-natif sont destinées aux widgets qui rendent leur propre interface utilisateur de manière native :

Les sessions de type complet-natif sont destinées aux widgets qui rendent leur propre interface utilisateur de manière native :

Les sessions de type complet-natif sont destinées aux widgets qui rendent leur propre interface utilisateur de manière native :

Les sessions de type complet-natif sont destinées aux widgets qui rendent leur propre interface utilisateur de manière native :

  • startWidgetSession crée un état et des métadonnées partagés pour le widget natif code.
  • updateWidgetSession fusionne ou remplace l'état et marque la session active à nouveau.
  • stopWidgetSession enregistre un dernier état et marque la session arrêtée.
  • sendWidgetMessage file les tâches app-à-widget ou widget-à-app.
  • acknowledgeWidgetMessages marque les messages comme reçus.
  • completeWidgetMessage stocke une réponse ou un échec pour les tâches asynchrones.

Les messages sont idempotents après exécution : une tentative de reprise d'un message terminé ou échoué retourne le résultat existant au lieu de l'effacer.

MéthodeDescription
areActivitiesSupportedVérifiez si le pont d'activité de modèle natif peut s'exécuter sur le dispositif actuel.
startTemplateActivityEnregistrer une activité de modèle SVG et démarrer le pont de l'activité native Live.
updateTemplateActivityRemplacer la définition de l'activité, l'état ou l'ouvrir une URL.
endTemplateActivityTerminer une activité en cours et conserver optionnellement un dernier instantané d'état.
performTemplateActionExécuter des patchs déclaratifs, des mutations de cadre, des mutations de temporisateur et l'enregistrement d'événements.
getTemplateActivityLire une activité de modèle stockée.
listTemplateActivitiesLister toutes les activités de modèle stockées.
listTemplateEventsLire les événements d'action émis par les actions de modèle.
acknowledgeTemplateEventsMarquer les événements de modèle comme traités.
startWidgetSessionDémarrer une session de widget natif complète basée sur un état partagé en JSON.
updateWidgetSessionFusionner ou remplacer l'état d'une session de widget natif complète.
stopWidgetSessionArrêter une session de widget natif complète et conserver optionnellement l'état final.
getWidgetSessionLire une session de widget natif complète.
listWidgetSessionsLister toutes les sessions de widgets natifs complets.
sendWidgetMessageEnfile une messagerie entre l'application et le widget natif code.
listWidgetMessagesLister les messages de pont en file d'attente.
acknowledgeWidgetMessagesMarquer les messages de pont comme reconnus.
completeWidgetMessageTerminer ou échouer un message de pont asynchrone.
getPluginVersionRenvoyer la marque de version de l'implémentation de la plateforme.

Le plugin embarque également des aides natives pour les cibles de widgets :

  • CapgoTemplateWidgetBridge résout une surface de modèle SVG en svg, frameId, hotspots, et métadonnées.
  • CapgoTemplateActionIntent se connecte les boutons de widget iOS interactifs à des actions de modèle.
  • CapgoNativeWidgetBridge charge les sessions et les messages full-native à partir du widget natif code.
  • Les helpers de modèle Android fournissent un comportement de réception d'action et de pont de widget correspondant.

La référence API est synchronisée à partir du src/definitions.ts dans le dépôt de plugin.

Si vous utilisez @capgo/capacitor-kit-de-widget pour planifier l'automatisation CI/CD, connectez-le avec En utilisant @capgo/capacitor-kit-de-widget pour la capacité native en utilisant @capgo/capacitor-kit de widgets Capgo CI/CD pour le flux de travail du produit dans Capgo CI/CD Capgo Builds natifs pour le flux de travail du produit dans Capgo Builds natifs Capgo Intégrations pour le flux de travail du produit dans Capgo Intégrations, et Intégration CI/CD pour le détail d'implémentation dans Intégration CI/CD