Radar is the location platform for mobile apps. This is a Cordova plugin to use its SDK.
Install the Cordova plugin:
$ cordova plugin install cordova-plugin-radar
Check the main documentation for details. There's a basic test app example as well.
Register and get your keys.
cordova.plugins.radar.initialize(key);
Before tracking the user's location, you must identify the user to cordova.plugins.radar. To identify the user, call:
cordova.plugins.radar.setUserId(userId);
where userId
is a stable unique ID string for the user.
To set an optional description for the user, displayed in the dashboard, call:
cordova.plugins.radar.setDescription(description);
where description
is a string.
You only need to call these methods once, as these settings will be persisted across app sessions.
To set Facebook as your place data provider, call:
cordova.plugins.radar.setPlacesProvider('facebook');
Before tracking the user's location, the user must have granted location permissions for the app. These are requested automatically when you initialized radar.
To determine the whether user has granted location permissions for the app, call:
cordova.plugins.radar.getPermissionsStatus().then((status) => {
// do something with status
});
status
will be a string, one of:
GRANTED
DENIED
UNKNOWN
To request location permissions for the app, call:
cordova.plugins.radar.requestPermissions(background);
where background
is a boolean indicating whether to request background location permissions or foreground location permissions. On Android, background
will be ignored.
Once you have initialized the SDK, you have identified the user, and the user has granted permissions, you can track the user's location.
To track the user's location in the foreground, call:
cordova.plugins.radar.trackOnce().then((result) => {
// do something with result.location, result.events, result.user.geofences
}).catch((err) => {
// optionally, do something with err
});
err
will be a string, one of:
ERROR_PUBLISHABLE_KEY
: the SDK was not initializedERROR_USER_ID
: the user was not identifiedERROR_PERMISSIONS
: the user has not granted location permissions for the appERROR_LOCATION
: location services were unavailable, or the location request timed outERROR_NETWORK
: the network was unavailable, or the network connection timed outERROR_UNAUTHORIZED
: the publishable API key is invalidERROR_SERVER
: an internal server error occurredERROR_UNKNOWN
: an unknown error occurred
Once you have initialized the SDK, you have identified the user, and the user has granted permissions, you can start tracking the user's location in the background.
To start tracking the user's location in the background, call:
cordova.plugins.radar.startTracking();
To stop tracking the user's location in the background (e.g., when the user logs out), call:
cordova.plugins.radar.stopTracking();
You only need to call these methods once, as these settings will be persisted across app sessions.
To listen for events and errors, you can add event listeners:
cordova.plugins.radar.onEvents(
(events, user) => {
// do something with result.events, result.user
}
);
cordova.plugins.radar.onError(
(err) => {
// do something with err
});
You should remove event listeners when you are done with them:
cordova.plugins.radar.offEvents();
cordova.plugins.radar.offError();
You can manually update the user's location by calling:
const location = {
latitude: 39.2904,
longitude: -76.6122,
accuracy: 65
};
cordova.plugins.radar.updateLocation(
{
latitude: document.getElementById('latitude').value,
longitude: document.getElementById('longitude').value,
accuracy: document.getElementById('accuracy').value
},
(result) => {
// do something with result.events, result.user.geofences
console.log(result);
}
);