@cedros/pay-react 1.1.30 → 1.1.32

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 (136) hide show
  1. package/README.md +53 -30
  2. package/dist/{AISettingsSection-BMh3hAb5.mjs → AISettingsSection-ChBtZVz7.mjs} +4 -4
  3. package/dist/{AISettingsSection-C0zqPbd6.js → AISettingsSection-DSROL7Lg.js} +2 -2
  4. package/dist/{AutosaveIndicator-3ctAnz8Y.mjs → AutosaveIndicator-BTa2YPNH.mjs} +1 -1
  5. package/dist/AutosaveIndicator-BgDnlrCW.js +1 -0
  6. package/dist/CedrosContext-3Dz7_9Ct.js +3 -0
  7. package/dist/{CedrosContext-5Gjveoba.mjs → CedrosContext-DQc_k5PG.mjs} +430 -314
  8. package/dist/ChatLogsSection-B5AdoZls.js +1 -0
  9. package/dist/{ChatLogsSection-BtJixYAp.mjs → ChatLogsSection-D8FX7Dmn.mjs} +2 -2
  10. package/dist/{ComplianceSection-BMnb1p4w.mjs → ComplianceSection-A1hgI_X2.mjs} +3 -3
  11. package/dist/ComplianceSection-UWfkNrmW.js +1 -0
  12. package/dist/CryptoButton-BQceZhbn.js +1 -0
  13. package/dist/{CryptoButton-Cl2kZbOP.mjs → CryptoButton-BuO_RZLj.mjs} +4 -5
  14. package/dist/{CustomersSection-dmwoBhcf.mjs → CustomersSection-BuSVgS16.mjs} +2 -2
  15. package/dist/CustomersSection-Rh552kcC.js +1 -0
  16. package/dist/DisputesSection-BtMdxOuD.js +1 -0
  17. package/dist/{DisputesSection-CHyLne76.mjs → DisputesSection-DqWrBCyC.mjs} +2 -2
  18. package/dist/Dropdown-CWYy2Rtt.js +1 -0
  19. package/dist/{Dropdown-BRSZlhik.mjs → Dropdown-DHCHYuTB.mjs} +1 -1
  20. package/dist/{ErrorBanner-lZJhCmDX.mjs → ErrorBanner-7naZtdtD.mjs} +1 -1
  21. package/dist/ErrorBanner-BOS1XAPu.js +1 -0
  22. package/dist/FAQSection-DczKj0C3.js +1 -0
  23. package/dist/{FAQSection-Di2xE9Sm.mjs → FAQSection-x0ya8PvI.mjs} +3 -3
  24. package/dist/{ImagesSection-D63PEjR6.mjs → ImagesSection-CMvHgbtL.mjs} +2 -2
  25. package/dist/ImagesSection-tRpBN-ls.js +1 -0
  26. package/dist/{InventorySection-Dp5Yu4TA.mjs → InventorySection-5PEOXciZ.mjs} +2 -2
  27. package/dist/InventorySection-clEVFr_r.js +1 -0
  28. package/dist/MessagingSection-BpwTsNW1.js +1 -0
  29. package/dist/{MessagingSection-BLCnCpEv.mjs → MessagingSection-Bt84iW-5.mjs} +3 -3
  30. package/dist/OrdersSection-Bsou3cwl.js +1 -0
  31. package/dist/{OrdersSection-Bd56F3cj.mjs → OrdersSection-kJzPO6CP.mjs} +2 -2
  32. package/dist/{PaymentSettingsSection-B5J56VAk.js → PaymentSettingsSection-CUgUJ7tm.js} +1 -1
  33. package/dist/{PaymentSettingsSection-52iw47Su.mjs → PaymentSettingsSection-s_XMFPik.mjs} +3 -3
  34. package/dist/{ReturnsSection-DUVeKrCd.mjs → ReturnsSection-BcwsQbrU.mjs} +2 -2
  35. package/dist/ReturnsSection-BwHv1HkV.js +1 -0
  36. package/dist/{SettingsSection-DKkHykaC.js → SettingsSection-B_feZEzU.js} +1 -1
  37. package/dist/{SettingsSection-vK9WIwXE.mjs → SettingsSection-OI1G3b40.mjs} +1 -1
  38. package/dist/{ShippingSection-CZRrXrlh.mjs → ShippingSection-B2GtSEvn.mjs} +2 -2
  39. package/dist/ShippingSection-DyTGH_Fh.js +1 -0
  40. package/dist/{SingleCategorySettings-C8xJ47_T.mjs → SingleCategorySettings-Cd76sY00.mjs} +4 -4
  41. package/dist/SingleCategorySettings-Ci6hJ0Xu.js +3 -0
  42. package/dist/{StatsBar-D4cOKG2e.mjs → StatsBar-B_lf0ph0.mjs} +1 -1
  43. package/dist/StatsBar-CVqsD8j2.js +1 -0
  44. package/dist/StorefrontSection-BxaWrsPc.js +1 -0
  45. package/dist/{StorefrontSection-uXSVbEAa.mjs → StorefrontSection-DW0q9GsC.mjs} +4 -4
  46. package/dist/{SubscriptionsSection-Ci_AZrWA.mjs → SubscriptionsSection-CNHPCync.mjs} +3 -3
  47. package/dist/SubscriptionsSection-QMoSKKot.js +1 -0
  48. package/dist/TaxSection-BKhh7kOv.js +1 -0
  49. package/dist/{TaxSection-BTukS_cU.mjs → TaxSection-BwLpiery.mjs} +2 -2
  50. package/dist/Token22Section-B_URxab9.js +1 -0
  51. package/dist/{Token22Section-DRsPJuTq.mjs → Token22Section-DyNDKGdU.mjs} +227 -212
  52. package/dist/{WalletManager-D-eoqUDy.mjs → WalletManager-CGR69MiR.mjs} +1 -1
  53. package/dist/{WalletManager-DXChB9LA.js → WalletManager-ZJbGQHrn.js} +1 -1
  54. package/dist/WebhooksSection-BIs2Qh-o.js +1 -0
  55. package/dist/{WebhooksSection-A8Y4ZGcj.mjs → WebhooksSection-bDVQE9Qp.mjs} +2 -2
  56. package/dist/admin.js +1 -1
  57. package/dist/admin.mjs +1 -1
  58. package/dist/crypto-only.js +1 -1
  59. package/dist/crypto-only.mjs +102 -105
  60. package/dist/{index-9QF_UfSN.mjs → index-CU6M10Rs.mjs} +13 -14
  61. package/dist/{index-Cq9ya93W.js → index-DVxx_62C.js} +10 -10
  62. package/dist/index.js +1 -1
  63. package/dist/index.mjs +31 -34
  64. package/dist/pay-react.css +1 -1
  65. package/dist/plugin-CuoGEYWr.mjs +339 -0
  66. package/dist/plugin-DNhaPAbC.js +1 -0
  67. package/dist/sections-BYdyCKFF.js +1 -0
  68. package/dist/{sections-more-Ixw6mM6R.mjs → sections-vLd_ind5.mjs} +263 -270
  69. package/dist/src/admin/plugin.d.ts.map +1 -1
  70. package/dist/src/admin/sectionIds.d.ts.map +1 -1
  71. package/dist/src/admin.d.ts +0 -7
  72. package/dist/src/admin.d.ts.map +1 -1
  73. package/dist/src/components/admin/LiquidityPoolTab.d.ts.map +1 -1
  74. package/dist/src/components/admin/PoolManagementView.d.ts.map +1 -1
  75. package/dist/src/components/admin/index.d.ts +0 -1
  76. package/dist/src/components/admin/index.d.ts.map +1 -1
  77. package/dist/src/index.d.ts +0 -1
  78. package/dist/src/index.d.ts.map +1 -1
  79. package/dist/src/managers/MeteoraPoolManager.d.ts.map +1 -1
  80. package/dist/src/utils/optionalPeerImport.d.ts +6 -0
  81. package/dist/src/utils/optionalPeerImport.d.ts.map +1 -0
  82. package/dist/stripe-only.js +1 -1
  83. package/dist/stripe-only.mjs +18 -19
  84. package/dist/styles-BwaDljnz.js +1 -0
  85. package/dist/{styles-DGagylUj.mjs → styles-fihm6qVA.mjs} +51 -52
  86. package/dist/testing/index.js +1 -1
  87. package/dist/testing/index.mjs +1 -1
  88. package/package.json +6 -8
  89. package/dist/AutosaveIndicator-DXRPr4P7.js +0 -1
  90. package/dist/CedrosContext-CCakH2SZ.js +0 -3
  91. package/dist/CedrosPayAdminDashboard-DaJ9JoGn.mjs +0 -250
  92. package/dist/CedrosPayAdminDashboard-Uvyh9p7A.js +0 -1
  93. package/dist/ChatLogsSection-FC3O536G.js +0 -1
  94. package/dist/ComplianceSection-BioTKm7k.js +0 -1
  95. package/dist/CryptoButton-DxFCYDlJ.js +0 -1
  96. package/dist/CustomersSection-z6ARxuex.js +0 -1
  97. package/dist/DisputesSection-BjHHQAi7.js +0 -1
  98. package/dist/Dropdown-j8o0OO5L.js +0 -1
  99. package/dist/ErrorBanner-CAgPnj62.js +0 -1
  100. package/dist/FAQSection-b34DMzgV.js +0 -1
  101. package/dist/ImagesSection-DGBA7iKY.js +0 -1
  102. package/dist/InventorySection-bVCECzX5.js +0 -1
  103. package/dist/LazyCedrosPayAdminDashboard-BqJDNrDI.mjs +0 -9
  104. package/dist/LazyCedrosPayAdminDashboard-CpfTtOBc.js +0 -1
  105. package/dist/MessagingSection-DU0dYNMy.js +0 -1
  106. package/dist/OrdersSection-FOFEAgs1.js +0 -1
  107. package/dist/ReturnsSection-BjpIVFfN.js +0 -1
  108. package/dist/ShippingSection-B5lk7zpS.js +0 -1
  109. package/dist/SingleCategorySettings-g7D-9lG1.js +0 -3
  110. package/dist/StatsBar-CWXw2ZT3.js +0 -1
  111. package/dist/StorefrontSection-BWnMB9k-.js +0 -1
  112. package/dist/SubscriptionsSection-DQfXkuDv.js +0 -1
  113. package/dist/TaxSection-cuPQISxZ.js +0 -1
  114. package/dist/ThemeContext-CFXyYx7A.js +0 -1
  115. package/dist/ThemeContext-l0bqcOGW.mjs +0 -126
  116. package/dist/Token22Section-CCfkDm8W.js +0 -1
  117. package/dist/WebhooksSection-CnEmaGH1.js +0 -1
  118. package/dist/icons-C3yDMnKE.mjs +0 -235
  119. package/dist/icons-Cjgd9YVo.js +0 -1
  120. package/dist/pay-react_false-CPX8Vyp9.mjs +0 -5
  121. package/dist/pay-react_false-DaeIe3_l.js +0 -1
  122. package/dist/sectionIds-D46-_-h-.js +0 -1
  123. package/dist/sectionIds-YktNxmRt.mjs +0 -124
  124. package/dist/sections-511_XBh4.js +0 -1
  125. package/dist/sections-CRaMa8ZB.mjs +0 -9
  126. package/dist/sections-more-Cgw2qJlA.js +0 -1
  127. package/dist/src/components/admin/CedrosPayAdminDashboard.d.ts +0 -40
  128. package/dist/src/components/admin/CedrosPayAdminDashboard.d.ts.map +0 -1
  129. package/dist/src/components/admin/LazyCedrosPayAdminDashboard.d.ts +0 -4
  130. package/dist/src/components/admin/LazyCedrosPayAdminDashboard.d.ts.map +0 -1
  131. package/dist/src/standalone-admin.d.ts +0 -8
  132. package/dist/src/standalone-admin.d.ts.map +0 -1
  133. package/dist/standalone-admin.d.ts +0 -2
  134. package/dist/standalone-admin.js +0 -1
  135. package/dist/standalone-admin.mjs +0 -4
  136. package/dist/styles--fxb3lCl.js +0 -1
