Saltar a contenido

@capgo/capacitor-kit de widget

Kit de widget y actividades en vivo para aplicaciones Capacitor, con plantillas impulsadas por SVG o sincronización de estado de widget nativo completo.

@capgo/capacitor-widget-kit da a una aplicación Capacitor dos formas de impulsar widgets y actividades en vivo:

  • Actividades de plantillas SVG: defina superficies de WidgetKit como SVG, cambie marcos nombrados desde toques, ejecute temporizadores de pausa/reproducción, mutue el estado JSON y recolecte eventos de acción en la aplicación.
  • Sesiones de widget nativo completo: mantenga la interfaz de usuario del widget completamente en Swift/Kotlin/Java mientras Capacitor posee el estado JSON compartido y mensajes de la aplicación a la widget o de la widget a la aplicación.

Use SVG templates when your widget can be rendered from resolved SVG strings. Use full-native sessions when the widget needs a custom native UI but still has to start, stop, sync state, or ask the app to complete async work.

ModoLo mejor paraPrincipal APIs
Actividad de plantilla SVGActividades en vivo o superficies de widget que se renderizan desde la salida SVGstartTemplateActivity, performTemplateAction, listTemplateEvents
Sesión de widget nativo completaWidgets renderizados nativamente que necesitan estado compartido y tareas asíncronasstartWidgetSession, updateWidgetSession, sendWidgetMessage

Ambos modos pueden coexistir en la misma aplicación. Por ejemplo, una aplicación de entrenamiento puede utilizar una actividad en vivo SVG para controles de marco/tiempo rápidos y una sesión de widget nativo completa para un widget de pantalla de inicio con un diseño de layout nativo más rico.

Los modelos SVG incluyen las piezas necesarias para superficies de widget interactivas:

  • frames mantenga variantes de SVG nombradas como summary, timer, o details.
  • frameMutations pase, cambiar, o avanzar por marcos después de una acción de hotspot.
  • timerMutations iniciar, pausar, reanudar, cambiar, resetear, detener, o cambiar la duración del temporizador.
  • patches actualice el estado JSON utilizando valores literales, plantillas, timestamps, incrementos, botones o operaciones de deshacer.
  • hotspots asignar áreas de toque a identificadores de acción.
  • listTemplateEvents permite que la aplicación procese acciones originadas en el widget más tarde.

La ejecución resuelve sustitutos como {{state.title}}, {{timers.rest.remainingText}}, y {{meta.template.kind}} antes de que la puente nativa devuelva una superficie para renderizar.

Las sesiones nativas son para widgets que renderizan su propia interfaz de usuario de forma nativa:

  • startWidgetSession crea un estado compartido y metadatos para el widget nativo code.
  • updateWidgetSession combina o reemplaza el estado y marca la sesión como activa nuevamente.
  • stopWidgetSession registra un estado final y marca la sesión como detenida.
  • sendWidgetMessage coloca en cola el trabajo de aplicación a widget o de widget a aplicación.
  • acknowledgeWidgetMessages marca los mensajes como recibidos.
  • completeWidgetMessage almacena una respuesta o un error para las tareas asíncronas.

Los mensajes son idempotentes después de la finalización: reintentar un mensaje completado o fallido devuelve el resultado existente en lugar de sobrescribirlo.

MétodoDescripción
areActivitiesSupportedVerificar si la puente de actividad de plantilla nativa puede ejecutarse en el dispositivo actual.
startTemplateActivityPersistir una plantilla de actividad SVG y iniciar la puente de actividad de Live nativa.
updateTemplateActivityReemplazar la definición de actividad, estado o abrir una URL.
endTemplateActivityFinalizar una actividad en ejecución y opcionalmente persistir una instantánea de estado de la actividad.
performTemplateActionEjecutar parches declarativos, mutaciones de marco, mutaciones de temporizador y registro de eventos.
getTemplateActivityLeer una plantilla de actividad almacenada.
listTemplateActivitiesListar todas las plantillas de actividad almacenadas.
listTemplateEventsLeer eventos de acción emitidos por acciones de plantilla.
acknowledgeTemplateEventsMarcar eventos de plantilla como procesados.
startWidgetSessionIniciar una sesión de widget nativa completa respaldada por un estado JSON compartido.
updateWidgetSessionUnir o reemplazar el estado de sesión de widget nativa completa.
stopWidgetSessionDetener una sesión de widget nativo completa y opcionalmente persistir el estado final.
getWidgetSessionLeer una sesión de widget nativo completa.
listWidgetSessionsListar todas las sesiones de widget nativo.
sendWidgetMessageColar un mensaje entre la aplicación y el widget nativo code.
listWidgetMessagesListar mensajes de puente colados.
acknowledgeWidgetMessagesMarcar mensajes de puente como reconocidos.
completeWidgetMessageCompletar o fallar un mensaje de puente asíncrono.
getPluginVersionDevolver el marcador de versión de la implementación de plataforma.

El plugin también envía ayudantes nativos para objetivos de widget:

  • CapgoTemplateWidgetBridge resuelve una superficie de plantilla SVG en svg, frameId, hotspots, y metadatos.
  • CapgoTemplateActionIntent conecta botones de widget iOS interactivos a acciones de plantilla.
  • CapgoNativeWidgetBridge carga sesiones y mensajes de widget nativo completos desde el widget nativo code.
  • Los ayudantes de plantilla de Android proporcionan comportamiento de receptor de acción y puente de widget coincidente.

La referencia API se sincroniza desde src/definitions.ts en el repositorio del plugin.