@cedros/pay-react 1.1.24 → 1.1.25

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.
Files changed (127) hide show
  1. package/dist/{AISettingsSection-IXS1Wt_1.js → AISettingsSection-BvSSiK2G.js} +1 -1
  2. package/dist/{AISettingsSection-Dw0ZlxMf.mjs → AISettingsSection-Dg1kazTI.mjs} +2 -2
  3. package/dist/{AutosaveIndicator-BJsg_kFZ.mjs → AutosaveIndicator-BHfkV59p.mjs} +1 -1
  4. package/dist/{AutosaveIndicator-CY_YHM1D.js → AutosaveIndicator-D2l7U8R1.js} +1 -1
  5. package/dist/CedrosContext-C2RjHLaQ.js +6 -0
  6. package/dist/{CedrosContext-DQUbL8yP.mjs → CedrosContext-CY6zvjvJ.mjs} +768 -617
  7. package/dist/ComplianceSection-BSE2f3Wo.mjs +534 -0
  8. package/dist/ComplianceSection-D6ETKG6b.js +1 -0
  9. package/dist/{CryptoButton-D1BCZBk4.mjs → CryptoButton-BV9owVe2.mjs} +2 -2
  10. package/dist/{CryptoButton-C1AAOOfj.js → CryptoButton-DpiCnyXE.js} +1 -1
  11. package/dist/{FAQSection-BmgmzDN5.js → FAQSection-6nGI0FK9.js} +1 -1
  12. package/dist/{FAQSection-C78MnK4k.mjs → FAQSection-uZG5V3pJ.mjs} +1 -1
  13. package/dist/{MessagingSection-CWLZcg11.js → MessagingSection-DrXb578q.js} +1 -1
  14. package/dist/{MessagingSection-De3t8bSI.mjs → MessagingSection-M0lj5yo4.mjs} +2 -2
  15. package/dist/{OrdersSection-_xKVzjSZ.mjs → OrdersSection-DteItv_O.mjs} +6 -6
  16. package/dist/{OrdersSection-BKOxsZw0.js → OrdersSection-_-rIw6XW.js} +1 -1
  17. package/dist/{PaymentSettingsSection-KjU_dN_d.mjs → PaymentSettingsSection-CdtdLFTg.mjs} +1 -1
  18. package/dist/{PaymentSettingsSection-BTEn9Dxb.js → PaymentSettingsSection-enTbUI95.js} +1 -1
  19. package/dist/SettingsSection-DUTEd6uV.js +1 -0
  20. package/dist/{SettingsSection-8QHZB59k.mjs → SettingsSection-mcT4LEhO.mjs} +19 -13
  21. package/dist/{SingleCategorySettings--LK0TZW0.mjs → SingleCategorySettings-BvHBVfSe.mjs} +4 -4
  22. package/dist/{SingleCategorySettings-CRXTMTo5.js → SingleCategorySettings-D2LVM5mn.js} +1 -1
  23. package/dist/{StorefrontSection-CeCpr8hn.mjs → StorefrontSection-BqQ36JIS.mjs} +2 -2
  24. package/dist/{StorefrontSection-C9DzCmOf.js → StorefrontSection-Du7hV2Gc.js} +1 -1
  25. package/dist/{SubscriptionsSection-C2xk8ApF.mjs → SubscriptionsSection-BYiCBwKZ.mjs} +7 -7
  26. package/dist/{SubscriptionsSection-Dn5SY6S_.js → SubscriptionsSection-C4BRN1dP.js} +1 -1
  27. package/dist/Token22Section-0c22NM5G.js +1 -0
  28. package/dist/Token22Section-BHvOhz5d.mjs +2260 -0
  29. package/dist/{WalletManager-Bwk3rgr1.js → WalletManager-B3UdQ5pQ.js} +1 -1
  30. package/dist/{WalletManager-CXvQ0Zu9.mjs → WalletManager-BIwH8Dw_.mjs} +1 -1
  31. package/dist/{configApi-Ch0Rr7TD.mjs → configApi-6XhAJGKX.mjs} +31 -0
  32. package/dist/{configApi-CxEbCAgG.js → configApi-DkduMQg1.js} +1 -1
  33. package/dist/crypto-only.js +1 -1
  34. package/dist/crypto-only.mjs +85 -83
  35. package/dist/{index-BHF82XBB.mjs → index-BkDimQDF.mjs} +7987 -7322
  36. package/dist/index-C7MWL6O8.js +84 -0
  37. package/dist/index.js +1 -1
  38. package/dist/index.mjs +42 -40
  39. package/dist/{sections-8e5Y3ukY.js → sections-5jO2aHAo.js} +1 -1
  40. package/dist/{sections-C1rb9YRh.mjs → sections-By4H1baL.mjs} +2 -2
  41. package/dist/src/admin/plugin.d.ts.map +1 -1
  42. package/dist/src/components/ComplianceGatePage.d.ts +38 -0
  43. package/dist/src/components/ComplianceGatePage.d.ts.map +1 -0
  44. package/dist/src/components/SubscribeButton.d.ts +1 -5
  45. package/dist/src/components/SubscribeButton.d.ts.map +1 -1
  46. package/dist/src/components/admin/AdminAuthManager.d.ts +7 -3
  47. package/dist/src/components/admin/AdminAuthManager.d.ts.map +1 -1
  48. package/dist/src/components/admin/AssetClassesTab.d.ts.map +1 -1
  49. package/dist/src/components/admin/CedrosPayAdminDashboard.d.ts +1 -1
  50. package/dist/src/components/admin/CedrosPayAdminDashboard.d.ts.map +1 -1
  51. package/dist/src/components/admin/ComplianceSanctionsApi.d.ts +3 -0
  52. package/dist/src/components/admin/ComplianceSanctionsApi.d.ts.map +1 -0
  53. package/dist/src/components/admin/ComplianceSection.d.ts +3 -0
  54. package/dist/src/components/admin/ComplianceSection.d.ts.map +1 -0
  55. package/dist/src/components/admin/GiftCardAnalytics.d.ts +3 -0
  56. package/dist/src/components/admin/GiftCardAnalytics.d.ts.map +1 -0
  57. package/dist/src/components/admin/GiftCardManager.d.ts +3 -0
  58. package/dist/src/components/admin/GiftCardManager.d.ts.map +1 -0
  59. package/dist/src/components/admin/LiquidityPoolTab.d.ts.map +1 -1
  60. package/dist/src/components/admin/PoolManagementView.d.ts +14 -0
  61. package/dist/src/components/admin/PoolManagementView.d.ts.map +1 -0
  62. package/dist/src/components/admin/ProductsSection.d.ts.map +1 -1
  63. package/dist/src/components/admin/RefundsSection.d.ts.map +1 -1
  64. package/dist/src/components/admin/SettingsSection.d.ts.map +1 -1
  65. package/dist/src/components/admin/Token22Section.d.ts.map +1 -1
  66. package/dist/src/components/admin/complianceTypes.d.ts +60 -0
  67. package/dist/src/components/admin/complianceTypes.d.ts.map +1 -0
  68. package/dist/src/components/admin/configApi.d.ts.map +1 -1
  69. package/dist/src/components/admin/icons.d.ts +1 -0
  70. package/dist/src/components/admin/icons.d.ts.map +1 -1
  71. package/dist/src/components/admin/useAdminAuth.d.ts +1 -1
  72. package/dist/src/components/admin/useAdminAuth.d.ts.map +1 -1
  73. package/dist/src/context/CedrosContext.d.ts.map +1 -1
  74. package/dist/src/ecommerce/components/catalog/TokenDisplay.d.ts +36 -0
  75. package/dist/src/ecommerce/components/catalog/TokenDisplay.d.ts.map +1 -0
  76. package/dist/src/ecommerce/components/checkout/CheckoutForm.d.ts.map +1 -1
  77. package/dist/src/ecommerce/components/checkout/SendAsGiftSection.d.ts +15 -0
  78. package/dist/src/ecommerce/components/checkout/SendAsGiftSection.d.ts.map +1 -0
  79. package/dist/src/ecommerce/components/gift-cards/GiftCardBalanceChecker.d.ts +19 -0
  80. package/dist/src/ecommerce/components/gift-cards/GiftCardBalanceChecker.d.ts.map +1 -0
  81. package/dist/src/ecommerce/components/orders/MyRedemptionsPage.d.ts +13 -0
  82. package/dist/src/ecommerce/components/orders/MyRedemptionsPage.d.ts.map +1 -0
  83. package/dist/src/ecommerce/components/orders/MyTokensPage.d.ts +15 -0
  84. package/dist/src/ecommerce/components/orders/MyTokensPage.d.ts.map +1 -0
  85. package/dist/src/ecommerce/components/orders/OrderDetails.d.ts.map +1 -1
  86. package/dist/src/ecommerce/hooks/useCartInventory.d.ts.map +1 -1
  87. package/dist/src/ecommerce/index.d.ts +10 -0
  88. package/dist/src/ecommerce/index.d.ts.map +1 -1
  89. package/dist/src/ecommerce/state/checkout/checkoutSchema.d.ts +3 -0
  90. package/dist/src/ecommerce/state/checkout/checkoutSchema.d.ts.map +1 -1
  91. package/dist/src/ecommerce/state/checkout/useCheckout.d.ts.map +1 -1
  92. package/dist/src/ecommerce/types.d.ts +6 -0
  93. package/dist/src/ecommerce/types.d.ts.map +1 -1
  94. package/dist/src/ecommerce/utils/cartItemMetadata.d.ts.map +1 -1
  95. package/dist/src/hooks/useComplianceCheck.d.ts +30 -0
  96. package/dist/src/hooks/useComplianceCheck.d.ts.map +1 -0
  97. package/dist/src/hooks/useSubscriptionManagement.d.ts.map +1 -1
  98. package/dist/src/index.d.ts +4 -0
  99. package/dist/src/index.d.ts.map +1 -1
  100. package/dist/src/managers/CreditsManager.d.ts.map +1 -1
  101. package/dist/src/managers/ManagerCache.d.ts +2 -2
  102. package/dist/src/managers/ManagerCache.d.ts.map +1 -1
  103. package/dist/src/managers/StripeManager.d.ts +7 -1
  104. package/dist/src/managers/StripeManager.d.ts.map +1 -1
  105. package/dist/src/managers/SubscriptionChangeManager.d.ts.map +1 -1
  106. package/dist/src/managers/SubscriptionManager.d.ts.map +1 -1
  107. package/dist/src/types/index.d.ts +14 -0
  108. package/dist/src/types/index.d.ts.map +1 -1
  109. package/dist/src/types/subscription.d.ts +21 -33
  110. package/dist/src/types/subscription.d.ts.map +1 -1
  111. package/dist/src/utils/exponentialBackoff.d.ts +22 -0
  112. package/dist/src/utils/exponentialBackoff.d.ts.map +1 -1
  113. package/dist/stripe-only.js +1 -1
  114. package/dist/stripe-only.mjs +2 -2
  115. package/dist/styles-BT4bhFey.js +1 -0
  116. package/dist/{styles-Ag-7ZvAB.mjs → styles-D4SQkuV3.mjs} +606 -609
  117. package/dist/testing/index.js +1 -1
  118. package/dist/testing/index.mjs +1 -1
  119. package/dist/{walletPool-C_0P4mTw.mjs → walletPool-DE-t1wSW.mjs} +1 -1
  120. package/dist/{walletPool-Ddv33tej.js → walletPool-IS7R3MR1.js} +1 -1
  121. package/package.json +1 -1
  122. package/dist/CedrosContext-7dwmEeUY.js +0 -6
  123. package/dist/SettingsSection-cKF0tLnS.js +0 -1
  124. package/dist/Token22Section-DUUl59dZ.js +0 -1
  125. package/dist/Token22Section-HygkDNtL.mjs +0 -1685
  126. package/dist/index-OaWkrl0G.js +0 -84
  127. package/dist/styles-21F1-oqx.js +0 -1
@@ -33,12 +33,20 @@ export interface RetryConfig {
33
33
  shouldRetry?: (error: Error, attempt: number) => boolean;
34
34
  /** Optional name for logging */
35
35
  name?: string;
36
+ /** Optional key used to coalesce identical in-flight operations */
37
+ inFlightKey?: string;
36
38
  }
