Mulai
Salin prompt pengaturan dengan langkah instalasi dan panduan markdown lengkap untuk plugin ini.
Set up this Capacitor plugin in the project.
Use the package manager already used by the project.
Install these package(s): `@capgo/capacitor-incoming-call-kit`
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/incoming-call-kit/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.
-
Pasang paket
Jendela Terminal bun add @capgo/capacitor-incoming-call-kit -
Sinkronkan proyek native
Jendela Terminal bunx cap sync -
Pilih sumber ring Anda Putuskan apakah event panggilan masuk berasal dari backend Anda, sebuah SDK seperti Twilio atau Stream, atau jalur push asli seperti FCM atau PushKit.
Bagaimana integrasi ini berfungsi bersama
Bagian berjudul “Bagaimana integrasi ini berfungsi bersama”Plugin ini hanya memiliki presentasi panggilan masuk asli. Aplikasi Anda masih memiliki transportasi, autentikasi, dan sesi media sebenarnya.
Polanya produksi yang umum adalah:
- Backend Anda atau SDK panggilan memancarkan event ring.
- Aplikasi Anda memanggil
showIncomingCall(). - Plugin menampilkan UI panggilan masuk asli.
callAcceptedmenginformasikan aplikasi Anda untuk bergabung dengan ruang sebenarnya atau sesi VoIP.callDeclined,callEndedataucallTimedOutmenginformasikan aplikasi Anda untuk membersihkan state remote.
Integrasi minimal
Bagian berjudul “Integrasi minimal”import { IncomingCallKit } from '@capgo/capacitor-incoming-call-kit';
await IncomingCallKit.requestPermissions();await IncomingCallKit.requestFullScreenIntentPermission();
await IncomingCallKit.addListener('callAccepted', async ({ call }) => { console.log('Accepted', call.callId, call.extra); // Start or join your real call session here.});
await IncomingCallKit.addListener('callDeclined', ({ call }) => { console.log('Declined', call.callId); // Tell your backend or SDK that the user declined.});
await IncomingCallKit.addListener('callTimedOut', ({ call }) => { console.log('Timed out', call.callId); // Clear ringing state in your backend or SDK.});
await IncomingCallKit.showIncomingCall({ callId: 'call-42', callerName: 'Ada Lovelace', handle: '+39 555 010 020', appName: 'Capgo Phone', hasVideo: true, timeoutMs: 45_000, extra: { roomId: 'room-42', callerUserId: 'user_ada', }, android: { channelId: 'calls', channelName: 'Incoming Calls', showFullScreen: true, }, ios: { handleType: 'phoneNumber', },});Opsi penting
Bagian berjudul “Opsi penting”callId: identifikasi stabil yang digunakan kembali kemudian denganendCall()timeoutMs: waktu tunggu tidak jelas yang tidak dijawabextra: JSON acak yang dikembalikan dalam pesan pendengarandroid.channelIddanandroid.channelName: pengaturan saluran peringatan Androidandroid.showFullScreen: meminta aktivitas panggilan masuk Android penuh layarios.handleType: pilihgeneric,phoneNumber, atauemailAddressuntuk CallKit
Mengelola panggilan aktif
Judul bagian “Mengelola panggilan aktif”const { calls } = await IncomingCallKit.getActiveCalls();
await IncomingCallKit.endCall({ callId: 'call-42', reason: 'remote-ended',});
await IncomingCallKit.endAllCalls({ reason: 'session-reset',});Model peristiwa
Judul bagian “Model peristiwa”incomingCallDisplayed: antarmuka native ditampilkan dengan suksescallAccepted: pengguna menerima dari antarmuka nativecallDeclined: pengguna menolak sebelum bergabungcallEnded: aplikasi Anda atau platform mengakhiri panggilan yang sedang diikuticallTimedOut: panggilan tetap tidak dijawab hinggatimeoutMs
Setiap event membawa payload yang telah dinormalisasi dan objek aslinya. call Catatan platform extra Bagian berjudul “Catatan platform”
- Baca panduan Android sebelum mengandalkan intent layar penuh pada Android 14 dan seterusnya. Web tidak didukung.
- Section titled “Platform notes” Read the iOS guide
- before wiring CallKit into a PushKit or APNs flow.