cordova-launch-review
v4.1.0
Published
Cordova/Phonegap plugin for iOS and Android to assist in leaving user reviews/ratings in the App Stores.
Downloads
10,882
Maintainers
Readme
Cordova Launch Review plugin
Table of Contents
Overview
Cordova/Phonegap plugin for iOS and Android to assist in leaving user reviews/ratings in the App Stores.
- Launches the platform's App Store page for the current app in order for the user to leave a review.
- On iOS 10.3 and above, invokes the native in-app rating dialog which allows a user to rate your app without needing to open the App Store.
- On Android, invokes the native in-app review dialog
The plugin published to npm as cordova-launch-review
I dedicate a considerable amount of my free time to developing and maintaining this Cordova plugin, along with my other Open Source software. To help ensure this plugin is kept updated, new features are added and bugfixes are implemented quickly, please donate a couple of dollars (or a little more if you can stretch) as this will help me to afford to dedicate time to its maintenance. Please consider donating if you're using this plugin in an app that makes you money, if you're being paid to make the app, if you're asking for new features or priority bug fixes.
Installation
Using the Cordova/Phonegap CLI
$ cordova plugin add cordova-launch-review
Usage
The plugin is exposed via the LaunchReview
global namespace.
launch()
Platforms: Android and iOS
Launches the App Store page for the current app in order for the user to leave a review.
On Android, opens the app's in the Play Store where the user can leave a review by pressing the stars to give a rating.
On iOS, opens the app's page in the App Store and automatically opens the dialog for the user to leave a rating or review.
LaunchReview.launch(success, error, appId);
Parameters
- {function} success - (optional) function to execute on successfully launching store app.
- {function} error - (optional) function to execute on failure to launch store app. Will be passed a single argument which is the error message string.
- {string} appID - (optional) the platform-specific app ID to use to open the page in the store app
- If not specified, the plugin will use the app ID for the app in which the plugin is contained.
- On Android this is the full package name of the app. For example, for Google Maps:
com.google.android.apps.maps
- On iOS this is the Apple ID of the app. For example, for Google Maps:
585027354
Simple usage
LaunchReview.launch();
Advanced usage
var appId, platform = device.platform.toLowerCase();
switch(platform){
case "ios":
appId = "585027354";
break;
case "android":
appId = "com.google.android.apps.maps";
break;
}
LaunchReview.launch(function(){
console.log("Successfully launched store app");
},function(err){
console.log("Error launching store app: " + err);
}, appId);
rating()
Platforms: Android and iOS
On iOS 10.3 and above, invokes the native in-app rating dialog which allows a user to rate your app without needing to open the App Store.
On Android, invokes the native in-app review dialog which allows a user to rate/review your app without needing to open the Play Store.
LaunchReview.rating(success, error);
iOS notes
- The Rating dialog will not be displayed every time
LaunchReview.rating()
is called - iOS limits the frequency with which it can be called (see here). - The Rating dialog may take several seconds to appear while iOS queries the Apple servers before displaying the dialog.
- The success function will be called up to 3 times:
- First: after
LaunchReview.rating()
is called and the request to show the dialog is successful. Will be passed the valuerequested
. - Second: if and when the Rating dialog is actually displayed. Will be passed the value
shown
. - Third: if and when the Rating dialog is dismissed. Will be passed the value
dismissed
.
- First: after
- Detection of the display of the Rating dialog is done using inspection of the private class name.
- This is not officially sanctioned by Apple, so while it should pass App Store review, it may break if the class name is changed in a future iOS version.
- Since there's no guarantee the dialog will be displayed, and even then it may take several seconds before it displays, the only way to determine if it has not be shown is to set a timeout after successful requesting of the dialog which is cleared upon successful display of the dialog, or otherwise expires after a pre-determined period (i.e. a few seconds).
- See the Advanced usage below and the example project code for an illustration of this approach.
Android notes
- Be sure to follow the Android guidelines on when to request an in-app review
- Google Play enforces a quota on how often a user can be shown the review dialog which means the dialog might not display after you call this method.
- The user must first rate your app in the native dialog before being shown the review textarea input.
- Neither
success
orerror
will not be called if dialog was not shown due to rate limiting, etc.- If you need to know the outcome it's therefore best to set timeout after which you assume the dialog has failed to show - see the example project for an example of this.
- If you're having problems with getting the native rating dialog to appear, make sure you've followed all the steps in the Android guidelines on testing in-app reviews.
Parameters
- {function} success - (optional) function to execute on successfully requesting (note: this does not guarantee it will be displayed) the launch rating dialog
- iOS
- Will be passed a single string argument which indicates the result:
requested
,shown
ordismissed
. - Will be called the first time after
LaunchReview.rating()
is called and the request to show the dialog is successful with valuerequested
. - May be called a second time if/when the rating dialog is successfully displayed with value
shown
. - May be called a third time if/when the rating dialog is dismissed with value
dismissed
.
- Will be passed a single string argument which indicates the result:
- Android
- Will be passed a single string argument which indicates the result:
requested
- May be called once after the dialog was successfully displayed and the user dismisses the dialog.
- Will be passed a single string argument which indicates the result:
- iOS
- {function} error - (optional) function to execute on failure to launch rating dialog.
- Will be passed a single argument which is the error message string.
Simple usage
LaunchReview.rating();
Advanced usage
//max time to wait for rating dialog to display on iOS
var MAX_DIALOG_WAIT_TIME_IOS = 5*1000;
//max time to wait for rating dialog to display on Android and be submitted by user
var MAX_DIALOG_WAIT_TIME_ANDROID = 60*1000;
var ratingTimerId;
function ratingDialogNotShown(){
var msg;
if(cordova.platformId === "android"){
msg = "Rating dialog outcome not received (after " + MAX_DIALOG_WAIT_TIME_ANDROID + "ms)";
}else if(cordova.platformId === "ios"){
msg = "Rating dialog was not shown (after " + MAX_DIALOG_WAIT_TIME_IOS + "ms)";
}
console.warn(msg);
}
function rating(){
if(cordova.platformId === "android"){
ratingTimerId = setTimeout(ratingDialogNotShown, MAX_DIALOG_WAIT_TIME_ANDROID);
}
LaunchReview.rating(function(status){
if(status === "requested"){
if(cordova.platformId === "android"){
console.log("Displayed rating dialog");
clearTimeout(ratingTimerId);
}else if(cordova.platformId === "ios"){
console.log("Requested rating dialog");
ratingTimerId = setTimeout(ratingDialogNotShown, MAX_DIALOG_WAIT_TIME_IOS);
}
}else if(status === "shown"){
console.log("Rating dialog displayed");
clearTimeout(ratingTimerId);
}else if(status === "dismissed"){
console.log("Rating dialog dismissed");
clearTimeout(ratingTimerId);
}
}, function (err){
console.error("Error launching rating dialog: " + err);
clearTimeout(ratingTimerId);
});
}
rating(); // app invokes eg. via UI action
isRatingSupported()
Platforms: Android and iOS
Indicates if the current platform/version supports in-app ratings dialog, i.e. calling LaunchReview.rating()
.
Will return true
if current platform is Android or iOS 10.3+.
var isSupported = LaunchReview.isRatingSupported();
Example usage
if(LaunchReview.isRatingSupported()){
LaunchReview.rating();
}else{
LaunchReview.launch();
}
Example project
An example project illustrating use of this plugin can be found here: https://github.com/dpa99c/cordova-launch-review-example
License
================
The MIT License
Copyright (c) 2015-2020 Working Edge Ltd.
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.