37
39
  export interface RetryStats {
38
40
  attempts: number;
39
41
  totalDelay: number;
40
42
  lastError: Error | null;
41
43
  }
44
+ export declare class RetryableHttpError extends Error {
45
+ readonly httpStatus: number;
46
+ readonly retryAfterMs?: number;
47
+ constructor(message: string, httpStatus: number, retryAfterMs?: number);
48
+ static fromResponse(response: Response, message: string): RetryableHttpError;
49
+ }
42
50
  /**
43
51
  * Retry a function with exponential backoff
44
52
  *
@@ -100,5 +108,19 @@ export declare const RETRY_PRESETS: {
100
108
  readonly backoffFactor: 2;
101
109
  readonly maxDelayMs: 60000;
102
110
  };
111
+ /** At most one retry for writes with a real idempotency guarantee */
112
+ readonly IDEMPOTENT_WRITE: {
113
+ readonly maxRetries: 1;
114
+ readonly initialDelayMs: 1000;
115
+ readonly backoffFactor: 2;
116
+ readonly maxDelayMs: 10000;
117
+ };
118
+ /** Never automatically retry non-idempotent writes */
119
+ readonly WRITE_ONCE: {
120
+ readonly maxRetries: 0;
121
+ readonly initialDelayMs: 1000;
122
+ readonly backoffFactor: 2;
123
+ readonly maxDelayMs: 10000;
124
+ };
103
125
  };
104
126
  //# sourceMappingURL=exponentialBackoff.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"exponentialBackoff.d.ts","sourceRoot":"","sources":["../../../src/utils/exponentialBackoff.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;GAmBG;AAKH,MAAM,WAAW,WAAW;IAC1B,oDAAoD;IACpD,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,oDAAoD;IACpD,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,sCAAsC;IACtC,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,qDAAqD;IACrD,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,mEAAmE;IACnE,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,yDAAyD;IACzD,WAAW,CAAC,EAAE,CAAC,KAAK,EAAE,KAAK,EAAE,OAAO,EAAE,MAAM,KAAK,OAAO,CAAC;IACzD,gCAAgC;IAChC,IAAI,CAAC,EAAE,MAAM,CAAC;CACf;AAED,MAAM,WAAW,UAAU;IACzB,QAAQ,EAAE,MAAM,CAAC;IACjB,UAAU,EAAE,MAAM,CAAC;IACnB,SAAS,EAAE,KAAK,GAAG,IAAI,CAAC;CACzB;AA8DD;;;;;;;;;;;;;;;;;;;;;;;;;;;GA2BG;AACH,wBAAsB,gBAAgB,CAAC,CAAC,EACtC,EAAE,EAAE,MAAM,OAAO,CAAC,CAAC,CAAC,EACpB,MAAM,GAAE,WAAgB,GACvB,OAAO,CAAC,CAAC,CAAC,CAuDZ;AAED;;GAEG;AACH,eAAO,MAAM,aAAa;IACxB,6EAA6E;;;;;;;IAO7E,2DAA2D;;;;;;;IAO3D,4EAA4E;;;;;;;IAO5E,gEAAgE;;;;;;;CAOxD,CAAC"}
