@umituz/react-native-subscription 2.27.72 → 2.27.74

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 CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@umituz/react-native-subscription",
3
- "version": "2.27.72",
3
+ "version": "2.27.74",
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 "../../utils/packageTypeDetector";
8
+ import type { SubscriptionPackageType } from "../../../utils/packageTypeDetector";
9
9
  import type {
10
10
  SubscriptionStatusType,
11
11
  PeriodType,
@@ -13,7 +13,16 @@ import type {
13
13
  Platform,
14
14
  PurchaseSource,
15
15
  PurchaseType
16
- } from "./SubscriptionConstants";
16
+ } from "../../subscription/core/SubscriptionConstants";
17
+
18
+ export type {
19
+ SubscriptionStatusType,
20
+ PeriodType,
21
+ PackageType,
22
+ Platform,
23
+ PurchaseSource,
24
+ PurchaseType
25
+ };
17
26
 
18
27
  export type CreditType = "text" | "image";
19
28
 
@@ -91,7 +100,3 @@ export interface DeductCreditsResult {
91
100
  };
92
101
  }
93
102
 
94
- export const DEFAULT_CREDITS_CONFIG: CreditsConfig = {
95
- collectionName: "user_credits",
96
- creditLimit: 0,
97
- };
@@ -5,7 +5,7 @@ import type {
5
5
  PeriodType,
6
6
  PackageType,
7
7
  Platform
8
- } from "../../domain/entities/SubscriptionConstants";
8
+ } from "../../subscription/core/SubscriptionConstants";
9
9
 
10
10
  export type {
11
11
  PurchaseSource,
@@ -4,23 +4,19 @@
4
4
  * Replaces Context API with a simpler, testable approach
5
5
  */
6
6
 
7
- import type { CreditsConfig } from "../../domain/entities/Credits";
8
- import { DEFAULT_CREDITS_CONFIG } from "../../domain/entities/Credits";
7
+ import type { CreditsConfig } from "../core/Credits";
9
8
  import type { CreditsRepository } from "./CreditsRepository";
10
9
  import { createCreditsRepository } from "./CreditsRepository";
11
10
 
12
11
  let globalRepository: CreditsRepository | null = null;
13
- let globalConfig: CreditsConfig = DEFAULT_CREDITS_CONFIG;
12
+ let globalConfig: CreditsConfig | null = null;
14
13
 
15
14
  /**
16
15
  * Configure credits repository for the application
17
16
  * Must be called once during app initialization
18
17
  */
19
- export function configureCreditsRepository(config: Partial<CreditsConfig>): void {
20
- globalConfig = {
21
- ...DEFAULT_CREDITS_CONFIG,
22
- ...config,
23
- };
18
+ export function configureCreditsRepository(config: CreditsConfig): void {
19
+ globalConfig = config;
24
20
  globalRepository = createCreditsRepository(globalConfig);
25
21
  }
26
22
 
@@ -48,13 +44,11 @@ export function getCreditsRepository(): CreditsRepository {
48
44
  * Get the current credits configuration
49
45
  */
50
46
  export function getCreditsConfig(): CreditsConfig {
47
+ if (!globalConfig) {
48
+ throw new Error(
49
+ "CreditsConfig not configured. Call configureCreditsRepository() first."
50
+ );
51
+ }
51
52
  return globalConfig;
52
53
  }
53
54
 
54
- /**
55
- * Reset repository (for testing)
56
- */
57
- export function resetCreditsRepository(): void {
58
- globalRepository = null;
59
- globalConfig = DEFAULT_CREDITS_CONFIG;
60
- }
@@ -5,8 +5,8 @@
5
5
 
6
6
  import { useCallback } from "react";
7
7
  import { useMutation, useQueryClient } from "@umituz/react-native-design-system";
8
- import type { UserCredits } from "../../domain/entities/Credits";
9
- import { getCreditsRepository } from "../../infrastructure/repositories/CreditsRepositoryProvider";
8
+ import type { UserCredits } from "../core/Credits";
9
+ import { getCreditsRepository } from "../infrastructure/CreditsRepositoryProvider";
10
10
  import { creditsQueryKeys } from "./useCredits";
11
11
 
12
12
  import { timezoneService } from "@umituz/react-native-design-system";
@@ -5,7 +5,7 @@
5
5
 
6
6
  import type { ImageSourcePropType } from "react-native";
7
7
  import type { PaywallTranslations, PaywallLegalUrls, SubscriptionFeature } from "../entities/types";
8
- import type { PurchaseSource, PackageAllocationMap } from "../../../domain/entities/Credits";
8
+ import type { PurchaseSource, PackageAllocationMap } from "../../credits/core/Credits";
9
9
 
10
10
  /**
11
11
  * Trial display configuration
@@ -2,7 +2,7 @@ import { useCallback } from "react";
2
2
  import type { PurchasesPackage } from "react-native-purchases";
3
3
  import { useRestorePurchase } from "../../../revenuecat/presentation/hooks/useRestorePurchase";
4
4
  import { useAuthAwarePurchase } from "../../../presentation/hooks/useAuthAwarePurchase";
5
- import type { PurchaseSource } from "../../../domain/entities/Credits";
5
+ import type { PurchaseSource } from "../../credits/core/Credits";
6
6
 
7
7
  interface UsePaywallActionsProps {
8
8
  source?: PurchaseSource;
@@ -4,9 +4,9 @@
4
4
  */
5
5
 
6
6
  import type { CustomerInfo } from "react-native-purchases";
7
- import type { RevenueCatConfig } from "../../domain/value-objects/RevenueCatConfig";
8
- import type { PurchaseSource } from "../../../domain/entities/Credits";
9
- import { getPremiumEntitlement } from "../../domain/types/RevenueCatTypes";
7
+ import type { RevenueCatConfig } from "../../core/RevenueCatConfig";
8
+ import type { PurchaseSource } from "../../../credits/core/Credits";
9
+ import { getPremiumEntitlement } from "../../core/RevenueCatTypes";
10
10
 
11
11
  export async function syncPremiumStatus(
12
12
  config: RevenueCatConfig,
@@ -6,7 +6,7 @@
6
6
  import { useCallback } from "react";
7
7
  import type { PurchasesPackage } from "react-native-purchases";
8
8
  import { usePremium } from "./usePremium";
9
- import type { PurchaseSource } from "../../domain/entities/Credits";
9
+ import type { PurchaseSource } from "../../credits/core/Credits";
10
10
 
11
11
  export interface PurchaseAuthProvider {
12
12
  isAuthenticated: () => boolean;
@@ -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] Credits increased, executing pending action");
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
- }, [creditBalance]);
130
+ hasSubscriptionRef.current = hasSubscription;
131
+ }, [creditBalance, hasSubscription]);
130
132
 
