This is a react native module that launches the addressbook and when the user taps on a contact various fields (name, phone, and email) are returned. This is for android version 5 (or higher) only.
For ios, you can use one of the many select-contact-* modules I have previously built.
If you want to be able to select multiple contacts at once for android, please use https://github.com/lwhiteley/react-native-android-contactpicker by @lwhiteley
npm install react-native-select-contact-android --save
var SelectContacts = require('react-native-select-contact-android')
SelectContacts.pickContact({timeout: 45000}, (err, contact) => {
if (err){
if(typeof err === 'object'){
if (err.message == "user canceled") {
console.log("user hit back button in contact picker");
} else if (err.message == "timed out") {
console.log("timed out");
} else if (err.message == "android version not supported") {
console.log("invalid android version");
}
}
// log out err object
console.log(err)
} else {
console.log(contact.name);
console.log(contact.phoneNumbers);
console.log(contact.emailAddresses);
console.log(contact)
/**
Sample contact:
{
id: "100",
name: "John Doe",
phoneNumbers: [ {"number": "+1-555-555-5555"} ],
emailAddresses: [ {"email": "[email protected]"} ]
}
**/
}
})
Property | Description |
---|---|
timeout (number) | Value in milliseconds (ms) that states how long to wait for the user to select a contact Default: 45000 |
- In
android/settings.gradle
...
include ':react-native-select-contact-android'
project(':react-native-select-contact-android').projectDir = new File(settingsDir, '../node_modules/react-native-select-contact-android/android')
- In
android/app/build.gradle
...
dependencies {
...
compile project(':react-native-select-contact-android')
}
- register module (in android/app/src/main/java/[your-app-namespace]/MainApplication.java)
import com.rhaker.reactnativeselectcontacts.ReactNativeSelectContacts; // <------ add import
public class MainApplication extends Application implements ReactApplication {
private final ReactNativeHost mReactNativeHost = new ReactNativeHost(this) {
...
@Override
protected List<ReactPackage> getPackages() {
return Arrays.<ReactPackage>asList(
new MainReactPackage(),
new ReactNativeSelectContacts()
);
}
};
...
}
- add Contacts permission (in android/app/src/main/AndroidManifest.xml)
...
<uses-permission android:name="android.permission.READ_CONTACTS" />
...
The properties phoneNumbers and emailAddresses will be returned as empty arrays if no phone numbers or emails are found.
The following will cause a callback that indicates an error (use the console.log to see the specific message):
-
Android Version below 5.0 is used.
-
User denies access to the addressbook
-
The user takes longer than 45 seconds to pick a contact.
-
User hits the back button and never picks a contact.
This module has been updated by @lwhiteley to handle RN version 0.29+. Special thanks for all the hard work!
The approach prior to @lwhiteley's version relied heavily on @satya164 comments at facebook/react-native#3334. If you are using a module that also uses his approach, you might have to make some adjustments. Special thanks also to @rt2zz and his react-native-contacts repo. Finally, Brent Vatne is always amazingly helpful with everything and deserves to be thanked.