@cedros/pay-react 1.1.27 → 1.1.29
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/{AISettingsSection-DELur7D2.js → AISettingsSection-B7qrycfY.js} +2 -2
- package/dist/{AISettingsSection-BlIv3CzS.mjs → AISettingsSection-DtAgMsDw.mjs} +6 -4
- package/dist/{AutosaveIndicator-Bed0-ekg.mjs → AutosaveIndicator-BEvABoKU.mjs} +1 -1
- package/dist/AutosaveIndicator-DiyeAg93.js +1 -0
- package/dist/CedrosContext-5Gjveoba.mjs +2555 -0
- package/dist/CedrosContext-CCakH2SZ.js +3 -0
- package/dist/CedrosPayAdminDashboard-CAwEvn66.js +1 -0
- package/dist/CedrosPayAdminDashboard-CBuvNAtB.mjs +250 -0
- package/dist/{ChatLogsSection-v4zwzCTC.mjs → ChatLogsSection-Ber5o8hF.mjs} +19 -17
- package/dist/ChatLogsSection-DLxMMi9I.js +1 -0
- package/dist/ComplianceSection-Buu0zTiL.js +1 -0
- package/dist/{ComplianceSection-CemgfDrL.mjs → ComplianceSection-ZCr0wsvw.mjs} +18 -15
- package/dist/{CryptoButton-BV9owVe2.mjs → CryptoButton-Cl2kZbOP.mjs} +26 -24
- package/dist/CryptoButton-DxFCYDlJ.js +1 -0
- package/dist/CustomersSection-BywmMLur.js +1 -0
- package/dist/{CustomersSection-D_j7OrfS.mjs → CustomersSection-D9UknSKC.mjs} +21 -19
- package/dist/{DisputesSection-BcAbXp3K.mjs → DisputesSection-C_eySK-W.mjs} +19 -17
- package/dist/DisputesSection-DwkHGv2a.js +1 -0
- package/dist/Dropdown-B90Zabxr.mjs +111 -0
- package/dist/Dropdown-CtY91emj.js +1 -0
- package/dist/ErrorBanner-CZXsHi3H.mjs +22 -0
- package/dist/ErrorBanner-Cx2dUhps.js +1 -0
- package/dist/{FAQSection-Dn38OhB_.mjs → FAQSection-Bv_Hdt8B.mjs} +8 -6
- package/dist/FAQSection-DlPLnIJD.js +1 -0
- package/dist/ImagesSection-B4Jzet79.js +1 -0
- package/dist/{ImagesSection-Ctw9Icym.mjs → ImagesSection-DpdXQ6qu.mjs} +6 -4
- package/dist/InventorySection-BgRdpn1l.js +1 -0
- package/dist/{InventorySection-DmhjUlRZ.mjs → InventorySection-DZMu9DMw.mjs} +25 -23
- package/dist/MessagingSection-CxV-pf-f.js +1 -0
- package/dist/{MessagingSection-B1FaGxkp.mjs → MessagingSection-D_cOBfFt.mjs} +5 -4
- package/dist/OrdersSection-BbAX79Ff.js +1 -0
- package/dist/{OrdersSection-Bj8bPdg8.mjs → OrdersSection-wfPavit9.mjs} +27 -24
- package/dist/PaymentSettingsSection-BdBDgaRg.js +1 -0
- package/dist/PaymentSettingsSection-DunzBo9n.mjs +648 -0
- package/dist/ReturnsSection-7k4LZ8yp.js +1 -0
- package/dist/{ReturnsSection-BC0L8r2e.mjs → ReturnsSection-B4FL7bUv.mjs} +11 -9
- package/dist/{SettingsSection-vdYFSNxB.js → SettingsSection-Cz2Yjdhr.js} +1 -1
- package/dist/{SettingsSection-KYdEizq_.mjs → SettingsSection-DoeNDbqd.mjs} +1 -1
- package/dist/{ShippingSection-BOgto6_9.mjs → ShippingSection-BlVsYC6B.mjs} +5 -3
- package/dist/ShippingSection-C-HI8rOb.js +1 -0
- package/dist/{SingleCategorySettings-suJ8z9d8.mjs → SingleCategorySettings-B406nnF-.mjs} +143 -140
- package/dist/SingleCategorySettings-BqC2UXt3.js +3 -0
- package/dist/StatsBar-D4v-I_Dj.mjs +25 -0
- package/dist/StatsBar-m6GSRNxs.js +1 -0
- package/dist/StorefrontSection-Axvh_KeS.js +1 -0
- package/dist/{StorefrontSection-BRvIGBEJ.mjs → StorefrontSection-BK_rhrAi.mjs} +121 -119
- package/dist/{SubscriptionsSection-D60qrX9a.mjs → SubscriptionsSection-D8V9RBv-.mjs} +11 -9
- package/dist/SubscriptionsSection-EeULMWIB.js +1 -0
- package/dist/{TaxSection-C7-pv-Rl.mjs → TaxSection-Cj6TXL6x.mjs} +23 -21
- package/dist/TaxSection-CzHPhaHl.js +1 -0
- package/dist/ThemeContext-CFXyYx7A.js +1 -0
- package/dist/ThemeContext-l0bqcOGW.mjs +126 -0
- package/dist/Token22Section-DqRKVG_G.js +1 -0
- package/dist/{Token22Section-CrHLQ0EB.mjs → Token22Section-DtYAcT54.mjs} +7 -6
- package/dist/{WalletManager-BIwH8Dw_.mjs → WalletManager-D-eoqUDy.mjs} +21 -19
- package/dist/WalletManager-DXChB9LA.js +1 -0
- package/dist/WebhooksSection-D--iPZuM.js +1 -0
- package/dist/{WebhooksSection-COPW4Ec0.mjs → WebhooksSection-DBAIxtBy.mjs} +40 -38
- package/dist/admin.d.ts +2 -0
- package/dist/admin.js +1 -0
- package/dist/admin.mjs +8 -0
- package/dist/configApi-BS5UJfzm.js +1 -0
- package/dist/{configApi-6XhAJGKX.mjs → configApi-BUXZOMWK.mjs} +57 -3
- package/dist/crypto-only.js +1 -1
- package/dist/crypto-only.mjs +214 -202
- package/dist/dateHelpers-BKW_lGND.js +1 -0
- package/dist/dateHelpers-yvPkofYQ.mjs +6 -0
- package/dist/fetchWithTimeout-CG0EKbhf.js +1 -0
- package/dist/fetchWithTimeout-DmMOwL0Q.mjs +195 -0
- package/dist/index-9QF_UfSN.mjs +18668 -0
- package/dist/index-Cq9ya93W.js +84 -0
- package/dist/index.js +1 -1
- package/dist/index.mjs +74 -64
- package/dist/safeHref-DqJPLPl5.mjs +12 -0
- package/dist/safeHref-DyHIpVjY.js +1 -0
- package/dist/sectionIds-B_tFiNvF.js +1 -0
- package/dist/sectionIds-DBavltrL.mjs +359 -0
- package/dist/sections-BHph7CYj.mjs +9 -0
- package/dist/sections-C2zEJr5G.js +1 -0
- package/dist/sections-more-C1VNVwkp.js +1 -0
- package/dist/sections-more-CMFgfU4d.mjs +3082 -0
- package/dist/src/admin/index.d.ts +3 -3
- package/dist/src/admin/index.d.ts.map +1 -1
- package/dist/src/admin/plugin.d.ts.map +1 -1
- package/dist/src/admin/types.d.ts +2 -6
- package/dist/src/admin/types.d.ts.map +1 -1
- package/dist/src/admin.d.ts +9 -0
- package/dist/src/admin.d.ts.map +1 -0
- package/dist/src/components/admin/LazyCedrosPayAdminDashboard.d.ts +4 -0
- package/dist/src/components/admin/LazyCedrosPayAdminDashboard.d.ts.map +1 -0
- package/dist/src/components/admin/PaymentReadinessChecklist.d.ts +9 -0
- package/dist/src/components/admin/PaymentReadinessChecklist.d.ts.map +1 -0
- package/dist/src/components/admin/PaymentSettingsSection.d.ts.map +1 -1
- package/dist/src/components/admin/PaymentSetupGuide.d.ts +6 -0
- package/dist/src/components/admin/PaymentSetupGuide.d.ts.map +1 -0
- package/dist/src/components/admin/ProductsSection.d.ts.map +1 -1
- package/dist/src/components/admin/configApi.d.ts +1 -1
- package/dist/src/components/admin/configApi.d.ts.map +1 -1
- package/dist/src/components/admin/icons.d.ts +3 -50
- package/dist/src/components/admin/icons.d.ts.map +1 -1
- package/dist/src/components/admin/index.d.ts +1 -1
- package/dist/src/components/admin/index.d.ts.map +1 -1
- package/dist/src/components/admin/types.d.ts +43 -0
- package/dist/src/components/admin/types.d.ts.map +1 -1
- package/dist/src/context/CedrosContext.d.ts +2 -0
- package/dist/src/context/CedrosContext.d.ts.map +1 -1
- package/dist/src/ecommerce/__tests__/featureFlags.test.d.ts +2 -0
- package/dist/src/ecommerce/__tests__/featureFlags.test.d.ts.map +1 -0
- package/dist/src/ecommerce/adapters/paywall/paywallAdapter.d.ts.map +1 -1
- package/dist/src/ecommerce/components/general/ErrorBoundary.d.ts +1 -1
- package/dist/src/ecommerce/components/ui/button.d.ts +1 -1
- package/dist/src/ecommerce/components/ui/sheet.d.ts +1 -1
- package/dist/src/ecommerce/config/context.d.ts +2 -0
- package/dist/src/ecommerce/config/context.d.ts.map +1 -1
- package/dist/src/ecommerce/config/types.d.ts +2 -0
- package/dist/src/ecommerce/config/types.d.ts.map +1 -1
- package/dist/src/ecommerce/index.d.ts +2 -0
- package/dist/src/ecommerce/index.d.ts.map +1 -1
- package/dist/src/featureFlags.d.ts +41 -0
- package/dist/src/featureFlags.d.ts.map +1 -0
- package/dist/src/index.d.ts +4 -2
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/managers/StripeManager.d.ts.map +1 -1
- package/dist/src/managers/SubscriptionManager.d.ts +1 -0
- package/dist/src/managers/SubscriptionManager.d.ts.map +1 -1
- package/dist/src/types/index.d.ts +14 -1
- package/dist/src/types/index.d.ts.map +1 -1
- package/dist/src/types/subscription.d.ts +47 -1
- package/dist/src/types/subscription.d.ts.map +1 -1
- package/dist/src/utils/validateConfig.d.ts.map +1 -1
- package/dist/stripe-only.js +1 -1
- package/dist/stripe-only.mjs +35 -33
- package/dist/styles--fxb3lCl.js +1 -0
- package/dist/{styles-D4SQkuV3.mjs → styles-DGagylUj.mjs} +53 -51
- package/dist/testing/index.js +1 -1
- package/dist/testing/index.mjs +1 -1
- package/dist/tokenMintValidator-DAjQld0r.mjs +98 -0
- package/dist/tokenMintValidator-DNBhoefh.js +4 -0
- package/dist/{walletPool-DE-t1wSW.mjs → walletPool-9MylB2QK.mjs} +1 -1
- package/dist/walletPool-BjTXX6Vn.js +1 -0
- package/package.json +6 -5
- package/dist/AutosaveIndicator-Dn_qA2hK.js +0 -1
- package/dist/CedrosContext-C2RjHLaQ.js +0 -6
- package/dist/CedrosContext-CY6zvjvJ.mjs +0 -2801
- package/dist/ChatLogsSection-BH5tLA4T.js +0 -1
- package/dist/ComplianceSection-DP2a9-S0.js +0 -1
- package/dist/CryptoButton-DpiCnyXE.js +0 -1
- package/dist/CustomersSection-CBwy_waO.js +0 -1
- package/dist/DisputesSection-BLjIk60n.js +0 -1
- package/dist/FAQSection-wNeH0i6Q.js +0 -1
- package/dist/ImagesSection-0ZzKlzMJ.js +0 -1
- package/dist/InventorySection-zV6lTmue.js +0 -1
- package/dist/MessagingSection-B_wdFR0j.js +0 -1
- package/dist/OrdersSection-Dw2FX-1d.js +0 -1
- package/dist/PaymentSettingsSection-BYF4D-GR.js +0 -1
- package/dist/PaymentSettingsSection-EnMxeWjv.mjs +0 -94
- package/dist/ReturnsSection-D_pJVxuG.js +0 -1
- package/dist/ShippingSection-1DRSTu49.js +0 -1
- package/dist/SingleCategorySettings-DwCnBdRf.js +0 -3
- package/dist/StorefrontSection-RumGkb3C.js +0 -1
- package/dist/SubscriptionsSection-C2aLLn7L.js +0 -1
- package/dist/TaxSection-Dt1DnM51.js +0 -1
- package/dist/Token22Section-DY3mUwTY.js +0 -1
- package/dist/WalletManager-B3UdQ5pQ.js +0 -1
- package/dist/WebhooksSection-CKeiJ7Py.js +0 -1
- package/dist/configApi-DkduMQg1.js +0 -1
- package/dist/index-C0g-JxJk.js +0 -84
- package/dist/index-DXnuQp5x.mjs +0 -22128
- package/dist/sections-C1NpK7hk.mjs +0 -9
- package/dist/sections-DVVSZBhW.js +0 -1
- package/dist/styles-BT4bhFey.js +0 -1
- package/dist/walletPool-IS7R3MR1.js +0 -1
|
@@ -1 +0,0 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const t=require("./index-C0g-JxJk.js");exports.CouponsSection=t.CouponsSection;exports.ProductsSection=t.ProductsSection;exports.RefundsSection=t.RefundsSection;exports.SettingsSection=t.SettingsSection;exports.TransactionsSection=t.TransactionsSection;
|
package/dist/styles-BT4bhFey.js
DELETED
|
@@ -1 +0,0 @@
|
|
|
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;
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const a=require("@solana/wallet-adapter-wallets"),e=require("./CedrosContext-C2RjHLaQ.js");class r{adapters=null;poolId;isCleanedUp=!1;constructor(l){this.poolId=l??`pool_${Date.now()}_${Math.random().toString(36).slice(2,11)}`,e.getLogger().debug(`[WalletPool] Created pool: ${this.poolId}`)}getAdapters(){return typeof window>"u"?[]:this.isCleanedUp?(e.getLogger().warn(`[WalletPool] Attempted to use pool after cleanup: ${this.poolId}`),[]):this.adapters!==null?this.adapters:(e.getLogger().debug(`[WalletPool] Initializing adapters for pool: ${this.poolId}`),this.adapters=[new a.PhantomWalletAdapter,new a.SolflareWalletAdapter],this.adapters)}async cleanup(){if(this.isCleanedUp){e.getLogger().debug(`[WalletPool] Pool already cleaned up: ${this.poolId}`);return}if(e.getLogger().debug(`[WalletPool] Cleaning up pool: ${this.poolId}`),this.isCleanedUp=!0,this.adapters===null)return;const l=this.adapters.map(async t=>{try{t.connected&&(e.getLogger().debug(`[WalletPool] Disconnecting wallet: ${t.name}`),await t.disconnect())}catch(n){e.getLogger().warn(`[WalletPool] Failed to disconnect wallet ${t.name}:`,n)}});await Promise.allSettled(l),this.adapters=null,e.getLogger().debug(`[WalletPool] Pool cleanup complete: ${this.poolId}`)}isInitialized(){return this.adapters!==null}getId(){return this.poolId}}function i(o){return new r(o)}exports.WalletPool=r;exports.createWalletPool=i;
|