Installations
npm install af-google-places
Developer Guide
Typescript
No
Module System
CommonJS
Node Version
6.5.0
NPM Version
5.4.2
Score
51
Supply Chain
65.1
Quality
65.8
Maintenance
50
Vulnerability
93.4
License
Releases
Contributors
Unable to fetch Contributors
Languages
Java (65.79%)
Objective-C (31.28%)
JavaScript (1.75%)
Ruby (1.18%)
Developer
tolu360
Download Statistics
Total Downloads
1,465
Last Day
1
Last Week
2
Last Month
6
Last Year
261
GitHub Statistics
566 Stars
207 Commits
290 Forks
16 Watching
5 Branches
18 Contributors
Bundle Size
877.00 B
Minified
421.00 B
Minified + Gzipped
Package Meta Information
Latest Version
2.2.0
Package Id
af-google-places@2.2.0
Size
21.16 MB
NPM Version
5.4.2
Node Version
6.5.0
Total Downloads
Cumulative downloads
Total Downloads
1,465
Last day
0%
1
Compared to previous day
Last week
0%
2
Compared to previous week
Last month
100%
6
Compared to previous month
Last year
26.1%
261
Compared to previous year
Daily Downloads
Weekly Downloads
Monthly Downloads
Yearly Downloads
Peer Dependencies
2
react-native-google-places
iOS/Android Google Places Widgets (Autocomplete, Place Picker) and API Services for React Native Apps
Shots
Versioning:
- for RN >= 0.40.0, use v2+ (e.g. react-native-google-places@2.1.0)
- for RN (0.33.0 - 0.39.0), use v1+ or 0.8.8 (e.g. react-native-google-places@1.1.0)
Install
npm i react-native-google-places --save
react-native link react-native-google-places
OR
yarn add react-native-google-places
react-native link react-native-google-places
Google Places API Set-Up
- Sign up for Google Places API for Android in Google API Console to grab your Android API key (not browser key).
- Read further API setup guides at https://developers.google.com/places/android-api/signup.
- Similarly, sign up for Google Places API for iOS in Google API Console to grab your iOS API key (not browser key).
- Ensure you check out further guides at https://developers.google.com/places/ios-api/start.
- With both keys in place, you can proceed.
Post-install Steps
iOS (requires CocoaPods)
Auto Linking With Your Project (iOS & Android)
- This was done automatically for you when you ran
react-native link react-native-google-places
. Or you can run the command now if you have not already.
Manual Linking With Your Project (iOS)
- In XCode, in the project navigator, right click
Libraries ➜ Add Files to [your project's name]
. - Go to
node_modules
âžœreact-native-google-places
and addRNGooglePlaces.xcodeproj
. - In XCode, in the project navigator, select your project. Add
libRNGooglePlaces.a
to your project'sBuild Phases
âžœLink Binary With Libraries
.
Install CocoaPods Dependencies
- If you do not have CocoaPods already installed on your machine, run
gem install cocoapods
to set it up the first time. (Hint: Go grab a cup of coffee!) - If you are not using Cocoapods in your project already, run
cd ios && pod init
at the root directory of your project. - Add
pod 'GooglePlaces'
,pod 'GooglePlacePicker'
andpod 'GoogleMaps'
to your Podfile. Otherwise just edit your Podfile to include:
1source 'https://github.com/CocoaPods/Specs.git' 2 3target 'YOUR_APP_TARGET_NAME' do 4 5 pod 'GooglePlaces' 6 pod 'GoogleMaps' 7 pod 'GooglePlacePicker' 8 9end
- In your AppDelegate.m file, import the Google Places library by adding
@import GooglePlaces;
and@import GoogleMaps;
on top of the file. - Within the
didFinishLaunchingWithOptions
method, instantiate the library as follows:
1[GMSPlacesClient provideAPIKey:@"YOUR_IOS_API_KEY_HERE"]; 2[GMSServices provideAPIKey:@"YOUR_IOS_API_KEY_HERE"];
- By now, you should be all set to install the packages from your Podfile. Run
pod install
from yourios
directory. - Close Xcode, and then open (double-click) your project's .xcworkspace file to launch Xcode. From this time onwards, you must use the
.xcworkspace
file to open the project. Or just use thereact-native run-ios
command as usual to run your app in the simulator.
Android
- In your AndroidManifest.xml file, request location permissions and add your API key in a meta-data tag (ensure you are within the
<application>
tag as follows:
1<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" /> 2<application 3 android:name=".MainApplication" 4 ...> 5 <meta-data 6 android:name="com.google.android.geo.API_KEY" 7 android:value="YOUR_ANDROID_API_KEY_HERE"/> 8 ... 9</application>
Manual Linking With Your Project (Android)
- The following additional setup steps are optional as they should have been taken care of, for you when you ran
react-native link react-native-google-places
. Otherwise, do the following or just ensure they are in place; - Add the following in your
android/settings.gradle
file:
1include ':react-native-google-places' 2project(':react-native-google-places').projectDir = new File(rootProject.projectDir, '../node_modules/react-native-google-places/android')
- Add the following in your
android/app/build.grade
file:
1dependencies { 2 ... 3 compile project(':react-native-google-places') 4}
- Add the following in your
...MainApplication.java
file:
1import com.arttitude360.reactnative.rngoogleplaces.RNGooglePlacesPackage; 2 3@Override 4protected List<ReactPackage> getPackages() { 5 return Arrays.<ReactPackage>asList( 6 new MainReactPackage(), 7 ... 8 new RNGooglePlacesPackage() //<-- Add line 9 ); 10}
- Finally, we can run
react-native run-android
to get started.
Usage
Allows your users to enter place names and addresses - and autocompletes your users' queries as they type.
Import library
1import RNGooglePlaces from 'react-native-google-places';
Open Autocomplete Modal (e.g as Callback to an onPress event)
1class GPlacesDemo extends Component { 2 openSearchModal() { 3 RNGooglePlaces.openAutocompleteModal() 4 .then((place) => { 5 console.log(place); 6 // place represents user's selection from the 7 // suggestions and it is a simplified Google Place object. 8 }) 9 .catch(error => console.log(error.message)); // error is a Javascript Error object 10 } 11 12 render() { 13 return ( 14 <View style={styles.container}> 15 <TouchableOpacity 16 style={styles.button} 17 onPress={() => this.openSearchModal()} 18 > 19 <Text>Pick a Place</Text> 20 </TouchableOpacity> 21 </View> 22 ); 23 } 24}
Optional Parameters
To filter autocomplete results as listed for Android and iOS in the official docs, you can pass an options
object as a parameter to the openAutocompleteModal()
method as follows:
1 RNGooglePlaces.openAutocompleteModal({ 2 type: 'establishment', 3 country: 'CA', 4 latitude: 53.544389, 5 longitude: -113.490927, 6 radius: 10 7 }) 8 .then((place) => { 9 console.log(place); 10 }) 11 .catch(error => console.log(error.message));
type
(String) - The type of results to return. Can be one of (geocode
,address
,establishment
,regions
, andcities
). (optional)country
(String) - Limit results to a specific country using a ISO 3166-1 Alpha-2 country code (case insensitive). If this is not set, no country filtering will take place. (optional)latitude
(Number) - Latitude of the point around which you wish to retrieve place information (required iflongitude
is given)longitude
(Number) - Longitude of the point around which you wish to retrieve place information (required iflatitude
is given)radius
(Number) - Radius (in kilo-meters) within which to retrieve place information. Only works iflatitude
andlongitude
are also given. Note that setting a radius biases results to the indicated area, but may not fully restrict results to the specified area. Defaults to0.1
.useOverlay
(Boolean) [Android Only] - If true, the autocomplete modal will open as an overlay. Defaults tofalse
.
Open PlacePicker Modal
1class GPlacesDemo extends Component { 2 openSearchModal() { 3 RNGooglePlaces.openPlacePickerModal() 4 .then((place) => { 5 console.log(place); 6 // place represents user's selection from the 7 // suggestions and it is a simplified Google Place object. 8 }) 9 .catch(error => console.log(error.message)); // error is a Javascript Error object 10 } 11 12 render() { 13 return ( 14 <View style={styles.container}> 15 <TouchableOpacity 16 style={styles.button} 17 onPress={() => this.openSearchModal()} 18 > 19 <Text>Open Place Picker</Text> 20 </TouchableOpacity> 21 </View> 22 ); 23 } 24}
To set the initial viewport that the place picker map should show when the picker is launched, you can pass a latLngBounds
object as a parameter
to the openPlacePickerModal()
method as follows. The latLngBounds
object takes the following optional keys:
latitude
(Number) - Latitude of the point which you want the map centered on (required iflongitude
is given)longitude
(Number) - Longitude of the point which you want the map centered on (required iflatitude
is given)radius
(Number) - Radius (in kilo-meters) from the center of the map view to the edge. Use this to set the default "zoom" of the map view when it is first opened. Only works iflatitude
andlongitude
are also given. Defaults to0.1
.
If no initial viewport is set (no argument is passed to the openPlacePickerModal()
method), the viewport will be centered on the device's location, with the zoom at city-block level.
1 RNGooglePlaces.openPlacePickerModal({ 2 latitude: 53.544389, 3 longitude: -113.490927, 4 radius: 0.01 // 10 meters 5 }) 6 .then((place) => { 7 console.log(place); 8 }) 9 .catch(error => console.log(error.message));
Example Response from the Autocomplete & PlacePicker Modals
1{ 2 placeID: "ChIJZa6ezJa8j4AR1p1nTSaRtuQ", 3 website: "https://www.facebook.com/", 4 phoneNumber: "+1 650-543-4800", 5 address: "1 Hacker Way, Menlo Park, CA 94025, USA", 6 name: "Facebook HQ", 7 types: [ 'street_address', 'geocode' ], 8 latitude: 37.4843428, 9 longitude: -122.14839939999999 10}
- Note: The keys available from the response from the resolved
Promise
from callingRNGooglePlaces.openAutocompleteModal()
are dependent on the selected place - asphoneNumber, website
are not set on allGoogle Place
objects.
Using Your Own Custom UI/Views
If you have specific branding needs or you would rather build out your own custom search input and suggestions list (think Uber
), you may profit from calling the API methods below which would get you autocomplete predictions programmatically using the underlying iOS and Android SDKs
.
Get Autocomplete Predictions
1 RNGooglePlaces.getAutocompletePredictions('facebook') 2 .then((results) => this.setState({ predictions: results })) 3 .catch((error) => console.log(error.message));
Optional Parameters
To filter autocomplete results as listed for Android and iOS in the official docs, you can pass an options
object as a second parameter to the getAutocompletePredictions()
method as follows:
1 RNGooglePlaces.getAutocompletePredictions('Lagos', { 2 type: 'cities', 3 country: 'NG' 4 }) 5 .then((place) => { 6 console.log(place); 7 }) 8 .catch(error => console.log(error.message));
OR
1RNGooglePlaces.getAutocompletePredictions('pizza', { 2 type: 'establishments', 3 latitude: 53.544389, 4 longitude: -113.490927, 5 radius: 10 6 }) 7 .then((place) => { 8 console.log(place); 9 }) 10 .catch(error => console.log(error.message));
type
(String) - The type of results to return. Can be one of (geocode
,address
,establishment
,regions
, andcities
). (optional)country
(String) - Limit results to a specific country using a ISO 3166-1 Alpha-2 country code (case insensitive). If this is not set, no country filtering will take place. (optional)latitude
(Number) - Latitude of the point around which you wish to retrieve place information (required iflongitude
is given)longitude
(Number) - Longitude of the point around which you wish to retrieve place information (required iflatitude
is given)radius
(Number) - Radius (in kilo-meters) within which to retrieve place information. Only works iflatitude
andlongitude
are also given. Note that setting a radius biases results to the indicated area, but may not fully restrict results to the specified area. Defaults to0.1
.
Example Response from Calling getAutocompletePredictions()
1[ { primaryText: 'Facebook HQ', 2 placeID: 'ChIJZa6ezJa8j4AR1p1nTSaRtuQ', 3 secondaryText: 'Hacker Way, Menlo Park, CA, United States', 4 fullText: 'Facebook HQ, Hacker Way, Menlo Park, CA, United States' }, 5 types: [ 'street_address', 'geocode' ], 6 { primaryText: 'Facebook Way', 7 placeID: 'EitGYWNlYm9vayBXYXksIE1lbmxvIFBhcmssIENBLCBVbml0ZWQgU3RhdGVz', 8 secondaryText: 'Menlo Park, CA, United States', 9 fullText: 'Facebook Way, Menlo Park, CA, United States' }, 10 types: [ 'street_address', 'geocode' ], 11 12 ... 13]
Look-Up A Place By ID
1 RNGooglePlaces.lookUpPlaceByID('ChIJZa6ezJa8j4AR1p1nTSaRtuQ') 2 .then((results) => console.log(results)) 3 .catch((error) => console.log(error.message));
Example Response from Calling lookUpPlaceByID()
1{ name: 'Facebook HQ', 2 website: 'https://www.facebook.com/', 3 longitude: -122.14835169999999, 4 address: '1 Hacker Way, Menlo Park, CA 94025, USA', 5 latitude: 37.48485, 6 placeID: 'ChIJZa6ezJa8j4AR1p1nTSaRtuQ', 7 types: [ 'street_address', 'geocode' ], 8 phoneNumber: '+1 650-543-4800' 9}
Design Hint
The typical use flow would be to call getAutocompletePredictions()
when the value of your search input changes to populate your suggestion listview and call lookUpPlaceByID()
to retrieve the place details when a place on your listview is selected.
PS (from Google)
- Use of the
getAutocompletePredictions()
method is subject to tiered query limits. See the documentation on Android & iOS Usage Limits. - Also, your UI must either display a 'Powered by Google' attribution, or appear within a Google-branded map.
Troubleshooting
On iOS
You have to link dependencies and re-run the build:
- Run
react-native link
- Try
Manual Linking With Your Project
steps above. - Run
react-native run-ios
On Android
- Run "android" and make sure every packages is updated.
- If not installed yet, you have to install the following packages:
-
Extras / Google Play services
-
Extras / Google Repository
-
Android (API 23+) / Google APIs Intel x86 Atom System Image Rev. 13
-
Check manual installation steps
-
Ensure your API key has permissions for
Google Place
andGoogle Android Maps
-
If you have a different version of play serivces than the one included in this library (which is currently at 10.2.0), use the following instead (switch 10.0.1 for the desired version) in your
android/app/build.grade
file:1... 2dependencies { 3 ... 4 compile(project(':react-native-google-places')){ 5 exclude group: 'com.google.android.gms', module: 'play-services-base' 6 exclude group: 'com.google.android.gms', module: 'play-services-places' 7 exclude group: 'com.google.android.gms', module: 'play-services-location' 8 } 9 compile 'com.google.android.gms:play-services-base:10.0.1' 10 compile 'com.google.android.gms:play-services-places:10.0.1' 11 compile 'com.google.android.gms:play-services-location:10.0.1' 12}
License
The MIT License.
No vulnerabilities found.
Reason
no binaries found in the repo
Reason
0 existing vulnerabilities detected
Reason
Found 7/21 approved changesets -- score normalized to 3
Reason
0 commit(s) and 0 issue activity found in the last 90 days -- score normalized to 0
Reason
no effort to earn an OpenSSF best practices badge detected
Reason
security policy file not detected
Details
- Warn: no security policy file detected
- Warn: no security file to analyze
- Warn: no security file to analyze
- Warn: no security file to analyze
Reason
project is not fuzzed
Details
- Warn: no fuzzer integrations found
Reason
license file not detected
Details
- Warn: project does not have a license file
Reason
branch protection not enabled on development/release branches
Details
- Warn: branch protection not enabled for branch 'master'
Reason
SAST tool is not run on all commits -- score normalized to 0
Details
- Warn: 0 commits out of 16 are checked with a SAST tool
Score
3
/10
Last Scanned on 2024-12-30
The Open Source Security Foundation is a cross-industry collaboration to improve the security of open source software (OSS). The Scorecard provides security health metrics for open source projects.
Learn More