Skip to content

mparisot/twilio_client_phonegap

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

89 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Twilio Client Phonegap plugins for iOS and Android (version 1.0.5)

These are Phonegap plugins that expose the same JS API as Twilio Client for web as much as possible, meaning you should be able to use the same Twilio Client code from your web application inside of your Phonegap application with few if any modifications.

Latest versions tested with this plugin

(as of April 7, 2016)

  • Cordova 6.1.1
  • Cordova Android 5.1.1
  • Cordova iOS 4.1.0
  • Twilio Client for iOS 1.2.8
  • Twilio Client for Android 1.2.10
  • XCode 7.3
  • Android SDK 23

Android Support Library

  • Versions 1.0.4 and earlier of the plugin required you to include the Android support library v4 in the lib. Cordova now has a solution for requiring Android libs through Gradle dependencies. This will save you a step on installation, as well as making this plugin (as of versin 1.0.5) compatible with other plugins such as the PhoneGap Push plugin. One handy tip I found on that plugin is that you may need to update your Android support library using this command line tool, if you get an error saying that the Android Support v4 library can not be found:

android update sdk --no-ui --filter "extra"

Please file an issue if you have problems with the Android support library or any compatibility issues with other plugins.

Android Marshmallow Support

  • Android Target SDK 23 does not work with version 1.0.5 of the plugin for Android 6.0 users, due to runtime permission requirements for recording audio. The plugin requires an update to support Cordova's runtime permissions model. In the meantime, use API Level 22 for your Android apps.

Example application

https://github.com/jefflinwood/TwilioClientPhoneGapExampleApp

PhoneGap/Cordova Overview

Both Platforms at once

##Instructions

cordova plugin add  https://github.com/jefflinwood/twilio_client_phonegap.git

iOS only

##Instructions

 plugman install --platform ios --project platforms/ios --plugin https://github.com/jefflinwood/twilio_client_phonegap.git

  • After installing the Twilio Client plugin, you will need to download and install the Twilio Client SDK for iOS - follow the directions provided after plugman finishes.

Android only

Instructions

plugman install --platform android --project platforms/android --plugin https://github.com/jefflinwood/twilio_client_phonegap.git

  • After installing the Twilio Client plugin, you will need to download and install the Twilio Client SDK for Android - follow the directions provided after plugman finishes. Be sure to include all of the library files, or your app will crash after receiving a call.

Additional Features

In addition to the standard features of the Twilio Client JS Library, you can also use the included showNotification and cancelNotification functions to display a UILocalNotifcation to the user when during an incoming call while the app is running in the background:

Twilio.Connection.showNotification("Notification Text", "notification_sound.wav");
Twilio.Connection.cancelNotification();

You can also turn the device's speaker phone on or off during a call using the following method:

Twilio.Connection.setSpeaker("on");

Limitations

This is plugin is a first cut and should be considered alpha. Please use it and break it :) Report any issues using the Github issue tracker.

Some of the event handlers are currently no-ops because of differences between the web SDK and the iOS SDK, i.e. they both expose events the other does not, e.g. Twilio.Device.cancel is a no-op and there is no JS SDK notion of -(void)deviceDidStartListeningForIncomingConnections:(TCDevice*)device, etc.

Twilio.Connection objects are just proxy objects that delegate to the Objective-C layer.

Sounds are currently disabled and the JS methods that control them are no-ops because enabling them causes EXC_BAD_ACCESS errors. Will fix.

Methods that interrogate the client device or connection and return a result e.g. Twilio.Device.status() take a callback function with the response as the argument. Unfortunately I think this is unavoidable due to communication between the Phonegap JS and iOS layers being strictly asynchronous, e.g.

Twilio.Device.connect(function(connection) {
    alert(connection.status());
})

becomes:

Twilio.Device.connect(function(connection) {
    connection.status(function(status) { alert(status) });
})

Twilio Client documentation: http://www.twilio.com/docs/client/twilio-js

About

Phonegap plugins for the Twilio Client iOS and Android SDKs

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Java 55.0%
  • Objective-C 31.5%
  • JavaScript 13.5%