Saltar al contenido

@capgo/capacitor-kit-de-widget

WidgetKit 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 le 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.

Utilice plantillas SVG cuando su widget puede ser renderizado a partir de cadenas de SVG resueltas. Utilice sesiones de widget nativo completo cuando el widget necesita una interfaz de usuario nativa personalizada pero aún tiene que iniciar, detener, sincronizar estado o pedir a la aplicación que complete el trabajo asíncrono.

Demo animada de WidgetKit que muestra el estado y controles de la plantilla de widget impulsados por Capacitor
Flujo de plantilla de widget
ModoMejor paraAPI principales
Actividad de plantilla SVGActividades en vivo o superficies de widget que renderizan desde la salida SVGstartTemplateActivity, performTemplateAction, listTemplateEvents
Sesión de widget nativa completaWidgets renderizados nativamente que necesitan estado compartido y trabajos asíncronosstartWidgetSession, updateWidgetSession, sendWidgetMessage

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

variantes de SVG nombradas como

  • frames , o summary, timerpuede cambiar, alternar, o avanzar a través de marcos después de una acción de hotspot. details.
  • frameMutations comenzar, pausar, reanudar, cambiar, resetear, detener, o cambiar la duración del temporizador.
  • timerMutations actualizar el estado JSON utilizando valores literales, plantillas, fechas y horas, incrementos, alternativas o operaciones de desestablecimiento.
  • patches asignar áreas de toque a identificadores de acción.
  • hotspots permite que la aplicación procese acciones originadas en el widget más tarde.
  • listTemplateEvents La ejecución resuelve los reemplazos como __CAPGO_KEEP_0__.

La ejecución resuelve los reemplazos como __CAPGO_KEEP_0__. {{state.title}}, {{timers.rest.remainingText}}y antes de que el puente nativo devuelva una superficie para la renderización. {{meta.template.kind}} Capacidades del Puente Nativo Completo

crea un estado compartido y metadatos para el widget nativo __CAPGO_KEEP_0__.

  • startWidgetSession creates shared state and metadata for native widget code.
  • updateWidgetSession registra un estado final y marca la sesión detenida.
  • stopWidgetSession coloca en cola el trabajo de aplicación a widget o de widget a aplicación.
  • sendWidgetMessage marca los mensajes como recibidos.
  • acknowledgeWidgetMessages almacena una respuesta o un error para las tareas asíncronas.
  • completeWidgetMessage Los mensajes son idempotentes después de la finalización: repetir un mensaje completado o fallido devuelve el resultado existente en lugar de sobreescribirlo.

Full-Native Bridge Capabilities

MétodoDescripción
areActivitiesSupportedVerificar si la puente de actividad nativa de plantilla puede ejecutarse en el dispositivo actual.
startTemplateActivityPersistir una plantilla de actividad SVG y iniciar la puente de actividad nativa de Live.
updateTemplateActivitySustituir 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 última actividad.
performTemplateActionEjecutar parches declarativos, mutaciones de marco, mutaciones de temporizador y registro de eventos.
getTemplateActivityLeer una actividad de plantilla almacenada.
listTemplateActivitiesListar todas las actividades de plantilla almacenadas.
listTemplateEventsLeer eventos de acción emitidos por acciones de plantilla.
acknowledgeTemplateEventsMarcar eventos de plantilla como procesados.
startWidgetSessionIniciar una sesión de widget nativo completo respaldado por un estado JSON compartido.
updateWidgetSessionUnir o reemplazar el estado de sesión de widget nativo completo.
stopWidgetSessionDetener una sesión de widget nativo completo y opcionalmente persistir el estado final.
getWidgetSessionLeer una sesión de widget nativo completo.
listWidgetSessionsListar todas las sesiones de widget nativo completo.
sendWidgetMessageColar un mensaje entre la aplicación y el widget nativo code.
listWidgetMessagesListar mensajes de puente en cola.
acknowledgeWidgetMessagesMarcar mensajes de puente como reconocidos.
completeWidgetMessageCompletar o fallar un mensaje de puente asíncrono.
getPluginVersionDevolver el marcador de versión de 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 interactivos de iOS a acciones de plantilla.
  • CapgoNativeWidgetBridge carga sesiones y mensajes nativos completos desde el widget 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.

Sigue adelante desde @capgo/capacitor-kit-de-widget

Sección titulada “Sigue adelante desde @capgo/capacitor-kit-de-widget”

Si estás utilizando @capgo/capacitor-kit-de-widget para planificar la automatización de CI/CD, conecta con Usando @capgo/capacitor-kit-de-widget para la capacidad nativa en Usando @capgo/capacitor-kit-de-widget, Capgo CI/CD para el flujo de trabajo del producto en Capgo CI/CD, Capgo Compilaciones Nativas para el flujo de trabajo del producto en Capgo Compilaciones Nativas, Capgo Integraciones para el flujo de trabajo del producto en Capgo Integraciones, Integración CI/CD para los detalles de implementación en Integración CI/CD.