Saltar al contenido principal
Volver a plugins
@capgo/capacitor-background-task
Tutorial
por github.com/Cap-go

Tarea de fondo

Programar tareas de recarga periódicas de fondo en iOS y Android con la inscripción de tarea de Expo estilo

Guía

Tutorial sobre tarea de fondo

Usando @capgo/capacitor-tarea-de-fondo

Schedule periodic background fetch work in a Capacitor app with named tasks, persistent registration, status checks, unregistering, and a development trigger. The plugin uses Android WorkManager and iOS BGTaskScheduler.

Instalar

npm install @capgo/capacitor-background-task
npx cap sync

Configuración de iOS

Agregar soporte de procesamiento de fondo ios/App/App/Info.plist:

<key>UIBackgroundModes</key>
<array>
  <string>processing</string>
</array>
<key>BGTaskSchedulerPermittedIdentifiers</key>
<array>
  <string>app.capgo.backgroundtask.processing</string>
</array>

Luego ejecuta:

npx cap sync ios

¿Qué Esta Plugin Exposa

  • defineTask - Defina el callback de JavaScript para una tarea nombrada.
  • registerTaskAsync - Persista y programar una tarea periódica.
  • unregisterTaskAsync - Cancelar una tarea.
  • isTaskRegisteredAsync - Verificar el estado de registro de una tarea.
  • getRegisteredTasksAsync - Listar nombres de tareas registradas.
  • getStatusAsync - Verificar la disponibilidad de tareas de fondo nativas.
  • triggerTaskWorkerForTestingAsync - Desencadenar tareas registradas inmediatamente para el desarrollo.
  • addExpirationListener - Reactiva cuando iOS expira una tarea.

Ejemplo de uso

Define la tarea en el ámbito del módulo para que esté disponible cuando el sistema active la aplicación:

import { BackgroundTask, BackgroundTaskResult } from '@capgo/capacitor-background-task';

const SYNC_TASK = 'sync-offline-data';

BackgroundTask.defineTask(SYNC_TASK, async () => {
  try {
    await fetch('https://api.example.com/sync', { method: 'POST' });
    return BackgroundTaskResult.Success;
  } catch {
    return BackgroundTaskResult.Failed;
  }
});

await BackgroundTask.registerTaskAsync(SYNC_TASK, {
  minimumInterval: 30,
  requiresNetwork: true,
});

Verificar el estado y los nombres de tareas registradas:

const status = await BackgroundTask.getStatusAsync();
const tasks = await BackgroundTask.getRegisteredTasksAsync();

console.log({ status, tasks });

Desencadenar una ejecución de desarrollo:

await BackgroundTask.triggerTaskWorkerForTestingAsync();

Cancelar la tarea:

await BackgroundTask.unregisterTaskAsync(SYNC_TASK);

Notas de plataforma

  • Las programaciones de tareas de fondo son oportunistas, no temporizadores exactos.
  • El trabajo periódico de Android tiene un mínimo de intervalo de 15 minutos.
  • iOS trata minimumInterval como una fecha de inicio más temprana y puede ejecutarse más tarde.
  • Probar el procesamiento de fondo de iOS en un dispositivo físico.

Referencia completa

Sigue adelante desde Usando @capgo/capacitor-tarea-de-fondo

Si estás utilizando Usando @capgo/capacitor-tarea-de-fondo para planificar el trabajo de plugin nativo, conecta con @capgo/capacitor-tarea-de-fondo para obtener detalles de implementación en @capgo/capacitor-tarea-de-fondo, Inicio para obtener detalles de implementación en Inicio, Directorio de Plugins de Capgo para el flujo de trabajo del producto en Directorio de Plugins de Capgo Capacitor Plugins por Capgo para el detalle de implementación en Capacitor Plugins por Capgo, y Agregar o Actualizar Plugins para el detalle de implementación en Agregar o Actualizar Plugins.