Mulai Berlatih
Copas 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 ringan Anda Putuskan apakah event panggilan masuk berasal dari backend Anda, sebuah SDK seperti Twilio atau Stream, atau jalur push native seperti FCM atau PushKit.
Bagaimana integrasi ini berfungsi bersama
Bagian berjudul “Bagaimana integrasi ini berfungsi bersama”Plugin ini hanya memiliki presentasi panggilan masuk native. Aplikasi Anda masih memiliki transportasi, autentikasi, dan sesi media yang sebenarnya.
Polanya produksi yang umum adalah:
- Backend Anda atau panggilan SDK mengeluarkan event ring.
- Aplikasi Anda memanggil
showIncomingCall(). - Plugin menampilkan UI panggilan masuk native.
callAcceptedmenginformasikan aplikasi Anda untuk bergabung dengan ruang nyata atau sesi VoIP.callDeclined,callEndedataucallTimedOutmenginformasikan aplikasi Anda untuk membersihkan status remote.
Integrasi minimal
Judul bagian “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
Judul bagian “Opsi penting”callId: identifikasi stabil yang digunakan kembali nantiendCall()timeoutMstimeout maksimalextraJSON acak yang dikembalikan dalam pesan pembacaandroid.channelIddanandroid.channelNamepengaturan saluran notifikasi Androidandroid.showFullScreenminta aktivitas panggilan masuk penuh layar Androidios.handleTypepilihgeneric,phoneNumber, atauemailAddressuntuk CallKit
Pengelolaan panggilan aktif
Bab berjudul “Pengelolaan panggilan aktif”const { calls } = await IncomingCallKit.getActiveCalls();
await IncomingCallKit.endCall({ callId: 'call-42', reason: 'remote-ended',});
await IncomingCallKit.endAllCalls({ reason: 'session-reset',});Model peristiwa
Model AcaraincomingCallDisplayed: UI asli ditampilkan dengan suksescallAccepted: pengguna menerima dari UI aslicallDeclined: pengguna menolak sebelum bergabungcallEnded: aplikasi Anda atau platform mengakhiri panggilan yang sedang diikuticallTimedOut: panggilan tetap tidak dijawab hinggatimeoutMs
Setiap acara membawa payload yang telah dinormalisasi dan objek asli Anda. call Catatan Platform extra Baca Catatan Platform
Model Acara
: UI asli ditampilkan dengan sukses- : pengguna menerima dari UI asli Petunjuk iOS __CAPGO_KEEP_0__
- Baca panduan Petunjuk Android __CAPGO_KEEP_0__
- Tidak didukung