@umituz/react-native-subscription 2.27.73 → 2.27.75
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/package.json +1 -1
- package/src/domains/credits/core/Credits.ts +2 -2
- package/src/domains/credits/core/UserCreditsDocument.ts +1 -1
- package/src/domains/subscription/presentation/useFeatureGate.ts +5 -3
- package/src/domains/subscription/presentation/useSubscriptionSettingsConfig.ts +6 -6
- package/src/presentation/types/SubscriptionDetailTypes.ts +1 -1
- package/src/presentation/types/SubscriptionSettingsTypes.ts +1 -1
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@umituz/react-native-subscription",
|
|
3
|
-
"version": "2.27.
|
|
3
|
+
"version": "2.27.75",
|
|
4
4
|
"description": "Complete subscription management with RevenueCat, paywall UI, and credits system for React Native apps",
|
|
5
5
|
"main": "./src/index.ts",
|
|
6
6
|
"types": "./src/index.ts",
|
|
@@ -5,7 +5,7 @@
|
|
|
5
5
|
* Designed to be used across hundreds of apps with configurable limits.
|
|
6
6
|
*/
|
|
7
7
|
|
|
8
|
-
import type { SubscriptionPackageType } from "
|
|
8
|
+
import type { SubscriptionPackageType } from "../../../utils/packageTypeDetector";
|
|
9
9
|
import type {
|
|
10
10
|
SubscriptionStatusType,
|
|
11
11
|
PeriodType,
|
|
@@ -13,7 +13,7 @@ import type {
|
|
|
13
13
|
Platform,
|
|
14
14
|
PurchaseSource,
|
|
15
15
|
PurchaseType
|
|
16
|
-
} from "
|
|
16
|
+
} from "../../subscription/core/SubscriptionConstants";
|
|
17
17
|
|
|
18
18
|
export type {
|
|
19
19
|
SubscriptionStatusType,
|
|
@@ -113,20 +113,22 @@ export function useFeatureGate(params: UseFeatureGateParams): UseFeatureGateResu
|
|
|
113
113
|
useEffect(() => {
|
|
114
114
|
const prevBalance = prevCreditBalanceRef.current ?? 0;
|
|
115
115
|
const creditsIncreased = creditBalance > prevBalance;
|
|
116
|
+
const subscriptionAcquired = hasSubscription && !hasSubscriptionRef.current;
|
|
116
117
|
|
|
117
|
-
if (isWaitingForPurchaseRef.current && creditsIncreased && pendingActionRef.current) {
|
|
118
|
+
if (isWaitingForPurchaseRef.current && (creditsIncreased || subscriptionAcquired) && pendingActionRef.current) {
|
|
118
119
|
const action = pendingActionRef.current;
|
|
119
120
|
pendingActionRef.current = null;
|
|
120
121
|
isWaitingForPurchaseRef.current = false;
|
|
121
122
|
|
|
122
123
|
if (typeof __DEV__ !== "undefined" && __DEV__) {
|
|
123
|
-
console.log("[useFeatureGate]
|
|
124
|
+
console.log("[useFeatureGate] Access acquired (credits or subscription), executing pending action");
|
|
124
125
|
}
|
|
125
126
|
action();
|
|
126
127
|
}
|
|
127
128
|
|
|
128
129
|
prevCreditBalanceRef.current = creditBalance;
|
|
129
|
-
|
|
130
|
+
hasSubscriptionRef.current = hasSubscription;
|
|
131
|
+
}, [creditBalance, hasSubscription]);
|
|
130
132
|
|
|
131
133
|
const requireFeature = useCallback(
|
|
132
134
|
(action: () => void | Promise<void>) => {
|
|
@@ -4,24 +4,24 @@
|
|
|
4
4
|
*/
|
|
5
5
|
|
|
6
6
|
import { useMemo, useCallback } from "react";
|
|
7
|
-
import { useCredits } from "
|
|
7
|
+
import { useCredits } from "../../credits/presentation/useCredits";
|
|
8
8
|
import { usePaywallVisibility } from "./usePaywallVisibility";
|
|
9
|
-
import { calculateDaysRemaining } from "
|
|
10
|
-
import { formatDate } from "
|
|
9
|
+
import { calculateDaysRemaining } from "../core/SubscriptionStatus";
|
|
10
|
+
import { formatDate } from "../../../presentation/utils/subscriptionDateUtils";
|
|
11
11
|
import { useCreditsArray, getSubscriptionStatusType } from "./useSubscriptionSettingsConfig.utils";
|
|
12
|
-
import { getCreditsConfig } from "../../infrastructure/
|
|
12
|
+
import { getCreditsConfig } from "../../credits/infrastructure/CreditsRepositoryProvider";
|
|
13
13
|
import type {
|
|
14
14
|
SubscriptionSettingsConfig,
|
|
15
15
|
SubscriptionStatusType,
|
|
16
16
|
UseSubscriptionSettingsConfigParams,
|
|
17
|
-
} from "
|
|
17
|
+
} from "../../../presentation/types/SubscriptionSettingsTypes";
|
|
18
18
|
|
|
19
19
|
export type {
|
|
20
20
|
SubscriptionSettingsConfig,
|
|
21
21
|
SubscriptionSettingsItemConfig,
|
|
22
22
|
SubscriptionSettingsTranslations,
|
|
23
23
|
UseSubscriptionSettingsConfigParams,
|
|
24
|
-
} from "
|
|
24
|
+
} from "../../../presentation/types/SubscriptionSettingsTypes";
|
|
25
25
|
|
|
26
26
|
export const useSubscriptionSettingsConfig = (
|
|
27
27
|
params: Omit<UseSubscriptionSettingsConfigParams, 'userId'>
|
|
@@ -3,7 +3,7 @@
|
|
|
3
3
|
* Type definitions for subscription detail screen and components
|
|
4
4
|
*/
|
|
5
5
|
|
|
6
|
-
import type { SubscriptionStatusType } from "../../
|
|
6
|
+
import type { SubscriptionStatusType } from "../../domains/subscription/core/SubscriptionStatus";
|
|
7
7
|
import type { CreditInfo } from "../components/details/PremiumDetailsCardTypes";
|
|
8
8
|
|
|
9
9
|
export type { SubscriptionStatusType, CreditInfo };
|
|
@@ -3,7 +3,7 @@
|
|
|
3
3
|
* Type definitions for subscription settings configuration
|
|
4
4
|
*/
|
|
5
5
|
|
|
6
|
-
import type { SubscriptionStatusType } from "../../
|
|
6
|
+
import type { SubscriptionStatusType } from "../../domains/subscription/core/SubscriptionConstants";
|
|
7
7
|
import type {
|
|
8
8
|
SubscriptionDetailConfig,
|
|
9
9
|
UpgradePromptConfig,
|