131
133
  const requireFeature = useCallback(
132
134
  (action: () => void | Promise<void>) => {
@@ -5,7 +5,7 @@
5
5
  */
6
6
 
7
7
  import { useCallback, useSyncExternalStore } from "react";
8
- import type { PurchaseSource } from "../../domain/entities/Credits";
8
+ import type { PurchaseSource } from "../../credits/core/Credits";
9
9
 
10
10
  type Listener = () => void;
11
11
 
@@ -4,24 +4,24 @@
4
4
  */
5
5
 
6
6
  import { useMemo, useCallback } from "react";
7
- import { useCredits } from "./useCredits";
7
+ import { useCredits } from "../../credits/presentation/useCredits";
8
8
  import { usePaywallVisibility } from "./usePaywallVisibility";
9
- import { calculateDaysRemaining } from "../../domain/entities/SubscriptionStatus";
10
- import { formatDate } from "../utils/subscriptionDateUtils";
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/repositories/CreditsRepositoryProvider";
12
+ import { getCreditsConfig } from "../../credits/infrastructure/CreditsRepositoryProvider";
13
13
  import type {
14
14
  SubscriptionSettingsConfig,
15
15
  SubscriptionStatusType,
16
16
  UseSubscriptionSettingsConfigParams,
17
- } from "../types/SubscriptionSettingsTypes";
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 "../types/SubscriptionSettingsTypes";
24
+ } from "../../../presentation/types/SubscriptionSettingsTypes";
25
25
 
26
26
  export const useSubscriptionSettingsConfig = (
27
27
  params: Omit<UseSubscriptionSettingsConfigParams, 'userId'>
@@ -4,8 +4,8 @@
4
4
  */
5
5
 
6
6
  import { useMemo } from "react";
7
- import type { UserCredits } from "../../domain/entities/Credits";
8
- import { resolveSubscriptionStatus, type PeriodType, type SubscriptionStatusType } from "../../domain/entities/SubscriptionStatus";
7
+ import type { UserCredits } from "../../credits/core/Credits";
8
+ import { resolveSubscriptionStatus, type PeriodType, type SubscriptionStatusType } from "../core/SubscriptionStatus";
9
9
  import type { SubscriptionSettingsTranslations } from "../types/SubscriptionSettingsTypes";
10
10
 
11
11
  export interface CreditsInfo {
package/src/index.ts CHANGED
@@ -68,7 +68,6 @@ export type {
68
68
  DeductCreditsResult,
69
69
  } from "./domains/credits/core/Credits";
70
70
 
71
- export { DEFAULT_CREDITS_CONFIG } from "./domains/credits/core/Credits";
72
71
 
73
72
  // Utils
74
73
  export * from "./utils";
@@ -3,7 +3,7 @@
3
3
  * Type definitions for subscription detail screen and components
4
4
  */
5
5
 
6
- import type { SubscriptionStatusType } from "../../domain/entities/SubscriptionStatus";
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 "../../domain/entities/SubscriptionStatus";
6
+ import type { SubscriptionStatusType } from "../../domains/subscription/core/SubscriptionConstants";
7
7
  import type {
8
8
  SubscriptionDetailConfig,
9
9
  UpgradePromptConfig,
@@ -1,7 +1,7 @@
1
1
  import { timezoneService } from "@umituz/react-native-design-system";
2
- import type { ISubscriptionRepository } from "../../application/ports/ISubscriptionRepository";
3
- import type { SubscriptionStatus } from "../../domain/entities/SubscriptionStatus";
4
- import { SubscriptionRepositoryError } from "../../domain/errors/SubscriptionError";
2
+ import type { ISubscriptionRepository } from "../application/ports/ISubscriptionRepository";
3
+ import type { SubscriptionStatus } from "../../domains/subscription/core/SubscriptionStatus";
4
+ import { SubscriptionRepositoryError } from "../utils/SubscriptionError";
5
5
 
6
6
  export interface ActivationHandlerConfig {
7
7
  repository: ISubscriptionRepository;
@@ -2,7 +2,7 @@
2
2
  * ISubscriptionRepository Interface
3
3
  */
4
4
 
5
- import { SubscriptionStatus } from '../../domain/entities/SubscriptionStatus';
5
+ import { SubscriptionStatus } from '../../../domains/subscription/core/SubscriptionStatus';
6
6
 
7
7
  export interface ISubscriptionRepository {
8
8
  getSubscriptionStatus(userId: string): Promise<SubscriptionStatus | null>;
@@ -3,7 +3,7 @@
3
3
  * Defines the contract for subscription service operations
4
4
  */
5
5
 
6
- import type { SubscriptionStatus } from '../../domain/entities/SubscriptionStatus';
6
+ import type { SubscriptionStatus } from '../../../domains/subscription/core/SubscriptionStatus';
7
7
 
8
8
  export interface ISubscriptionService {
9
9
  /**
@@ -2,8 +2,8 @@
2
2
  * Subscription Config Value Object
3
3
  */
4
4
 
5
- import { ISubscriptionRepository } from "../../application/ports/ISubscriptionRepository";
6
- import { SubscriptionStatus } from "../entities/SubscriptionStatus";
5
+ import { ISubscriptionRepository } from "../application/ports/ISubscriptionRepository";
6
+ import { SubscriptionStatus } from "../../domains/subscription/core/SubscriptionStatus";
7
7
 
8
8
  export interface SubscriptionConfig {
9
9
  repository: ISubscriptionRepository;
@@ -14,7 +14,7 @@
14
14
  * });
15
15
  */
16
16
 
17
- import type { CreditsRepository } from "../infrastructure/repositories/CreditsRepository";
17
+ import type { CreditsRepository } from "../domains/credits/infrastructure/CreditsRepository";
18
18
  import { createCreditChecker } from "./creditChecker";
19
19
 
20
20
  export interface AICreditHelpersConfig {
@@ -5,7 +5,7 @@
5
5
  * Generic - works with any generation type mapping.
6
6
  */
7
7
 
8
- import type { CreditsRepository } from "../infrastructure/repositories/CreditsRepository";
8
+ import type { CreditsRepository } from "../domains/credits/infrastructure/CreditsRepository";
9
9
 
10
10
  export interface CreditCheckResult {
11
11
  success: boolean;
@@ -1,5 +1,5 @@
1
1
  import { detectPackageType, type SubscriptionPackageType } from "./packageTypeDetector";
2
- import type { PackageAllocationMap } from "../domain/entities/Credits";
2
+ import type { PackageAllocationMap } from "../domains/credits/core/Credits";
3
3
 
4
4
  /**
5
5
  * Get credit allocation for a package type from provided allocations map