1
+ {"version":3,"file":"exponentialBackoff.d.ts","sourceRoot":"","sources":["../../../src/utils/exponentialBackoff.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;GAmBG;AAKH,MAAM,WAAW,WAAW;IAC1B,oDAAoD;IACpD,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,oDAAoD;IACpD,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,sCAAsC;IACtC,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,qDAAqD;IACrD,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,mEAAmE;IACnE,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,yDAAyD;IACzD,WAAW,CAAC,EAAE,CAAC,KAAK,EAAE,KAAK,EAAE,OAAO,EAAE,MAAM,KAAK,OAAO,CAAC;IACzD,gCAAgC;IAChC,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,mEAAmE;IACnE,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB;AAED,MAAM,WAAW,UAAU;IACzB,QAAQ,EAAE,MAAM,CAAC;IACjB,UAAU,EAAE,MAAM,CAAC;IACnB,SAAS,EAAE,KAAK,GAAG,IAAI,CAAC;CACzB;AAuBD,qBAAa,kBAAmB,SAAQ,KAAK;IAC3C,SAAgB,UAAU,EAAE,MAAM,CAAC;IACnC,SAAgB,YAAY,CAAC,EAAE,MAAM,CAAC;gBAE1B,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,EAAE,YAAY,CAAC,EAAE,MAAM;IAStE,MAAM,CAAC,YAAY,CAAC,QAAQ,EAAE,QAAQ,EAAE,OAAO,EAAE,MAAM,GAAG,kBAAkB;CAY7E;AAgFD;;;;;;;;;;;;;;;;;;;;;;;;;;;GA2BG;AACH,wBAAsB,gBAAgB,CAAC,CAAC,EACtC,EAAE,EAAE,MAAM,OAAO,CAAC,CAAC,CAAC,EACpB,MAAM,GAAE,WAAgB,GACvB,OAAO,CAAC,CAAC,CAAC,CA+EZ;AAED;;GAEG;AACH,eAAO,MAAM,aAAa;IACxB,6EAA6E;;;;;;;IAO7E,2DAA2D;;;;;;;IAO3D,4EAA4E;;;;;;;IAO5E,gEAAgE;;;;;;;IAOhE,qEAAqE;;;;;;;IAOrE,sDAAsD;;;;;;;CAO9C,CAAC"}
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./styles-21F1-oqx.js"),t=require("./CedrosContext-7dwmEeUY.js");exports.CEDROS_EVENTS=e.CEDROS_EVENTS;exports.CSP_PRESETS=e.CSP_PRESETS;exports.CedrosPay=e.CedrosPay;exports.CreditsButton=e.CreditsButton;exports.CreditsSubscribeButton=e.CreditsSubscribeButton;exports.PaymentMethodBadge=e.PaymentMethodBadge;exports.PaymentModal=e.PaymentModal;exports.ProductPrice=e.ProductPrice;exports.PurchaseButton=e.PurchaseButton;exports.RPC_PROVIDERS=e.RPC_PROVIDERS;exports.SECURITY_RECOMMENDATIONS=e.SECURITY_RECOMMENDATIONS;exports.StripeButton=e.StripeButton;exports.SubscribeButton=e.SubscribeButton;exports.SubscriptionManagementPanel=e.SubscriptionManagementPanel;exports.calculateDiscountPercentage=e.calculateDiscountPercentage;exports.createTranslator=e.createTranslator;exports.detectLocale=e.detectLocale;exports.emitPaymentError=e.emitPaymentError;exports.emitPaymentProcessing=e.emitPaymentProcessing;exports.emitPaymentStart=e.emitPaymentStart;exports.emitPaymentSuccess=e.emitPaymentSuccess;exports.emitWalletConnect=e.emitWalletConnect;exports.emitWalletConnected=e.emitWalletConnected;exports.emitWalletError=e.emitWalletError;exports.formatCSP=e.formatCSP;exports.formatCouponCodes=e.formatCouponCodes;exports.generateCSP=e.generateCSP;exports.generateCSPDirectives=e.generateCSPDirectives;exports.getAvailableLocales=e.getAvailableLocales;exports.getLocalizedError=e.getLocalizedError;exports.getUserErrorMessage=e.getUserErrorMessage;exports.isRetryableError=e.isRetryableError;exports.loadLocale=e.loadLocale;exports.logSecurityReport=e.logSecurityReport;exports.parseCouponCodes=e.parseCouponCodes;exports.stackCheckoutCoupons=e.stackCheckoutCoupons;exports.useCreditsPayment=e.useCreditsPayment;exports.useCreditsSubscription=e.useCreditsSubscription;exports.useLocalizedError=e.useLocalizedError;exports.usePaymentMode=e.usePaymentMode;exports.useStripeCheckout=e.useStripeCheckout;exports.useSubscription=e.useSubscription;exports.useSubscriptionManagement=e.useSubscriptionManagement;exports.useTranslation=e.useTranslation;exports.validateSecurity=e.validateSecurity;exports.CIRCUIT_BREAKER_PRESETS=t.CIRCUIT_BREAKER_PRESETS;exports.CedrosProvider=t.CedrosProvider;exports.CircuitBreakerOpenError=t.CircuitBreakerOpenError;exports.CircuitState=t.CircuitState;exports.ERROR_CATEGORIES=t.ERROR_CATEGORIES;exports.LogLevel=t.LogLevel;exports.Logger=t.Logger;exports.RATE_LIMITER_PRESETS=t.RATE_LIMITER_PRESETS;exports.RETRY_PRESETS=t.RETRY_PRESETS;exports.createCircuitBreaker=t.createCircuitBreaker;exports.createLogger=t.createLogger;exports.createRateLimiter=t.createRateLimiter;exports.getLogger=t.getLogger;exports.retryWithBackoff=t.retryWithBackoff;exports.useCedrosContext=t.useCedrosContext;exports.useCedrosTheme=t.useCedrosTheme;exports.validateConfig=t.validateConfig;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./styles-BT4bhFey.js"),t=require("./CedrosContext-C2RjHLaQ.js");exports.CEDROS_EVENTS=e.CEDROS_EVENTS;exports.CSP_PRESETS=e.CSP_PRESETS;exports.CedrosPay=e.CedrosPay;exports.CreditsButton=e.CreditsButton;exports.CreditsSubscribeButton=e.CreditsSubscribeButton;exports.PaymentMethodBadge=e.PaymentMethodBadge;exports.PaymentModal=e.PaymentModal;exports.ProductPrice=e.ProductPrice;exports.PurchaseButton=e.PurchaseButton;exports.RPC_PROVIDERS=e.RPC_PROVIDERS;exports.SECURITY_RECOMMENDATIONS=e.SECURITY_RECOMMENDATIONS;exports.StripeButton=e.StripeButton;exports.SubscribeButton=e.SubscribeButton;exports.SubscriptionManagementPanel=e.SubscriptionManagementPanel;exports.calculateDiscountPercentage=e.calculateDiscountPercentage;exports.createTranslator=e.createTranslator;exports.detectLocale=e.detectLocale;exports.emitPaymentError=e.emitPaymentError;exports.emitPaymentProcessing=e.emitPaymentProcessing;exports.emitPaymentStart=e.emitPaymentStart;exports.emitPaymentSuccess=e.emitPaymentSuccess;exports.emitWalletConnect=e.emitWalletConnect;exports.emitWalletConnected=e.emitWalletConnected;exports.emitWalletError=e.emitWalletError;exports.formatCSP=e.formatCSP;exports.formatCouponCodes=e.formatCouponCodes;exports.generateCSP=e.generateCSP;exports.generateCSPDirectives=e.generateCSPDirectives;exports.getAvailableLocales=e.getAvailableLocales;exports.getLocalizedError=e.getLocalizedError;exports.getUserErrorMessage=e.getUserErrorMessage;exports.isRetryableError=e.isRetryableError;exports.loadLocale=e.loadLocale;exports.logSecurityReport=e.logSecurityReport;exports.parseCouponCodes=e.parseCouponCodes;exports.stackCheckoutCoupons=e.stackCheckoutCoupons;exports.useCreditsPayment=e.useCreditsPayment;exports.useCreditsSubscription=e.useCreditsSubscription;exports.useLocalizedError=e.useLocalizedError;exports.usePaymentMode=e.usePaymentMode;exports.useStripeCheckout=e.useStripeCheckout;exports.useSubscription=e.useSubscription;exports.useSubscriptionManagement=e.useSubscriptionManagement;exports.useTranslation=e.useTranslation;exports.validateSecurity=e.validateSecurity;exports.CIRCUIT_BREAKER_PRESETS=t.CIRCUIT_BREAKER_PRESETS;exports.CedrosProvider=t.CedrosProvider;exports.CircuitBreakerOpenError=t.CircuitBreakerOpenError;exports.CircuitState=t.CircuitState;exports.ERROR_CATEGORIES=t.ERROR_CATEGORIES;exports.LogLevel=t.LogLevel;exports.Logger=t.Logger;exports.RATE_LIMITER_PRESETS=t.RATE_LIMITER_PRESETS;exports.RETRY_PRESETS=t.RETRY_PRESETS;exports.createCircuitBreaker=t.createCircuitBreaker;exports.createLogger=t.createLogger;exports.createRateLimiter=t.createRateLimiter;exports.getLogger=t.getLogger;exports.retryWithBackoff=t.retryWithBackoff;exports.useCedrosContext=t.useCedrosContext;exports.useCedrosTheme=t.useCedrosTheme;exports.validateConfig=t.validateConfig;
@@ -1,5 +1,5 @@
1
- import { C as s, a as t, b as r, c as o, d as i, P as n, e as c, f as u, g as C, R as E, S, h as P, i as l, j as R, k as d, l as m, m as g, n as p, o as T, p as y, q as L, r as b, s as B, t as M, u as _, v as f, w as I, x as h, y as v, z as O, A as k, B as A, D, E as x, F as N, G as W, H as z, I as U, J as j, K as G, L as K, M as V, N as Y, O as q, Q as w } from "./styles-Ag-7ZvAB.mjs";
2
- import { C as H, a as J, b as Q, c as X, E as Z, L as $, d as ee, R as ae, e as se, f as te, g as re, h as oe, i as ie, r as ne, u as ce, j as ue, v as Ce } from "./CedrosContext-DQUbL8yP.mjs";
1
+ import { C as s, a as t, b as r, c as o, d as i, P as n, e as c, f as u, g as C, R as E, S, h as P, i as l, j as R, k as d, l as m, m as g, n as p, o as T, p as y, q as L, r as b, s as B, t as M, u as _, v as f, w as I, x as h, y as v, z as O, A as k, B as A, D, E as x, F as N, G as W, H as z, I as U, J as j, K as G, L as K, M as V, N as Y, O as q, Q as w } from "./styles-D4SQkuV3.mjs";
2
+ import { C as H, a as J, b as Q, c as X, E as Z, L as $, d as ee, R as ae, e as se, f as te, g as re, h as oe, i as ie, r as ne, u as ce, j as ue, v as Ce } from "./CedrosContext-CY6zvjvJ.mjs";
3
3
  export {
4
4
  s as CEDROS_EVENTS,
5
5
  H as CIRCUIT_BREAKER_PRESETS,
@@ -0,0 +1 @@
1
+ "use strict";var $e=Object.create;var ye=Object.defineProperty;var Ae=Object.getOwnPropertyDescriptor;var ze=Object.getOwnPropertyNames;var Ue=Object.getPrototypeOf,Oe=Object.prototype.hasOwnProperty;var Fe=(e,t,r,s)=>{if(t&&typeof t=="object"||typeof t=="function")for(let n of ze(t))!Oe.call(e,n)&&n!==r&&ye(e,n,{get:()=>t[n],enumerable:!(s=Ae(t,n))||s.enumerable});return e};var We=(e,t,r)=>(r=e!=null?$e(Ue(e)):{},Fe(t||!e||!e.__esModule?ye(r,"default",{value:e,enumerable:!0}):r,e));const S=require("./CedrosContext-C2RjHLaQ.js"),i=require("react/jsx-runtime"),f=require("react");function He(e){return!e||!e.coupon_codes?[]:e.coupon_codes.split(",").map(t=>t.trim()).filter(t=>t.length>0)}function Ye(e,t=", "){return e.join(t)}function Qe(e,t){return e<=0?0:(e-t)/e*100}function Ve(e,t){if(!t||t.length===0)return e;let r=e,s=0;for(const n of t)if(n.discountType==="percentage"){const u=1-n.discountValue/100;r=r*u}else n.discountType==="fixed"&&(s+=n.discountValue);return r=r-s,r<0&&(r=0),Math.ceil(r*100)/100}function Ce(e){const t=Number(e);if(!Number.isFinite(t)||t<=0)return 1;const r=Math.floor(t);return r>0?r:1}function ie(e){return e.map(t=>({resource:t.resource,quantity:Ce(t.quantity),variantId:t.variantId,metadata:t.metadata}))}function ee(e){return e.reduce((t,r)=>t+Ce(r.quantity),0)}function Ge(e){return!!(e&&e.length>0&&(e.length>1||e.length===1&&(e[0].quantity??1)>1))}const G=new Map,le=new Map,H=new Map,ae=1e3,xe=200,ue=2e3;function Ke(e){const t=H.get(e);return t?Date.now()<t?!0:(H.delete(e),!1):!1}function Xe(e,t=xe){const r=Date.now()+t;if(H.set(e,r),H.size>ae){const s=Array.from(H.keys()).slice(0,H.size-ae);for(const n of s)H.delete(n)}}function Je(e,t=ue){const r=G.get(e);if(!r)return!1;const n=Date.now()-r;return n<t?(S.getLogger().debug(`[Deduplication] Duplicate request blocked: ${e} (${n}ms ago)`),!0):!1}function Ze(e){if(G.set(e,Date.now()),G.size>ae){const t=Array.from(G.keys()).slice(0,G.size-ae);for(const r of t)G.delete(r)}}function et(e){return le.get(e)||null}function tt(e,t){le.set(e,t);const r=()=>{le.delete(e),Ze(e)};return t.then(r,r),t}async function rt(e,t,r={}){const{windowMs:s=ue,throwOnDuplicate:n=!0}=r,u=et(e);if(u)return S.getLogger().debug(`[Deduplication] Reusing in-flight request: ${e}`),u;if(Je(e,s)){if(n)throw new Error(`Duplicate request blocked: ${e}`);S.getLogger().warn(`[Deduplication] Duplicate request blocked but not throwing: ${e}`);return}const h=t();return tt(e,h)}function K(e,t,r={}){const{cooldownMs:s=xe,deduplicationWindowMs:n=ue}=r;return async()=>{if(Ke(e)){S.getLogger().debug(`[Deduplication] Button in cooldown: ${e}`);return}Xe(e,s);try{await rt(e,async()=>{const u=t();u instanceof Promise&&await u},{windowMs:n,throwOnDuplicate:!1})}catch(u){if(u instanceof Error&&u.message.includes("Duplicate request"))return;throw u}}}function we(e){return{background:"none",border:"none",fontSize:"1.5rem",cursor:"pointer",color:e,opacity:.6,padding:"0.25rem",lineHeight:1}}const W={PAYMENT_START:"cedros:payment:start",WALLET_CONNECT:"cedros:wallet:connect",WALLET_CONNECTED:"cedros:wallet:connected",WALLET_ERROR:"cedros:wallet:error",PAYMENT_PROCESSING:"cedros:payment:processing",PAYMENT_SUCCESS:"cedros:payment:success",PAYMENT_ERROR:"cedros:payment:error"};function Q(e,t){if(typeof window>"u")return;const r=new CustomEvent(e,{detail:t,bubbles:!0,cancelable:!1});window.dispatchEvent(r)}function X(e,t,r){Q(W.PAYMENT_START,{timestamp:Date.now(),method:e,resource:t,itemCount:r})}function st(e){Q(W.WALLET_CONNECT,{timestamp:Date.now(),wallet:e})}function nt(e,t){Q(W.WALLET_CONNECTED,{timestamp:Date.now(),wallet:e,publicKey:t})}function ot(e,t){Q(W.WALLET_ERROR,{timestamp:Date.now(),wallet:t,error:e})}function J(e,t,r){Q(W.PAYMENT_PROCESSING,{timestamp:Date.now(),method:e,resource:t,itemCount:r})}function Z(e,t,r,s){Q(W.PAYMENT_SUCCESS,{timestamp:Date.now(),method:e,transactionId:t,resource:r,itemCount:s})}function F(e,t,r,s){Q(W.PAYMENT_ERROR,{timestamp:Date.now(),method:e,error:t,resource:r,itemCount:s})}function it(e){return e instanceof S.PaymentError&&e.canRetry()}function at(e){return e instanceof S.PaymentError?e.getUserMessage():e instanceof Error?e.message:String(e)}function ct(e){switch(e){case"mainnet-beta":return"https://api.mainnet-beta.solana.com";case"devnet":return"https://api.devnet.solana.com";case"testnet":return"https://api.testnet.solana.com";default:return"https://api.mainnet-beta.solana.com"}}function lt(e){try{const t=new URL(e);return`${t.protocol}//${t.host}`}catch{return e}}function Se(e={}){const{solanaCluster:t="mainnet-beta",solanaEndpoint:r,customRpcProviders:s=[],allowUnsafeScripts:n=!1,additionalScriptSrc:u=[],additionalConnectSrc:h=[],additionalFrameSrc:x=[],includeStripe:C=!0,includeSolana:l=!0}=e;n&&console.warn("[CedrosPay] SECURITY WARNING: allowUnsafeScripts is enabled. This adds 'unsafe-inline' and 'unsafe-eval' to script-src, which significantly weakens CSP protection against XSS attacks. Only use this in development or if absolutely required by your framework.");const a=["'self'"];n&&a.push("'unsafe-inline'","'unsafe-eval'"),C&&a.push("https://js.stripe.com"),a.push(...u);const o=["'self'"];if(C&&o.push("https://api.stripe.com","https://*.stripe.com"),l){const p=ct(t);if(o.push(p),r){const c=lt(r);o.includes(c)||o.push(c)}s.forEach(c=>{o.includes(c)||o.push(c)})}o.push(...h);const d=["'self'"];return C&&d.push("https://js.stripe.com","https://checkout.stripe.com"),d.push(...x),{scriptSrc:a,connectSrc:o,frameSrc:d}}function Pe(e,t="header"){const{scriptSrc:r,connectSrc:s,frameSrc:n}=e;switch(t){case"header":case"meta":case"nextjs":case"nginx":{const u=[];return r.length>0&&u.push(`script-src ${r.join(" ")}`),s.length>0&&u.push(`connect-src ${s.join(" ")}`),n.length>0&&u.push(`frame-src ${n.join(" ")}`),u.join("; ")}case"helmet":{const u={};return r.length>0&&(u.scriptSrc=r),s.length>0&&(u.connectSrc=s),n.length>0&&(u.frameSrc=n),u}case"directives":return{scriptSrc:r,connectSrc:s,frameSrc:n};default:throw new Error(`Unknown CSP format: ${t}`)}}function ut(e={},t="header"){const r=Se(e);return Pe(r,t)}const dt={HELIUS:"https://*.helius-rpc.com",QUICKNODE:"https://*.quicknode.pro",ALCHEMY:"https://*.alchemy.com",ANKR:"https://rpc.ankr.com",TRITON:"https://*.rpcpool.com"},pt={MAINNET_CUSTOM_RPC:e=>({solanaCluster:"mainnet-beta",solanaEndpoint:e,allowUnsafeScripts:!1}),MAINNET_NEXTJS:e=>({solanaCluster:"mainnet-beta",solanaEndpoint:e,allowUnsafeScripts:!1}),DEVNET:()=>({solanaCluster:"devnet",allowUnsafeScripts:!1}),CRYPTO_ONLY:e=>({solanaCluster:"mainnet-beta",solanaEndpoint:e,includeStripe:!1}),STRIPE_ONLY:()=>({includeStripe:!0,includeSolana:!1})};function de(){const{stripeManager:e}=S.useCedrosContext(),[t,r]=f.useState({status:"idle",error:null,transactionId:null}),s=f.useRef(!1),n=f.useCallback(async(x,C,l,a,o,d)=>{if(s.current)return{success:!1,error:"Payment already in progress"};s.current=!0,r({status:"loading",error:null,transactionId:null});const p={resource:x,successUrl:C,cancelUrl:l,metadata:a,customerEmail:o,couponCode:d};try{const c=await e.processPayment(p);return r({status:c.success?"success":"error",error:c.success?null:c.error||"Payment failed",transactionId:c.success&&c.transactionId||null}),c}catch(c){const m=c instanceof Error?c.message:"Payment failed";return r({status:"error",error:m,transactionId:null}),{success:!1,error:m}}finally{s.current=!1}},[e]),u=f.useCallback(async(x,C,l,a,o,d,p,c,m,g,y,b,R)=>{if(s.current)return{success:!1,error:"Payment already in progress"};s.current=!0,r({status:"loading",error:null,transactionId:null});const P=ie(x);try{const v=await e.processCartCheckout({items:P,successUrl:C,cancelUrl:l,metadata:a,customerEmail:o,customerName:p,customerPhone:c,shippingAddress:m,billingAddress:g,couponCode:d,tipAmount:y,shippingMethodId:b,paymentMethodId:R});return r({status:v.success?"success":"error",error:v.success?null:v.error||"Cart checkout failed",transactionId:v.success&&v.transactionId||null}),v}catch(v){const I=v instanceof Error?v.message:"Cart checkout failed";return r({status:"error",error:I,transactionId:null}),{success:!1,error:I}}finally{s.current=!1}},[e]),h=f.useCallback(()=>{r({status:"idle",error:null,transactionId:null}),s.current=!1},[]);return{...t,processPayment:n,processCartCheckout:u,reset:h}}function te(e,t){return f.useMemo(()=>{const r=Ge(t),s=e||(t?.length===1?t[0].resource:"");return{isCartMode:r,effectiveResource:s}},[e,t])}const ft=(e,t,r)=>{const s=e[t];return s?typeof s=="function"?s():Promise.resolve(s):new Promise((n,u)=>{(typeof queueMicrotask=="function"?queueMicrotask:setTimeout)(u.bind(null,new Error("Unknown variable dynamic import: "+t+(t.split("/").length!==r?". Note that variables only represent file names one level deep.":""))))})},ce=new Map;let oe=null;async function be(e){if(ce.has(e))return ce.get(e);try{const t=await ft(Object.assign({"./translations/ar.json":()=>Promise.resolve().then(()=>require("./ar-LVoQZTFI.js")),"./translations/bn.json":()=>Promise.resolve().then(()=>require("./bn-BR5Cv1T4.js")),"./translations/de.json":()=>Promise.resolve().then(()=>require("./de-pQxy-oD1.js")),"./translations/en.json":()=>Promise.resolve().then(()=>require("./en-Yikrt96u.js")),"./translations/es.json":()=>Promise.resolve().then(()=>require("./es-D24cg8dD.js")),"./translations/fil.json":()=>Promise.resolve().then(()=>require("./fil-BOBft9G-.js")),"./translations/fr.json":()=>Promise.resolve().then(()=>require("./fr-Ct9ub8Fa.js")),"./translations/he.json":()=>Promise.resolve().then(()=>require("./he-DtQqRKRq.js")),"./translations/id.json":()=>Promise.resolve().then(()=>require("./id-CiM2mL7C.js")),"./translations/in.json":()=>Promise.resolve().then(()=>require("./in-Bzcjmxcc.js")),"./translations/it.json":()=>Promise.resolve().then(()=>require("./it-Blb_pIJl.js")),"./translations/jp.json":()=>Promise.resolve().then(()=>require("./jp-9NHyIuwY.js")),"./translations/kr.json":()=>Promise.resolve().then(()=>require("./kr-DvzJ-0yX.js")),"./translations/ms.json":()=>Promise.resolve().then(()=>require("./ms-BOAu5pUB.js")),"./translations/nl.json":()=>Promise.resolve().then(()=>require("./nl-WHh_DfO8.js")),"./translations/pa.json":()=>Promise.resolve().then(()=>require("./pa-B7kIhZCF.js")),"./translations/pl.json":()=>Promise.resolve().then(()=>require("./pl-H0hBKdvF.js")),"./translations/pt.json":()=>Promise.resolve().then(()=>require("./pt-DwGrViQ3.js")),"./translations/ru.json":()=>Promise.resolve().then(()=>require("./ru-CB2m0UDT.js")),"./translations/ta.json":()=>Promise.resolve().then(()=>require("./ta-CAS197uN.js")),"./translations/th.json":()=>Promise.resolve().then(()=>require("./th-Cpz2cFcg.js")),"./translations/tr.json":()=>Promise.resolve().then(()=>require("./tr-hQrEFk86.js")),"./translations/uk.json":()=>Promise.resolve().then(()=>require("./uk-DrK2Sv8C.js")),"./translations/ur.json":()=>Promise.resolve().then(()=>require("./ur-D5-7mN9a.js")),"./translations/vn.json":()=>Promise.resolve().then(()=>require("./vn-B_iut9YL.js")),"./translations/zh.json":()=>Promise.resolve().then(()=>require("./zh-PR82dCHr.js"))}),`./translations/${e}.json`,3),r=t.default||t;return ce.set(e,r),r}catch{return null}}async function mt(){if(oe)return oe;const e=Object.assign({"./translations/ar.json":()=>Promise.resolve().then(()=>require("./ar-LVoQZTFI.js")),"./translations/bn.json":()=>Promise.resolve().then(()=>require("./bn-BR5Cv1T4.js")),"./translations/de.json":()=>Promise.resolve().then(()=>require("./de-pQxy-oD1.js")),"./translations/en.json":()=>Promise.resolve().then(()=>require("./en-Yikrt96u.js")),"./translations/es.json":()=>Promise.resolve().then(()=>require("./es-D24cg8dD.js")),"./translations/fil.json":()=>Promise.resolve().then(()=>require("./fil-BOBft9G-.js")),"./translations/fr.json":()=>Promise.resolve().then(()=>require("./fr-Ct9ub8Fa.js")),"./translations/he.json":()=>Promise.resolve().then(()=>require("./he-DtQqRKRq.js")),"./translations/id.json":()=>Promise.resolve().then(()=>require("./id-CiM2mL7C.js")),"./translations/in.json":()=>Promise.resolve().then(()=>require("./in-Bzcjmxcc.js")),"./translations/it.json":()=>Promise.resolve().then(()=>require("./it-Blb_pIJl.js")),"./translations/jp.json":()=>Promise.resolve().then(()=>require("./jp-9NHyIuwY.js")),"./translations/kr.json":()=>Promise.resolve().then(()=>require("./kr-DvzJ-0yX.js")),"./translations/ms.json":()=>Promise.resolve().then(()=>require("./ms-BOAu5pUB.js")),"./translations/nl.json":()=>Promise.resolve().then(()=>require("./nl-WHh_DfO8.js")),"./translations/pa.json":()=>Promise.resolve().then(()=>require("./pa-B7kIhZCF.js")),"./translations/pl.json":()=>Promise.resolve().then(()=>require("./pl-H0hBKdvF.js")),"./translations/pt.json":()=>Promise.resolve().then(()=>require("./pt-DwGrViQ3.js")),"./translations/ru.json":()=>Promise.resolve().then(()=>require("./ru-CB2m0UDT.js")),"./translations/ta.json":()=>Promise.resolve().then(()=>require("./ta-CAS197uN.js")),"./translations/th.json":()=>Promise.resolve().then(()=>require("./th-Cpz2cFcg.js")),"./translations/tr.json":()=>Promise.resolve().then(()=>require("./tr-hQrEFk86.js")),"./translations/uk.json":()=>Promise.resolve().then(()=>require("./uk-DrK2Sv8C.js")),"./translations/ur.json":()=>Promise.resolve().then(()=>require("./ur-D5-7mN9a.js")),"./translations/vn.json":()=>Promise.resolve().then(()=>require("./vn-B_iut9YL.js")),"./translations/zh.json":()=>Promise.resolve().then(()=>require("./zh-PR82dCHr.js"))}),t=[];for(const r in e){const s=r.match(/\.\/translations\/([a-z]{2,3}(?:-[A-Z]{2})?)\.json$/);s&&t.push(s[1])}return oe=t.length>0?t:["en"],oe}function ve(){return typeof navigator>"u"?"en":(navigator.language||navigator.userLanguage||"en").split("-")[0].toLowerCase()}async function je(e){let t=await be(e);if(t||(t=await be("en"),t))return t;throw new Error("Critical: No translation files found, not even en.json")}function ke(e){return(t,r)=>{const s=t.split(".");let n=e;for(const u of s)if(n&&typeof n=="object"&&u in n)n=n[u];else return t;return typeof n!="string"?t:r?Object.entries(r).reduce((u,[h,x])=>u.replace(new RegExp(`\\{${h}\\}`,"g"),x),n):n}}function gt(e,t,r=!0){const s=t.errors[e];if(!s){const n=S.getUserFriendlyError(e);return r&&n.action?`${n.message} ${n.action}`:n.message}return r&&s.action?`${s.message} ${s.action}`:s.message}function V(e){const[t,r]=f.useState(null),[s,n]=f.useState(!0),u=f.useMemo(()=>e||ve(),[e]);return f.useEffect(()=>{let x=!1;return(async()=>{n(!0);try{const l=await je(u);x||(r(l),n(!1))}catch(l){console.error("[CedrosPay] Failed to load translations:",l),x||n(!1)}})(),()=>{x=!0}},[u]),{t:f.useMemo(()=>t?ke(t):x=>({"ui.purchase":"Purchase","ui.pay_with_card":"Pay with Card","ui.pay_with_crypto":"Pay with USDC","ui.pay_with_usdc":"Pay with USDC","ui.card":"Card","ui.usdc_solana":"USDC (Solana)","ui.crypto":"Crypto","ui.processing":"Processing...","ui.loading":"Loading...","ui.connect_wallet":"Connect Wallet","ui.connecting":"Connecting..."})[x]||x,[t]),locale:u,isLoading:s,translations:t}}function ht(e,t=!0){const{translations:r}=V();if(!r){const n=S.getUserFriendlyError(e);return t&&n.action?`${n.message} ${n.action}`:n.message}const s=r.errors[e];if(!s){const n=S.getUserFriendlyError(e);return t&&n.action?`${n.message} ${n.action}`:n.message}return t&&s.action?`${s.message} ${s.action}`:s.message}function pe({resource:e,items:t,successUrl:r,cancelUrl:s,metadata:n,customerEmail:u,couponCode:h,label:x,disabled:C=!1,onAttempt:l,onSuccess:a,onError:o,className:d=""}){const{status:p,error:c,transactionId:m,processPayment:g,processCartCheckout:y}=de(),b=S.useCedrosTheme(),{isCartMode:R,effectiveResource:P}=te(e,t),{t:v,translations:I}=V(),B=x||v("ui.pay_with_card"),A=b.unstyled?d:`${b.className} cedros-theme__stripe-button ${d}`.trim(),$=c&&typeof c!="string"?c?.code??null:null,w=c?typeof c=="string"?c:(j=>{if(!j||!I)return"";const M=I.errors[j];return M?M.action?`${M.message} ${M.action}`:M.message:""})($):null,k=f.useCallback(async()=>{S.getLogger().debug("[StripeButton] executePayment with couponCode:",h);const j=R&&t?ee(t):void 0;if(X("stripe",P,j),l&&l("stripe"),!R&&!P){const U="Invalid payment configuration: missing resource or items";S.getLogger().error("[StripeButton]",U),F("stripe",U,P,j),o&&o(U);return}let M;J("stripe",P,j),R&&t?(S.getLogger().debug("[StripeButton] Processing cart checkout with coupon:",h),M=await y(t,r,s,n,u,h)):P&&(S.getLogger().debug("[StripeButton] Processing single payment with coupon:",h),M=await g(P,r,s,n,u,h)),M&&M.success&&M.transactionId?(Z("stripe",M.transactionId,P,j),a&&a(M.transactionId)):M&&!M.success&&M.error&&(F("stripe",M.error,P,j),o&&o(M.error))},[h,R,P,t,r,s,n,u,y,g,l,a,o]),D=f.useMemo(()=>R&&t?`stripe-cart-${t.map(j=>j.resource).join("-")}`:`stripe-${P||"unknown"}`,[R,t,P]),E=f.useMemo(()=>K(D,k),[D,k]),T=p==="loading",_=C||T;return i.jsxs("div",{className:A,style:b.unstyled?{}:b.style,children:[i.jsx("button",{onClick:E,disabled:_,className:b.unstyled?d:"cedros-theme__button cedros-theme__stripe",type:"button",children:T?v("ui.processing"):B}),w&&i.jsx("div",{className:b.unstyled?"":"cedros-theme__error",children:w}),m&&i.jsx("div",{className:b.unstyled?"":"cedros-theme__success",children:v("ui.payment_successful")})]})}function Ee(){const{creditsManager:e}=S.useCedrosContext(),[t,r]=f.useState({status:"idle",error:null,transactionId:null,requirement:null,holdId:null}),s=f.useRef(!1),n=f.useCallback(async(l,a)=>{r(o=>({...o,status:"loading",error:null}));try{const o=await e.requestQuote(l,a);return r(d=>({...d,status:"idle",requirement:o})),o}catch(o){const d=o instanceof Error?o.message:"Failed to fetch credits quote";return r(p=>({...p,status:"error",error:d})),null}},[e]),u=f.useCallback(async(l,a)=>{r(o=>({...o,status:"loading",error:null}));try{const o=ie(l),d=await e.requestCartQuote(o,a);return r(p=>({...p,status:"idle"})),d}catch(o){const d=o instanceof Error?o.message:"Failed to fetch cart credits quote";return r(p=>({...p,status:"error",error:d})),null}},[e]),h=f.useCallback(async(l,a,o,d)=>{if(s.current)return{success:!1,error:"Payment already in progress"};s.current=!0,r({status:"loading",error:null,transactionId:null,requirement:null,holdId:null});try{const p=await e.processPayment(l,a,o,d);return r({status:p.success?"success":"error",error:p.success?null:p.error||"Credits payment failed",transactionId:p.success&&p.transactionId||null,requirement:null,holdId:null}),p}catch(p){const c=p instanceof Error?p.message:"Credits payment failed";return r({status:"error",error:c,transactionId:null,requirement:null,holdId:null}),{success:!1,error:c}}finally{s.current=!1}},[e]),x=f.useCallback(async(l,a,o,d)=>{if(s.current)return{success:!1,error:"Payment already in progress"};s.current=!0,r({status:"loading",error:null,transactionId:null,requirement:null,holdId:null});let p=null;try{const c=ie(l),m=await e.requestCartQuote(c,o);if(!m)return r({status:"error",error:"Credits payment not available for this cart",transactionId:null,requirement:null,holdId:null}),{success:!1,error:"Credits payment not available"};p=(await e.createCartHold({cartId:m.cartId,authToken:a})).holdId,r(b=>({...b,holdId:p}));const y=await e.authorizeCartPayment({cartId:m.cartId,holdId:p,authToken:a,metadata:d});if(!y.success&&p)try{await e.releaseHold(p,a)}catch(b){S.getLogger().warn("[useCreditsPayment] Hold release failed, will expire server-side",{holdId:p,error:b instanceof Error?b.message:String(b)})}return r({status:y.success?"success":"error",error:y.success?null:y.error||"Cart credits payment failed",transactionId:y.success&&y.transactionId||null,requirement:null,holdId:null}),{success:y.success,transactionId:y.transactionId,error:y.error}}catch(c){const m=c instanceof Error?c.message:"Cart credits payment failed";if(p)try{await e.releaseHold(p,a)}catch(g){S.getLogger().warn("[useCreditsPayment] Hold release failed, will expire server-side",{holdId:p,error:g instanceof Error?g.message:String(g)})}return r({status:"error",error:m,transactionId:null,requirement:null,holdId:null}),{success:!1,error:m}}finally{s.current=!1}},[e]),C=f.useCallback(()=>{r({status:"idle",error:null,transactionId:null,requirement:null,holdId:null}),s.current=!1},[]);return{...t,fetchQuote:n,fetchCartQuote:u,processPayment:h,processCartPayment:x,reset:C}}function fe({resource:e,items:t,authToken:r,metadata:s,couponCode:n,label:u,disabled:h=!1,onAttempt:x,onSuccess:C,onError:l,className:a=""}){const{status:o,error:d,transactionId:p,processPayment:c,processCartPayment:m}=Ee(),g=S.useCedrosTheme(),{isCartMode:y,effectiveResource:b}=te(e,t),{t:R,translations:P}=V(),v=u||R("ui.pay_with_credits")||"Pay with Credits",I=g.unstyled?a:`${g.className} cedros-theme__credits-button ${a}`.trim(),B=d&&typeof d!="string"?d?.code??null:null,$=d?typeof d=="string"?d:(T=>{if(!T||!P)return"";const _=P.errors[T];return _?_.action?`${_.message} ${_.action}`:_.message:""})(B):null,q=f.useCallback(async()=>{S.getLogger().debug("[CreditsButton] executePayment");const T=y&&t?ee(t):void 0;if(X("credits",b,T),x&&x("credits"),!r){const j="Authentication required: please log in to pay with credits";S.getLogger().error("[CreditsButton]",j),F("credits",j,b,T),l&&l(j);return}if(!y&&!b){const j="Invalid payment configuration: missing resource";S.getLogger().error("[CreditsButton]",j),F("credits",j,b,T),l&&l(j);return}let _;J("credits",b,T),y&&t?(S.getLogger().debug("[CreditsButton] Processing cart checkout"),_=await m(t,r,n,s)):b&&(S.getLogger().debug("[CreditsButton] Processing single payment"),_=await c(b,r,n,s)),_&&_.success&&_.transactionId?(Z("credits",_.transactionId,b,T),C&&C(_.transactionId)):_&&!_.success&&_.error&&(F("credits",_.error,b,T),l&&l(_.error))},[r,y,b,t,n,s,c,m,x,C,l]),w=f.useMemo(()=>y&&t?`credits-cart-${t.map(T=>T.resource).join("-")}`:`credits-${b||"unknown"}`,[y,t,b]),k=f.useMemo(()=>K(w,q),[w,q]),D=o==="loading",E=h||D;return i.jsxs("div",{className:I,style:g.unstyled?{}:g.style,children:[i.jsx("button",{onClick:k,disabled:E,className:g.unstyled?a:"cedros-theme__button cedros-theme__credits",type:"button",children:D?R("ui.processing"):v}),$&&i.jsx("div",{className:g.unstyled?"":"cedros-theme__error",children:$}),p&&i.jsx("div",{className:g.unstyled?"":"cedros-theme__success",children:R("ui.payment_successful")})]})}const yt=f.lazy(()=>Promise.resolve().then(()=>require("./CryptoButton-DpiCnyXE.js")).then(e=>e.CryptoButton$1).then(e=>({default:e.CryptoButton}))),Me=({isOpen:e,onClose:t,resource:r,items:s,cardLabel:n="Card",cryptoLabel:u="USDC (Solana)",creditsLabel:h="Pay with Credits",showCard:x=!0,showCrypto:C=!0,showCredits:l=!1,onPaymentAttempt:a,onPaymentSuccess:o,onPaymentError:d,onStripeSuccess:p,onCryptoSuccess:c,onCreditsSuccess:m,onStripeError:g,onCryptoError:y,onCreditsError:b,customerEmail:R,successUrl:P,cancelUrl:v,metadata:I,couponCode:B,authToken:A,testPageUrl:$,hideMessages:q=!1})=>{const{tokens:w}=S.useCedrosTheme();return f.useEffect(()=>{const k=D=>{D.key==="Escape"&&e&&t()};return window.addEventListener("keydown",k),()=>window.removeEventListener("keydown",k)},[e,t]),f.useEffect(()=>{if(e){const k=window.scrollY;return document.body.style.position="fixed",document.body.style.top=`-${k}px`,document.body.style.width="100%",document.body.style.overflowY="scroll",()=>{const D=document.body.style.top?Math.abs(parseInt(document.body.style.top.replace("px",""),10)):0;document.body.style.position="",document.body.style.top="",document.body.style.width="",document.body.style.overflowY="",window.scrollTo(0,D)}}},[e]),e?i.jsx("div",{className:"cedros-modal-overlay",style:{position:"fixed",top:0,left:0,right:0,bottom:0,backgroundColor:w.modalOverlay,display:"flex",alignItems:"center",justifyContent:"center",zIndex:9999,padding:"1rem"},onClick:t,children:i.jsxs("div",{className:"cedros-modal-content",style:{backgroundColor:w.modalBackground,borderRadius:"12px",padding:"2rem",maxWidth:"400px",width:"100%",boxShadow:"0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04)",border:`1px solid ${w.modalBorder}`},onClick:k=>k.stopPropagation(),children:[i.jsxs("div",{style:{display:"flex",justifyContent:"space-between",alignItems:"center",marginBottom:"1.5rem"},children:[i.jsx("h3",{style:{margin:0,fontSize:"1.25rem",fontWeight:600,color:w.surfaceText},children:"Choose Payment Method"}),i.jsx("button",{type:"button",onClick:t,style:we(w.surfaceText),"aria-label":"Close modal",children:"×"})]}),i.jsxs("div",{style:{display:"flex",flexDirection:"column",gap:"1rem"},children:[x&&i.jsx(pe,{resource:r,items:s,label:n,onAttempt:a,onSuccess:p||o,onError:g||d,customerEmail:R,successUrl:P,cancelUrl:v,metadata:I,couponCode:B}),C&&i.jsx(f.Suspense,{fallback:null,children:i.jsx(yt,{resource:r,items:s,label:u,onAttempt:a,onSuccess:c||o,onError:y||d,testPageUrl:$,hideMessages:q,metadata:I,couponCode:B})}),l&&i.jsx(fe,{resource:r,items:s,label:h,authToken:A,onAttempt:a?()=>a("credits"):void 0,onSuccess:m||o,onError:b||d,metadata:I,couponCode:B})]})]})}):null},Re=({resource:e,items:t,label:r,cardLabel:s,cryptoLabel:n,creditsLabel:u,showCard:h=!0,showCrypto:x=!0,showCredits:C=!1,onPaymentAttempt:l,onPaymentSuccess:a,onPaymentError:o,onStripeSuccess:d,onCryptoSuccess:p,onCreditsSuccess:c,onStripeError:m,onCryptoError:g,onCreditsError:y,customerEmail:b,successUrl:R,cancelUrl:P,metadata:v,couponCode:I,authToken:B,autoDetectWallets:A=!0,testPageUrl:$,hideMessages:q=!1,renderModal:w})=>{const k=S.useCedrosTheme(),[D,E]=f.useState(!1),{status:T,processPayment:_,processCartCheckout:j}=de(),{isCartMode:M,effectiveResource:U}=te(e,t),{t:L}=V(),O=r||L("ui.purchase"),Le=s||L("ui.card"),Ne=n||L("ui.usdc_solana"),De=u||L("ui.pay_with_credits")||"Pay with Credits",me=f.useCallback(async()=>{if(A&&h){const{detectSolanaWallets:N}=await Promise.resolve().then(()=>require("./walletDetection-bNmV5ItZ.js"));if(!N()){const se=M?void 0:U,ne=M&&t?ee(t):void 0;X("stripe",se,ne),l&&l("stripe"),J("stripe",se,ne);let z;M&&t?z=await j(t,R,P,v,b,I):U&&(z=await _(U,R,P,v,b,I)),z&&z.success&&z.transactionId?(Z("stripe",z.transactionId,se,ne),d?d(z.transactionId):a&&a(z.transactionId)):z&&!z.success&&z.error&&(F("stripe",z.error,se,ne),m?m(z.error):o&&o(z.error));return}}E(!0)},[A,h,M,t,U,j,_,R,P,v,b,I,a,o,d,m,l]),ge=f.useMemo(()=>M&&t?`purchase-cart-${t.map(N=>N.resource).join("-")}`:`purchase-${U||"unknown"}`,[M,t,U]),Be=f.useMemo(()=>K(ge,me),[ge,me]),re=T==="loading",he={isOpen:D,onClose:()=>E(!1),resource:M?void 0:U,items:M?t:void 0,cardLabel:Le,cryptoLabel:Ne,creditsLabel:De,showCard:h,showCrypto:x,showCredits:C,onPaymentAttempt:l,onPaymentSuccess:N=>{E(!1),a?.(N)},onPaymentError:N=>{E(!1),o?.(N)},onStripeSuccess:N=>{E(!1),d?.(N)},onCryptoSuccess:N=>{E(!1),p?.(N)},onCreditsSuccess:N=>{E(!1),c?.(N)},onStripeError:N=>{E(!1),m?.(N)},onCryptoError:N=>{E(!1),g?.(N)},onCreditsError:N=>{E(!1),y?.(N)},customerEmail:b,successUrl:R,cancelUrl:P,metadata:v,couponCode:I,authToken:B,testPageUrl:$,hideMessages:q};return i.jsxs("div",{className:k.unstyled?"":k.className,style:k.unstyled?{}:k.style,children:[i.jsx("button",{onClick:Be,disabled:re,className:k.unstyled?"":"cedros-theme__button cedros-theme__stripe",style:{width:"100%",cursor:re?"not-allowed":"pointer",opacity:re?.6:1},type:"button",children:re?L("ui.processing"):O}),w?w(he):i.jsx(Me,{...he})]})},bt={"mainnet-beta":"https://api.mainnet-beta.solana.com",devnet:"https://api.devnet.solana.com",testnet:"https://api.testnet.solana.com"};function Ct(){const[e,t]=f.useState(null);return f.useEffect(()=>{let r=!1;return import("@solana/wallet-adapter-react").then(s=>{r||t(s)}),()=>{r=!0}},[]),e}function xt({endpoint:e,wallets:t,children:r}){const s=Ct();if(!s)return i.jsx(i.Fragment,{children:r});const{ConnectionProvider:n,WalletProvider:u}=s;return i.jsx(n,{endpoint:e,children:i.jsx(u,{wallets:t,autoConnect:!1,children:r})})}const wt=f.lazy(()=>Promise.resolve().then(()=>require("./CryptoButton-DpiCnyXE.js")).then(e=>e.CryptoButton$1).then(e=>({default:e.CryptoButton})));function St(e){const{resource:t,items:r,checkout:s={},display:n={},callbacks:u={},advanced:h={}}=e,{config:x,walletPool:C}=S.useCedrosContext(),l=S.useCedrosTheme(),{isCartMode:a}=te(t,r),o=n.showCrypto??!0,d=f.useMemo(()=>({marginTop:"0.5rem",fontSize:"0.875rem",color:l.tokens.surfaceText,opacity:.7,textAlign:"center"}),[l.tokens.surfaceText]),p=f.useMemo(()=>o?h.wallets&&h.wallets.length>0?h.wallets:C.getAdapters():[],[h.wallets,C,o]),c=f.useMemo(()=>r?ee(r):0,[r]),{onPaymentSuccess:m,onPaymentError:g,onPaymentAttempt:y}=u,b=f.useCallback(j=>m?.({transactionId:j,method:"stripe"}),[m]),R=f.useCallback(j=>m?.({transactionId:j,method:"crypto"}),[m]),P=f.useCallback(j=>g?.({message:j,method:"stripe"}),[g]),v=f.useCallback(j=>g?.({message:j,method:"crypto"}),[g]),I=f.useCallback(j=>m?.({transactionId:j,method:"credits"}),[m]),B=f.useCallback(j=>g?.({message:j,method:"credits"}),[g]),A=f.useCallback(()=>y?.("credits"),[y]),$=o?x.solanaEndpoint??bt[x.solanaCluster]:"";if(!t&&(!r||r.length===0))return S.getLogger().error('CedrosPay: Must provide either "resource" or "items" prop'),i.jsx("div",{className:n.className,style:{color:l.tokens.errorText},children:"Configuration error: No resource or items provided"});const q=n.showCard??!0,w=n.showCredits??!1,k=n.showPurchaseButton??!1,D=n.layout??"vertical",E=n.hideMessages??!1,T=h.autoDetectWallets??!0,_=i.jsx("div",{className:l.unstyled?n.className:`cedros-theme__pay ${n.className||""}`,children:i.jsxs("div",{className:l.unstyled?"":`cedros-theme__pay-content cedros-theme__pay-content--${D}`,children:[k?i.jsx(Re,{resource:a?void 0:t||r?.[0]?.resource,items:a?r:void 0,label:n.purchaseLabel,cardLabel:n.cardLabel,cryptoLabel:n.cryptoLabel,showCard:q,showCrypto:o,onPaymentAttempt:u.onPaymentAttempt,onPaymentSuccess:b,onPaymentError:P,onStripeSuccess:b,onCryptoSuccess:R,onStripeError:P,onCryptoError:v,customerEmail:s.customerEmail,successUrl:s.successUrl,cancelUrl:s.cancelUrl,metadata:s.metadata,couponCode:s.couponCode,autoDetectWallets:T,testPageUrl:h.testPageUrl,hideMessages:E,renderModal:n.renderModal}):i.jsxs(i.Fragment,{children:[q&&i.jsx(pe,{resource:a?void 0:t||r?.[0]?.resource,items:a?r:void 0,customerEmail:s.customerEmail,successUrl:s.successUrl,cancelUrl:s.cancelUrl,metadata:s.metadata,couponCode:s.couponCode,label:n.cardLabel,onAttempt:u.onPaymentAttempt,onSuccess:b,onError:P}),o&&i.jsx(f.Suspense,{fallback:null,children:i.jsx(wt,{resource:a?void 0:t||r?.[0]?.resource,items:a?r:void 0,metadata:s.metadata,couponCode:s.couponCode,label:n.cryptoLabel,onAttempt:u.onPaymentAttempt,onSuccess:R,onError:v,testPageUrl:h.testPageUrl,hideMessages:E})}),w&&i.jsx(fe,{resource:a?void 0:t||r?.[0]?.resource,items:a?r:void 0,authToken:s.authToken,metadata:s.metadata,couponCode:s.couponCode,label:n.creditsLabel,onAttempt:A,onSuccess:I,onError:B})]}),a&&r&&r.length>1&&!E&&i.jsxs("div",{style:d,children:["Checking out ",c," items"]})]})});return i.jsx("div",{className:l.unstyled?n.className:l.className,style:l.unstyled?{}:l.style,children:i.jsx(xt,{endpoint:$||"https://api.devnet.solana.com",wallets:p,children:_})})}function Pt({product:e,paymentMethod:t,showOriginalPrice:r=!1,className:s="",style:n={}}){const u=t==="stripe",h=u?e.fiatAmount:e.cryptoAmount,x=u?e.effectiveFiatAmount:e.effectiveCryptoAmount,C=u?e.fiatCurrency.toUpperCase():e.cryptoToken,l=u?e.hasStripeCoupon:e.hasCryptoCoupon,a=u?e.stripeDiscountPercent:e.cryptoDiscountPercent;return i.jsxs("div",{className:s,style:n,children:[r&&l&&i.jsxs("span",{style:{textDecoration:"line-through",opacity:.6,marginRight:"0.5rem",fontSize:"0.875em"},children:[h.toFixed(2)," ",C]}),i.jsxs("span",{style:{fontWeight:600},children:[x.toFixed(2)," ",C]}),l&&a>0&&i.jsxs("span",{style:{marginLeft:"0.5rem",padding:"0.125rem 0.375rem",backgroundColor:"#10b981",color:"white",borderRadius:"0.25rem",fontSize:"0.75em",fontWeight:600},children:[a,"% OFF"]})]})}function vt({product:e,paymentMethod:t,className:r="",style:s={}}){const n=t==="stripe",u=n?e.hasStripeCoupon:e.hasCryptoCoupon,h=n?e.stripeDiscountPercent:e.cryptoDiscountPercent,x=n?e.stripeCouponCode:e.cryptoCouponCode;if(!u||h===0)return null;const C=n?`${h}% off with card!`:`${h}% off with crypto!`;return i.jsxs("div",{className:r,style:{display:"inline-flex",alignItems:"center",padding:"0.5rem 0.75rem",backgroundColor:n?"#6366f1":"#10b981",color:"white",borderRadius:"0.375rem",fontSize:"0.875rem",fontWeight:600,...s},children:[C,x&&i.jsxs("span",{style:{marginLeft:"0.5rem",opacity:.8,fontSize:"0.75em",fontWeight:400},children:["(",x,")"]})]})}function _e(){const{subscriptionManager:e}=S.useCedrosContext(),[t,r]=f.useState({status:"idle",error:null,sessionId:null,subscriptionStatus:null,expiresAt:null}),s=f.useRef(!1),n=f.useCallback(async C=>{if(s.current)return{success:!1,error:"Payment already in progress"};s.current=!0,r(l=>({...l,status:"loading",error:null}));try{const l=await e.processSubscription(C);return r(a=>({...a,status:l.success?"success":"error",error:l.success?null:l.error||"Subscription failed",sessionId:l.success&&l.transactionId||null})),l}catch(l){const a=S.formatError(l,"Subscription failed");return r(o=>({...o,status:"error",error:a})),{success:!1,error:a}}finally{s.current=!1}},[e]),u=f.useCallback(async C=>{r(l=>({...l,status:"checking",error:null}));try{const l=await e.checkSubscriptionStatus(C);return r(a=>({...a,status:l.active?"success":"idle",subscriptionStatus:l.status,expiresAt:l.expiresAt||l.currentPeriodEnd||null})),l}catch(l){const a=l instanceof Error?l.message:"Failed to check subscription status";throw r(o=>({...o,status:"error",error:a})),l}},[e]),h=f.useCallback(async(C,l,a)=>{r(o=>({...o,status:"loading",error:null}));try{const o=await e.requestSubscriptionQuote(C,l,a);return r(d=>({...d,status:"idle"})),o}catch(o){const d=o instanceof Error?o.message:"Failed to get subscription quote";throw r(p=>({...p,status:"error",error:d})),o}},[e]),x=f.useCallback(()=>{r({status:"idle",error:null,sessionId:null,subscriptionStatus:null,expiresAt:null})},[]);return{...t,processSubscription:n,checkStatus:u,requestQuote:h,reset:x}}function jt({resource:e,interval:t,intervalDays:r,trialDays:s,successUrl:n,cancelUrl:u,customerEmail:h,label:x,disabled:C=!1,onAttempt:l,onSuccess:a,onError:o,className:d=""}){const{status:p,error:c,sessionId:m,processSubscription:g}=_e(),y=S.useCedrosTheme(),{t:b,translations:R}=V(),P=x||b("ui.subscribe"),v=y.unstyled?d:`${y.className} cedros-theme__stripe-button ${d}`.trim(),I=c&&typeof c!="string"?c?.code??null:null,A=c?typeof c=="string"?c:(E=>{if(!E||!R)return"";const T=R.errors[E];return T?T.action?`${T.message} ${T.action}`:T.message:""})(I):null,$=f.useCallback(async()=>{S.getLogger().debug("[SubscribeButton] executeSubscription:",{resource:e,interval:t,intervalDays:r,trialDays:s}),X("stripe",e),l&&l("stripe"),J("stripe",e);const E=await g({resource:e,interval:t,intervalDays:r,trialDays:s,customerEmail:h,successUrl:n,cancelUrl:u});E.success&&E.transactionId?(Z("stripe",E.transactionId,e),a&&a(E.transactionId)):!E.success&&E.error&&(F("stripe",E.error,e),o&&o(E.error))},[e,t,r,s,h,n,u,g,l,a,o]),q=f.useMemo(()=>`subscribe-${e}-${t}`,[e,t]),w=f.useMemo(()=>K(q,$),[q,$]),k=p==="loading",D=C||k;return i.jsxs("div",{className:v,style:y.unstyled?{}:y.style,children:[i.jsx("button",{onClick:w,disabled:D,className:y.unstyled?d:"cedros-theme__button cedros-theme__stripe",type:"button",children:k?b("ui.processing"):P}),A&&i.jsx("div",{className:y.unstyled?"":"cedros-theme__error",children:A}),m&&i.jsx("div",{className:y.unstyled?"":"cedros-theme__success",children:b("ui.redirecting_to_checkout")})]})}function Te(){const{subscriptionManager:e,creditsManager:t}=S.useCedrosContext(),[r,s]=f.useState({status:"idle",error:null,sessionId:null,subscriptionStatus:null,expiresAt:null,creditsRequirement:null}),n=f.useRef(!1),u=f.useCallback(async(l,a)=>{s(o=>({...o,status:"checking",error:null}));try{const o=await e.checkSubscriptionStatus({resource:l,userId:a});return s(d=>({...d,status:o.active?"success":"idle",subscriptionStatus:o.status,expiresAt:o.expiresAt||o.currentPeriodEnd||null})),o}catch(o){const d=S.formatError(o,"Failed to check subscription status");return s(p=>({...p,status:"error",error:d})),null}},[e]),h=f.useCallback(async(l,a,o)=>{s(d=>({...d,status:"loading",error:null}));try{const d=await t.requestQuote(l,o?.couponCode);return s(p=>({...p,status:"idle",creditsRequirement:d})),d}catch(d){const p=S.formatError(d,"Failed to get subscription quote");return s(c=>({...c,status:"error",error:p})),null}},[t]),x=f.useCallback(async(l,a,o,d)=>{if(n.current)return{success:!1,error:"Payment already in progress"};if(!o){const p="Authentication required for credits payment";return s(c=>({...c,status:"error",error:p})),{success:!1,error:p}}n.current=!0,s(p=>({...p,status:"loading",error:null}));try{const p=await t.processPayment(l,o,d?.couponCode,{interval:a,...d?.intervalDays&&{intervalDays:String(d.intervalDays)}});return p.success?s({status:"success",error:null,sessionId:p.transactionId||null,subscriptionStatus:"active",expiresAt:null,creditsRequirement:null}):s(c=>({...c,status:"error",error:p.error||"Credits subscription payment failed"})),p}catch(p){const c=S.formatError(p,"Credits subscription payment failed");return s(m=>({...m,status:"error",error:c})),{success:!1,error:c}}finally{n.current=!1}},[t]),C=f.useCallback(()=>{s({status:"idle",error:null,sessionId:null,subscriptionStatus:null,expiresAt:null,creditsRequirement:null})},[]);return{...r,checkStatus:u,requestQuote:h,processPayment:x,reset:C}}function kt({resource:e,interval:t,intervalDays:r,authToken:s,userId:n,couponCode:u,label:h,disabled:x=!1,onAttempt:C,onSuccess:l,onError:a,className:o="",hideMessages:d=!1,autoCheckStatus:p=!1}){const{status:c,error:m,subscriptionStatus:g,expiresAt:y,checkStatus:b,processPayment:R}=Te(),P=S.useCedrosTheme(),{t:v,translations:I}=V(),B=f.useRef(b);f.useEffect(()=>{B.current=b},[b]),f.useEffect(()=>{p&&n&&(S.getLogger().debug("[CreditsSubscribeButton] Auto-checking subscription status",{resource:e,userId:n}),B.current(e,n))},[p,n,e]);const A=h||v("ui.subscribe_with_credits")||"Subscribe with Credits",$=m&&typeof m!="string"?m?.code??null:null,w=m?typeof m=="string"?m:(L=>{if(!L||!I)return"";const O=I.errors[L];return O?O.action?`${O.message} ${O.action}`:O.message:""})($):null,k=f.useCallback(async()=>{if(S.getLogger().debug("[CreditsSubscribeButton] executeSubscriptionFlow",{resource:e,interval:t,intervalDays:r,hasAuthToken:!!s}),X("credits",e),C&&C("credits"),!s){const O="Authentication required: please log in to subscribe with credits";S.getLogger().error("[CreditsSubscribeButton]",O),F("credits",O,e),a&&a(O);return}J("credits",e);const L=await R(e,t,s,{couponCode:u,intervalDays:r});L.success&&L.transactionId?(Z("credits",L.transactionId,e),l&&l(L.transactionId)):!L.success&&L.error&&(F("credits",L.error,e),a&&a(L.error))},[e,t,r,s,u,R,C,l,a]),D=f.useMemo(()=>`credits-subscribe-${e}-${t}`,[e,t]),E=f.useMemo(()=>K(D,k,{cooldownMs:200,deduplicationWindowMs:0}),[D,k]),T=c==="loading"||c==="checking",_=g==="active"||g==="trialing",j=x||T||_;let M=A;if(T)M=v("ui.processing");else if(_&&y){const L=new Date(y).toLocaleDateString();M=`${v("ui.subscribed_until")} ${L}`}else _&&(M=v("ui.subscribed"));const U=P.unstyled?o:`${P.className} cedros-theme__credits-button ${o}`.trim();return i.jsxs("div",{className:U,style:P.unstyled?{}:P.style,children:[i.jsx("button",{onClick:E,disabled:j,className:P.unstyled?o:"cedros-theme__button cedros-theme__credits",type:"button",children:M}),!d&&w&&i.jsx("div",{className:P.unstyled?"":"cedros-theme__error",children:w}),!d&&_&&i.jsx("div",{className:P.unstyled?"":"cedros-theme__success",children:v("ui.subscription_active")})]})}function Ie(){const{subscriptionChangeManager:e}=S.useCedrosContext(),[t,r]=f.useState({status:"idle",error:null,subscription:null,changePreview:null,userId:null}),s=f.useRef(t);s.current=t;const n=f.useCallback(async(o,d)=>{r(p=>({...p,status:"loading",error:null}));try{const p=await e.getDetails(o,d);return r(c=>({...c,status:"success",subscription:p,userId:d})),p}catch(p){const c=p instanceof Error?p.message:"Failed to load subscription";return r(m=>({...m,status:"error",error:c})),null}},[e]),u=f.useCallback(async(o,d,p,c)=>{r(m=>({...m,status:"loading",error:null}));try{const m={currentResource:o,newResource:d,userId:p,newInterval:c},g=await e.previewChange(m);return r(y=>({...y,status:"idle",changePreview:g})),g}catch(m){const g=m instanceof Error?m.message:"Failed to preview change";return r(y=>({...y,status:"error",error:g})),null}},[e]),h=f.useCallback(async o=>{const{subscription:d,userId:p}=s.current;if(!d||!p)return r(c=>({...c,status:"error",error:"No subscription loaded"})),null;r(c=>({...c,status:"loading",error:null}));try{const c={subscriptionId:d.id,newResource:o.newResource,prorationBehavior:o.prorationBehavior},m=await e.changeSubscription(c);return m.success?r(g=>({...g,status:"success",subscription:g.subscription?{...g.subscription,resource:m.newResource,interval:g.subscription.interval,status:m.status,currentPeriodEnd:m.currentPeriodEnd}:null,changePreview:null})):r(g=>({...g,status:"error",error:m.error||"Failed to change subscription"})),m}catch(c){const m=c instanceof Error?c.message:"Failed to change subscription";return r(g=>({...g,status:"error",error:m})),null}},[e]),x=f.useCallback(async o=>{const{subscription:d,userId:p}=s.current;if(!d||!p)return r(c=>({...c,status:"error",error:"No subscription loaded"})),null;r(c=>({...c,status:"loading",error:null}));try{const c={subscriptionId:d.id,atPeriodEnd:!o},m=await e.cancel(c);if(m.success){const g=m.atPeriodEnd?d.status:"canceled";r(y=>({...y,status:"success",subscription:y.subscription?{...y.subscription,status:g,cancelAtPeriodEnd:m.atPeriodEnd}:null}))}else r(g=>({...g,status:"error",error:m.error||"Failed to cancel subscription"}));return m}catch(c){const m=c instanceof Error?c.message:"Failed to cancel subscription";return r(g=>({...g,status:"error",error:m})),null}},[e]),C=f.useCallback(async(o,d)=>{const p=s.current.subscription?.customerId??(o.startsWith("cus_")?o:null);if(!p)return r(c=>({...c,status:"error",error:"No Stripe customer ID available for billing portal"})),null;r(c=>({...c,status:"loading",error:null}));try{const c=await e.getBillingPortalUrl({customerId:p,returnUrl:d});try{if(new URL(c.url).protocol!=="https:")throw new Error("Billing portal URL must use HTTPS")}catch{throw new Error("Invalid billing portal URL")}return window.location.href=c.url,c}catch(c){const m=c instanceof Error?c.message:"Failed to open billing portal";return r(g=>({...g,status:"error",error:m})),null}},[e]),l=f.useCallback(()=>{r(o=>({...o,changePreview:null}))},[]),a=f.useCallback(()=>{r({status:"idle",error:null,subscription:null,changePreview:null,userId:null})},[]);return{...t,loadSubscription:n,previewChange:u,changeSubscription:h,cancelSubscription:x,openBillingPortal:C,clearPreview:l,reset:a}}const Et={bg:"#fff",bgMuted:"#f9fafb",bgHighlight:"#eff6ff",text:"#111827",textMuted:"#6b7280",textFaint:"#9ca3af",border:"#e5e7eb",borderLight:"#f3f4f6",primary:"#3b82f6",error:"#ef4444",errorBg:"#fef2f2",errorBorder:"#fecaca",warningBg:"#fef3c7",warningBorder:"#fcd34d",warningText:"#92400e",buttonBg:"#f3f4f6",buttonBorder:"#d1d5db",buttonText:"#374151"},Mt={bg:"#1e293b",bgMuted:"#334155",bgHighlight:"rgba(59, 130, 246, 0.15)",text:"#f1f5f9",textMuted:"#94a3b8",textFaint:"#64748b",border:"#475569",borderLight:"#334155",primary:"#3b82f6",error:"#ef4444",errorBg:"rgba(239, 68, 68, 0.15)",errorBorder:"rgba(239, 68, 68, 0.3)",warningBg:"rgba(245, 158, 11, 0.15)",warningBorder:"rgba(245, 158, 11, 0.3)",warningText:"#fbbf24",buttonBg:"#334155",buttonBorder:"#475569",buttonText:"#e2e8f0"};function Rt(e){const t=e?Mt:Et;return{container:{padding:"24px",backgroundColor:t.bg,borderRadius:"8px",border:`1px solid ${t.border}`,fontFamily:"system-ui, -apple-system, sans-serif",color:t.text},error:{padding:"12px 16px",backgroundColor:t.errorBg,border:`1px solid ${t.errorBorder}`,borderRadius:"6px",color:t.error,marginBottom:"16px"},loading:{padding:"24px",textAlign:"center",color:t.textMuted},details:{marginBottom:"24px"},title:{margin:"0 0 16px 0",fontSize:"18px",fontWeight:600,color:t.text},detailRow:{display:"flex",justifyContent:"space-between",alignItems:"center",padding:"8px 0",borderBottom:`1px solid ${t.borderLight}`},label:{color:t.textMuted,fontSize:"14px"},value:{color:t.text,fontSize:"14px",fontWeight:500},statusBadge:{padding:"4px 8px",borderRadius:"4px",color:"#fff",fontSize:"12px",fontWeight:500,textTransform:"capitalize"},cancelNotice:{marginTop:"12px",padding:"8px 12px",backgroundColor:t.warningBg,border:`1px solid ${t.warningBorder}`,borderRadius:"6px",color:t.warningText,fontSize:"13px"},prorationPreview:{padding:"16px",backgroundColor:t.bgMuted,borderRadius:"8px",marginBottom:"24px"},previewTitle:{margin:"0 0 12px 0",fontSize:"16px",fontWeight:600,color:t.text},previewDetails:{marginBottom:"16px"},previewRow:{display:"flex",justifyContent:"space-between",padding:"6px 0",fontSize:"14px",color:t.textMuted},previewTotal:{borderTop:`1px solid ${t.border}`,marginTop:"8px",paddingTop:"12px",fontWeight:600,color:t.text},previewActions:{display:"flex",gap:"12px",justifyContent:"flex-end"},cancelButton:{padding:"8px 16px",backgroundColor:t.bg,border:`1px solid ${t.buttonBorder}`,borderRadius:"6px",color:t.buttonText,cursor:"pointer",fontSize:"14px"},confirmButton:{padding:"8px 16px",backgroundColor:t.primary,border:"none",borderRadius:"6px",color:"#fff",cursor:"pointer",fontSize:"14px",fontWeight:500},plansSection:{marginBottom:"24px"},plansTitle:{margin:"0 0 12px 0",fontSize:"16px",fontWeight:600,color:t.text},plansList:{display:"grid",gridTemplateColumns:"repeat(auto-fit, minmax(200px, 1fr))",gap:"16px"},planCard:{padding:"16px",backgroundColor:t.bg,border:`1px solid ${t.border}`,borderRadius:"8px",textAlign:"center"},currentPlan:{borderColor:t.primary,backgroundColor:t.bgHighlight},planName:{fontSize:"16px",fontWeight:600,color:t.text,marginBottom:"4px"},planPrice:{fontSize:"14px",color:t.textMuted,marginBottom:"8px"},planDescription:{fontSize:"12px",color:t.textFaint,marginBottom:"12px"},currentBadge:{display:"inline-block",padding:"4px 8px",backgroundColor:t.primary,color:"#fff",borderRadius:"4px",fontSize:"12px",fontWeight:500},changePlanButton:{padding:"8px 16px",backgroundColor:t.buttonBg,border:`1px solid ${t.buttonBorder}`,borderRadius:"6px",color:t.buttonText,cursor:"pointer",fontSize:"14px",width:"100%"},actions:{display:"flex",gap:"12px",justifyContent:"flex-end",paddingTop:"16px",borderTop:`1px solid ${t.border}`},portalButton:{padding:"10px 20px",backgroundColor:t.primary,border:"none",borderRadius:"6px",color:"#fff",cursor:"pointer",fontSize:"14px",fontWeight:500},cancelSubscriptionButton:{padding:"10px 20px",backgroundColor:t.bg,border:`1px solid ${t.error}`,borderRadius:"6px",color:t.error,cursor:"pointer",fontSize:"14px"}}}function Y(e,t){return new Intl.NumberFormat("en-US",{style:"currency",currency:t.toUpperCase()}).format(e/100)}function qe(e){return new Date(e).toLocaleDateString("en-US",{year:"numeric",month:"long",day:"numeric"})}function _t(e){switch(e){case"active":return"#22c55e";case"trialing":return"#3b82f6";case"past_due":return"#f59e0b";case"canceled":case"expired":return"#ef4444";default:return"#6b7280"}}function Tt({preview:e,onConfirm:t,onCancel:r,isLoading:s,styles:n}){const u=e.immediateAmount<0;return i.jsxs("div",{className:"cedros-proration-preview",style:n.prorationPreview,children:[i.jsx("h4",{style:n.previewTitle,children:"Change Preview"}),i.jsxs("div",{style:n.previewDetails,children:[i.jsxs("div",{style:n.previewRow,children:[i.jsx("span",{children:"Current plan:"}),i.jsxs("span",{children:[Y(e.currentPlanPrice,e.currency),"/period"]})]}),i.jsxs("div",{style:n.previewRow,children:[i.jsx("span",{children:"New plan:"}),i.jsxs("span",{children:[Y(e.newPlanPrice,e.currency),"/period"]})]}),i.jsxs("div",{style:n.previewRow,children:[i.jsx("span",{children:"Days remaining:"}),i.jsxs("span",{children:[e.daysRemaining," days"]})]}),e.prorationDetails&&i.jsxs(i.Fragment,{children:[i.jsxs("div",{style:n.previewRow,children:[i.jsx("span",{children:"Unused credit:"}),i.jsxs("span",{children:["-",Y(e.prorationDetails.unusedCredit,e.currency)]})]}),i.jsxs("div",{style:n.previewRow,children:[i.jsx("span",{children:"New plan cost:"}),i.jsx("span",{children:Y(e.prorationDetails.newPlanCost,e.currency)})]})]}),i.jsxs("div",{style:{...n.previewRow,...n.previewTotal},children:[i.jsx("span",{children:u?"Credit to account:":"Amount due now:"}),i.jsx("span",{style:{color:u?"#22c55e":"#ef4444"},children:Y(Math.abs(e.immediateAmount),e.currency)})]}),i.jsxs("div",{style:n.previewRow,children:[i.jsx("span",{children:"Effective date:"}),i.jsx("span",{children:qe(e.effectiveDate)})]})]}),i.jsxs("div",{style:n.previewActions,children:[i.jsx("button",{onClick:r,style:n.cancelButton,disabled:s,children:"Cancel"}),i.jsx("button",{onClick:t,style:n.confirmButton,disabled:s,children:s?"Processing...":"Confirm Change"})]})]})}function It({resource:e,userId:t,availablePlans:r=[],onSubscriptionChanged:s,onSubscriptionCanceled:n,billingPortalReturnUrl:u,showBillingPortal:h=!1,className:x,style:C}){const{mode:l}=S.useCedrosTheme(),a=f.useMemo(()=>Rt(l==="dark"),[l]),{subscription:o,changePreview:d,status:p,error:c,loadSubscription:m,previewChange:g,changeSubscription:y,cancelSubscription:b,openBillingPortal:R,clearPreview:P}=Ie();f.useEffect(()=>{m(e,t)},[e,t,m]);const v=f.useRef(null),I=f.useCallback(async(w,k)=>{v.current={resource:w,interval:k},await g(e,w,t,k)},[e,t,g]),B=f.useCallback(async()=>{if(!d)return;const w=v.current;(await y({newResource:w?.resource||e,newInterval:w?.interval,immediate:!0}))?.success&&w&&w.interval&&(s?.(w.resource,w.interval),v.current=null)},[d,e,y,s]),A=f.useCallback(async w=>{(await b(w))?.success&&n?.()},[b,n]),$=f.useCallback(()=>{R(t,u)},[t,u,R]),q=p==="loading";return i.jsxs("div",{className:`cedros-subscription-panel ${x||""}`,style:{...a.container,...C},children:[c&&i.jsx("div",{className:"cedros-subscription-error",style:a.error,children:c}),q&&!o&&i.jsx("div",{className:"cedros-subscription-loading",style:a.loading,children:"Loading subscription..."}),o&&i.jsxs(i.Fragment,{children:[i.jsxs("div",{className:"cedros-subscription-details",style:a.details,children:[i.jsx("h3",{style:a.title,children:"Current Subscription"}),i.jsxs("div",{style:a.detailRow,children:[i.jsx("span",{style:a.label,children:"Plan:"}),i.jsx("span",{style:a.value,children:o.resource})]}),i.jsxs("div",{style:a.detailRow,children:[i.jsx("span",{style:a.label,children:"Status:"}),i.jsx("span",{style:{...a.statusBadge,backgroundColor:_t(o.status)},children:o.status})]}),i.jsxs("div",{style:a.detailRow,children:[i.jsx("span",{style:a.label,children:"Price:"}),i.jsxs("span",{style:a.value,children:[Y(o.pricePerPeriod,o.currency),"/",o.interval]})]}),i.jsxs("div",{style:a.detailRow,children:[i.jsx("span",{style:a.label,children:"Current period ends:"}),i.jsx("span",{style:a.value,children:qe(o.currentPeriodEnd)})]}),o.cancelAtPeriodEnd&&i.jsx("div",{style:a.cancelNotice,children:"Subscription will cancel at end of current period"})]}),d&&i.jsx(Tt,{preview:d,onConfirm:B,onCancel:P,isLoading:q,styles:a}),r.length>0&&!d&&i.jsxs("div",{className:"cedros-available-plans",style:a.plansSection,children:[i.jsx("h4",{style:a.plansTitle,children:"Available Plans"}),i.jsx("div",{style:a.plansList,children:r.map(w=>{const k=w.resource===o.resource;return i.jsxs("div",{style:{...a.planCard,...k?a.currentPlan:{}},children:[i.jsx("div",{style:a.planName,children:w.name}),i.jsxs("div",{style:a.planPrice,children:[Y(w.price,w.currency),"/",w.interval]}),w.description&&i.jsx("div",{style:a.planDescription,children:w.description}),k?i.jsx("span",{style:a.currentBadge,children:"Current Plan"}):i.jsx("button",{onClick:()=>I(w.resource,w.interval),style:a.changePlanButton,disabled:q,children:w.price>o.pricePerPeriod?"Upgrade":"Downgrade"})]},w.resource)})})]}),i.jsxs("div",{className:"cedros-subscription-actions",style:a.actions,children:[h&&o.paymentMethod==="stripe"&&i.jsx("button",{onClick:$,style:a.portalButton,disabled:q,children:"Manage Billing"}),o.status==="active"&&!o.cancelAtPeriodEnd&&i.jsx("button",{onClick:()=>A(!1),style:a.cancelSubscriptionButton,disabled:q,children:"Cancel Subscription"})]})]})]})}function qt(){if(typeof window>"u")return{passed:!0,severity:"info",message:"HTTPS check skipped (SSR environment)"};const e=window.location.protocol==="https:",t=window.location.hostname==="localhost"||window.location.hostname==="127.0.0.1";return e||t?{passed:!0,severity:"info",message:"HTTPS enforced"}:{passed:!1,severity:"error",message:"Page not served over HTTPS",recommendation:"Enable HTTPS for all payment pages. Stripe.js requires HTTPS in production."}}function Lt(){return typeof document>"u"?{passed:!0,severity:"info",message:"CSP check skipped (SSR environment)"}:document.querySelector('meta[http-equiv="Content-Security-Policy"]')?{passed:!0,severity:"info",message:"Content Security Policy detected"}:{passed:!1,severity:"warning",message:"No Content Security Policy detected",recommendation:"Configure CSP headers to protect against XSS and CDN compromise. Use generateCSP() helper from @cedros/pay-react."}}function Nt(){return process.env.NODE_ENV==="development"||typeof window<"u"&&window.location.hostname==="localhost"?{passed:!0,severity:"info",message:"Running in development mode (some security checks relaxed)"}:{passed:!0,severity:"info",message:"Running in production mode"}}function Dt(){return{passed:!0,severity:"info",message:"Stripe.js loaded via @stripe/stripe-js package (CSP recommended, not SRI)",recommendation:"Ensure CSP script-src includes https://js.stripe.com"}}function Bt(){return typeof window>"u"?{passed:!0,severity:"info",message:"Mixed content check skipped (SSR environment)"}:window.location.protocol==="https:"?{passed:!0,severity:"info",message:"Mixed content protection active (HTTPS page)"}:{passed:!0,severity:"info",message:"Mixed content check skipped (HTTP page)"}}function $t(){const e=[qt(),Lt(),Nt(),Dt(),Bt()],t=e.some(u=>u.severity==="error"&&!u.passed),r=e.some(u=>u.severity==="warning"&&!u.passed);let s,n;return t?(s="vulnerable",n="Security issues detected. Review errors and apply recommendations."):r?(s="warnings",n="Minor security warnings detected. Consider applying recommendations."):(s="secure",n="All security checks passed."),{checks:e,overallStatus:s,summary:n}}function At(e){process.env.NODE_ENV!=="production"&&(console.group("🔒 Cedros Pay Security Report"),console.log(`Status: ${e.overallStatus.toUpperCase()}`),console.log(`Summary: ${e.summary}`),console.log(""),e.checks.forEach(t=>{const r=t.passed?"✅":t.severity==="error"?"❌":"⚠️";console.log(`${r} ${t.message}`),t.recommendation&&console.log(` → ${t.recommendation}`)}),console.groupEnd())}const zt={CSP:"Use generateCSP() from @cedros/pay-react to generate Content Security Policy headers",HTTPS:"Always serve payment pages over HTTPS in production",PACKAGE_UPDATES:"Keep @stripe/stripe-js and @cedros/pay-react updated for security patches",AUDIT:"Run npm audit regularly to check for known vulnerabilities",MONITORING:"Monitor Stripe security advisories and apply updates promptly",NO_SRI:"Do NOT use SRI hashes for Stripe.js - use CSP instead"};exports.CEDROS_EVENTS=W;exports.CSP_PRESETS=pt;exports.CedrosPay=St;exports.CreditsButton=fe;exports.CreditsSubscribeButton=kt;exports.PaymentMethodBadge=vt;exports.PaymentModal=Me;exports.ProductPrice=Pt;exports.PurchaseButton=Re;exports.RPC_PROVIDERS=dt;exports.SECURITY_RECOMMENDATIONS=zt;exports.StripeButton=pe;exports.SubscribeButton=jt;exports.SubscriptionManagementPanel=It;exports.calculateDiscountPercentage=Qe;exports.createDedupedClickHandler=K;exports.createTranslator=ke;exports.detectLocale=ve;exports.emitPaymentError=F;exports.emitPaymentProcessing=J;exports.emitPaymentStart=X;exports.emitPaymentSuccess=Z;exports.emitWalletConnect=st;exports.emitWalletConnected=nt;exports.emitWalletError=ot;exports.formatCSP=Pe;exports.formatCouponCodes=Ye;exports.generateCSP=ut;exports.generateCSPDirectives=Se;exports.getAvailableLocales=mt;exports.getCartItemCount=ee;exports.getLocalizedError=gt;exports.getModalCloseButtonStyles=we;exports.getUserErrorMessage=at;exports.isRetryableError=it;exports.loadLocale=je;exports.logSecurityReport=At;exports.normalizeCartItems=ie;exports.parseCouponCodes=He;exports.stackCheckoutCoupons=Ve;exports.useCreditsPayment=Ee;exports.useCreditsSubscription=Te;exports.useLocalizedError=ht;exports.usePaymentMode=te;exports.useStripeCheckout=de;exports.useSubscription=_e;exports.useSubscriptionManagement=Ie;exports.useTranslation=V;exports.validateSecurity=$t;