Inicio
Copie un prompt de configuración con los pasos de instalación y la guía de markdown completa para este plugin.
Set up this Capacitor plugin in the project.
Use the package manager already used by the project.
Install these package(s): `@capgo/capacitor-live-activities`
Run the required Capacitor sync/update step after installation.
Read this markdown guide for the full setup steps: https://raw.githubusercontent.com/Cap-go/website/refs/heads/main/apps/docs/src/content/docs/docs/plugins/live-activities/getting-started.mdx
Use that guide for platform-specific steps, native file edits, permissions, config changes, imports, and usage setup.
If that guide references other docs pages, read them too.
Instalar
Sección titulada “Instalar”bun add @capgo/capacitor-live-activitiesbunx cap syncConfiguración de iOS
Sección titulada “Configuración de iOS”La instalación y sincronización del plugin no crean la interfaz de usuario de Actividad en vivo nativa. El kit de actividades requiere una extensión de widget que registre una configuración de Actividad en vivo antes de startActivity poder mostrar nada.
Requisitos
Sección titulada “Requisitos”- Utilice iOS 16.1 o posterior para ambas metas de la aplicación y la extensión de widget.
- Pruebe en un dispositivo iOS o un simulador compatible. La isla dinámica solo aparece en modelos de dispositivos compatibles; otros dispositivos utilizan la presentación de pantalla de bloqueo.
- Mantenga los datos estáticos y dinámicos combinados de ActivityKit por debajo del límite de 4 KB de Apple.
1. Cree una extensión de widget
Sección titulada “1. Crea una extensión de Widget”Abrir el proyecto nativo de iOS:
bunx cap open iosLuego:
- Seleccionar Archivo > Nuevo > Objetivo.
- Agregar una Extensión de Widget.
- Habilitar Incluir Actividad en vivo.
- Deshabilitar Incluir Configuración de Intención a menos que la aplicación también necesite un widget configurable.
- Asegúrese de que la extensión generada esté integrada en el objetivo principal de la aplicación.
La Extensión de Widget debe contener un ActivityConfiguration y regístrelo en su WidgetBundle. Debe proporcionar cada presentación de Actividad en vivo requerida:
- Pantalla de bloqueo
- Dynamic Island ampliado
- Dynamic Island compacto con leading y trailing
- Dynamic Island mínimo
Agregar el objetivo solo no es suficiente. La aplicación nativa o el plugin deben llamar a las API de solicitud, actualización y finalización de ActivityKit. La extensión debe contener SwiftUI code que pueda descodificar y renderizar el mismo ActivityAttributes y estado de contenido utilizado por esas llamadas. Incluya modelos compartidos de ActivityKit en ambos objetivos de la aplicación principal y la Extensión de Widget. El template de Actividad en vivo generado por Xcode no renderiza automáticamente los diseños JSON pasados a este plugin; la extensión también necesita un renderizador de diseños nativos compatibles.
2. Habilitar Actividades en Vivo
Sección titulada “2. Habilitar Actividades en Vivo”Agregue la siguiente clave a la configuración principal de la aplicación para iOS Info.plist:
<key>NSSupportsLiveActivities</key><true/>Si el proyecto genera sus Info.plist, agregue Actividades en Vivo con un valor booleano de YES bajo las propiedades de configuración personalizadas del objetivo de iOS de la aplicación principal en lugar de
3. Configurar el Grupo de Aplicación para Imágenes Compartidas
Sección titulada “3. Configurar el Grupo de Aplicación para Imágenes Compartidas”Un Grupo de Aplicación solo es necesario cuando se utiliza saveImage, removeImage, listImageso cleanupImages. El plugin deriva el identificador de grupo de la aplicación a partir del identificador del paquete principal utilizando este formato exacto:
group.<MAIN_APP_BUNDLE_ID>.liveactivitiesPor ejemplo, una aplicación con identificador de paquete com.example.delivery debe utilizar:
group.com.example.delivery.liveactivitiesEn Xcode, agregue la Capacidad de grupos de la aplicación a ambos objetivos del paquete principal y la extensión de Widget, luego habilite el mismo identificador en ambos objetivos.
Las extensiones de actividad en vivo no pueden acceder a la red. Descargue imágenes remotas en la aplicación principal y guárdelas en el grupo de la aplicación compartido antes de referenciarlas desde una actividad en vivo. Para imágenes embaladas, también habilite la extensión de Widget en la membresía de objetivos del activo.
4. Configurar enlaces profundos
Título de sección “4. Configurar enlaces profundos”When utilizando behavior.widgetUrl o una secuencia de temporizador tapUrl, registra el esquema de URL o enlace universal en la aplicación principal. Para un esquema personalizado como myapp://order/12345, agrega el esquema en la configuración de Info > Tipos de URL de la aplicación principal objetivo.
5. Opcional: Habilitar Actualizaciones Servidor-Dirigidas
Sección titulada “5. Opcional: Habilitar Actualizaciones Servidor-Dirigidas”Las notificaciones de push no son necesarias para actualizaciones locales iniciadas por la aplicación. Para comenzar, actualizar o finalizar Actividades en vivo desde un servidor:
- Agrega la Notificaciones de Push capacidad a la aplicación principal objetivo.
- Obtenga tokens de notificación de ActivityKit y envíelos al servidor.
- Enviar notificaciones de ActivityKit a través de APNs utilizando el tipo de notificación de "push".
liveactivityAgregar - al aplicación principal
NSSupportsLiveActivitiesFrequentUpdatessolamente cuando el caso de uso requiere actualizaciones de notificación de push frecuentes.Info.plistLos tokens de notificación de ActivityKit son separados de los tokens de dispositivo de notificación estándar del usuario. Habilitar la capacidad de notificaciones de push sola no es suficiente; las actualizaciones impulsadas por el servidor requieren el manejo nativo de tokens y un backend de APNs.
Lista de Verificación de Configuración Nativa
Sección titulada “Lista de Verificación de Configuración Nativa”
Antes de llamar a, verifique que: startActivityesté habilitado en el objetivo de aplicación principal.
NSSupportsLiveActivitiesActivityKit push tokens are separate from standard user-notification device tokens. Enabling the Push Notifications capability alone is not sufficient; server-driven updates require native token handling and an APNs backend.- The Widget Extension está integrado y registra un
ActivityConfiguration. - La implementación nativa de ActivityKit y la extensión de Widget utilizan el mismo
ActivityAttributestipo. - Los objetivos de implementación de la aplicación y la extensión de Widget son iOS 16.1 o posterior.
- Las actividades en vivo están habilitadas para la aplicación en iOS Settings.
- El grupo de aplicación correspondiente está habilitado en ambos objetivos cuando se utilizan imágenes compartidas.
- Cualquier esquema de URL personalizado utilizado por
widgetUrlotapUrlse registra.
Importar
Título de sección “Importar”import { CapgoLiveActivities } from '@capgo/capacitor-live-activities';API Resumen general
Sección titulada “API Resumen general”areActivitiesSupported
Sección titulada “areActivitiesSupported”Comprueba si las actividades en vivo están soportadas en este dispositivo. Requiere iOS 16.1+ y soporte de dispositivo.
import { CapgoLiveActivities } from '@capgo/capacitor-live-activities';
const { supported, reason } = await CapgoLiveActivities.areActivitiesSupported();if (supported) { console.log('Live Activities are supported!');} else { console.log('Not supported:', reason);}startActivity
Sección titulada “startActivity”Inicia una nueva actividad en vivo con el diseño especificado y los datos.
import { CapgoLiveActivities } from '@capgo/capacitor-live-activities';
const { activityId } = await CapgoLiveActivities.startActivity({ layout: { type: 'container', direction: 'horizontal', children: [ { type: 'text', content: 'Order #{{orderNumber}}', fontSize: 16, fontWeight: 'bold' }, { type: 'text', content: '{{status}}', fontSize: 14, color: '#666666' } ] }, dynamicIslandLayout: { expanded: { leading: { type: 'image', source: 'sfSymbol', value: 'box.truck' }, trailing: { type: 'text', content: '{{eta}}' }, center: { type: 'text', content: '{{status}}' }, bottom: { type: 'progress', value: 'progress' } }, compactLeading: { type: 'image', source: 'sfSymbol', value: 'box.truck' }, compactTrailing: { type: 'text', content: '{{eta}}' }, minimal: { type: 'image', source: 'sfSymbol', value: 'box.truck' } }, data: { orderNumber: '12345', status: 'On the way', eta: '10 min', progress: 0.6 }});console.log('Started activity:', activityId);updateActivity
Sección titulada “updateActivity”Actualiza una actividad en vivo existente con nuevos datos.
import { CapgoLiveActivities } from '@capgo/capacitor-live-activities';
await CapgoLiveActivities.updateActivity({ activityId: 'abc123', data: { status: 'Arrived!', eta: 'Now', progress: 1.0 }, alertConfiguration: { title: 'Delivery Update', body: 'Your order has arrived!' }});endActivity
Sección titulada “endActivity”Finalice una Actividad en vivo.
import { CapgoLiveActivities } from '@capgo/capacitor-live-activities';
await CapgoLiveActivities.endActivity({ activityId: 'abc123', data: { status: 'Delivered' }, dismissalPolicy: 'after', dismissAfter: Date.now() + 3600000 // 1 hour from now});getAllActivities
Sección titulada “obtenerTodasLasActividades”Obtener todas las actividades en vivo actualmente activas.
import { CapgoLiveActivities } from '@capgo/capacitor-live-activities';
const { activities } = await CapgoLiveActivities.getAllActivities();activities.forEach(activity => { console.log(`Activity ${activity.activityId}: ${activity.state}`);});saveImage
Sección titulada “guardarImagen”Guardar una imagen en el contenedor compartido de App Group para su uso en Actividades en vivo. Las imágenes deben guardarse en el contenedor compartido para ser accesibles desde la extensión del widget.
import { CapgoLiveActivities } from '@capgo/capacitor-live-activities';
const { success, imageName } = await CapgoLiveActivities.saveImage({ imageData: 'base64EncodedImageData...', name: 'product-image', compressionQuality: 0.8});// Use in layout with: { type: 'image', source: 'saved', value: imageName }removeImage
Sección titulada “eliminarImagen”Eliminar una imagen guardada del contenedor compartido.
import { CapgoLiveActivities } from '@capgo/capacitor-live-activities';
const { success } = await CapgoLiveActivities.removeImage({ name: 'product-image' });listImages
Sección titulada “listarImágenes”Listar todas las imágenes guardadas en el contenedor compartido.
import { CapgoLiveActivities } from '@capgo/capacitor-live-activities';
const { images } = await CapgoLiveActivities.listImages();console.log('Saved images:', images);cleanupImages
Sección titulada “cleanupImages”Eliminar todas las imágenes guardadas del contenedor compartido.
import { CapgoLiveActivities } from '@capgo/capacitor-live-activities';
await CapgoLiveActivities.cleanupImages();startTimerSequence
Sección titulada “startTimerSequence”Iniciar una secuencia de temporizador para ejercicios/deportes. En iOS: Se muestra en Actividad en vivo y Isla Dinámica En Android: Se muestra como una notificación de primer plano con temporizador
import { CapgoLiveActivities } from '@capgo/capacitor-live-activities';
const { sequenceId } = await CapgoLiveActivities.startTimerSequence({ title: 'HIIT Workout', steps: [ { duration: 30, title: 'Jumping Jacks', subtitle: 'Warm up', color: '#FF6B00', icon: 'figure.jumprope' }, { duration: 10, title: 'Rest', color: '#00C853', icon: 'pause.circle' }, { duration: 45, title: 'Burpees', subtitle: 'High intensity', color: '#FF0000', icon: 'flame.fill' }, { duration: 15, title: 'Rest', color: '#00C853', icon: 'pause.circle' }, { duration: 45, title: 'Mountain Climbers', color: '#FF0000', icon: 'figure.run' }, { duration: 15, title: 'Rest', color: '#00C853', icon: 'pause.circle' }, ], loop: true, loopCount: 3, soundEnabled: true, vibrateEnabled: true, countdownBeeps: true, tapUrl: 'myapp://workout/hiit'});pauseTimerSequence
Sección titulada “pauseTimerSequence”Pausar la secuencia de temporizador.
import { CapgoLiveActivities } from '@capgo/capacitor-live-activities';
await CapgoLiveActivities.pauseTimerSequence({ sequenceId: 'abc123' });resumeTimerSequence
Sección titulada “resumeTimerSequence”Reanuda una secuencia de temporizador suspendida.
import { CapgoLiveActivities } from '@capgo/capacitor-live-activities';
await CapgoLiveActivities.resumeTimerSequence({ sequenceId: 'abc123' });stopTimerSequence
Sección titulada “stopTimerSequence”Detener y descartar la secuencia de temporizador.
import { CapgoLiveActivities } from '@capgo/capacitor-live-activities';
await CapgoLiveActivities.stopTimerSequence({ sequenceId: 'abc123' });skipTimerStep
Sección titulada “skipTimerStep”Saltar al siguiente paso en la secuencia.
import { CapgoLiveActivities } from '@capgo/capacitor-live-activities';
await CapgoLiveActivities.skipTimerStep({ sequenceId: 'abc123' });previousTimerStep
Sección titulada “previousTimerStep”Volver al paso anterior en la secuencia.
import { CapgoLiveActivities } from '@capgo/capacitor-live-activities';
await CapgoLiveActivities.previousTimerStep({ sequenceId: 'abc123' });getTimerState
Sección titulada “getTimerState”Obtenga el estado actual de una secuencia de temporizador.
import { CapgoLiveActivities } from '@capgo/capacitor-live-activities';
const state = await CapgoLiveActivities.getTimerState({ sequenceId: 'abc123' });console.log(`Step ${state.currentStepIndex + 1}/${state.totalSteps}: ${state.currentStep.title}`);console.log(`Time remaining: ${state.remainingSeconds}s`);Referencia de tipo
Sección titulada “Referencia de tipo”AreActivitiesSupportedResult
Sección titulada “AreActivitiesSupportedResult”Resultado de verificar si se admiten actividades.
export interface AreActivitiesSupportedResult { /** Whether Live Activities are supported on this device */ supported: boolean; /** Reason if not supported */ reason?: string;}StartActivityOptions
Sección titulada “StartActivityOptions”Opciones para iniciar una actividad en vivo.
export interface StartActivityOptions { /** Main activity layout (lock screen widget) */ layout: ActivityLayout; /** Dynamic Island layout configuration */ dynamicIslandLayout: DynamicIslandLayout; /** Activity behavior settings */ behavior?: LiveActivitiesBehavior; /** Dynamic data for the activity */ data: Record<string, unknown>; /** Stale date timestamp (activity becomes stale after this) */ staleDate?: number; /** Relevance score for activity ordering (0-100) */ relevanceScore?: number;}StartActivityResult
Sección titulada “StartActivityResult”Resultado de iniciar una actividad.
export interface StartActivityResult { /** Unique activity identifier */ activityId: string;}UpdateActivityOptions
Sección titulada “Actualizar opciones de actividad en vivo”Opciones para actualizar una actividad en vivo.
export interface UpdateActivityOptions { /** Activity ID to update */ activityId: string; /** Updated data */ data: Record<string, unknown>; /** Optional alert to show with update */ alertConfiguration?: ActivityAlertConfiguration; /** Updated stale date */ staleDate?: number; /** Updated relevance score */ relevanceScore?: number;}EndActivityOptions
Sección titulada “Opciones para finalizar actividad en vivo”Opciones para finalizar una actividad en vivo.
export interface EndActivityOptions { /** Activity ID to end */ activityId: string; /** Final data to display */ data?: Record<string, unknown>; /** Dismissal policy */ dismissalPolicy?: 'immediate' | 'default' | 'after'; /** Dismiss after timestamp (when dismissalPolicy is 'after') */ dismissAfter?: number;}GetAllActivitiesResult
Sección titulada “Resultado de obtener todas las actividades”Resultado de obtener todas las actividades.
export interface GetAllActivitiesResult { /** List of activities */ activities: ActivityInfo[];}SaveImageOptions
Sección titulada “Opciones para guardar imagen”Opciones para guardar una imagen.
export interface SaveImageOptions { /** Base64 encoded image data */ imageData: string; /** Name to save the image as */ name: string; /** JPEG compression quality (0-1, default 0.8) */ compressionQuality?: number;}SaveImageResult
Sección titulada “Guardar imagen”Resultado de guardar una imagen.
export interface SaveImageResult { /** Whether the save was successful */ success: boolean; /** Saved image name */ imageName: string;}RemoveImageOptions
Sección titulada “Opciones de eliminar imagen”Opciones para eliminar una imagen.
export interface RemoveImageOptions { /** Name of the image to remove */ name: string;}RemoveImageResult
Sección titulada “Resultado de eliminar imagen”Resultado de eliminar una imagen.
export interface RemoveImageResult { /** Whether the removal was successful */ success: boolean;}ListImagesResult
Sección titulada “Resultados de listar imágenes”Resultado de listar imágenes.
export interface ListImagesResult { /** List of saved image names */ images: string[];}TimerSequenceOptions
Sección titulada “Opciones de secuencia de temporizador”Opciones para iniciar una secuencia de temporizador.
export interface TimerSequenceOptions { /** Array of steps in the sequence */ steps: TimerStep[]; /** Overall title for the sequence (e.g., "HIIT Workout", "Tabata") */ title?: string; /** Whether to loop the sequence when complete */ loop?: boolean; /** Number of times to loop (if loop is true, 0 means infinite) */ loopCount?: number; /** Play sound on step change (default: true) */ soundEnabled?: boolean; /** Vibrate on step change (default: true) */ vibrateEnabled?: boolean; /** Play countdown beeps in last 3 seconds (default: true) */ countdownBeeps?: boolean; /** Deep link URL when tapping the notification/activity */ tapUrl?: string; /** Keep screen on during timer (Android only, default: false) */ keepScreenOn?: boolean;}Fuente de Verdad
Sección titulada “Fuente de Verdad”Esta página se genera a partir del plugin’s src/definitions.tsRe-ruta la sincronización cuando los cambios públicos API cambian en la fuente.
Sigue adelante desde Inicio
Sección titulada “Sigue adelante desde Inicio”Si estás utilizando Inicio para planificar la consola de dashboard y API operaciones, conectarlo con Usando @capgo/capacitor-actividades-en-vivo para la capacidad nativa en Usando @capgo/capacitor-actividades-en-vivo API Resumen para el detalle de implementación en API Resumen Introducción para el detalle de implementación en Introducción API Claves para el detalle de implementación en API Claves, y Dispositivos para el detalle de implementación en Dispositivos.