Saltar al contenido

iOS

En iOS, el plugin informa la llamada entrante a CallKit. Eso te da la hoja de llamada entrante del sistema y acciones de llamada estándar sin que tengas que construir tu propia interfaz de llamada nativa.

requestPermissions() se resuelve inmediatamente en iOS porque CallKit mismo no requiere un diálogo de permiso de ejecución.

import { IncomingCallKit } from '@capgo/capacitor-incoming-call-kit';
await IncomingCallKit.showIncomingCall({
callId: 'call-42',
callerName: 'Ada Lovelace',
handle: '+1 555 010 020',
ios: {
handleType: 'phoneNumber',
supportsHolding: true,
supportsDTMF: false,
},
});

Usar ios.handleType para controlar cómo CallKit formatea el manejo:

  • generic para identificadores específicos de la aplicación
  • phoneNumber para números de teléfono reales
  • emailAddress para identidades basadas en correo electrónico

Este plugin no registra PushKit ni APNs para usted.

Para un sonido de timbre verdadero en segundo plano o estado de terminación en iOS, su aplicación de host todavía necesita la configuración nativa de Apple push que coincida con su estrategia de transporte:

  1. Habilite las notificaciones de empuje cuando su transporte utiliza la entrega de Apple push.
  2. Habilite el modo de fondo de voz sobre IP cuando su aplicación utiliza un flujo de empuje de VoIP.
  3. Entregue el evento de llamada entrante a su aplicación e invoque este plugin tan pronto como esté disponible la Capacitor puente.

Si su evento de timbre existe solo en JavaScript, obtendrá la mejor experiencia mientras la aplicación ya está ejecutándose en el fondo.

CallKit no reemplaza su media SDK. Si la sesión de llamada real utiliza acceso a micrófono o cámara, los descripciones de uso todavía pertenecen a su aplicación:

<key>NSMicrophoneUsageDescription</key>
<string>This app uses the microphone for calls.</string>
<key>NSCameraUsageDescription</key>
<string>This app uses the camera for video calls.</string>

Añada solo las claves que su flujo de llamada real necesita.

Mantenga estas responsabilidades en su capa de aplicación

Sección titulada “Mantenga estas responsabilidades en su capa de aplicación”
  • Registro de PushKit y APNs
  • Autenticación y refresco de token
  • Unirse a la sala real o sesión de VoIP después de callAccepted
  • Finalizar o reconciliar el estado de llamada remota cuando el plugin emite callDeclined, callEnded, o callTimedOut