react-native-rate-app 1.4.12 → 1.5.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +1 -1
- package/RateApp.podspec +3 -25
- package/android/build.gradle +21 -41
- package/android/src/main/AndroidManifest.xml +1 -2
- package/android/src/main/java/com/rateapp/RateAppModule.kt +2 -12
- package/android/src/main/java/com/rateapp/RateAppPackage.kt +10 -12
- package/app.plugin.js +1 -1
- package/ios/RateApp-Bridging-Header.h +1 -1
- package/ios/RateApp.h +1 -7
- package/ios/RateApp.mm +15 -11
- package/ios/RateApp.swift +21 -12
- package/lib/module/NativeRateApp.js +5 -0
- package/lib/module/NativeRateApp.js.map +1 -0
- package/lib/module/constants.js +6 -6
- package/lib/module/constants.js.map +1 -1
- package/lib/module/index.js +16 -16
- package/lib/module/index.js.map +1 -1
- package/lib/module/package.json +1 -0
- package/lib/module/plugin/withReactNativeRateApp.js +4 -4
- package/lib/typescript/package.json +1 -0
- package/lib/typescript/setupJest.d.ts +1 -0
- package/lib/typescript/setupJest.d.ts.map +1 -0
- package/lib/typescript/{codegenSpec → src}/NativeRateApp.d.ts +1 -1
- package/lib/typescript/src/NativeRateApp.d.ts.map +1 -0
- package/lib/typescript/{constants.d.ts → src/constants.d.ts} +1 -1
- package/lib/typescript/src/constants.d.ts.map +1 -0
- package/lib/typescript/{index.d.ts → src/index.d.ts} +3 -3
- package/lib/typescript/src/index.d.ts.map +1 -0
- package/lib/typescript/{plugin → src/plugin}/withReactNativeRateApp.d.ts +1 -1
- package/lib/typescript/src/plugin/withReactNativeRateApp.d.ts.map +1 -0
- package/lib/typescript/src/types.d.ts.map +1 -0
- package/package.json +73 -59
- package/src/{codegenSpec/NativeRateApp.ts → NativeRateApp.ts} +3 -3
- package/src/constants.ts +6 -6
- package/src/index.tsx +17 -17
- package/src/plugin/withReactNativeRateApp.ts +4 -4
- package/src/types.ts +4 -4
- package/android/generated/java/com/rateapp/NativeRateAppSpec.java +0 -46
- package/android/generated/jni/CMakeLists.txt +0 -28
- package/android/generated/jni/RateAppSpec-generated.cpp +0 -44
- package/android/generated/jni/RateAppSpec.h +0 -31
- package/android/generated/jni/react/renderer/components/RateAppSpec/RateAppSpecJSI.h +0 -54
- package/android/gradle.properties +0 -5
- package/android/src/main/AndroidManifestNew.xml +0 -2
- package/android/src/newarch/RateApp.kt +0 -8
- package/android/src/oldarch/RateApp.kt +0 -14
- package/ios/generated/ReactCodegen/RateAppSpec/RateAppSpec-generated.mm +0 -53
- package/ios/generated/ReactCodegen/RateAppSpec/RateAppSpec.h +0 -68
- package/ios/generated/ReactCodegen/RateAppSpecJSI.h +0 -54
- package/lib/commonjs/codegenSpec/NativeRateApp.js +0 -9
- package/lib/commonjs/codegenSpec/NativeRateApp.js.map +0 -1
- package/lib/commonjs/constants.js +0 -15
- package/lib/commonjs/constants.js.map +0 -1
- package/lib/commonjs/index.js +0 -140
- package/lib/commonjs/index.js.map +0 -1
- package/lib/commonjs/package.json +0 -1
- package/lib/commonjs/plugin/withReactNativeRateApp.js +0 -56
- package/lib/commonjs/plugin/withReactNativeRateApp.js.map +0 -1
- package/lib/commonjs/types.js +0 -14
- package/lib/commonjs/types.js.map +0 -1
- package/lib/module/codegenSpec/NativeRateApp.js +0 -5
- package/lib/module/codegenSpec/NativeRateApp.js.map +0 -1
- package/lib/typescript/codegenSpec/NativeRateApp.d.ts.map +0 -1
- package/lib/typescript/constants.d.ts.map +0 -1
- package/lib/typescript/index.d.ts.map +0 -1
- package/lib/typescript/plugin/withReactNativeRateApp.d.ts.map +0 -1
- package/lib/typescript/types.d.ts.map +0 -1
- /package/lib/typescript/{types.d.ts → src/types.d.ts} +0 -0
|
@@ -1,68 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* This code was generated by [react-native-codegen](https://www.npmjs.com/package/react-native-codegen).
|
|
3
|
-
*
|
|
4
|
-
* Do not edit this file as changes may cause incorrect behavior and will be lost
|
|
5
|
-
* once the code is regenerated.
|
|
6
|
-
*
|
|
7
|
-
* @generated by codegen project: GenerateModuleObjCpp
|
|
8
|
-
*
|
|
9
|
-
* We create an umbrella header (and corresponding implementation) here since
|
|
10
|
-
* Cxx compilation in BUCK has a limitation: source-code producing genrule()s
|
|
11
|
-
* must have a single output. More files => more genrule()s => slower builds.
|
|
12
|
-
*/
|
|
13
|
-
|
|
14
|
-
#ifndef __cplusplus
|
|
15
|
-
#error This file must be compiled as Obj-C++. If you are importing it, you must change your file extension to .mm.
|
|
16
|
-
#endif
|
|
17
|
-
|
|
18
|
-
// Avoid multiple includes of RateAppSpec symbols
|
|
19
|
-
#ifndef RateAppSpec_H
|
|
20
|
-
#define RateAppSpec_H
|
|
21
|
-
|
|
22
|
-
#import <Foundation/Foundation.h>
|
|
23
|
-
#import <RCTRequired/RCTRequired.h>
|
|
24
|
-
#import <RCTTypeSafety/RCTConvertHelpers.h>
|
|
25
|
-
#import <RCTTypeSafety/RCTTypedModuleConstants.h>
|
|
26
|
-
#import <React/RCTBridgeModule.h>
|
|
27
|
-
#import <React/RCTCxxConvert.h>
|
|
28
|
-
#import <React/RCTManagedPointer.h>
|
|
29
|
-
#import <ReactCommon/RCTTurboModule.h>
|
|
30
|
-
#import <optional>
|
|
31
|
-
#import <vector>
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
NS_ASSUME_NONNULL_BEGIN
|
|
35
|
-
|
|
36
|
-
@protocol NativeRateAppSpec <RCTBridgeModule, RCTTurboModule>
|
|
37
|
-
|
|
38
|
-
- (void)requestReview:(RCTPromiseResolveBlock)resolve
|
|
39
|
-
reject:(RCTPromiseRejectBlock)reject;
|
|
40
|
-
- (void)requestReviewAppGallery:(RCTPromiseResolveBlock)resolve
|
|
41
|
-
reject:(RCTPromiseRejectBlock)reject;
|
|
42
|
-
- (void)requestReviewGalaxyStore:(NSString *)androidPackageName
|
|
43
|
-
resolve:(RCTPromiseResolveBlock)resolve
|
|
44
|
-
reject:(RCTPromiseRejectBlock)reject;
|
|
45
|
-
|
|
46
|
-
@end
|
|
47
|
-
|
|
48
|
-
@interface NativeRateAppSpecBase : NSObject {
|
|
49
|
-
@protected
|
|
50
|
-
facebook::react::EventEmitterCallback _eventEmitterCallback;
|
|
51
|
-
}
|
|
52
|
-
- (void)setEventEmitterCallback:(EventEmitterCallbackWrapper *)eventEmitterCallbackWrapper;
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
@end
|
|
56
|
-
|
|
57
|
-
namespace facebook::react {
|
|
58
|
-
/**
|
|
59
|
-
* ObjC++ class for module 'NativeRateApp'
|
|
60
|
-
*/
|
|
61
|
-
class JSI_EXPORT NativeRateAppSpecJSI : public ObjCTurboModule {
|
|
62
|
-
public:
|
|
63
|
-
NativeRateAppSpecJSI(const ObjCTurboModule::InitParams ¶ms);
|
|
64
|
-
};
|
|
65
|
-
} // namespace facebook::react
|
|
66
|
-
|
|
67
|
-
NS_ASSUME_NONNULL_END
|
|
68
|
-
#endif // RateAppSpec_H
|
|
@@ -1,54 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* This code was generated by [react-native-codegen](https://www.npmjs.com/package/react-native-codegen).
|
|
3
|
-
*
|
|
4
|
-
* Do not edit this file as changes may cause incorrect behavior and will be lost
|
|
5
|
-
* once the code is regenerated.
|
|
6
|
-
*
|
|
7
|
-
* @generated by codegen project: GenerateModuleH.js
|
|
8
|
-
*/
|
|
9
|
-
|
|
10
|
-
#pragma once
|
|
11
|
-
|
|
12
|
-
#include <ReactCommon/TurboModule.h>
|
|
13
|
-
#include <react/bridging/Bridging.h>
|
|
14
|
-
|
|
15
|
-
namespace facebook::react {
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
template <typename T>
|
|
19
|
-
class JSI_EXPORT NativeRateAppCxxSpec : public TurboModule {
|
|
20
|
-
public:
|
|
21
|
-
static constexpr std::string_view kModuleName = "RateApp";
|
|
22
|
-
|
|
23
|
-
protected:
|
|
24
|
-
NativeRateAppCxxSpec(std::shared_ptr<CallInvoker> jsInvoker) : TurboModule(std::string{NativeRateAppCxxSpec::kModuleName}, jsInvoker) {
|
|
25
|
-
methodMap_["requestReview"] = MethodMetadata {.argCount = 0, .invoker = __requestReview};
|
|
26
|
-
methodMap_["requestReviewAppGallery"] = MethodMetadata {.argCount = 0, .invoker = __requestReviewAppGallery};
|
|
27
|
-
methodMap_["requestReviewGalaxyStore"] = MethodMetadata {.argCount = 1, .invoker = __requestReviewGalaxyStore};
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
private:
|
|
31
|
-
static jsi::Value __requestReview(jsi::Runtime &rt, TurboModule &turboModule, const jsi::Value* /*args*/, size_t /*count*/) {
|
|
32
|
-
static_assert(
|
|
33
|
-
bridging::getParameterCount(&T::requestReview) == 1,
|
|
34
|
-
"Expected requestReview(...) to have 1 parameters");
|
|
35
|
-
return bridging::callFromJs<jsi::Value>(rt, &T::requestReview, static_cast<NativeRateAppCxxSpec*>(&turboModule)->jsInvoker_, static_cast<T*>(&turboModule));
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
static jsi::Value __requestReviewAppGallery(jsi::Runtime &rt, TurboModule &turboModule, const jsi::Value* /*args*/, size_t /*count*/) {
|
|
39
|
-
static_assert(
|
|
40
|
-
bridging::getParameterCount(&T::requestReviewAppGallery) == 1,
|
|
41
|
-
"Expected requestReviewAppGallery(...) to have 1 parameters");
|
|
42
|
-
return bridging::callFromJs<jsi::Value>(rt, &T::requestReviewAppGallery, static_cast<NativeRateAppCxxSpec*>(&turboModule)->jsInvoker_, static_cast<T*>(&turboModule));
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
static jsi::Value __requestReviewGalaxyStore(jsi::Runtime &rt, TurboModule &turboModule, const jsi::Value* args, size_t count) {
|
|
46
|
-
static_assert(
|
|
47
|
-
bridging::getParameterCount(&T::requestReviewGalaxyStore) == 2,
|
|
48
|
-
"Expected requestReviewGalaxyStore(...) to have 2 parameters");
|
|
49
|
-
return bridging::callFromJs<jsi::Value>(rt, &T::requestReviewGalaxyStore, static_cast<NativeRateAppCxxSpec*>(&turboModule)->jsInvoker_, static_cast<T*>(&turboModule),
|
|
50
|
-
count <= 0 ? throw jsi::JSError(rt, "Expected argument in position 0 to be passed") : args[0].asString(rt));
|
|
51
|
-
}
|
|
52
|
-
};
|
|
53
|
-
|
|
54
|
-
} // namespace facebook::react
|
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
exports.default = void 0;
|
|
7
|
-
var _reactNative = require("react-native");
|
|
8
|
-
var _default = exports.default = _reactNative.TurboModuleRegistry.getEnforcing("RateApp");
|
|
9
|
-
//# sourceMappingURL=NativeRateApp.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"names":["_reactNative","require","_default","exports","default","TurboModuleRegistry","getEnforcing"],"sourceRoot":"../../../src","sources":["codegenSpec/NativeRateApp.ts"],"mappings":";;;;;;AACA,IAAAA,YAAA,GAAAC,OAAA;AAAmD,IAAAC,QAAA,GAAAC,OAAA,CAAAC,OAAA,GAQpCC,gCAAmB,CAACC,YAAY,CAAO,SAAS,CAAC","ignoreList":[]}
|
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
exports.IOS_REVIEW_URL = exports.ANDROID_MARKET_URLS = void 0;
|
|
7
|
-
var _types = require("./types");
|
|
8
|
-
const IOS_REVIEW_URL = exports.IOS_REVIEW_URL = "itms-apps://apps.apple.com/app/id";
|
|
9
|
-
const ANDROID_MARKET_URLS = exports.ANDROID_MARKET_URLS = {
|
|
10
|
-
[_types.AndroidMarket.GOOGLE]: "market://details?id={packageName}",
|
|
11
|
-
[_types.AndroidMarket.AMAZON]: "amzn://apps/android?p={packageName}",
|
|
12
|
-
[_types.AndroidMarket.SAMSUNG]: "samsungapps://ProductDetail/{packageName}",
|
|
13
|
-
[_types.AndroidMarket.HUAWEI]: "appmarket://details?id={packageName}"
|
|
14
|
-
};
|
|
15
|
-
//# sourceMappingURL=constants.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"names":["_types","require","IOS_REVIEW_URL","exports","ANDROID_MARKET_URLS","AndroidMarket","GOOGLE","AMAZON","SAMSUNG","HUAWEI"],"sourceRoot":"../../src","sources":["constants.ts"],"mappings":";;;;;;AAAA,IAAAA,MAAA,GAAAC,OAAA;AAEO,MAAMC,cAAc,GAAAC,OAAA,CAAAD,cAAA,GAAG,mCAAmC;AAE1D,MAAME,mBAAkD,GAAAD,OAAA,CAAAC,mBAAA,GAAG;EAChE,CAACC,oBAAa,CAACC,MAAM,GAAG,mCAAmC;EAC3D,CAACD,oBAAa,CAACE,MAAM,GAAG,qCAAqC;EAC7D,CAACF,oBAAa,CAACG,OAAO,GAAG,2CAA2C;EACpE,CAACH,oBAAa,CAACI,MAAM,GAAG;AAC1B,CAAC","ignoreList":[]}
|
package/lib/commonjs/index.js
DELETED
|
@@ -1,140 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
var _exportNames = {
|
|
7
|
-
requestReview: true,
|
|
8
|
-
openStoreForReview: true,
|
|
9
|
-
getAndroidMarketUrl: true
|
|
10
|
-
};
|
|
11
|
-
exports.requestReview = exports.openStoreForReview = exports.getAndroidMarketUrl = exports.default = void 0;
|
|
12
|
-
var _reactNative = require("react-native");
|
|
13
|
-
var _NativeRateApp = _interopRequireDefault(require("./codegenSpec/NativeRateApp"));
|
|
14
|
-
var _constants = require("./constants");
|
|
15
|
-
Object.keys(_constants).forEach(function (key) {
|
|
16
|
-
if (key === "default" || key === "__esModule") return;
|
|
17
|
-
if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;
|
|
18
|
-
if (key in exports && exports[key] === _constants[key]) return;
|
|
19
|
-
Object.defineProperty(exports, key, {
|
|
20
|
-
enumerable: true,
|
|
21
|
-
get: function () {
|
|
22
|
-
return _constants[key];
|
|
23
|
-
}
|
|
24
|
-
});
|
|
25
|
-
});
|
|
26
|
-
var _types = require("./types");
|
|
27
|
-
Object.keys(_types).forEach(function (key) {
|
|
28
|
-
if (key === "default" || key === "__esModule") return;
|
|
29
|
-
if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;
|
|
30
|
-
if (key in exports && exports[key] === _types[key]) return;
|
|
31
|
-
Object.defineProperty(exports, key, {
|
|
32
|
-
enumerable: true,
|
|
33
|
-
get: function () {
|
|
34
|
-
return _types[key];
|
|
35
|
-
}
|
|
36
|
-
});
|
|
37
|
-
});
|
|
38
|
-
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
39
|
-
/**
|
|
40
|
-
* Custom error for rate app operations
|
|
41
|
-
*/
|
|
42
|
-
class RateAppError extends Error {
|
|
43
|
-
constructor(message) {
|
|
44
|
-
super(message);
|
|
45
|
-
this.name = "RateAppError";
|
|
46
|
-
}
|
|
47
|
-
}
|
|
48
|
-
const RNRateApp = {
|
|
49
|
-
/**
|
|
50
|
-
* Requests a review from the user.
|
|
51
|
-
*
|
|
52
|
-
* @param {RequestReviewProps} props - The properties for the review request.
|
|
53
|
-
* @param {AndroidMarket} [props.androidMarket=AndroidMarket.GOOGLE] - The market where the app's review request should be directed on Android.
|
|
54
|
-
* @param {string} [props.androidPackageName] - The package name of the app to request a review for on Samsung Galaxy Store.
|
|
55
|
-
* @returns {Promise<boolean>} A promise that resolves to a boolean indicating whether the review was successfully requested.
|
|
56
|
-
*/
|
|
57
|
-
async requestReview({
|
|
58
|
-
androidMarket = _types.AndroidMarket.GOOGLE,
|
|
59
|
-
androidPackageName
|
|
60
|
-
} = {}) {
|
|
61
|
-
try {
|
|
62
|
-
if (_reactNative.Platform.OS === "android") {
|
|
63
|
-
switch (androidMarket) {
|
|
64
|
-
case _types.AndroidMarket.SAMSUNG:
|
|
65
|
-
if (!androidPackageName) {
|
|
66
|
-
throw new RateAppError("androidPackageName is required for Samsung Galaxy Store");
|
|
67
|
-
}
|
|
68
|
-
return await _NativeRateApp.default.requestReviewGalaxyStore(androidPackageName);
|
|
69
|
-
case _types.AndroidMarket.HUAWEI:
|
|
70
|
-
return await _NativeRateApp.default.requestReviewAppGallery();
|
|
71
|
-
default:
|
|
72
|
-
return await _NativeRateApp.default.requestReview();
|
|
73
|
-
}
|
|
74
|
-
}
|
|
75
|
-
return await _NativeRateApp.default.requestReview();
|
|
76
|
-
} catch (error) {
|
|
77
|
-
throw new RateAppError(`Failed to request review: ${error}`);
|
|
78
|
-
}
|
|
79
|
-
},
|
|
80
|
-
/**
|
|
81
|
-
* Opens the store listing for the app.
|
|
82
|
-
* @param props The properties for the store listing.
|
|
83
|
-
* @returns A promise that resolves to a boolean indicating whether the store listing was successfully opened.
|
|
84
|
-
*/
|
|
85
|
-
async openStoreForReview({
|
|
86
|
-
iOSAppId,
|
|
87
|
-
androidPackageName,
|
|
88
|
-
androidMarket = _types.AndroidMarket.GOOGLE
|
|
89
|
-
}) {
|
|
90
|
-
const isIOS = _reactNative.Platform.OS === "ios";
|
|
91
|
-
const ismacOS = _reactNative.Platform.OS === "macos";
|
|
92
|
-
const isAndroid = _reactNative.Platform.OS === "android";
|
|
93
|
-
let url = "";
|
|
94
|
-
if (isIOS || ismacOS) {
|
|
95
|
-
if (!iOSAppId) {
|
|
96
|
-
throw new RateAppError("iOSAppId is required for iOS and macOS");
|
|
97
|
-
}
|
|
98
|
-
url = `${_constants.IOS_REVIEW_URL}${iOSAppId}?action=write-review`;
|
|
99
|
-
} else if (isAndroid) {
|
|
100
|
-
if (!androidPackageName) {
|
|
101
|
-
throw new RateAppError("androidPackageName is required for Android");
|
|
102
|
-
}
|
|
103
|
-
url = this.getAndroidMarketUrl(androidMarket, androidPackageName);
|
|
104
|
-
} else {
|
|
105
|
-
throw new RateAppError(`Unsupported platform: ${_reactNative.Platform.OS}`);
|
|
106
|
-
}
|
|
107
|
-
try {
|
|
108
|
-
const canOpenURL = await _reactNative.Linking.canOpenURL(url);
|
|
109
|
-
if (canOpenURL) {
|
|
110
|
-
await _reactNative.Linking.openURL(url);
|
|
111
|
-
}
|
|
112
|
-
return canOpenURL;
|
|
113
|
-
} catch (error) {
|
|
114
|
-
throw new RateAppError(`Failed to open store for review: ${error}`);
|
|
115
|
-
}
|
|
116
|
-
},
|
|
117
|
-
/**
|
|
118
|
-
* Gets the URL for the Android market.
|
|
119
|
-
* @param androidMarket The market where the app's store listing should be opened on Android.
|
|
120
|
-
* @param androidPackageName The package name of the app to open the store listing for on Android.
|
|
121
|
-
* @returns The URL for the Android market.
|
|
122
|
-
*/
|
|
123
|
-
getAndroidMarketUrl(androidMarket, androidPackageName) {
|
|
124
|
-
const urlTemplate = _constants.ANDROID_MARKET_URLS[androidMarket];
|
|
125
|
-
if (!urlTemplate) {
|
|
126
|
-
throw new RateAppError(`Unsupported Android market: ${androidMarket}`);
|
|
127
|
-
}
|
|
128
|
-
return urlTemplate.replace("{packageName}", androidPackageName);
|
|
129
|
-
}
|
|
130
|
-
};
|
|
131
|
-
const {
|
|
132
|
-
requestReview,
|
|
133
|
-
openStoreForReview,
|
|
134
|
-
getAndroidMarketUrl
|
|
135
|
-
} = RNRateApp;
|
|
136
|
-
exports.getAndroidMarketUrl = getAndroidMarketUrl;
|
|
137
|
-
exports.openStoreForReview = openStoreForReview;
|
|
138
|
-
exports.requestReview = requestReview;
|
|
139
|
-
var _default = exports.default = RNRateApp;
|
|
140
|
-
//# sourceMappingURL=index.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"names":["_reactNative","require","_NativeRateApp","_interopRequireDefault","_constants","Object","keys","forEach","key","prototype","hasOwnProperty","call","_exportNames","exports","defineProperty","enumerable","get","_types","e","__esModule","default","RateAppError","Error","constructor","message","name","RNRateApp","requestReview","androidMarket","AndroidMarket","GOOGLE","androidPackageName","Platform","OS","SAMSUNG","RateApp","requestReviewGalaxyStore","HUAWEI","requestReviewAppGallery","error","openStoreForReview","iOSAppId","isIOS","ismacOS","isAndroid","url","IOS_REVIEW_URL","getAndroidMarketUrl","canOpenURL","Linking","openURL","urlTemplate","ANDROID_MARKET_URLS","replace","_default"],"sourceRoot":"../../src","sources":["index.tsx"],"mappings":"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","ignoreList":[]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"type":"commonjs"}
|
|
@@ -1,56 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
exports.default = void 0;
|
|
7
|
-
var _configPlugins = require("@expo/config-plugins");
|
|
8
|
-
/**
|
|
9
|
-
* Modifies the `Info.plist` file to add `LSApplicationQueriesSchemes`,
|
|
10
|
-
* allowing the app to open App Store links.
|
|
11
|
-
*
|
|
12
|
-
* @param {ConfigPlugin} config - The Expo configuration object.
|
|
13
|
-
* @returns {ConfigPlugin} - The modified Expo configuration.
|
|
14
|
-
*/
|
|
15
|
-
const withCustomInfoPlist = config => {
|
|
16
|
-
return (0, _configPlugins.withInfoPlist)(config, config => {
|
|
17
|
-
if (!config.modResults.LSApplicationQueriesSchemes) {
|
|
18
|
-
config.modResults.LSApplicationQueriesSchemes = [];
|
|
19
|
-
}
|
|
20
|
-
if (!config.modResults.LSApplicationQueriesSchemes.includes("itms-apps")) {
|
|
21
|
-
config.modResults.LSApplicationQueriesSchemes.push("itms-apps");
|
|
22
|
-
}
|
|
23
|
-
return config;
|
|
24
|
-
});
|
|
25
|
-
};
|
|
26
|
-
|
|
27
|
-
/**
|
|
28
|
-
* Adds the `StoreKit.framework` to the iOS Xcode project.
|
|
29
|
-
* This framework is required for in-app review prompts.
|
|
30
|
-
*
|
|
31
|
-
* @param {ConfigPlugin} config - The Expo configuration object.
|
|
32
|
-
* @returns {ConfigPlugin} - The modified Expo configuration.
|
|
33
|
-
*/
|
|
34
|
-
const withStoreKitFramework = config => {
|
|
35
|
-
return (0, _configPlugins.withXcodeProject)(config, config => {
|
|
36
|
-
config.modResults.addFramework("StoreKit.framework", {
|
|
37
|
-
required: true
|
|
38
|
-
});
|
|
39
|
-
return config;
|
|
40
|
-
});
|
|
41
|
-
};
|
|
42
|
-
|
|
43
|
-
/**
|
|
44
|
-
* Applies both `withCustomInfoPlist` and `withStoreKitFramework`
|
|
45
|
-
* to enable in-app rating functionality in a React Native app.
|
|
46
|
-
*
|
|
47
|
-
* @param {ConfigPlugin} config - The Expo configuration object.
|
|
48
|
-
* @returns {ConfigPlugin} - The modified Expo configuration.
|
|
49
|
-
*/
|
|
50
|
-
const withReactNativeRateApp = config => {
|
|
51
|
-
const configWithInfoPlist = withCustomInfoPlist(config);
|
|
52
|
-
const configWithStoreKit = withStoreKitFramework(configWithInfoPlist);
|
|
53
|
-
return configWithStoreKit;
|
|
54
|
-
};
|
|
55
|
-
var _default = exports.default = withReactNativeRateApp;
|
|
56
|
-
//# sourceMappingURL=withReactNativeRateApp.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"names":["_configPlugins","require","withCustomInfoPlist","config","withInfoPlist","modResults","LSApplicationQueriesSchemes","includes","push","withStoreKitFramework","withXcodeProject","addFramework","required","withReactNativeRateApp","configWithInfoPlist","configWithStoreKit","_default","exports","default"],"sourceRoot":"../../../src","sources":["plugin/withReactNativeRateApp.ts"],"mappings":";;;;;;AAAA,IAAAA,cAAA,GAAAC,OAAA;AAMA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAMC,mBAAiC,GAAIC,MAAM,IAAK;EACpD,OAAO,IAAAC,4BAAa,EAACD,MAAM,EAAGA,MAAM,IAAK;IACvC,IAAI,CAACA,MAAM,CAACE,UAAU,CAACC,2BAA2B,EAAE;MAClDH,MAAM,CAACE,UAAU,CAACC,2BAA2B,GAAG,EAAE;IACpD;IACA,IAAI,CAACH,MAAM,CAACE,UAAU,CAACC,2BAA2B,CAACC,QAAQ,CAAC,WAAW,CAAC,EAAE;MACxEJ,MAAM,CAACE,UAAU,CAACC,2BAA2B,CAACE,IAAI,CAAC,WAAW,CAAC;IACjE;IACA,OAAOL,MAAM;EACf,CAAC,CAAC;AACJ,CAAC;;AAED;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAMM,qBAAmC,GAAIN,MAAM,IAAK;EACtD,OAAO,IAAAO,+BAAgB,EAACP,MAAM,EAAGA,MAAM,IAAK;IAC1CA,MAAM,CAACE,UAAU,CAACM,YAAY,CAAC,oBAAoB,EAAE;MAAEC,QAAQ,EAAE;IAAK,CAAC,CAAC;IACxE,OAAOT,MAAM;EACf,CAAC,CAAC;AACJ,CAAC;;AAED;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAMU,sBAAoC,GAAIV,MAAM,IAAK;EACvD,MAAMW,mBAAmB,GAAGZ,mBAAmB,CAACC,MAAM,CAAC;EACvD,MAAMY,kBAAkB,GAAGN,qBAAqB,CAACK,mBAAmB,CAAC;EACrE,OAAOC,kBAAkB;AAC3B,CAAC;AAAC,IAAAC,QAAA,GAAAC,OAAA,CAAAC,OAAA,GAEaL,sBAAsB","ignoreList":[]}
|
package/lib/commonjs/types.js
DELETED
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
exports.AndroidMarket = void 0;
|
|
7
|
-
let AndroidMarket = exports.AndroidMarket = /*#__PURE__*/function (AndroidMarket) {
|
|
8
|
-
AndroidMarket["GOOGLE"] = "google";
|
|
9
|
-
AndroidMarket["AMAZON"] = "amazon";
|
|
10
|
-
AndroidMarket["SAMSUNG"] = "samsung";
|
|
11
|
-
AndroidMarket["HUAWEI"] = "huawei";
|
|
12
|
-
return AndroidMarket;
|
|
13
|
-
}({});
|
|
14
|
-
//# sourceMappingURL=types.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"names":["AndroidMarket","exports"],"sourceRoot":"../../src","sources":["types.ts"],"mappings":";;;;;;IAAYA,aAAa,GAAAC,OAAA,CAAAD,aAAA,0BAAbA,aAAa;EAAbA,aAAa;EAAbA,aAAa;EAAbA,aAAa;EAAbA,aAAa;EAAA,OAAbA,aAAa;AAAA","ignoreList":[]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"names":["TurboModuleRegistry","getEnforcing"],"sourceRoot":"../../../src","sources":["codegenSpec/NativeRateApp.ts"],"mappings":";;AACA,SAASA,mBAAmB,QAAQ,cAAc;AAQlD,eAAeA,mBAAmB,CAACC,YAAY,CAAO,SAAS,CAAC","ignoreList":[]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"NativeRateApp.d.ts","sourceRoot":"","sources":["../../../src/codegenSpec/NativeRateApp.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;AAGhD,MAAM,WAAW,IAAK,SAAQ,WAAW;IACvC,aAAa,IAAI,OAAO,CAAC,OAAO,CAAC,CAAC;IAClC,uBAAuB,IAAI,OAAO,CAAC,OAAO,CAAC,CAAC;IAC5C,wBAAwB,CAAC,kBAAkB,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC,CAAC;CACxE;;AAED,wBAAiE"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"constants.d.ts","sourceRoot":"","sources":["../../src/constants.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,SAAS,CAAC;AAExC,eAAO,MAAM,cAAc,sCAAsC,CAAC;AAElE,eAAO,MAAM,mBAAmB,EAAE,MAAM,CAAC,aAAa,EAAE,MAAM,CAK7D,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.tsx"],"names":[],"mappings":"AAGA,OAAO,EACL,aAAa,EACb,KAAK,uBAAuB,EAC5B,KAAK,kBAAkB,EACxB,MAAM,SAAS,CAAC;AAYjB,QAAA,MAAM,SAAS;IACb;;;;;;;OAOG;2DAIA,kBAAkB,GAAQ,OAAO,CAAC,OAAO,CAAC;IAuB7C;;;;OAIG;yEAKA,uBAAuB,GAAG,OAAO,CAAC,OAAO,CAAC;IA+B7C;;;;;OAKG;uCAEc,aAAa,sBACR,MAAM,GACzB,MAAM;CAOV,CAAC;AAEF,cAAc,aAAa,CAAC;AAC5B,cAAc,SAAS,CAAC;AACxB,eAAO,MAAQ,aAAa,4CAnFvB,kBAAkB,KAAQ,OAAO,CAAC,OAAO,CAAC,EAmFjB,kBAAkB,qDAnD3C,uBAAuB,KAAG,OAAO,CAAC,OAAO,CAAC,EAmDG,mBAAmB,kBAblD,aAAa,sBACR,MAAM,KACzB,MAYM,CAAC;AACZ,eAAe,SAAS,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"withReactNativeRateApp.d.ts","sourceRoot":"","sources":["../../../src/plugin/withReactNativeRateApp.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,YAAY,EAGlB,MAAM,sBAAsB,CAAC;AAmC9B;;;;;;GAMG;AACH,QAAA,MAAM,sBAAsB,EAAE,YAI7B,CAAC;AAEF,eAAe,sBAAsB,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/types.ts"],"names":[],"mappings":"AAAA,oBAAY,aAAa;IACvB,MAAM,WAAW;IACjB,MAAM,WAAW;IACjB,OAAO,YAAY;IACnB,MAAM,WAAW;CAClB;AAED,MAAM,WAAW,uBAAuB;IACtC;;OAEG;IACH,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB;;OAEG;IACH,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAC5B;;;OAGG;IACH,aAAa,CAAC,EAAE,aAAa,CAAC;CAC/B;AAED,MAAM,WAAW,kBAAkB;IACjC;;;OAGG;IACH,aAAa,CAAC,EAAE,OAAO,CAAC,aAAa,EAAE,aAAa,CAAC,MAAM,CAAC,CAAC;IAC7D;;OAEG;IACH,kBAAkB,CAAC,EAAE,MAAM,CAAC;CAC7B"}
|
|
File without changes
|