@@ -1 +0,0 @@
1
- "use strict";var ze=Object.create;var Ce=Object.defineProperty;var Ue=Object.getOwnPropertyDescriptor;var Oe=Object.getOwnPropertyNames;var Fe=Object.getPrototypeOf,We=Object.prototype.hasOwnProperty;var He=(e,t,r,s)=>{if(t&&typeof t=="object"||typeof t=="function")for(let n of Oe(t))!We.call(e,n)&&n!==r&&Ce(e,n,{get:()=>t[n],enumerable:!(s=Ue(t,n))||s.enumerable});return e};var Ye=(e,t,r)=>(r=e!=null?ze(Fe(e)):{},He(t||!e||!e.__esModule?Ce(r,"default",{value:e,enumerable:!0}):r,e));const z=require("./CedrosContext-CCakH2SZ.js"),i=require("react/jsx-runtime"),f=require("react"),q=require("./fetchWithTimeout-CG0EKbhf.js"),H=require("./ThemeContext-CFXyYx7A.js");function Qe(e){return!e||!e.coupon_codes?[]:e.coupon_codes.split(",").map(t=>t.trim()).filter(t=>t.length>0)}function Ve(e,t=", "){return e.join(t)}function Ge(e,t){return e<=0?0:(e-t)/e*100}function Ke(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 we(e){const t=Number(e);if(!Number.isFinite(t)||t<=0)return 1;const r=Math.floor(t);return r>0?r:1}function ce(e){return e.map(t=>({resource:t.resource,quantity:we(t.quantity),variantId:t.variantId,metadata:t.metadata}))}function re(e){return e.reduce((t,r)=>t+we(r.quantity),0)}function Xe(e){return!!(e&&e.length>0&&(e.length>1||e.length===1&&(e[0].quantity??1)>1))}const X=new Map,de=new Map,Q=new Map,le=1e3,Se=200,pe=2e3;function Je(e){const t=Q.get(e);return t?Date.now()<t?!0:(Q.delete(e),!1):!1}function Ze(e,t=Se){const r=Date.now()+t;if(Q.set(e,r),Q.size>le){const s=Array.from(Q.keys()).slice(0,Q.size-le);for(const n of s)Q.delete(n)}}function et(e,t=pe){const r=X.get(e);if(!r)return!1;const n=Date.now()-r;return n<t?(q.getLogger().debug(`[Deduplication] Duplicate request blocked: ${e} (${n}ms ago)`),!0):!1}function tt(e){if(X.set(e,Date.now()),X.size>le){const t=Array.from(X.keys()).slice(0,X.size-le);for(const r of t)X.delete(r)}}function rt(e){return de.get(e)||null}function st(e,t){de.set(e,t);const r=()=>{de.delete(e),tt(e)};return t.then(r,r),t}async function nt(e,t,r={}){const{windowMs:s=pe,throwOnDuplicate:n=!0}=r,u=rt(e);if(u)return q.getLogger().debug(`[Deduplication] Reusing in-flight request: ${e}`),u;if(et(e,s)){if(n)throw new Error(`Duplicate request blocked: ${e}`);q.getLogger().warn(`[Deduplication] Duplicate request blocked but not throwing: ${e}`);return}const h=t();return st(e,h)}function J(e,t,r={}){const{cooldownMs:s=Se,deduplicationWindowMs:n=pe}=r;return async()=>{if(Je(e)){q.getLogger().debug(`[Deduplication] Button in cooldown: ${e}`);return}Ze(e,s);try{await nt(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 Pe(e){return{background:"none",border:"none",fontSize:"1.5rem",cursor:"pointer",color:e,opacity:.6,padding:"0.25rem",lineHeight:1}}const Y={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 G(e,t){if(typeof window>"u")return;const r=new CustomEvent(e,{detail:t,bubbles:!0,cancelable:!1});window.dispatchEvent(r)}function Z(e,t,r){G(Y.PAYMENT_START,{timestamp:Date.now(),method:e,resource:t,itemCount:r})}function ot(e){G(Y.WALLET_CONNECT,{timestamp:Date.now(),wallet:e})}function it(e,t){G(Y.WALLET_CONNECTED,{timestamp:Date.now(),wallet:e,publicKey:t})}function at(e,t){G(Y.WALLET_ERROR,{timestamp:Date.now(),wallet:t,error:e})}function ee(e,t,r){G(Y.PAYMENT_PROCESSING,{timestamp:Date.now(),method:e,resource:t,itemCount:r})}function te(e,t,r,s){G(Y.PAYMENT_SUCCESS,{timestamp:Date.now(),method:e,transactionId:t,resource:r,itemCount:s})}function W(e,t,r,s){G(Y.PAYMENT_ERROR,{timestamp:Date.now(),method:e,error:t,resource:r,itemCount:s})}function ct(e){return e instanceof z.PaymentError&&e.canRetry()}function lt(e){return e instanceof z.PaymentError?e.getUserMessage():e instanceof Error?e.message:String(e)}function ut(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 dt(e){try{const t=new URL(e);return`${t.protocol}//${t.host}`}catch{return e}}function ve(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=ut(t);if(o.push(p),r){const c=dt(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 je(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 pt(e={},t="header"){const r=ve(e);return je(r,t)}const ft={HELIUS:"https://*.helius-rpc.com",QUICKNODE:"https://*.quicknode.pro",ALCHEMY:"https://*.alchemy.com",ANKR:"https://rpc.ankr.com",TRITON:"https://*.rpcpool.com"},mt={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 fe(){const{stripeManager:e}=z.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,M)=>{if(s.current)return{success:!1,error:"Payment already in progress"};s.current=!0,r({status:"loading",error:null,transactionId:null});const S=ce(x);try{const P=await e.processCartCheckout({items:S,successUrl:C,cancelUrl:l,metadata:a,customerEmail:o,customerName:p,customerPhone:c,shippingAddress:m,billingAddress:g,couponCode:d,tipAmount:y,shippingMethodId:b,paymentMethodId:M});return r({status:P.success?"success":"error",error:P.success?null:P.error||"Cart checkout failed",transactionId:P.success&&P.transactionId||null}),P}catch(P){const _=P instanceof Error?P.message:"Cart checkout failed";return r({status:"error",error:_,transactionId:null}),{success:!1,error:_}}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 se(e,t){return f.useMemo(()=>{const r=Xe(t),s=e||(t?.length===1?t[0].resource:"");return{isCartMode:r,effectiveResource:s}},[e,t])}const gt=(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.":""))))})},ue=new Map;let ae=null;async function xe(e){if(ue.has(e))return ue.get(e);try{const t=await gt(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 ue.set(e,r),r}catch{return null}}async function ht(){if(ae)return ae;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 ae=t.length>0?t:["en"],ae}function ke(){return typeof navigator>"u"?"en":(navigator.language||navigator.userLanguage||"en").split("-")[0].toLowerCase()}async function Ee(e){let t=await xe(e);if(t||(t=await xe("en"),t))return t;throw new Error("Critical: No translation files found, not even en.json")}function Me(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 yt(e,t,r=!0){const s=t.errors[e];if(!s){const n=z.getUserFriendlyError(e);return r&&n.action?`${n.message} ${n.action}`:n.message}return r&&s.action?`${s.message} ${s.action}`:s.message}function K(e){const[t,r]=f.useState(null),[s,n]=f.useState(!0),u=f.useMemo(()=>e||ke(),[e]);return f.useEffect(()=>{let x=!1;return(async()=>{n(!0);try{const l=await Ee(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?Me(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 bt(e,t=!0){const{translations:r}=K();if(!r){const n=z.getUserFriendlyError(e);return t&&n.action?`${n.message} ${n.action}`:n.message}const s=r.errors[e];if(!s){const n=z.getUserFriendlyError(e);return t&&n.action?`${n.message} ${n.action}`:n.message}return t&&s.action?`${s.message} ${s.action}`:s.message}function me({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}=fe(),b=H.useCedrosTheme(),{isCartMode:M,effectiveResource:S}=se(e,t),{t:P,translations:_}=K(),B=x||P("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:(v=>{if(!v||!_)return"";const E=_.errors[v];return E?E.action?`${E.message} ${E.action}`:E.message:""})($):null,j=f.useCallback(async()=>{q.getLogger().debug("[StripeButton] executePayment with couponCode:",h);const v=M&&t?re(t):void 0;if(Z("stripe",S,v),l&&l("stripe"),!M&&!S){const O="Invalid payment configuration: missing resource or items";q.getLogger().error("[StripeButton]",O),W("stripe",O,S,v),o&&o(O);return}let E;ee("stripe",S,v),M&&t?(q.getLogger().debug("[StripeButton] Processing cart checkout with coupon:",h),E=await y(t,r,s,n,u,h)):S&&(q.getLogger().debug("[StripeButton] Processing single payment with coupon:",h),E=await g(S,r,s,n,u,h)),E&&E.success&&E.transactionId?(te("stripe",E.transactionId,S,v),a&&a(E.transactionId)):E&&!E.success&&E.error&&(W("stripe",E.error,S,v),o&&o(E.error))},[h,M,S,t,r,s,n,u,y,g,l,a,o]),D=f.useMemo(()=>M&&t?`stripe-cart-${t.map(v=>v.resource).join("-")}`:`stripe-${S||"unknown"}`,[M,t,S]),k=f.useMemo(()=>J(D,j),[D,j]),T=p==="loading",R=C||T;return i.jsxs("div",{className:A,style:b.unstyled?{}:b.style,children:[i.jsx("button",{onClick:k,disabled:R,className:b.unstyled?d:"cedros-theme__button cedros-theme__stripe",type:"button",children:T?P("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:P("ui.payment_successful")})]})}function Re(){const{creditsManager:e}=z.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=ce(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=ce(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){q.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){q.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 ge({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}=Re(),g=H.useCedrosTheme(),{isCartMode:y,effectiveResource:b}=se(e,t),{t:M,translations:S}=K(),P=u||M("ui.pay_with_credits")||"Pay with Credits",_=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||!S)return"";const R=S.errors[T];return R?R.action?`${R.message} ${R.action}`:R.message:""})(B):null,I=f.useCallback(async()=>{q.getLogger().debug("[CreditsButton] executePayment");const T=y&&t?re(t):void 0;if(Z("credits",b,T),x&&x("credits"),!r){const v="Authentication required: please log in to pay with credits";q.getLogger().error("[CreditsButton]",v),W("credits",v,b,T),l&&l(v);return}if(!y&&!b){const v="Invalid payment configuration: missing resource";q.getLogger().error("[CreditsButton]",v),W("credits",v,b,T),l&&l(v);return}let R;ee("credits",b,T),y&&t?(q.getLogger().debug("[CreditsButton] Processing cart checkout"),R=await m(t,r,n,s)):b&&(q.getLogger().debug("[CreditsButton] Processing single payment"),R=await c(b,r,n,s)),R&&R.success&&R.transactionId?(te("credits",R.transactionId,b,T),C&&C(R.transactionId)):R&&!R.success&&R.error&&(W("credits",R.error,b,T),l&&l(R.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]),j=f.useMemo(()=>J(w,I),[w,I]),D=o==="loading",k=h||D;return i.jsxs("div",{className:_,style:g.unstyled?{}:g.style,children:[i.jsx("button",{onClick:j,disabled:k,className:g.unstyled?a:"cedros-theme__button cedros-theme__credits",type:"button",children:D?M("ui.processing"):P}),$&&i.jsx("div",{className:g.unstyled?"":"cedros-theme__error",children:$}),p&&i.jsx("div",{className:g.unstyled?"":"cedros-theme__success",children:M("ui.payment_successful")})]})}const Ct=f.lazy(()=>Promise.resolve().then(()=>require("./CryptoButton-DxFCYDlJ.js")).then(e=>e.CryptoButton$1).then(e=>({default:e.CryptoButton}))),Te=({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:M,successUrl:S,cancelUrl:P,metadata:_,couponCode:B,authToken:A,testPageUrl:$,hideMessages:I=!1})=>{const{tokens:w}=H.useCedrosTheme();return f.useEffect(()=>{const j=D=>{D.key==="Escape"&&e&&t()};return window.addEventListener("keydown",j),()=>window.removeEventListener("keydown",j)},[e,t]),f.useEffect(()=>{if(e){const j=window.scrollY;return document.body.style.position="fixed",document.body.style.top=`-${j}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:j=>j.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:Pe(w.surfaceText),"aria-label":"Close modal",children:"×"})]}),i.jsxs("div",{style:{display:"flex",flexDirection:"column",gap:"1rem"},children:[x&&i.jsx(me,{resource:r,items:s,label:n,onAttempt:a,onSuccess:p||o,onError:g||d,customerEmail:M,successUrl:S,cancelUrl:P,metadata:_,couponCode:B}),C&&i.jsx(f.Suspense,{fallback:null,children:i.jsx(Ct,{resource:r,items:s,label:u,onAttempt:a,onSuccess:c||o,onError:y||d,testPageUrl:$,hideMessages:I,metadata:_,couponCode:B})}),l&&i.jsx(ge,{resource:r,items:s,label:h,authToken:A,onAttempt:a?()=>a("credits"):void 0,onSuccess:m||o,onError:b||d,metadata:_,couponCode:B})]})]})}):null},_e=({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:M,cancelUrl:S,metadata:P,couponCode:_,authToken:B,autoDetectWallets:A=!0,testPageUrl:$,hideMessages:I=!1,renderModal:w})=>{const j=H.useCedrosTheme(),[D,k]=f.useState(!1),{status:T,processPayment:R,processCartCheckout:v}=fe(),{isCartMode:E,effectiveResource:O}=se(e,t),{t:L}=K(),F=r||L("ui.purchase"),De=s||L("ui.card"),Be=n||L("ui.usdc_solana"),$e=u||L("ui.pay_with_credits")||"Pay with Credits",he=f.useCallback(async()=>{if(A&&h){const{detectSolanaWallets:N}=await Promise.resolve().then(()=>require("./walletDetection-bNmV5ItZ.js"));if(!N()){const oe=E?void 0:O,ie=E&&t?re(t):void 0;Z("stripe",oe,ie),l&&l("stripe"),ee("stripe",oe,ie);let U;E&&t?U=await v(t,M,S,P,b,_):O&&(U=await R(O,M,S,P,b,_)),U&&U.success&&U.transactionId?(te("stripe",U.transactionId,oe,ie),d?d(U.transactionId):a&&a(U.transactionId)):U&&!U.success&&U.error&&(W("stripe",U.error,oe,ie),m?m(U.error):o&&o(U.error));return}}k(!0)},[A,h,E,t,O,v,R,M,S,P,b,_,a,o,d,m,l]),ye=f.useMemo(()=>E&&t?`purchase-cart-${t.map(N=>N.resource).join("-")}`:`purchase-${O||"unknown"}`,[E,t,O]),Ae=f.useMemo(()=>J(ye,he),[ye,he]),ne=T==="loading",be={isOpen:D,onClose:()=>k(!1),resource:E?void 0:O,items:E?t:void 0,cardLabel:De,cryptoLabel:Be,creditsLabel:$e,showCard:h,showCrypto:x,showCredits:C,onPaymentAttempt:l,onPaymentSuccess:N=>{k(!1),a?.(N)},onPaymentError:N=>{k(!1),o?.(N)},onStripeSuccess:N=>{k(!1),d?.(N)},onCryptoSuccess:N=>{k(!1),p?.(N)},onCreditsSuccess:N=>{k(!1),c?.(N)},onStripeError:N=>{k(!1),m?.(N)},onCryptoError:N=>{k(!1),g?.(N)},onCreditsError:N=>{k(!1),y?.(N)},customerEmail:b,successUrl:M,cancelUrl:S,metadata:P,couponCode:_,authToken:B,testPageUrl:$,hideMessages:I};return i.jsxs("div",{className:j.unstyled?"":j.className,style:j.unstyled?{}:j.style,children:[i.jsx("button",{onClick:Ae,disabled:ne,className:j.unstyled?"":"cedros-theme__button cedros-theme__stripe",style:{width:"100%",cursor:ne?"not-allowed":"pointer",opacity:ne?.6:1},type:"button",children:ne?L("ui.processing"):F}),w?w(be):i.jsx(Te,{...be})]})},xt={"mainnet-beta":"https://api.mainnet-beta.solana.com",devnet:"https://api.devnet.solana.com",testnet:"https://api.testnet.solana.com"};function wt(){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 St({endpoint:e,wallets:t,children:r}){const s=wt();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 Pt=f.lazy(()=>Promise.resolve().then(()=>require("./CryptoButton-DxFCYDlJ.js")).then(e=>e.CryptoButton$1).then(e=>({default:e.CryptoButton})));function vt(e){const{resource:t,items:r,checkout:s={},display:n={},callbacks:u={},advanced:h={}}=e,{config:x,walletPool:C}=z.useCedrosContext(),l=H.useCedrosTheme(),{isCartMode:a}=se(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?re(r):0,[r]),{onPaymentSuccess:m,onPaymentError:g,onPaymentAttempt:y}=u,b=f.useCallback(v=>m?.({transactionId:v,method:"stripe"}),[m]),M=f.useCallback(v=>m?.({transactionId:v,method:"crypto"}),[m]),S=f.useCallback(v=>g?.({message:v,method:"stripe"}),[g]),P=f.useCallback(v=>g?.({message:v,method:"crypto"}),[g]),_=f.useCallback(v=>m?.({transactionId:v,method:"credits"}),[m]),B=f.useCallback(v=>g?.({message:v,method:"credits"}),[g]),A=f.useCallback(()=>y?.("credits"),[y]),$=o?x.solanaEndpoint??xt[x.solanaCluster]:"";if(!t&&(!r||r.length===0))return q.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 I=n.showCard??!0,w=n.showCredits??!1,j=n.showPurchaseButton??!1,D=n.layout??"vertical",k=n.hideMessages??!1,T=h.autoDetectWallets??!0,R=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:[j?i.jsx(_e,{resource:a?void 0:t||r?.[0]?.resource,items:a?r:void 0,label:n.purchaseLabel,cardLabel:n.cardLabel,cryptoLabel:n.cryptoLabel,showCard:I,showCrypto:o,onPaymentAttempt:u.onPaymentAttempt,onPaymentSuccess:b,onPaymentError:S,onStripeSuccess:b,onCryptoSuccess:M,onStripeError:S,onCryptoError:P,customerEmail:s.customerEmail,successUrl:s.successUrl,cancelUrl:s.cancelUrl,metadata:s.metadata,couponCode:s.couponCode,autoDetectWallets:T,testPageUrl:h.testPageUrl,hideMessages:k,renderModal:n.renderModal}):i.jsxs(i.Fragment,{children:[I&&i.jsx(me,{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:S}),o&&i.jsx(f.Suspense,{fallback:null,children:i.jsx(Pt,{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:M,onError:P,testPageUrl:h.testPageUrl,hideMessages:k})}),w&&i.jsx(ge,{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:_,onError:B})]}),a&&r&&r.length>1&&!k&&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(St,{endpoint:$||"https://api.devnet.solana.com",wallets:p,children:R})})}function jt({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 kt({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 Ie(){const{subscriptionManager:e}=z.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=z.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 Et({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}=Ie(),y=H.useCedrosTheme(),{t:b,translations:M}=K(),S=x||b("ui.subscribe"),P=y.unstyled?d:`${y.className} cedros-theme__stripe-button ${d}`.trim(),_=c&&typeof c!="string"?c?.code??null:null,A=c?typeof c=="string"?c:(k=>{if(!k||!M)return"";const T=M.errors[k];return T?T.action?`${T.message} ${T.action}`:T.message:""})(_):null,$=f.useCallback(async()=>{q.getLogger().debug("[SubscribeButton] executeSubscription:",{resource:e,interval:t,intervalDays:r,trialDays:s}),Z("stripe",e),l&&l("stripe"),ee("stripe",e);const k=await g({resource:e,interval:t,intervalDays:r,trialDays:s,customerEmail:h,successUrl:n,cancelUrl:u});k.success&&k.transactionId?(te("stripe",k.transactionId,e),a&&a(k.transactionId)):!k.success&&k.error&&(W("stripe",k.error,e),o&&o(k.error))},[e,t,r,s,h,n,u,g,l,a,o]),I=f.useMemo(()=>`subscribe-${e}-${t}`,[e,t]),w=f.useMemo(()=>J(I,$),[I,$]),j=p==="loading",D=C||j;return i.jsxs("div",{className:P,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:j?b("ui.processing"):S}),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 qe(){const{subscriptionManager:e,creditsManager:t}=z.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=z.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=z.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=z.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 Mt({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:M}=qe(),S=H.useCedrosTheme(),{t:P,translations:_}=K(),B=f.useRef(b);f.useEffect(()=>{B.current=b},[b]),f.useEffect(()=>{p&&n&&(q.getLogger().debug("[CreditsSubscribeButton] Auto-checking subscription status",{resource:e,userId:n}),B.current(e,n))},[p,n,e]);const A=h||P("ui.subscribe_with_credits")||"Subscribe with Credits",$=m&&typeof m!="string"?m?.code??null:null,w=m?typeof m=="string"?m:(L=>{if(!L||!_)return"";const F=_.errors[L];return F?F.action?`${F.message} ${F.action}`:F.message:""})($):null,j=f.useCallback(async()=>{if(q.getLogger().debug("[CreditsSubscribeButton] executeSubscriptionFlow",{resource:e,interval:t,intervalDays:r,hasAuthToken:!!s}),Z("credits",e),C&&C("credits"),!s){const F="Authentication required: please log in to subscribe with credits";q.getLogger().error("[CreditsSubscribeButton]",F),W("credits",F,e),a&&a(F);return}ee("credits",e);const L=await M(e,t,s,{couponCode:u,intervalDays:r});L.success&&L.transactionId?(te("credits",L.transactionId,e),l&&l(L.transactionId)):!L.success&&L.error&&(W("credits",L.error,e),a&&a(L.error))},[e,t,r,s,u,M,C,l,a]),D=f.useMemo(()=>`credits-subscribe-${e}-${t}`,[e,t]),k=f.useMemo(()=>J(D,j,{cooldownMs:200,deduplicationWindowMs:0}),[D,j]),T=c==="loading"||c==="checking",R=g==="active"||g==="trialing",v=x||T||R;let E=A;if(T)E=P("ui.processing");else if(R&&y){const L=new Date(y).toLocaleDateString();E=`${P("ui.subscribed_until")} ${L}`}else R&&(E=P("ui.subscribed"));const O=S.unstyled?o:`${S.className} cedros-theme__credits-button ${o}`.trim();return i.jsxs("div",{className:O,style:S.unstyled?{}:S.style,children:[i.jsx("button",{onClick:k,disabled:v,className:S.unstyled?o:"cedros-theme__button cedros-theme__credits",type:"button",children:E}),!d&&w&&i.jsx("div",{className:S.unstyled?"":"cedros-theme__error",children:w}),!d&&R&&i.jsx("div",{className:S.unstyled?"":"cedros-theme__success",children:P("ui.subscription_active")})]})}function Le(){const{subscriptionChangeManager:e}=z.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 Rt={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"},Tt={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 _t(e){const t=e?Tt:Rt;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 V(e,t){return new Intl.NumberFormat("en-US",{style:"currency",currency:t.toUpperCase()}).format(e/100)}function Ne(e){return new Date(e).toLocaleDateString("en-US",{year:"numeric",month:"long",day:"numeric"})}function It(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 qt({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:[V(e.currentPlanPrice,e.currency),"/period"]})]}),i.jsxs("div",{style:n.previewRow,children:[i.jsx("span",{children:"New plan:"}),i.jsxs("span",{children:[V(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:["-",V(e.prorationDetails.unusedCredit,e.currency)]})]}),i.jsxs("div",{style:n.previewRow,children:[i.jsx("span",{children:"New plan cost:"}),i.jsx("span",{children:V(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:V(Math.abs(e.immediateAmount),e.currency)})]}),i.jsxs("div",{style:n.previewRow,children:[i.jsx("span",{children:"Effective date:"}),i.jsx("span",{children:Ne(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 Lt({resource:e,userId:t,availablePlans:r=[],onSubscriptionChanged:s,onSubscriptionCanceled:n,billingPortalReturnUrl:u,showBillingPortal:h=!1,className:x,style:C}){const{mode:l}=H.useCedrosTheme(),a=f.useMemo(()=>_t(l==="dark"),[l]),{subscription:o,changePreview:d,status:p,error:c,loadSubscription:m,previewChange:g,changeSubscription:y,cancelSubscription:b,openBillingPortal:M,clearPreview:S}=Le();f.useEffect(()=>{m(e,t)},[e,t,m]);const P=f.useRef(null),_=f.useCallback(async(w,j)=>{P.current={resource:w,interval:j},await g(e,w,t,j)},[e,t,g]),B=f.useCallback(async()=>{if(!d)return;const w=P.current;(await y({newResource:w?.resource||e,newInterval:w?.interval,immediate:!0}))?.success&&w&&w.interval&&(s?.(w.resource,w.interval),P.current=null)},[d,e,y,s]),A=f.useCallback(async w=>{(await b(w))?.success&&n?.()},[b,n]),$=f.useCallback(()=>{M(t,u)},[t,u,M]),I=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}),I&&!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:It(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:[V(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:Ne(o.currentPeriodEnd)})]}),o.cancelAtPeriodEnd&&i.jsx("div",{style:a.cancelNotice,children:"Subscription will cancel at end of current period"})]}),d&&i.jsx(qt,{preview:d,onConfirm:B,onCancel:S,isLoading:I,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 j=w.resource===o.resource;return i.jsxs("div",{style:{...a.planCard,...j?a.currentPlan:{}},children:[i.jsx("div",{style:a.planName,children:w.name}),i.jsxs("div",{style:a.planPrice,children:[V(w.price,w.currency),"/",w.interval]}),w.description&&i.jsx("div",{style:a.planDescription,children:w.description}),j?i.jsx("span",{style:a.currentBadge,children:"Current Plan"}):i.jsx("button",{onClick:()=>_(w.resource,w.interval),style:a.changePlanButton,disabled:I,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:I,children:"Manage Billing"}),o.status==="active"&&!o.cancelAtPeriodEnd&&i.jsx("button",{onClick:()=>A(!1),style:a.cancelSubscriptionButton,disabled:I,children:"Cancel Subscription"})]})]})]})}function Nt(){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 Dt(){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 Bt(){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 $t(){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 At(){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 zt(){const e=[Nt(),Dt(),Bt(),$t(),At()],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 Ut(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 Ot={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=Y;exports.CSP_PRESETS=mt;exports.CedrosPay=vt;exports.CreditsButton=ge;exports.CreditsSubscribeButton=Mt;exports.PaymentMethodBadge=kt;exports.PaymentModal=Te;exports.ProductPrice=jt;exports.PurchaseButton=_e;exports.RPC_PROVIDERS=ft;exports.SECURITY_RECOMMENDATIONS=Ot;exports.StripeButton=me;exports.SubscribeButton=Et;exports.SubscriptionManagementPanel=Lt;exports.calculateDiscountPercentage=Ge;exports.createDedupedClickHandler=J;exports.createTranslator=Me;exports.detectLocale=ke;exports.emitPaymentError=W;exports.emitPaymentProcessing=ee;exports.emitPaymentStart=Z;exports.emitPaymentSuccess=te;exports.emitWalletConnect=ot;exports.emitWalletConnected=it;exports.emitWalletError=at;exports.formatCSP=je;exports.formatCouponCodes=Ve;exports.generateCSP=pt;exports.generateCSPDirectives=ve;exports.getAvailableLocales=ht;exports.getCartItemCount=re;exports.getLocalizedError=yt;exports.getModalCloseButtonStyles=Pe;exports.getUserErrorMessage=lt;exports.isRetryableError=ct;exports.loadLocale=Ee;exports.logSecurityReport=Ut;exports.normalizeCartItems=ce;exports.parseCouponCodes=Qe;exports.stackCheckoutCoupons=Ke;exports.useCreditsPayment=Re;exports.useCreditsSubscription=qe;exports.useLocalizedError=bt;exports.usePaymentMode=se;exports.useStripeCheckout=fe;exports.useSubscription=Ie;exports.useSubscriptionManagement=Le;exports.useTranslation=K;exports.validateSecurity=zt;