Saltare al contenuto

iOS

Su iOS, il plugin riferisce l'arrivo della chiamata a CallKit. Ciò ti consente di avere la schermata di chiamata in arrivo del sistema e azioni di chiamata standardizzate senza dover costruire la tua UI di chiamata nativa.

requestPermissions() risolve immediatamente su iOS perché CallKit stesso non richiede un dialogo di autorizzazione in esecuzione.

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,
},
});

Usa ios.handleType per controllare come CallKit formatta la maniglia:

  • generic per identificatori specifici dell'applicazione
  • phoneNumber per numeri di telefono reali
  • emailAddress per identità basate su email

Questo plugin non si registra PushKit o APNs per te.

Per una suoneria di background o di stato terminato su iOS, la tua app host richiede ancora la configurazione di push nativa Apple che corrisponde alla tua strategia di trasporto:

  1. Abilita le notifiche push quando il tuo trasporto utilizza la consegna di push Apple.
  2. Abilita il modulo di background Voice over IP quando la tua app utilizza un flusso di chiamata VoIP.
  3. Inoltra l'evento di chiamata in arrivo alla tua app e invoca questo plugin non appena è disponibile il ponte Capacitor.

Se l'evento di suoneria esiste solo in JavaScript, avrai la migliore esperienza mentre l'app è già in esecuzione in primo piano.

CallKit non sostituisce il tuo media SDK. Se la sessione di chiamata reale utilizza l'accesso al microfono o alla telecamera, i descrittori di utilizzo devono ancora essere presenti nella tua app:

<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>

Aggiungi solo le chiavi che il tuo flusso di chiamata reale richiede.

Mantieni queste responsabilità nel tuo layer di app

Sezione intitolata “Mantieni queste responsabilità nel tuo layer di app”
  • Registrazione di PushKit e APNs
  • Autenticazione e aggiornamento del token
  • Unirsi alla stanza reale o alla sessione VoIP dopo callAccepted
  • Terminare o conciliare lo stato della chiamata remota quando il plugin emette callDeclined, callEndedo callTimedOut