@cedros/pay-react 1.1.30 → 1.1.31

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 (129) hide show
  1. package/README.md +53 -30
  2. package/dist/{AISettingsSection-C0zqPbd6.js → AISettingsSection-B12x5sV5.js} +2 -2
  3. package/dist/{AISettingsSection-BMh3hAb5.mjs → AISettingsSection-DXWDF4Cf.mjs} +4 -4
  4. package/dist/AutosaveIndicator-CJdkhZis.js +1 -0
  5. package/dist/{AutosaveIndicator-3ctAnz8Y.mjs → AutosaveIndicator-D966vOrP.mjs} +1 -1
  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-CH37u0nX.js +1 -0
  9. package/dist/{ChatLogsSection-BtJixYAp.mjs → ChatLogsSection-DR7mpuQS.mjs} +2 -2
  10. package/dist/{ComplianceSection-BMnb1p4w.mjs → ComplianceSection-C61_Hf-X.mjs} +3 -3
  11. package/dist/ComplianceSection-DS4e2IBp.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-Bzs9Qon3.js +1 -0
  15. package/dist/{CustomersSection-dmwoBhcf.mjs → CustomersSection-CWWvusxs.mjs} +2 -2
  16. package/dist/DisputesSection-ClcYIHga.js +1 -0
  17. package/dist/{DisputesSection-CHyLne76.mjs → DisputesSection-D8rcS5Vs.mjs} +2 -2
  18. package/dist/{Dropdown-BRSZlhik.mjs → Dropdown-0y3S40Xf.mjs} +1 -1
  19. package/dist/Dropdown-BuKiVR_L.js +1 -0
  20. package/dist/{ErrorBanner-lZJhCmDX.mjs → ErrorBanner-DAjYj6Dx.mjs} +1 -1
  21. package/dist/ErrorBanner-DxrRVqwe.js +1 -0
  22. package/dist/FAQSection-0UnN2BZs.js +1 -0
  23. package/dist/{FAQSection-Di2xE9Sm.mjs → FAQSection-Dck0NM-A.mjs} +3 -3
  24. package/dist/{ImagesSection-D63PEjR6.mjs → ImagesSection-Bn9GrRRa.mjs} +2 -2
  25. package/dist/ImagesSection-CSwBHvNl.js +1 -0
  26. package/dist/{InventorySection-Dp5Yu4TA.mjs → InventorySection-Dytfmtn8.mjs} +2 -2
  27. package/dist/InventorySection-ymxaMcIg.js +1 -0
  28. package/dist/{MessagingSection-BLCnCpEv.mjs → MessagingSection-CHFbSxJL.mjs} +3 -3
  29. package/dist/MessagingSection-Dtfv0DvU.js +1 -0
  30. package/dist/OrdersSection-BuzTs9XG.js +1 -0
  31. package/dist/{OrdersSection-Bd56F3cj.mjs → OrdersSection-vYNuVF5X.mjs} +2 -2
  32. package/dist/{PaymentSettingsSection-B5J56VAk.js → PaymentSettingsSection-BOaW8lLv.js} +1 -1
  33. package/dist/{PaymentSettingsSection-52iw47Su.mjs → PaymentSettingsSection-BqdGrXen.mjs} +3 -3
  34. package/dist/{ReturnsSection-DUVeKrCd.mjs → ReturnsSection-CRzhXKtI.mjs} +2 -2
  35. package/dist/ReturnsSection-i5W_3so1.js +1 -0
  36. package/dist/{SettingsSection-vK9WIwXE.mjs → SettingsSection-6o3d8DrH.mjs} +1 -1
  37. package/dist/{SettingsSection-DKkHykaC.js → SettingsSection-CIhO51Zj.js} +1 -1
  38. package/dist/ShippingSection-BUzPW1AG.js +1 -0
  39. package/dist/{ShippingSection-CZRrXrlh.mjs → ShippingSection-CbNzGyCP.mjs} +2 -2
  40. package/dist/SingleCategorySettings-BxVUUy8R.js +3 -0
  41. package/dist/{SingleCategorySettings-C8xJ47_T.mjs → SingleCategorySettings-Qj_ptB_x.mjs} +4 -4
  42. package/dist/{StatsBar-D4cOKG2e.mjs → StatsBar-CwCBHBn-.mjs} +1 -1
  43. package/dist/StatsBar-DDUWoizP.js +1 -0
  44. package/dist/StorefrontSection-CZZj5he9.js +1 -0
  45. package/dist/{StorefrontSection-uXSVbEAa.mjs → StorefrontSection-DIYDmj59.mjs} +4 -4
  46. package/dist/SubscriptionsSection-Bof5MElz.js +1 -0
  47. package/dist/{SubscriptionsSection-Ci_AZrWA.mjs → SubscriptionsSection-lMVHdV5X.mjs} +3 -3
  48. package/dist/TaxSection-Be-9v60Z.js +1 -0
  49. package/dist/{TaxSection-BTukS_cU.mjs → TaxSection-dD7PzQvG.mjs} +2 -2
  50. package/dist/Token22Section-Di5fHsrU.js +1 -0
  51. package/dist/{Token22Section-DRsPJuTq.mjs → Token22Section-Dos0CYEk.mjs} +2 -2
  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-A8Y4ZGcj.mjs → WebhooksSection-5gqXzIhq.mjs} +2 -2
  55. package/dist/WebhooksSection-CiLDyl7c.js +1 -0
  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-BIkt3boU.mjs +339 -0
  66. package/dist/plugin-Dw8_Q8rE.js +1 -0
  67. package/dist/sections-D1d83mfH.js +1 -0
  68. package/dist/{sections-more-Ixw6mM6R.mjs → sections-DcUfZQNE.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/index.d.ts +0 -1
  74. package/dist/src/components/admin/index.d.ts.map +1 -1
  75. package/dist/src/index.d.ts +0 -1
  76. package/dist/src/index.d.ts.map +1 -1
  77. package/dist/stripe-only.js +1 -1
  78. package/dist/stripe-only.mjs +18 -19
  79. package/dist/styles-BwaDljnz.js +1 -0
  80. package/dist/{styles-DGagylUj.mjs → styles-fihm6qVA.mjs} +51 -52
  81. package/dist/testing/index.js +1 -1
  82. package/dist/testing/index.mjs +1 -1
  83. package/package.json +6 -8
  84. package/dist/AutosaveIndicator-DXRPr4P7.js +0 -1
  85. package/dist/CedrosContext-CCakH2SZ.js +0 -3
  86. package/dist/CedrosPayAdminDashboard-DaJ9JoGn.mjs +0 -250
  87. package/dist/CedrosPayAdminDashboard-Uvyh9p7A.js +0 -1
  88. package/dist/ChatLogsSection-FC3O536G.js +0 -1
  89. package/dist/ComplianceSection-BioTKm7k.js +0 -1
  90. package/dist/CryptoButton-DxFCYDlJ.js +0 -1
  91. package/dist/CustomersSection-z6ARxuex.js +0 -1
  92. package/dist/DisputesSection-BjHHQAi7.js +0 -1
  93. package/dist/Dropdown-j8o0OO5L.js +0 -1
  94. package/dist/ErrorBanner-CAgPnj62.js +0 -1
  95. package/dist/FAQSection-b34DMzgV.js +0 -1
  96. package/dist/ImagesSection-DGBA7iKY.js +0 -1
  97. package/dist/InventorySection-bVCECzX5.js +0 -1
  98. package/dist/LazyCedrosPayAdminDashboard-BqJDNrDI.mjs +0 -9
  99. package/dist/LazyCedrosPayAdminDashboard-CpfTtOBc.js +0 -1
  100. package/dist/MessagingSection-DU0dYNMy.js +0 -1
  101. package/dist/OrdersSection-FOFEAgs1.js +0 -1
  102. package/dist/ReturnsSection-BjpIVFfN.js +0 -1
  103. package/dist/ShippingSection-B5lk7zpS.js +0 -1
  104. package/dist/SingleCategorySettings-g7D-9lG1.js +0 -3
  105. package/dist/StatsBar-CWXw2ZT3.js +0 -1
  106. package/dist/StorefrontSection-BWnMB9k-.js +0 -1
  107. package/dist/SubscriptionsSection-DQfXkuDv.js +0 -1
  108. package/dist/TaxSection-cuPQISxZ.js +0 -1
  109. package/dist/ThemeContext-CFXyYx7A.js +0 -1
  110. package/dist/ThemeContext-l0bqcOGW.mjs +0 -126
  111. package/dist/Token22Section-CCfkDm8W.js +0 -1
  112. package/dist/WebhooksSection-CnEmaGH1.js +0 -1
  113. package/dist/icons-C3yDMnKE.mjs +0 -235
  114. package/dist/icons-Cjgd9YVo.js +0 -1
  115. package/dist/sectionIds-D46-_-h-.js +0 -1
  116. package/dist/sectionIds-YktNxmRt.mjs +0 -124
  117. package/dist/sections-511_XBh4.js +0 -1
  118. package/dist/sections-CRaMa8ZB.mjs +0 -9
  119. package/dist/sections-more-Cgw2qJlA.js +0 -1
  120. package/dist/src/components/admin/CedrosPayAdminDashboard.d.ts +0 -40
  121. package/dist/src/components/admin/CedrosPayAdminDashboard.d.ts.map +0 -1
  122. package/dist/src/components/admin/LazyCedrosPayAdminDashboard.d.ts +0 -4
  123. package/dist/src/components/admin/LazyCedrosPayAdminDashboard.d.ts.map +0 -1
  124. package/dist/src/standalone-admin.d.ts +0 -8
  125. package/dist/src/standalone-admin.d.ts.map +0 -1
  126. package/dist/standalone-admin.d.ts +0 -2
  127. package/dist/standalone-admin.js +0 -1
  128. package/dist/standalone-admin.mjs +0 -4
  129. package/dist/styles--fxb3lCl.js +0 -1
@@ -0,0 +1 @@
1
+ "use strict";var we=Object.create;var xe=Object.defineProperty;var ke=Object.getOwnPropertyDescriptor;var Ae=Object.getOwnPropertyNames;var Te=Object.getPrototypeOf,Ne=Object.prototype.hasOwnProperty;var Be=(t,i,s,n)=>{if(i&&typeof i=="object"||typeof i=="function")for(let a of Ae(i))!Ne.call(t,a)&&a!==s&&xe(t,a,{get:()=>i[a],enumerable:!(n=ke(i,a))||n.enumerable});return t};var me=(t,i,s)=>(s=t!=null?we(Te(t)):{},Be(i||!t||!t.__esModule?xe(s,"default",{value:t,enumerable:!0}):s,t));Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("react/jsx-runtime"),r=require("react"),Re=require("./plugin-Dw8_Q8rE.js"),ze=require("./ErrorBanner-DxrRVqwe.js"),ee=require("./configApi-BS5UJfzm.js"),Se=[{value:"text",label:"Short Text"},{value:"email",label:"Email"},{value:"phone",label:"Phone"},{value:"address",label:"Address"},{value:"textarea",label:"Long Text"},{value:"dropdown",label:"Dropdown"},{value:"file_upload",label:"File Upload"}],fe={fields:[],requiresApproval:!0},U={width:"100%",padding:"0.4rem 0.6rem",border:"1px solid rgba(0,0,0,0.2)",borderRadius:4,fontSize:"0.9rem",boxSizing:"border-box"},G={display:"block",fontSize:"0.8rem",fontWeight:500,marginBottom:4},Q={padding:"0.4rem 1rem",borderRadius:6,border:"1px solid rgba(0,0,0,0.2)",background:"white",cursor:"pointer",fontSize:"0.85rem"};function Ie(){return{id:Math.random().toString(36).slice(2),label:"",fieldType:"text",required:!1,options:[],placeholder:""}}function be({field:t,onSave:i,onCancel:s}){const[n,a]=r.useState(t),[c,y]=r.useState(""),p=o=>a(d=>({...d,...o})),b=()=>{const o=c.trim();o&&(p({options:[...n.options,o]}),y(""))};return e.jsxs("div",{style:{padding:"0.75rem",border:"1px solid rgba(37,99,235,0.3)",borderRadius:6,background:"#eff6ff",marginTop:6},children:[e.jsxs("div",{style:{display:"grid",gridTemplateColumns:"1fr 1fr",gap:"0.6rem",marginBottom:"0.6rem"},children:[e.jsxs("div",{children:[e.jsx("label",{style:G,children:"Label *"}),e.jsx("input",{style:U,value:n.label,onChange:o=>p({label:o.target.value}),placeholder:"e.g., Full Name"})]}),e.jsxs("div",{children:[e.jsx("label",{style:G,children:"Field Type"}),e.jsx("select",{style:U,value:n.fieldType,onChange:o=>p({fieldType:o.target.value,options:[]}),children:Se.map(o=>e.jsx("option",{value:o.value,children:o.label},o.value))})]})]}),e.jsxs("div",{style:{display:"grid",gridTemplateColumns:"1fr auto",gap:"0.6rem",alignItems:"end",marginBottom:"0.6rem"},children:[e.jsxs("div",{children:[e.jsx("label",{style:G,children:"Placeholder"}),e.jsx("input",{style:U,value:n.placeholder??"",onChange:o=>p({placeholder:o.target.value}),placeholder:"Optional hint text"})]}),e.jsxs("label",{style:{display:"flex",alignItems:"center",gap:6,fontSize:"0.85rem",cursor:"pointer",paddingBottom:2},children:[e.jsx("input",{type:"checkbox",checked:n.required,onChange:o=>p({required:o.target.checked})})," Required"]})]}),n.fieldType==="dropdown"&&e.jsxs("div",{style:{marginBottom:"0.6rem"},children:[e.jsx("label",{style:G,children:"Options"}),n.options.map((o,d)=>e.jsxs("div",{style:{display:"flex",gap:6,marginBottom:4},children:[e.jsx("span",{style:{flex:1,fontSize:"0.85rem",padding:"0.25rem 0.5rem",background:"white",border:"1px solid rgba(0,0,0,0.15)",borderRadius:4},children:o}),e.jsx("button",{type:"button",onClick:()=>p({options:n.options.filter((u,v)=>v!==d)}),style:{padding:"0.2rem 0.5rem",borderRadius:4,border:"1px solid rgba(0,0,0,0.2)",background:"white",cursor:"pointer",fontSize:"0.8rem",color:"#dc2626"},children:"x"})]},d)),e.jsxs("div",{style:{display:"flex",gap:6},children:[e.jsx("input",{style:{...U,flex:1},value:c,onChange:o=>y(o.target.value),onKeyDown:o=>o.key==="Enter"&&(o.preventDefault(),b()),placeholder:"Add option..."}),e.jsx("button",{type:"button",onClick:b,style:Q,children:"Add"})]})]}),e.jsxs("div",{style:{display:"flex",gap:6},children:[e.jsx("button",{type:"button",onClick:()=>i(n),disabled:!n.label.trim(),style:{padding:"0.35rem 1rem",borderRadius:6,border:"none",background:"#2563eb",color:"white",cursor:n.label.trim()?"pointer":"not-allowed",fontSize:"0.85rem",opacity:n.label.trim()?1:.5},children:"Save Field"}),e.jsx("button",{type:"button",onClick:s,style:Q,children:"Cancel"})]})]})}function De({fields:t,instructions:i}){const s={...U,fontSize:"0.85rem",background:"white",opacity:.6};return e.jsxs("div",{style:{padding:"1rem",border:"1px solid rgba(0,0,0,0.1)",borderRadius:8,background:"rgba(0,0,0,0.02)"},children:[e.jsx("div",{style:{fontSize:"0.75rem",fontWeight:600,color:"rgba(0,0,0,0.4)",textTransform:"uppercase",letterSpacing:"0.05em",marginBottom:"0.75rem"},children:"Preview — Redeemer View"}),i&&e.jsx("div",{style:{padding:"0.6rem 0.75rem",background:"#fffbeb",border:"1px solid #fcd34d",borderRadius:6,fontSize:"0.85rem",marginBottom:"0.75rem",color:"#92400e"},children:i}),t.length===0&&e.jsx("div",{style:{fontSize:"0.85rem",color:"rgba(0,0,0,0.35)",fontStyle:"italic"},children:"No fields added yet."}),t.map(n=>e.jsxs("div",{style:{marginBottom:"0.6rem"},children:[e.jsxs("label",{style:{display:"block",fontSize:"0.8rem",fontWeight:500,marginBottom:4},children:[n.label||"Unlabelled field",n.required&&e.jsx("span",{style:{color:"#dc2626",marginLeft:2},children:"*"})]}),n.fieldType==="textarea"&&e.jsx("textarea",{disabled:!0,rows:2,placeholder:n.placeholder??"",style:{...s,resize:"none"}}),n.fieldType==="file_upload"&&e.jsx("div",{style:{padding:"0.5rem",border:"1px dashed rgba(0,0,0,0.25)",borderRadius:4,fontSize:"0.8rem",color:"rgba(0,0,0,0.4)",textAlign:"center"},children:"File upload"}),n.fieldType==="dropdown"&&e.jsxs("select",{disabled:!0,style:s,children:[e.jsx("option",{children:n.placeholder||"Select..."}),n.options.map((a,c)=>e.jsx("option",{children:a},c))]}),!["textarea","file_upload","dropdown"].includes(n.fieldType)&&e.jsx("input",{disabled:!0,type:n.fieldType==="email"?"email":n.fieldType==="phone"?"tel":"text",placeholder:n.placeholder??"",style:s})]},n.id))]})}function Pe({value:t,onChange:i}){const s=t!==null,n=t??fe,[a,c]=r.useState(null),[y,p]=r.useState(null),[b,o]=r.useState(!1),d=h=>i({...n,...h}),u=()=>{c(null),p(null)},v=h=>{i(h?{...fe}:null),u()},x=()=>{const h=Ie();p(h),c("new")},f=h=>{p({...h}),c(h.id)},j=h=>{d({fields:a==="new"?[...n.fields,h]:n.fields.map(S=>S.id===h.id?h:S)}),u()},k=h=>{a===h&&u(),d({fields:n.fields.filter(S=>S.id!==h)})};return e.jsxs("div",{children:[e.jsxs("label",{style:{display:"flex",alignItems:"center",gap:8,cursor:"pointer",marginBottom:s?"1rem":4,fontSize:"0.9rem",fontWeight:500},children:[e.jsx("input",{type:"checkbox",checked:s,onChange:h=>v(h.target.checked)}),"Enable Redemption Form"]}),!s&&e.jsx("div",{style:{fontSize:"0.8rem",color:"rgba(0,0,0,0.4)"},children:"No redemption form — token holders cannot request physical redemption."}),s&&e.jsxs("div",{style:{display:"flex",flexDirection:"column",gap:"0.75rem"},children:[e.jsxs("div",{children:[e.jsx("label",{style:G,children:"Instructions shown to redeemer"}),e.jsx("textarea",{value:n.instructions??"",onChange:h=>d({instructions:h.target.value||void 0}),placeholder:"Describe requirements, turnaround times, etc.",rows:3,style:{...U,resize:"vertical"}})]}),e.jsxs("div",{style:{display:"grid",gridTemplateColumns:"auto 1fr",gap:"1rem",alignItems:"center",padding:"0.6rem 0.75rem",border:"1px solid rgba(0,0,0,0.1)",borderRadius:6,background:"rgba(0,0,0,0.02)"},children:[e.jsxs("label",{style:{display:"flex",alignItems:"center",gap:6,fontSize:"0.85rem",cursor:"pointer",whiteSpace:"nowrap"},children:[e.jsx("input",{type:"checkbox",checked:n.requiresApproval,onChange:h=>d({requiresApproval:h.target.checked})})," Requires admin approval"]}),e.jsxs("div",{children:[e.jsx("label",{style:G,children:"Estimated processing days"}),e.jsx("input",{type:"number",min:0,value:n.estimatedProcessingDays??"",onChange:h=>d({estimatedProcessingDays:h.target.value?Number(h.target.value):void 0}),placeholder:"e.g., 5",style:{...U,maxWidth:120}})]})]}),e.jsxs("div",{children:[e.jsxs("div",{style:{fontSize:"0.8rem",fontWeight:500,marginBottom:"0.5rem"},children:["Form Fields (",n.fields.length,")"]}),n.fields.length===0&&a!=="new"&&e.jsx("div",{style:{fontSize:"0.85rem",color:"rgba(0,0,0,0.35)",fontStyle:"italic",marginBottom:"0.5rem"},children:"No fields yet. Add fields below."}),e.jsxs("div",{style:{display:"flex",flexDirection:"column",gap:"0.4rem"},children:[n.fields.map(h=>e.jsxs("div",{children:[e.jsxs("div",{style:{padding:"0.5rem 0.75rem",border:"1px solid rgba(0,0,0,0.1)",borderRadius:6,background:"white",display:"flex",justifyContent:"space-between",alignItems:"center"},children:[e.jsxs("div",{style:{display:"flex",alignItems:"center",gap:8},children:[e.jsx("span",{style:{fontSize:"0.9rem"},children:h.label||e.jsx("em",{style:{color:"rgba(0,0,0,0.35)"},children:"Unlabelled"})}),e.jsx("span",{style:{padding:"2px 8px",borderRadius:10,background:"#dbeafe",color:"#1d4ed8",fontSize:"0.75rem"},children:Se.find(S=>S.value===h.fieldType)?.label??h.fieldType}),h.required&&e.jsx("span",{style:{padding:"2px 8px",borderRadius:10,background:"#fef3c7",color:"#92400e",fontSize:"0.75rem"},children:"required"})]}),e.jsxs("div",{style:{display:"flex",gap:4},children:[e.jsx("button",{type:"button",onClick:()=>f(h),style:{...Q,padding:"0.25rem 0.6rem",fontSize:"0.8rem"},children:"Edit"}),e.jsx("button",{type:"button",onClick:()=>k(h.id),style:{padding:"0.25rem 0.6rem",borderRadius:4,border:"1px solid rgba(220,38,38,0.3)",background:"white",cursor:"pointer",fontSize:"0.8rem",color:"#dc2626"},children:"Delete"})]})]}),a===h.id&&y&&e.jsx(be,{field:y,onSave:j,onCancel:u})]},h.id)),a==="new"&&y&&e.jsx(be,{field:y,onSave:j,onCancel:u})]}),a===null&&e.jsx("button",{type:"button",onClick:x,style:{...Q,marginTop:"0.5rem"},children:"+ Add Field"})]}),e.jsxs("div",{children:[e.jsx("button",{type:"button",onClick:()=>o(h=>!h),style:{...Q,background:b?"rgba(0,0,0,0.05)":"white"},children:b?"Hide Preview":"Show Preview"}),b&&e.jsx("div",{style:{marginTop:"0.75rem"},children:e.jsx(De,{fields:n.fields,instructions:n.instructions})})]})]})]})}const Me=[{value:"securities",label:"Securities (fungible)"},{value:"commodities",label:"Commodities (fungible)"},{value:"property",label:"Property (non-fungible)"},{value:"collectibles",label:"Collectibles (non-fungible)"}],Fe=t=>t==="securities"||t==="commodities";function Ee({c:t,onDeployPool:i,onEdit:s,onDelete:n}){const a=t.tokenizationConfig,c=Fe(a.assetClass);return e.jsxs("div",{style:{padding:"0.75rem 1rem",border:"1px solid rgba(0,0,0,0.1)",borderRadius:8,background:"white"},children:[e.jsxs("div",{style:{display:"flex",justifyContent:"space-between",alignItems:"center"},children:[e.jsxs("div",{children:[e.jsx("strong",{children:t.name}),e.jsx("span",{style:{marginLeft:8,fontSize:"0.8rem",padding:"2px 8px",borderRadius:10,background:c?"#dbeafe":"#fef3c7",color:c?"#1d4ed8":"#92400e"},children:a.assetClass}),a.tokenSymbol&&e.jsx("span",{style:{marginLeft:6,fontSize:"0.8rem",color:"rgba(0,0,0,0.5)"},children:a.tokenSymbol})]}),e.jsxs("div",{style:{display:"flex",alignItems:"center",gap:8,fontSize:"0.8rem"},children:[a.mintAddress?e.jsx("span",{style:{color:"#16a34a"},children:"Mint initialized"}):e.jsx("span",{style:{color:"rgba(0,0,0,0.4)"},children:"No mint"}),c&&a.mintAddress&&(a.liquidityPoolAddress?e.jsxs("span",{style:{padding:"2px 8px",borderRadius:10,background:"#dcfce7",color:"#15803d",fontSize:"0.75rem"},children:["Pool Active · ",a.liquidityPoolAddress.slice(0,4),"...",a.liquidityPoolAddress.slice(-4)]}):e.jsx("button",{type:"button",onClick:i,style:{padding:0,border:"none",background:"none",color:"#2563eb",cursor:"pointer",fontSize:"0.8rem",textDecoration:"underline"},children:"Deploy Pool"}))]})]}),t.description&&e.jsx("div",{style:{fontSize:"0.85rem",color:"rgba(0,0,0,0.5)",marginTop:4},children:t.description}),e.jsxs("div",{style:{display:"flex",justifyContent:"space-between",alignItems:"center",marginTop:6},children:[e.jsxs("div",{style:{display:"flex",gap:"1rem",flexWrap:"wrap",fontSize:"0.8rem",color:"rgba(0,0,0,0.4)"},children:[e.jsxs("span",{children:["Fee: ",a.transferFeeBps," bps"]}),a.treasuryAddress&&e.jsxs("span",{children:["Treasury: ",a.treasuryAddress.slice(0,8),"..."]}),a.allowedJurisdictions?.length>0&&e.jsxs("span",{style:{padding:"1px 7px",borderRadius:10,background:"#f3f4f6",color:"rgba(0,0,0,0.55)"},children:[a.allowedJurisdictions.length," jurisdiction",a.allowedJurisdictions.length!==1?"s":"",": ",a.allowedJurisdictions.join(", ")]})]}),e.jsxs("div",{style:{display:"flex",gap:6},children:[s&&e.jsx("button",{type:"button",onClick:s,style:{padding:"2px 10px",border:"1px solid rgba(0,0,0,0.15)",borderRadius:4,background:"white",cursor:"pointer",fontSize:"0.75rem",color:"#2563eb"},children:"Edit"}),n&&e.jsx("button",{type:"button",onClick:n,style:{padding:"2px 10px",border:"1px solid rgba(0,0,0,0.15)",borderRadius:4,background:"white",cursor:"pointer",fontSize:"0.75rem",color:"#dc2626"},children:"Delete"})]})]})]})}const pe={name:"",description:"",assetClass:"securities",tokenSymbol:"",tokenDecimals:2,transferFeeBps:250,maxTransferFee:500,treasuryAddress:"",regulatoryNotice:"",jurisdictions:"",redemptionConfig:null};function Le({serverUrl:t,apiKey:i,authManager:s,onNavigateToLiquidity:n}){const[a,c]=r.useState([]),[y,p]=r.useState(!0),[b,o]=r.useState(null),[d,u]=r.useState(!1),[v,x]=r.useState(!1),[f,j]=r.useState(pe),[k,h]=r.useState(null),S=r.useCallback(async(g,m)=>{if(s?.isAuthenticated())return s.fetchWithAuth(g,m);const N={"Content-Type":"application/json"};i&&(N["X-API-Key"]=i);const C=await fetch(`${t}${g}`,{...m,headers:{...N,...m?.headers}});if(!C.ok){const z=await C.text().catch(()=>`HTTP ${C.status}`);throw new Error(z)}return C.json()},[t,i,s]),T=r.useCallback(async()=>{try{p(!0),o(null);const g=await S("/admin/collections");c((g.collections||[]).filter(m=>m.tokenizationConfig))}catch(g){o(g instanceof Error?g.message:"Failed to load asset classes")}finally{p(!1)}},[S]);r.useEffect(()=>{T()},[T]);const l=()=>({name:f.name.trim(),description:f.description||void 0,active:!0,productIds:[],tokenizationConfig:{assetClass:f.assetClass,tokenSymbol:f.tokenSymbol||void 0,tokenDecimals:f.tokenDecimals,transferFeeBps:f.transferFeeBps,maxTransferFee:f.maxTransferFee,treasuryAddress:f.treasuryAddress||void 0,regulatoryNotice:f.regulatoryNotice||void 0,allowedJurisdictions:f.jurisdictions?f.jurisdictions.split(",").map(g=>g.trim().toUpperCase()).filter(Boolean):[],redemptionConfig:f.redemptionConfig||void 0}}),w=async()=>{if(f.name.trim()){x(!0),o(null);try{k?await S(`/admin/collections/${encodeURIComponent(k)}`,{method:"PUT",body:JSON.stringify(l())}):await S("/admin/collections",{method:"POST",body:JSON.stringify(l())}),j(pe),u(!1),h(null),await T()}catch(g){o(g instanceof Error?g.message:`Failed to ${k?"update":"create"} asset class`)}finally{x(!1)}}},_=g=>{const m=g.tokenizationConfig;j({name:g.name,description:g.description??"",assetClass:m.assetClass,tokenSymbol:m.tokenSymbol??"",tokenDecimals:m.tokenDecimals,transferFeeBps:m.transferFeeBps,maxTransferFee:m.maxTransferFee,treasuryAddress:m.treasuryAddress??"",regulatoryNotice:m.regulatoryNotice??"",jurisdictions:m.allowedJurisdictions.join(", "),redemptionConfig:m.redemptionConfig??null}),h(g.id),u(!0)},A=async g=>{if(window.confirm(`Delete asset class "${g.name}"? This cannot be undone.`)){o(null);try{await S(`/admin/collections/${encodeURIComponent(g.id)}`,{method:"DELETE"}),await T()}catch(m){o(m instanceof Error?m.message:"Failed to delete asset class")}}};return y?e.jsx("div",{style:{padding:"1rem 0",color:"rgba(0,0,0,0.5)"},children:"Loading asset classes..."}):e.jsxs("div",{children:[b&&e.jsx("div",{style:{padding:"0.75rem 1rem",background:"#fef2f2",border:"1px solid #fecaca",borderRadius:6,color:"#dc2626",marginBottom:"1rem",fontSize:"0.9rem"},children:b}),e.jsxs("div",{style:{display:"flex",justifyContent:"space-between",alignItems:"center",marginBottom:"1rem"},children:[e.jsxs("h4",{style:{margin:0},children:["Asset Classes (",a.length,")"]}),e.jsx("button",{type:"button",onClick:()=>{u(!d),d&&(h(null),j(pe))},style:{padding:"0.4rem 1rem",borderRadius:6,border:"1px solid rgba(0,0,0,0.2)",background:d?"rgba(0,0,0,0.05)":"white",cursor:"pointer",fontSize:"0.85rem"},children:d?"Cancel":"+ New Asset Class"})]}),d&&e.jsxs("div",{style:{padding:"1rem",border:"1px solid rgba(0,0,0,0.1)",borderRadius:8,marginBottom:"1rem",background:"rgba(0,0,0,0.02)"},children:[e.jsxs("div",{style:{display:"grid",gridTemplateColumns:"1fr 1fr",gap:"0.75rem",marginBottom:"0.75rem"},children:[e.jsxs("div",{children:[e.jsx("label",{style:{display:"block",fontSize:"0.8rem",fontWeight:500,marginBottom:4},children:"Name *"}),e.jsx("input",{type:"text",value:f.name,onChange:g=>j(m=>({...m,name:g.target.value})),placeholder:"e.g., Gold Tokens",style:{width:"100%",padding:"0.4rem 0.6rem",border:"1px solid rgba(0,0,0,0.2)",borderRadius:4,fontSize:"0.9rem"}})]}),e.jsxs("div",{children:[e.jsx("label",{style:{display:"block",fontSize:"0.8rem",fontWeight:500,marginBottom:4},children:"Asset Class *"}),e.jsx("select",{value:f.assetClass,onChange:g=>j(m=>({...m,assetClass:g.target.value})),style:{width:"100%",padding:"0.4rem 0.6rem",border:"1px solid rgba(0,0,0,0.2)",borderRadius:4,fontSize:"0.9rem"},children:Me.map(g=>e.jsx("option",{value:g.value,children:g.label},g.value))})]})]}),e.jsxs("div",{style:{marginBottom:"0.75rem"},children:[e.jsx("label",{style:{display:"block",fontSize:"0.8rem",fontWeight:500,marginBottom:4},children:"Description"}),e.jsx("input",{type:"text",value:f.description,onChange:g=>j(m=>({...m,description:g.target.value})),placeholder:"Brief description of this asset class",style:{width:"100%",padding:"0.4rem 0.6rem",border:"1px solid rgba(0,0,0,0.2)",borderRadius:4,fontSize:"0.9rem"}})]}),e.jsxs("div",{style:{display:"grid",gridTemplateColumns:"1fr 1fr 1fr",gap:"0.75rem",marginBottom:"0.75rem"},children:[e.jsxs("div",{children:[e.jsx("label",{style:{display:"block",fontSize:"0.8rem",fontWeight:500,marginBottom:4},children:"Token Symbol"}),e.jsx("input",{type:"text",value:f.tokenSymbol,onChange:g=>j(m=>({...m,tokenSymbol:g.target.value})),placeholder:"e.g., GOLD",style:{width:"100%",padding:"0.4rem 0.6rem",border:"1px solid rgba(0,0,0,0.2)",borderRadius:4,fontSize:"0.9rem"}})]}),e.jsxs("div",{children:[e.jsx("label",{style:{display:"block",fontSize:"0.8rem",fontWeight:500,marginBottom:4},children:"Transfer Fee (bps)"}),e.jsx("input",{type:"number",value:f.transferFeeBps,onChange:g=>j(m=>({...m,transferFeeBps:Number(g.target.value)})),style:{width:"100%",padding:"0.4rem 0.6rem",border:"1px solid rgba(0,0,0,0.2)",borderRadius:4,fontSize:"0.9rem"}})]}),e.jsxs("div",{children:[e.jsx("label",{style:{display:"block",fontSize:"0.8rem",fontWeight:500,marginBottom:4},children:"Treasury Address"}),e.jsx("input",{type:"text",value:f.treasuryAddress,onChange:g=>j(m=>({...m,treasuryAddress:g.target.value})),placeholder:"Solana address",style:{width:"100%",padding:"0.4rem 0.6rem",border:"1px solid rgba(0,0,0,0.2)",borderRadius:4,fontSize:"0.9rem"}})]})]}),e.jsxs("div",{style:{marginBottom:"0.75rem"},children:[e.jsx("label",{style:{display:"block",fontSize:"0.8rem",fontWeight:500,marginBottom:4},children:"Allowed Jurisdictions"}),e.jsx("input",{type:"text",value:f.jurisdictions,onChange:g=>j(m=>({...m,jurisdictions:g.target.value})),placeholder:"US, CA, GB (comma-separated, leave empty for all)",style:{width:"100%",padding:"0.4rem 0.6rem",border:"1px solid rgba(0,0,0,0.2)",borderRadius:4,fontSize:"0.9rem"}})]}),e.jsxs("div",{style:{marginBottom:"0.75rem"},children:[e.jsx("label",{style:{display:"block",fontSize:"0.8rem",fontWeight:500,marginBottom:4},children:"Regulatory Notice"}),e.jsx("textarea",{value:f.regulatoryNotice,onChange:g=>j(m=>({...m,regulatoryNotice:g.target.value})),placeholder:"Shown to buyers before purchase",rows:2,style:{width:"100%",padding:"0.4rem 0.6rem",border:"1px solid rgba(0,0,0,0.2)",borderRadius:4,fontSize:"0.9rem",resize:"vertical"}})]}),e.jsxs("div",{style:{marginBottom:"0.75rem"},children:[e.jsx("label",{style:{display:"block",fontSize:"0.8rem",fontWeight:600,marginBottom:8},children:"Redemption Form"}),e.jsx(Pe,{value:f.redemptionConfig,onChange:g=>j(m=>({...m,redemptionConfig:g}))})]}),e.jsx("button",{type:"button",onClick:w,disabled:v||!f.name.trim(),style:{padding:"0.5rem 1.5rem",borderRadius:6,border:"none",background:"#2563eb",color:"white",cursor:v?"wait":"pointer",fontSize:"0.9rem",opacity:v?.6:1},children:v?"Saving...":k?"Save Changes":"Create Asset Class"})]}),a.length===0?e.jsx("div",{style:{padding:"2rem",textAlign:"center",color:"rgba(0,0,0,0.4)",fontSize:"0.9rem"},children:"No asset classes configured. Create one to start tokenizing off-chain assets."}):e.jsx("div",{style:{display:"flex",flexDirection:"column",gap:"0.5rem"},children:a.map(g=>e.jsx(Ee,{c:g,onDeployPool:n,onEdit:()=>_(g),onDelete:()=>A(g)},g.id))})]})}const $e=[{value:"",label:"All statuses"},{value:"pending_info",label:"Pending Info"},{value:"info_submitted",label:"Info Submitted"},{value:"under_review",label:"Under Review"},{value:"approved",label:"Approved"},{value:"completed",label:"Completed"},{value:"rejected",label:"Rejected"}];function qe(t){switch(t){case"pending_info":return"cedros-admin__badge cedros-admin__badge--muted";case"info_submitted":return"cedros-admin__badge cedros-admin__badge--info";case"under_review":return"cedros-admin__badge cedros-admin__badge--warning";case"approved":return"cedros-admin__badge cedros-admin__badge--success";case"completed":return"cedros-admin__badge cedros-admin__badge--success";case"rejected":return"cedros-admin__badge cedros-admin__badge--failed";default:return"cedros-admin__badge cedros-admin__badge--muted"}}function Oe(t){return t.replace(/_/g," ").replace(/\b\w/g,i=>i.toUpperCase())}function We(t){return new Date(t).toLocaleDateString(void 0,{month:"short",day:"numeric",year:"numeric"})}function K(t){return t.length>12?`${t.slice(0,8)}…`:t}function je(t){return`https://solscan.io/tx/${t}`}function Ue({redemption:t,onAction:i,onComplete:s,actionBusy:n}){const[a,c]=r.useState(t.adminNotes??""),y=Object.entries(t.formData??{});return e.jsx("div",{style:{padding:"1rem 1.25rem",background:"rgba(0,0,0,0.02)",borderTop:"1px solid rgba(0,0,0,0.08)"},children:e.jsxs("div",{style:{display:"grid",gridTemplateColumns:"1fr 1fr",gap:"1.5rem"},children:[e.jsxs("div",{children:[e.jsx("div",{style:{fontWeight:600,fontSize:"0.8rem",marginBottom:8,textTransform:"uppercase",letterSpacing:"0.05em",opacity:.6},children:"Form Data"}),y.length===0?e.jsx("div",{style:{fontSize:"0.85rem",opacity:.5},children:"No form data submitted."}):e.jsx("dl",{style:{margin:0,display:"grid",gridTemplateColumns:"auto 1fr",gap:"4px 12px",fontSize:"0.85rem"},children:y.map(([p,b])=>e.jsxs(e.Fragment,{children:[e.jsx("dt",{style:{fontWeight:500,color:"rgba(0,0,0,0.6)",whiteSpace:"nowrap"},children:p},`k-${p}`),e.jsx("dd",{style:{margin:0,wordBreak:"break-word"},children:String(b??"—")},`v-${p}`)]}))}),(t.tokenMintSignature||t.tokenBurnSignature)&&e.jsxs("div",{style:{marginTop:12,fontSize:"0.8rem"},children:[e.jsx("div",{style:{fontWeight:600,marginBottom:4,opacity:.6,textTransform:"uppercase",letterSpacing:"0.05em"},children:"Signatures"}),t.tokenMintSignature&&e.jsxs("div",{children:["Mint:"," ",e.jsx("a",{href:je(t.tokenMintSignature),target:"_blank",rel:"noopener noreferrer",style:{fontFamily:"monospace",fontSize:"0.75rem"},children:K(t.tokenMintSignature)})]}),t.tokenBurnSignature&&e.jsxs("div",{children:["Burn:"," ",e.jsx("a",{href:je(t.tokenBurnSignature),target:"_blank",rel:"noopener noreferrer",style:{fontFamily:"monospace",fontSize:"0.75rem"},children:K(t.tokenBurnSignature)})]})]})]}),e.jsxs("div",{children:[e.jsx("label",{style:{display:"block",fontSize:"0.8rem",fontWeight:500,marginBottom:4},children:"Admin Notes"}),e.jsx("textarea",{value:a,onChange:p=>c(p.target.value),rows:4,style:{width:"100%",padding:"0.4rem 0.6rem",border:"1px solid rgba(0,0,0,0.2)",borderRadius:4,fontSize:"0.85rem",resize:"vertical",boxSizing:"border-box"},placeholder:"Internal notes (not shown to user)..."}),e.jsxs("div",{style:{display:"flex",gap:"0.5rem",marginTop:8,flexWrap:"wrap"},children:[t.status==="info_submitted"&&e.jsx("button",{className:"cedros-admin__button cedros-admin__button--primary cedros-admin__button--sm",disabled:n,onClick:()=>i(t.id,"under_review",a),children:n?"Saving...":"Mark Under Review"}),t.status==="under_review"&&e.jsxs(e.Fragment,{children:[e.jsx("button",{className:"cedros-admin__button cedros-admin__button--primary cedros-admin__button--sm",disabled:n,onClick:()=>i(t.id,"approved",a),children:n?"Saving...":"Approve"}),e.jsx("button",{className:"cedros-admin__button cedros-admin__button--outline cedros-admin__button--danger cedros-admin__button--sm",disabled:n,onClick:()=>i(t.id,"rejected",a),children:n?"Saving...":"Reject"})]}),t.status==="approved"&&e.jsx("button",{className:"cedros-admin__button cedros-admin__button--primary cedros-admin__button--sm",disabled:n,onClick:()=>s(t.id),children:n?"Processing...":"Complete"})]})]})]})})}function Ye({serverUrl:t,apiKey:i,authManager:s}){const[n,a]=r.useState([]),[c,y]=r.useState(!0),[p,b]=r.useState(null),[o,d]=r.useState(""),[u,v]=r.useState(null),[x,f]=r.useState(null),j=r.useCallback(async(l,w)=>{if(s?.isAuthenticated())return s.fetchWithAuth(l,w);const _={"Content-Type":"application/json"};i&&(_["X-API-Key"]=i);const A=await fetch(`${t}${l}`,{...w,headers:{..._,...w?.headers}});if(!A.ok){const g=await A.text().catch(()=>`HTTP ${A.status}`);throw new Error(g)}return A.json()},[t,i,s]),k=r.useCallback(async()=>{y(!0),b(null);try{const l=o?`?status=${encodeURIComponent(o)}&limit=50&offset=0`:"?limit=50&offset=0",w=await j(`/admin/asset-redemptions${l}`);a(w.redemptions??[])}catch(l){b(l instanceof Error?l.message:"Failed to load redemptions")}finally{y(!1)}},[j,o]);r.useEffect(()=>{k()},[k]);const h=r.useCallback(async(l,w,_)=>{f(l),b(null);try{await j(`/admin/asset-redemptions/${l}/status`,{method:"PATCH",body:JSON.stringify({status:w,adminNotes:_})}),v(null),await k()}catch(A){b(A instanceof Error?A.message:"Failed to update status")}finally{f(null)}},[j,k]),S=r.useCallback(async l=>{f(l),b(null);try{await j(`/admin/asset-redemptions/${l}/complete`,{method:"POST"}),v(null),await k()}catch(w){b(w instanceof Error?w.message:"Failed to complete redemption")}finally{f(null)}},[j,k]),T=l=>{v(w=>w===l?null:l)};return e.jsxs("div",{className:"cedros-admin__page",children:[e.jsxs("div",{style:{display:"flex",alignItems:"center",gap:"0.75rem",marginBottom:"1rem",flexWrap:"wrap"},children:[e.jsxs("div",{children:[e.jsx("label",{style:{display:"block",fontSize:"0.8rem",fontWeight:500,marginBottom:4},children:"Status"}),e.jsx("select",{value:o,onChange:l=>{d(l.target.value),v(null)},style:{padding:"0.4rem 0.6rem",border:"1px solid rgba(0,0,0,0.2)",borderRadius:4,fontSize:"0.9rem",minWidth:160},children:$e.map(l=>e.jsx("option",{value:l.value,children:l.label},l.value))})]}),e.jsx("div",{style:{alignSelf:"flex-end"},children:e.jsx("button",{className:"cedros-admin__button cedros-admin__button--outline",onClick:k,disabled:c,children:c?"Loading...":"Refresh"})})]}),p&&e.jsx("div",{style:{padding:"0.75rem 1rem",background:"#fef2f2",border:"1px solid #fecaca",borderRadius:6,color:"#dc2626",marginBottom:"1rem",fontSize:"0.9rem"},children:p}),c?e.jsx("div",{className:"cedros-admin__loading",children:"Loading redemptions..."}):n.length===0?e.jsx("div",{className:"cedros-admin__empty",children:"No redemption requests found."}):e.jsx("div",{className:"cedros-admin__table-container",children:e.jsxs("table",{className:"cedros-admin__table",children:[e.jsx("thead",{children:e.jsxs("tr",{children:[e.jsx("th",{children:"Date"}),e.jsx("th",{children:"Order"}),e.jsx("th",{children:"Product"}),e.jsx("th",{children:"Collection"}),e.jsx("th",{children:"User"}),e.jsx("th",{children:"Status"}),e.jsx("th",{children:"Actions"})]})}),e.jsx("tbody",{children:n.map(l=>e.jsxs(e.Fragment,{children:[e.jsxs("tr",{style:{cursor:"pointer"},onClick:()=>T(l.id),children:[e.jsx("td",{children:We(l.createdAt)}),e.jsx("td",{children:e.jsx("code",{title:l.orderId,children:K(l.orderId)})}),e.jsx("td",{children:e.jsx("code",{title:l.productId,children:K(l.productId)})}),e.jsx("td",{children:e.jsx("code",{title:l.collectionId,children:K(l.collectionId)})}),e.jsx("td",{children:l.userId?e.jsx("code",{title:l.userId,children:K(l.userId)}):e.jsx("span",{style:{opacity:.4},children:"—"})}),e.jsx("td",{children:e.jsx("span",{className:qe(l.status),children:Oe(l.status)})}),e.jsx("td",{onClick:w=>w.stopPropagation(),children:e.jsxs("div",{style:{display:"flex",gap:"0.4rem",flexWrap:"wrap"},children:[(l.status==="info_submitted"||l.status==="under_review"||l.status==="approved")&&e.jsx("button",{className:"cedros-admin__button cedros-admin__button--outline cedros-admin__button--sm",onClick:()=>T(l.id),children:u===l.id?"Close":"Review"}),l.status==="under_review"&&e.jsxs(e.Fragment,{children:[e.jsx("button",{className:"cedros-admin__button cedros-admin__button--primary cedros-admin__button--sm",disabled:x===l.id,onClick:()=>h(l.id,"approved",l.adminNotes??""),children:"Approve"}),e.jsx("button",{className:"cedros-admin__button cedros-admin__button--outline cedros-admin__button--danger cedros-admin__button--sm",disabled:x===l.id,onClick:()=>h(l.id,"rejected",l.adminNotes??""),children:"Reject"})]}),l.status==="approved"&&e.jsx("button",{className:"cedros-admin__button cedros-admin__button--primary cedros-admin__button--sm",disabled:x===l.id,onClick:()=>S(l.id),children:x===l.id?"Processing...":"Complete"})]})})]},l.id),u===l.id&&e.jsx("tr",{children:e.jsx("td",{colSpan:7,style:{padding:0},children:e.jsx(Ue,{redemption:l,onAction:h,onComplete:S,actionBusy:x===l.id})})},`${l.id}-detail`)]}))})]})})]})}const Ge={CA:{cashOutCents:1500,expirationProhibited:!0,escheatmentYears:3,notes:"Cash-out threshold increases to $15 on April 1, 2026."},CO:{cashOutCents:500,escheatmentYears:5},CT:{cashOutCents:300,escheatmentYears:3},FL:{expirationProhibited:!0,escheatmentYears:5},ME:{cashOutCents:500,escheatmentYears:3},MA:{cashOutCents:500,escheatmentYears:3,notes:"Cash-out also required when 90% of value is used."},MT:{cashOutCents:500,escheatmentYears:5},NJ:{cashOutCents:500,escheatmentYears:3},OR:{cashOutCents:500,escheatmentYears:3,notes:"May require at least one prior transaction."},RI:{cashOutCents:100,escheatmentYears:3},TX:{cashOutCents:250,escheatmentYears:3},VT:{cashOutCents:100,escheatmentYears:3},WA:{cashOutCents:500,escheatmentYears:5},PR:{cashOutCents:500,escheatmentYears:5}},ye={escheatmentYears:5},re=1e6,Ke={AL:"Alabama",AK:"Alaska",AZ:"Arizona",AR:"Arkansas",CA:"California",CO:"Colorado",CT:"Connecticut",DE:"Delaware",FL:"Florida",GA:"Georgia",HI:"Hawaii",ID:"Idaho",IL:"Illinois",IN:"Indiana",IA:"Iowa",KS:"Kansas",KY:"Kentucky",LA:"Louisiana",ME:"Maine",MD:"Maryland",MA:"Massachusetts",MI:"Michigan",MN:"Minnesota",MS:"Mississippi",MO:"Missouri",MT:"Montana",NE:"Nebraska",NV:"Nevada",NH:"New Hampshire",NJ:"New Jersey",NM:"New Mexico",NY:"New York",NC:"North Carolina",ND:"North Dakota",OH:"Ohio",OK:"Oklahoma",OR:"Oregon",PA:"Pennsylvania",RI:"Rhode Island",SC:"South Carolina",SD:"South Dakota",TN:"Tennessee",TX:"Texas",UT:"Utah",VT:"Vermont",VA:"Virginia",WA:"Washington",WV:"West Virginia",WI:"Wisconsin",WY:"Wyoming",DC:"District of Columbia",PR:"Puerto Rico"};function He({serverUrl:t,authManager:i}){const[s,n]=r.useState(null),[a,c]=r.useState(null),[y,p]=r.useState(null),[b,o]=r.useState(!0),d=r.useCallback(async()=>{try{const j=(await new ee.ConfigApiClient(t,void 0,i).getConfig("gift_cards")).config??{};n(j.business_state||null),c(j.min_gift_card_value_cents!=null?Number(j.min_gift_card_value_cents):null),p(j.max_gift_card_value_cents!=null?Number(j.max_gift_card_value_cents):null)}catch{}finally{o(!1)}},[t,i]);if(r.useEffect(()=>{d()},[d]),b)return e.jsx("div",{style:{padding:"2rem",textAlign:"center",opacity:.6},children:"Loading compliance data..."});const u=s?Ge[s]??ye:null,v=s?Ke[s]??s:null;return e.jsx("div",{children:s?e.jsxs(e.Fragment,{children:[e.jsxs("h3",{className:"cedros-admin__section-title",style:{marginBottom:"1rem"},children:["Compliance Guidance — ",v]}),e.jsxs("div",{style:{display:"grid",gap:"1rem",maxWidth:720},children:[e.jsx(Ve,{reg:u,minValueCents:a}),e.jsx(Xe,{reg:u}),e.jsx(Ze,{reg:u}),e.jsx(Qe,{maxValueCents:y})]}),e.jsx(et,{reg:u,minValueCents:a,maxValueCents:y})]}):e.jsx(Je,{})})}function Je(){return e.jsxs("div",{style:{padding:"2rem",textAlign:"center"},children:[e.jsx("p",{style:{fontSize:15,opacity:.7,marginBottom:"0.5rem"},children:"No business state configured."}),e.jsxs("p",{style:{fontSize:13,opacity:.5},children:["Set your ",e.jsx("strong",{children:"business_state"})," in the Gift Cards config category to see state-specific compliance guidance."]})]})}function te({title:t,children:i}){return e.jsxs("div",{style:{border:"1px solid rgba(0,0,0,0.1)",borderRadius:8,padding:"1rem 1.25rem"},children:[e.jsx("h4",{style:{margin:"0 0 0.5rem",fontSize:14,fontWeight:600},children:t}),e.jsx("div",{style:{fontSize:13,lineHeight:1.6},children:i})]})}function Ve({reg:t,minValueCents:i}){if(!t.cashOutCents)return e.jsx(te,{title:"Cash-Out Threshold",children:e.jsx("p",{style:{margin:0},children:"Your state does not have a specific cash-out threshold for gift cards. Federal law does not require cash redemption."})});const s=(t.cashOutCents/100).toFixed(2),n=i!=null&&i>t.cashOutCents;return e.jsxs(te,{title:"Cash-Out Threshold",children:[e.jsxs("p",{style:{margin:"0 0 0.5rem"},children:["Your state requires cash redemption for gift cards with a remaining balance of ",e.jsxs("strong",{children:["$",s]})," or less."]}),e.jsxs("p",{style:{margin:"0 0 0.5rem"},children:["Since this system uses ",e.jsx("strong",{children:"one-shot full redemption"})," (entire gift card value is converted to credits at once), cash-out is avoided by setting the minimum gift card face value above the threshold."]}),n?e.jsxs(oe,{ok:!0,children:["Min value ($",((i??0)/100).toFixed(2),") exceeds threshold"]}):e.jsxs(oe,{ok:!1,children:["Set ",e.jsx("code",{children:"min_gift_card_value_cents"})," above ",t.cashOutCents," to avoid cash-out obligations"]}),t.notes&&e.jsx("p",{style:{margin:"0.5rem 0 0",opacity:.7,fontStyle:"italic"},children:t.notes})]})}function Xe({reg:t}){return e.jsx(te,{title:"Expiration Rules",children:t.expirationProhibited?e.jsxs("p",{style:{margin:0},children:["Your state ",e.jsx("strong",{children:"prohibits"})," gift card expiration. Do not set expiration dates on gift cards."]}):e.jsxs("p",{style:{margin:0},children:["Federal law (CARD Act) requires gift cards to remain valid for at least ",e.jsx("strong",{children:"5 years"})," from purchase or last reload. Your state follows the federal minimum."]})})}function Ze({reg:t}){const i=t.escheatmentYears??ye.escheatmentYears;return e.jsxs(te,{title:"Escheatment (Unclaimed Property)",children:[e.jsxs("p",{style:{margin:"0 0 0.5rem"},children:["Gift card balances unredeemed for ",e.jsxs("strong",{children:[i," years"]})," may need to be reported and remitted to the state as unclaimed property."]}),e.jsxs("p",{style:{margin:0,opacity:.7},children:["The system tracks ",e.jsx("code",{children:"last_activity_at"})," on gift card redemptions to help identify dormant balances approaching the escheatment window."]})]})}function Qe({maxValueCents:t}){const i=t??re,s=i<=re;return e.jsxs(te,{title:"Anti-Money Laundering (AML)",children:[e.jsxs("p",{style:{margin:"0 0 0.5rem"},children:["FinCEN requires closed-loop prepaid cards to stay at or below ",e.jsx("strong",{children:"$10,000"})," per card. The server enforces this cap on product creation."]}),s?e.jsxs(oe,{ok:!0,children:["Max value ($",(i/100).toFixed(2),") within AML limit"]}):e.jsxs(oe,{ok:!1,children:[e.jsx("code",{children:"max_gift_card_value_cents"})," exceeds $10,000 AML cap"]})]})}function oe({ok:t,children:i}){return e.jsxs("div",{style:{display:"inline-flex",alignItems:"center",gap:6,padding:"4px 10px",borderRadius:6,fontSize:13,fontWeight:500,background:t?"rgba(34,197,94,0.1)":"rgba(234,179,8,0.15)",color:t?"#16a34a":"#a16207"},children:[e.jsx("span",{children:t?"✓":"⚠"}),i]})}function et({reg:t,minValueCents:i,maxValueCents:s}){const a=[{label:"AML: Max card value ≤ $10,000",ok:(s??re)<=re},...t.cashOutCents?[{label:`Cash-out: Min value > $${(t.cashOutCents/100).toFixed(2)} threshold`,ok:i!=null&&i>t.cashOutCents}]:[],{label:t.expirationProhibited?"Expiration: State prohibits expiration (no action needed)":"Expiration: Federal 5-year minimum applies",ok:!0},{label:`Escheatment: ${t.escheatmentYears??ye.escheatmentYears}-year dormancy tracking enabled`,ok:!0}];return e.jsxs("div",{style:{marginTop:"1.5rem"},children:[e.jsx("h4",{style:{fontSize:14,fontWeight:600,marginBottom:"0.75rem"},children:"Compliance Checklist"}),e.jsx("div",{style:{display:"flex",flexDirection:"column",gap:6},children:a.map((c,y)=>e.jsxs("div",{style:{display:"flex",alignItems:"center",gap:8,fontSize:13},children:[e.jsx("span",{style:{color:c.ok?"#16a34a":"#d97706",fontWeight:600},children:c.ok?"✓":"⚠"}),e.jsx("span",{children:c.label})]},y))})]})}function tt({serverUrl:t,apiKey:i,authManager:s}){const[n,a]=r.useState(null),[c,y]=r.useState(!0),[p,b]=r.useState(null),o=r.useCallback(async x=>{if(s?.isAuthenticated())return s.fetchWithAuth(x);const f={"Content-Type":"application/json"};i&&(f["X-API-Key"]=i);const j=await fetch(`${t}${x}`,{headers:f});if(!j.ok)throw new Error(`HTTP ${j.status}`);return j.json()},[t,i,s]),d=r.useCallback(async()=>{y(!0),b(null);try{const[x,f]=await Promise.all([o("/admin/gift-cards?limit=50"),o("/admin/gift-card-redemptions?limit=50").catch(()=>({redemptions:[]}))]),j=x.giftCards??[],k=f.redemptions??[],h=new Date,S=j.filter(m=>m.active&&(!m.expiresAt||new Date(m.expiresAt)>h)).length,T=j.filter(m=>m.expiresAt&&new Date(m.expiresAt)<=h).length,l=j.reduce((m,N)=>m+N.initialBalance,0),w=j.reduce((m,N)=>m+N.balance,0),_=k.reduce((m,N)=>m+N.faceValueCents,0),A=k.filter(m=>m.tokenMinted).length,g=j[0]?.currency||k[0]?.currency||"USD";a({totalCards:j.length,activeCards:S,expiredCards:T,totalIssuedCents:l,totalRemainingCents:w,totalRedeemedCents:_,redemptionCount:k.length,tokensMinted:A,currency:g.toUpperCase()})}catch(x){b(x instanceof Error?x.message:"Failed to load analytics")}finally{y(!1)}},[o]);r.useEffect(()=>{d()},[d]);const u=x=>`$${(x/100).toFixed(2)}`;if(c)return e.jsx("div",{className:"cedros-admin__loading",children:"Loading analytics..."});if(p)return e.jsxs("div",{style:{padding:"0.75rem",background:"rgba(220,38,38,0.08)",borderRadius:6,fontSize:13,color:"#b91c1c"},children:[p,e.jsx("button",{className:"cedros-admin__button cedros-admin__button--sm",style:{marginLeft:8},onClick:d,children:"Retry"})]});if(!n)return null;const v=n.totalIssuedCents>0?((n.totalIssuedCents-n.totalRemainingCents)/n.totalIssuedCents*100).toFixed(1):"0.0";return e.jsxs("div",{children:[e.jsx("h3",{className:"cedros-admin__section-title",style:{marginBottom:"1rem"},children:"Gift Card & Token Analytics"}),e.jsxs("div",{style:{display:"grid",gridTemplateColumns:"repeat(auto-fill, minmax(180px, 1fr))",gap:"0.75rem",marginBottom:"1.5rem"},children:[e.jsx($,{label:"Total Cards",value:String(n.totalCards)}),e.jsx($,{label:"Active",value:String(n.activeCards),accent:"green"}),e.jsx($,{label:"Expired",value:String(n.expiredCards),accent:n.expiredCards>0?"amber":void 0}),e.jsx($,{label:"Total Issued",value:u(n.totalIssuedCents),sub:n.currency}),e.jsx($,{label:"Remaining Balance",value:u(n.totalRemainingCents),sub:n.currency}),e.jsx($,{label:"Usage Rate",value:`${v}%`,sub:"issued vs. spent"}),e.jsx($,{label:"Redemptions",value:String(n.redemptionCount)}),e.jsx($,{label:"Tokens Minted",value:String(n.tokensMinted),sub:`of ${n.redemptionCount} redemptions`})]}),n.totalIssuedCents>0&&e.jsxs("div",{children:[e.jsx("div",{style:{fontSize:13,fontWeight:500,marginBottom:6},children:"Balance Breakdown"}),e.jsxs("div",{style:{display:"flex",height:24,borderRadius:6,overflow:"hidden",background:"rgba(0,0,0,0.05)"},children:[e.jsx("div",{style:{width:`${(n.totalIssuedCents-n.totalRemainingCents)/n.totalIssuedCents*100}%`,background:"#2563eb",minWidth:2},title:`Spent: ${u(n.totalIssuedCents-n.totalRemainingCents)}`}),e.jsx("div",{style:{width:`${n.totalRemainingCents/n.totalIssuedCents*100}%`,background:"#60a5fa",minWidth:2},title:`Remaining: ${u(n.totalRemainingCents)}`})]}),e.jsxs("div",{style:{display:"flex",gap:"1rem",marginTop:6,fontSize:12,opacity:.7},children:[e.jsxs("span",{children:[e.jsx("span",{style:{display:"inline-block",width:10,height:10,background:"#2563eb",borderRadius:2,marginRight:4}}),"Spent"]}),e.jsxs("span",{children:[e.jsx("span",{style:{display:"inline-block",width:10,height:10,background:"#60a5fa",borderRadius:2,marginRight:4}}),"Remaining"]})]})]})]})}function $({label:t,value:i,sub:s,accent:n}){const a=n==="green"?"#166534":n==="amber"?"#92400e":void 0;return e.jsxs("div",{style:{padding:"0.75rem 1rem",borderRadius:8,border:"1px solid rgba(0,0,0,0.08)",background:"rgba(0,0,0,0.01)"},children:[e.jsx("div",{style:{fontSize:12,opacity:.6,marginBottom:4},children:t}),e.jsx("div",{style:{fontSize:20,fontWeight:700,color:a},children:i}),s&&e.jsx("div",{style:{fontSize:11,opacity:.5,marginTop:2},children:s})]})}function nt({serverUrl:t,apiKey:i,authManager:s}){const[n,a]=r.useState([]),[c,y]=r.useState(!0),[p,b]=r.useState(null),[o,d]=r.useState("list"),[u,v]=r.useState(null),[x,f]=r.useState(!1),[j,k]=r.useState(null),h=r.useCallback(async(_,A)=>{if(s?.isAuthenticated())return s.fetchWithAuth(_,A);const g={"Content-Type":"application/json"};i&&(g["X-API-Key"]=i);const m=await fetch(`${t}${_}`,{...A,headers:{...g,...A?.headers}});if(!m.ok){const N=await m.text().catch(()=>`HTTP ${m.status}`);throw new Error(N)}return m.json()},[t,i,s]),S=r.useCallback(async()=>{y(!0),b(null);try{const A=await h(`/admin/gift-cards${x?"?activeOnly=true&limit=50":"?limit=50"}`);a(A.giftCards??[])}catch(_){b(_ instanceof Error?_.message:"Failed to load gift cards")}finally{y(!1)}},[h,x]);r.useEffect(()=>{S()},[S]);const T=(_,A)=>`$${(_/100).toFixed(2)} ${A.toUpperCase()}`,l=_=>{try{return new Date(_).toLocaleDateString(void 0,{month:"short",day:"numeric",year:"numeric"})}catch{return _}},w=_=>{v(_),d("adjust"),k(null)};return o==="create"?e.jsx(st,{onSubmit:async _=>{await h("/admin/gift-cards",{method:"POST",body:JSON.stringify(_)}),d("list"),S()},onCancel:()=>d("list")}):o==="adjust"&&u?e.jsx(it,{card:u,formatCents:T,onSubmit:async _=>{await h(`/admin/gift-cards/${encodeURIComponent(u.code)}/adjust`,{method:"POST",body:JSON.stringify({newBalance:_})}),d("list"),S()},onToggleActive:async()=>{await h(`/admin/gift-cards/${encodeURIComponent(u.code)}`,{method:"PUT",body:JSON.stringify({initialBalance:u.initialBalance,balance:u.balance,currency:u.currency,active:!u.active,expiresAt:u.expiresAt,metadata:u.metadata})}),d("list"),S()},onCancel:()=>{d("list"),v(null)}}):e.jsxs("div",{children:[e.jsxs("div",{style:{display:"flex",justifyContent:"space-between",alignItems:"center",marginBottom:"1rem"},children:[e.jsx("h3",{className:"cedros-admin__section-title",style:{margin:0},children:"Gift Card Inventory"}),e.jsxs("div",{style:{display:"flex",gap:"0.5rem",alignItems:"center"},children:[e.jsxs("label",{style:{fontSize:13,display:"flex",alignItems:"center",gap:4},children:[e.jsx("input",{type:"checkbox",checked:x,onChange:_=>f(_.target.checked)}),"Active only"]}),e.jsx("button",{className:"cedros-admin__button cedros-admin__button--primary cedros-admin__button--sm",onClick:()=>{d("create"),k(null)},children:"+ New Gift Card"})]})]}),p&&e.jsxs("div",{style:{padding:"0.75rem",background:"rgba(220,38,38,0.08)",borderRadius:6,marginBottom:"1rem",fontSize:13,color:"#b91c1c"},children:[p,e.jsx("button",{className:"cedros-admin__button cedros-admin__button--sm",style:{marginLeft:8},onClick:S,children:"Retry"})]}),j&&e.jsx("div",{style:{padding:"0.75rem",background:"rgba(22,163,74,0.08)",borderRadius:6,marginBottom:"1rem",fontSize:13,color:"#166534"},children:j}),c?e.jsx("div",{className:"cedros-admin__loading",children:"Loading..."}):n.length?e.jsx("div",{className:"cedros-admin__table-container",children:e.jsxs("table",{className:"cedros-admin__table",children:[e.jsx("thead",{children:e.jsxs("tr",{children:[e.jsx("th",{children:"Code"}),e.jsx("th",{children:"Balance"}),e.jsx("th",{children:"Initial"}),e.jsx("th",{children:"Status"}),e.jsx("th",{children:"Expires"}),e.jsx("th",{children:"Created"}),e.jsx("th",{})]})}),e.jsx("tbody",{children:n.map(_=>e.jsxs("tr",{children:[e.jsx("td",{children:e.jsxs("code",{style:{fontSize:12},children:[_.code.slice(0,12),"..."]})}),e.jsx("td",{style:{fontWeight:600},children:T(_.balance,_.currency)}),e.jsx("td",{style:{opacity:.7},children:T(_.initialBalance,_.currency)}),e.jsx("td",{children:e.jsx("span",{className:`cedros-admin__badge ${_.active?"cedros-admin__badge--success":"cedros-admin__badge--muted"}`,children:_.active?"Active":"Inactive"})}),e.jsx("td",{style:{fontSize:13},children:_.expiresAt?l(_.expiresAt):"—"}),e.jsx("td",{style:{fontSize:13},children:l(_.createdAt)}),e.jsx("td",{children:e.jsx("button",{className:"cedros-admin__button cedros-admin__button--outline cedros-admin__button--sm",onClick:()=>w(_),children:"Manage"})})]},_.code))})]})}):e.jsx("div",{className:"cedros-admin__empty",style:{padding:"2rem",textAlign:"center",opacity:.6},children:"No gift cards found."})]})}function st({onSubmit:t,onCancel:i}){const[s,n]=r.useState({code:"",initialBalance:"",currency:"USD",expiresAt:""}),[a,c]=r.useState(!1),[y,p]=r.useState(null),b=async o=>{o.preventDefault();const d=Math.round(parseFloat(s.initialBalance)*100);if(!d||d<0){p("Initial balance must be positive");return}c(!0),p(null);try{await t({...s.code.trim()?{code:s.code.trim().toUpperCase()}:{},initialBalance:d,currency:s.currency.toUpperCase(),...s.expiresAt?{expiresAt:new Date(s.expiresAt).toISOString()}:{}})}catch(u){p(u instanceof Error?u.message:"Failed to create gift card")}finally{c(!1)}};return e.jsxs("div",{children:[e.jsx("h3",{className:"cedros-admin__section-title",style:{marginBottom:"1rem"},children:"Create Gift Card"}),y&&e.jsx("div",{style:{padding:"0.75rem",background:"rgba(220,38,38,0.08)",borderRadius:6,marginBottom:"1rem",fontSize:13,color:"#b91c1c"},children:y}),e.jsxs("form",{onSubmit:b,children:[e.jsxs("div",{className:"cedros-admin__form-row",children:[e.jsxs("div",{className:"cedros-admin__field",children:[e.jsx("label",{className:"cedros-admin__field-label",children:"Code (optional, auto-generated if empty)"}),e.jsx("input",{type:"text",className:"cedros-admin__input",value:s.code,onChange:o=>n(d=>({...d,code:o.target.value})),placeholder:"Leave blank to auto-generate"})]}),e.jsxs("div",{className:"cedros-admin__field",children:[e.jsx("label",{className:"cedros-admin__field-label",children:"Initial Balance ($)"}),e.jsx("input",{type:"number",className:"cedros-admin__input",value:s.initialBalance,onChange:o=>n(d=>({...d,initialBalance:o.target.value})),placeholder:"25.00",step:"0.01",min:"0",required:!0})]})]}),e.jsxs("div",{className:"cedros-admin__form-row",children:[e.jsxs("div",{className:"cedros-admin__field",children:[e.jsx("label",{className:"cedros-admin__field-label",children:"Currency"}),e.jsx("input",{type:"text",className:"cedros-admin__input",value:s.currency,onChange:o=>n(d=>({...d,currency:o.target.value})),maxLength:3,required:!0})]}),e.jsxs("div",{className:"cedros-admin__field",children:[e.jsx("label",{className:"cedros-admin__field-label",children:"Expiration date (optional)"}),e.jsx("input",{type:"date",className:"cedros-admin__input",value:s.expiresAt,onChange:o=>n(d=>({...d,expiresAt:o.target.value}))})]})]}),e.jsxs("div",{className:"cedros-admin__form-actions",style:{marginTop:"1rem"},children:[e.jsx("button",{type:"submit",className:"cedros-admin__button cedros-admin__button--primary",disabled:a,children:a?"Creating...":"Create Gift Card"}),e.jsx("button",{type:"button",className:"cedros-admin__button cedros-admin__button--outline",onClick:i,children:"Cancel"})]})]})]})}function it({card:t,formatCents:i,onSubmit:s,onToggleActive:n,onCancel:a}){const[c,y]=r.useState((t.balance/100).toFixed(2)),[p,b]=r.useState(!1),[o,d]=r.useState(null),u=async x=>{x.preventDefault();const f=Math.round(parseFloat(c)*100);if(isNaN(f)||f<0){d("Balance must be >= 0");return}b(!0),d(null);try{await s(f)}catch(j){d(j instanceof Error?j.message:"Failed to adjust balance")}finally{b(!1)}},v=async()=>{b(!0),d(null);try{await n()}catch(x){d(x instanceof Error?x.message:"Failed to update status"),b(!1)}};return e.jsxs("div",{children:[e.jsx("h3",{className:"cedros-admin__section-title",style:{marginBottom:"1rem"},children:"Manage Gift Card"}),o&&e.jsx("div",{style:{padding:"0.75rem",background:"rgba(220,38,38,0.08)",borderRadius:6,marginBottom:"1rem",fontSize:13,color:"#b91c1c"},children:o}),e.jsxs("div",{style:{display:"grid",gridTemplateColumns:"1fr 1fr",gap:"0.5rem",maxWidth:500,marginBottom:"1.5rem",fontSize:13},children:[e.jsx("div",{style:{fontWeight:500},children:"Code"}),e.jsx("div",{style:{fontFamily:"monospace",wordBreak:"break-all"},children:t.code}),e.jsx("div",{style:{fontWeight:500},children:"Current Balance"}),e.jsx("div",{style:{fontWeight:600},children:i(t.balance,t.currency)}),e.jsx("div",{style:{fontWeight:500},children:"Initial Balance"}),e.jsx("div",{children:i(t.initialBalance,t.currency)}),e.jsx("div",{style:{fontWeight:500},children:"Status"}),e.jsx("div",{children:e.jsx("span",{className:`cedros-admin__badge ${t.active?"cedros-admin__badge--success":"cedros-admin__badge--muted"}`,children:t.active?"Active":"Inactive"})}),t.expiresAt&&e.jsxs(e.Fragment,{children:[e.jsx("div",{style:{fontWeight:500},children:"Expires"}),e.jsx("div",{children:new Date(t.expiresAt).toLocaleDateString()})]})]}),e.jsxs("form",{onSubmit:u,children:[e.jsxs("div",{className:"cedros-admin__field",style:{maxWidth:250},children:[e.jsx("label",{className:"cedros-admin__field-label",children:"New Balance ($)"}),e.jsx("input",{type:"number",className:"cedros-admin__input",value:c,onChange:x=>y(x.target.value),step:"0.01",min:"0",required:!0})]}),e.jsxs("div",{className:"cedros-admin__form-actions",style:{marginTop:"1rem",display:"flex",gap:"0.5rem"},children:[e.jsx("button",{type:"submit",className:"cedros-admin__button cedros-admin__button--primary",disabled:p,children:p?"Saving...":"Adjust Balance"}),e.jsx("button",{type:"button",className:`cedros-admin__button ${t.active?"cedros-admin__button--danger":"cedros-admin__button--outline"}`,onClick:v,disabled:p,children:t.active?"Deactivate":"Reactivate"}),e.jsx("button",{type:"button",className:"cedros-admin__button cedros-admin__button--outline",onClick:a,children:"Back"})]})]})]})}const at=0;class Ce{dlmmModule=null;bnClass=null;keypairClass=null;async loadDLMM(){if(this.dlmmModule)return this.dlmmModule;try{const i=await Promise.resolve().then(()=>require("./pay-react_false-DaeIe3_l.js"));return this.dlmmModule=i.default??i,this.dlmmModule}catch{throw new Error("Install @meteora-ag/dlmm to enable pool deployment: npm install @meteora-ag/dlmm")}}async loadBN(){if(this.bnClass)return this.bnClass;const i=await Promise.resolve().then(()=>require("./bn-CHyy7EgJ.js")).then(s=>s.bn);return this.bnClass=i.default??i,this.bnClass}async loadKeypair(){if(this.keypairClass)return this.keypairClass;const{Keypair:i}=await import("@solana/web3.js");return this.keypairClass=i,this.keypairClass}async computeBinId(i,s,n,a=1){const c=await this.loadDLMM(),y=c.getPricePerLamport(s,n,i);return c.getBinIdFromPrice(y,a,!0)}async findPresetParameter(i,s,n){const a=await this.loadDLMM(),c=n?{cluster:n}:void 0,{presetParameter2:y}=await a.getAllPresetParameters(i,c),p=y.find(b=>b.account.binStep===s);if(!p)throw new Error(`No PresetParameter2 found for binStep=${s}. Available: ${y.map(b=>b.account.binStep).join(", ")}`);return p.publicKey}async createPool(i,s,n,a,c,y=1,p){const b=await this.loadDLMM(),o=await this.loadBN(),d=p?{cluster:p}:void 0,u=await this.findPresetParameter(i,y,p),v=await b.createLbPair2(i,s,n,a,u,new o(c),d),x=v.instructions[0]?.keys?.[1]?.pubkey;if(!x)throw new Error("Failed to extract pool address from transaction");return{transaction:v,poolAddress:x}}async addBuybackLiquidity(i,s,n,a,c,y){const p=await this.loadDLMM(),b=await this.loadBN(),o=await this.loadKeypair(),d=y?{cluster:y}:void 0,u=await p.create(i,n,d),v=o.generate(),x=c-1,f=c;return{transaction:await u.initializePositionAndAddLiquidityByStrategy({positionPubKey:v.publicKey,totalXAmount:new b(0),totalYAmount:new b(a),strategy:{maxBinId:f,minBinId:x,strategyType:at},user:s,slippage:1}),positionKeypair:v}}async getPoolStatus(i,s,n){const a=await this.loadDLMM(),c=n?{cluster:n}:void 0,y=await a.create(i,s,c),p=await y.getActiveBin();return{address:s.toBase58(),activeBinId:p.binId,activeBinPrice:p.price,binStep:y.lbPair.binStep}}}const he=6,rt=1,ot="https://solscan.io/account",lt="https://app.meteora.ag/dlmm";function dt({serverUrl:t,authManager:i,poolAddress:s,buybackRateBps:n,usdcAmount:a,deployedAt:c,mintAddress:y,tokenDecimals:p=2,onConfigUpdated:b}){const[o,d]=r.useState("none"),[u,v]=r.useState(n!=null?n/100:80),[x,f]=r.useState(100),[j,k]=r.useState(!1),[h,S]=r.useState(!1),[T,l]=r.useState(null),[w,_]=r.useState(null),A=n!=null?`$${(n/1e4).toFixed(2)}`:"Unknown",g=a!=null?`$${(a/10**he).toFixed(2)}`:null,m=c?new Date(c).toLocaleDateString(void 0,{month:"short",day:"numeric",year:"numeric"}):null,N=s.length>16?`${s.slice(0,8)}...${s.slice(-8)}`:s,C=async()=>{k(!0),_(null),l(null);try{const B=new ee.ConfigApiClient(t,void 0,i),R=Math.round(u*100);await B.patchConfig("gift_cards",{buyback_rate_bps:R},`Buyback rate adjusted to ${u} cents`),l("Buyback rate updated"),d("none"),b()}catch(B){_(B instanceof Error?B.message:"Failed to update rate")}finally{k(!1)}},z=async()=>{if(y){S(!0),_(null),l(null);try{const{Connection:B,PublicKey:R,Keypair:M}=await import("@solana/web3.js"),F=new ee.ConfigApiClient(t,void 0,i),I=await F.getConfig("x402"),D=I.config?.rpc_url||"",P=I.config?.token_mint||"";if(!D||!P)throw new Error("RPC URL or USDC mint not configured");const L=new B(D,"confirmed"),O=window.solana;if(!O?.publicKey||!O.signTransaction)throw new Error("Wallet not connected");const ne=new Ce,le=new R(O.publicKey.toBase58()),E=u/100,de=await ne.computeBinId(E,p,he,rt),se=new R(s),H=Math.round(x*10**he),{transaction:J,positionKeypair:W}=await ne.addBuybackLiquidity(L,le,se,H,de),V=M.fromSecretKey(W.secretKey);J.partialSign(V);const Y=await O.signTransaction(J),X=await L.sendRawTransaction(Y.serialize());await L.confirmTransaction(X,"confirmed");const Z=a??0;await F.patchConfig("gift_cards",{liquidity_usdc_amount:Z+H},`Added ${x} USDC liquidity`),l(`Added $${x} USDC liquidity`),d("none"),b()}catch(B){_(B instanceof Error?B.message:"Failed to add liquidity")}finally{S(!1)}}};return e.jsxs("div",{children:[e.jsx("h3",{className:"cedros-admin__section-title",style:{marginBottom:"1rem"},children:"Liquidity Pool Active"}),e.jsxs("div",{style:{display:"grid",gridTemplateColumns:"1fr 1fr",gap:"0.75rem",maxWidth:600},children:[e.jsx("div",{style:{fontWeight:500,fontSize:13},children:"Pool Address"}),e.jsxs("div",{style:{fontSize:13,fontFamily:"monospace",wordBreak:"break-all"},children:[N,e.jsxs("span",{style:{marginLeft:8,display:"inline-flex",gap:6},children:[e.jsx(ct,{text:s}),e.jsx(_e,{href:`${ot}/${s}`,label:"Solscan"}),e.jsx(_e,{href:`${lt}/${s}`,label:"Meteora"})]})]}),e.jsx("div",{style:{fontWeight:500,fontSize:13},children:"Buyback Rate"}),e.jsxs("div",{style:{fontSize:13},children:[A," per $1.00"]}),g&&e.jsxs(e.Fragment,{children:[e.jsx("div",{style:{fontWeight:500,fontSize:13},children:"USDC Deposited"}),e.jsx("div",{style:{fontSize:13},children:g})]}),m&&e.jsxs(e.Fragment,{children:[e.jsx("div",{style:{fontWeight:500,fontSize:13},children:"Deployed"}),e.jsx("div",{style:{fontSize:13},children:m})]})]}),e.jsxs("div",{style:{marginTop:"1.25rem",display:"flex",gap:"0.5rem"},children:[e.jsx("button",{className:"cedros-admin__button",onClick:()=>d(o==="adjust_rate"?"none":"adjust_rate"),disabled:h||j,children:"Adjust Rate"}),e.jsx("button",{className:"cedros-admin__button",onClick:()=>d(o==="add_liquidity"?"none":"add_liquidity"),disabled:h||j||!y,children:"Add Liquidity"})]}),o==="adjust_rate"&&e.jsxs("div",{style:{marginTop:"1rem",padding:"1rem",borderRadius:8,border:"1px solid var(--cedros-admin-border, #e5e7eb)"},children:[e.jsxs("div",{className:"cedros-admin__field",children:[e.jsx("label",{className:"cedros-admin__field-label",children:"New buyback rate (cents per $1.00)"}),e.jsx("input",{type:"number",className:"cedros-admin__input",value:u,onChange:B=>v(Math.max(1,Math.min(99,parseInt(B.target.value)||80))),min:"1",max:"99",style:{maxWidth:200}}),e.jsxs("div",{style:{marginTop:4,fontSize:12,opacity:.75},children:["Profit per redemption: $",((100-u)/100).toFixed(2)]})]}),e.jsx("button",{className:"cedros-admin__button cedros-admin__button--primary",onClick:C,disabled:j,style:{marginTop:"0.75rem"},children:j?"Saving...":"Save Rate"})]}),o==="add_liquidity"&&e.jsxs("div",{style:{marginTop:"1rem",padding:"1rem",borderRadius:8,border:"1px solid var(--cedros-admin-border, #e5e7eb)"},children:[e.jsxs("div",{className:"cedros-admin__field",children:[e.jsx("label",{className:"cedros-admin__field-label",children:"USDC amount to add"}),e.jsx("input",{type:"number",className:"cedros-admin__input",value:x,onChange:B=>f(Math.max(1,parseFloat(B.target.value)||100)),min:"1",step:"1",style:{maxWidth:200}})]}),e.jsx("button",{className:"cedros-admin__button cedros-admin__button--primary",onClick:z,disabled:h,style:{marginTop:"0.75rem"},children:h?"Adding liquidity...":`Add $${x} USDC`}),e.jsx("div",{style:{marginTop:4,fontSize:12,opacity:.75},children:"Requires a connected wallet and USDC balance."})]}),T&&e.jsx("div",{style:{marginTop:"0.75rem",padding:"0.5rem 0.75rem",borderRadius:6,background:"rgba(22,163,74,0.1)",color:"#16a34a",fontSize:13},children:T}),w&&e.jsx("div",{style:{marginTop:"0.75rem",padding:"0.5rem 0.75rem",borderRadius:6,background:"rgba(239,68,68,0.1)",color:"#dc2626",fontSize:13},children:w})]})}function ct({text:t}){const[i,s]=r.useState(!1),n=()=>{navigator.clipboard.writeText(t).then(()=>{s(!0),setTimeout(()=>s(!1),1500)})};return e.jsx("button",{type:"button",onClick:n,style:{background:"none",border:"none",cursor:"pointer",fontSize:12,opacity:.7,padding:0},children:i?"Copied":"Copy"})}function _e({href:t,label:i}){return e.jsx("a",{href:t,target:"_blank",rel:"noopener noreferrer",style:{fontSize:12,opacity:.7},children:i})}const ie=6,ge=1;function ut({serverUrl:t,authManager:i,mintConfigured:s,mintAddress:n,tokenDecimals:a=2}){const[c,y]=r.useState({liquidityPoolAddress:null,buybackRateBps:null,rpcUrl:null,usdcMint:null,usdcAmount:null,deployedAt:null}),[p,b]=r.useState(!0),[o,d]=r.useState(80),[u,v]=r.useState(250),[x,f]=r.useState("idle"),[j,k]=r.useState(null),[h,S]=r.useState(null),[T,l]=r.useState(null),w=r.useRef(new Ce),_=r.useCallback(async()=>{try{const R=new ee.ConfigApiClient(t,void 0,i),[M,F]=await Promise.all([R.getConfig("gift_cards"),R.getConfig("x402")]),I=M.config??{},D=F.config??{},P=I.liquidity_pool_address||null;y({liquidityPoolAddress:P,buybackRateBps:I.buyback_rate_bps!=null?Number(I.buyback_rate_bps):null,rpcUrl:D.rpc_url||null,usdcMint:D.token_mint||null,usdcAmount:I.liquidity_usdc_amount!=null?Number(I.liquidity_usdc_amount):null,deployedAt:I.liquidity_deployed_at||null}),P&&S(P),I.buyback_rate_bps!=null&&d(Number(I.buyback_rate_bps)/100)}catch{}finally{b(!1)}},[t,i]);r.useEffect(()=>{_()},[_]);const A=typeof window<"u"&&!!window.solana?.publicKey,g=!!c.rpcUrl,m=!!c.usdcMint,N=s&&A&&g&&m&&x==="idle",C=async R=>{if(!(!n||!c.rpcUrl||!c.usdcMint)){f(R),k(null),l(null);try{const{Connection:M,PublicKey:F,Keypair:I}=await import("@solana/web3.js"),D=new M(c.rpcUrl,"confirmed"),P=window.solana;if(!P?.publicKey||!P.signTransaction)throw new Error("Wallet not connected");const L=w.current,O=new F(P.publicKey.toBase58()),ne=o/100,le=await L.computeBinId(ne,a,ie,ge);let E=h;if(R==="creating_pool"){const W=new F(n),V=new F(c.usdcMint),Y=await L.computeBinId(1,a,ie,ge),{transaction:X,poolAddress:Z}=await L.createPool(D,O,W,V,Y,ge),ce=await P.signTransaction(X),ue=await D.sendRawTransaction(ce.serialize());await D.confirmTransaction(ue,"confirmed"),E=Z.toBase58(),S(E)}if(R==="creating_pool"||R==="adding_liquidity"){if(f("adding_liquidity"),!E)throw new Error("Pool address not available");const W=new F(E),V=Math.round(u*10**ie),{transaction:Y,positionKeypair:X}=await L.addBuybackLiquidity(D,O,W,V,le),Z=I.fromSecretKey(X.secretKey);Y.partialSign(Z);const ce=await P.signTransaction(Y),ue=await D.sendRawTransaction(ce.serialize());await D.confirmTransaction(ue,"confirmed")}if(f("saving_config"),!E)throw new Error("Pool address not available");const de=new ee.ConfigApiClient(t,void 0,i),se=Math.round(o*100),H=Math.round(u*10**ie),J=new Date().toISOString();await de.patchConfig("gift_cards",{liquidity_pool_address:E,buyback_rate_bps:se,liquidity_usdc_amount:H,liquidity_deployed_at:J},"Meteora DLMM pool deployed for gift card buyback"),y(W=>({...W,liquidityPoolAddress:E,buybackRateBps:se,usdcAmount:H,deployedAt:J})),f("done")}catch(M){l(x==="idle"?R:x),k(M instanceof Error?M.message:"Deployment failed"),f("error")}}},z=()=>{N&&C("creating_pool")},B=()=>{!T||T==="idle"||T==="done"||T==="error"||C(T)};return p?e.jsx("div",{style:{padding:"2rem",textAlign:"center",opacity:.6},children:"Loading pool configuration..."}):c.liquidityPoolAddress?e.jsx(dt,{serverUrl:t,authManager:i,poolAddress:c.liquidityPoolAddress,buybackRateBps:c.buybackRateBps,usdcAmount:c.usdcAmount,deployedAt:c.deployedAt,mintAddress:n,tokenDecimals:a,onConfigUpdated:_}):x!=="idle"&&x!=="error"?e.jsx(pt,{step:x,poolAddress:h}):e.jsx(mt,{buybackCents:o,setBuybackCents:d,usdcAmount:u,setUsdcAmount:v,mintConfigured:s,walletConnected:A,hasRpcUrl:g,hasUsdcMint:m,canDeploy:N,onDeploy:z,errorMessage:j,canRetry:!!T&&T!=="creating_pool",onRetry:B})}function mt({buybackCents:t,setBuybackCents:i,usdcAmount:s,setUsdcAmount:n,mintConfigured:a,walletConnected:c,hasRpcUrl:y,hasUsdcMint:p,canDeploy:b,onDeploy:o,errorMessage:d,canRetry:u,onRetry:v}){const x=((100-t)/100).toFixed(2);return e.jsxs("div",{children:[e.jsx("h3",{className:"cedros-admin__section-title",style:{marginBottom:"0.5rem"},children:"Deploy Buyback Liquidity Pool"}),e.jsx("p",{style:{opacity:.7,marginBottom:"1rem",fontSize:14},children:"Create a Meteora DLMM pool to buy back gift card tokens at a discount. You earn the spread when tokens are resold at face value."}),e.jsxs("div",{className:"cedros-admin__form-row",children:[e.jsxs("div",{className:"cedros-admin__field",children:[e.jsx("label",{className:"cedros-admin__field-label",children:"Buyback rate (cents per $1.00)"}),e.jsx("input",{type:"number",className:"cedros-admin__input",value:t,onChange:f=>i(Math.max(1,Math.min(99,parseInt(f.target.value)||80))),min:"1",max:"99"}),e.jsxs("div",{style:{marginTop:4,fontSize:12,opacity:.75},children:["You earn $",x," profit per gift card redeemed"]})]}),e.jsxs("div",{className:"cedros-admin__field",children:[e.jsx("label",{className:"cedros-admin__field-label",children:"USDC amount"}),e.jsx("input",{type:"number",className:"cedros-admin__input",value:s,onChange:f=>n(Math.max(1,parseFloat(f.target.value)||250)),min:"1",step:"1"}),e.jsx("div",{style:{marginTop:4,fontSize:12,opacity:.75},children:"Minimum recommended: $250"})]})]}),e.jsxs("div",{style:{margin:"1rem 0",display:"flex",flexDirection:"column",gap:6},children:[e.jsx(ae,{label:"Token-22 mint initialized",met:a}),e.jsx(ae,{label:"Wallet connected",met:c}),e.jsx(ae,{label:"RPC URL configured",met:y}),e.jsx(ae,{label:"USDC mint configured",met:p})]}),d&&e.jsx("div",{style:{padding:"0.5rem 0.75rem",marginBottom:"0.75rem",borderRadius:6,background:"rgba(239,68,68,0.1)",color:"#dc2626",fontSize:13},children:d}),e.jsx("div",{style:{display:"flex",gap:"0.75rem",alignItems:"center"},children:u?e.jsx("button",{className:"cedros-admin__button cedros-admin__button--primary",onClick:v,children:"Retry (Resume from Failed Step)"}):e.jsx("button",{className:"cedros-admin__button cedros-admin__button--primary",onClick:o,disabled:!b,children:"Deploy Liquidity Pool"})})]})}const ve=[{key:"creating_pool",label:"Creating DLMM pool..."},{key:"adding_liquidity",label:"Depositing USDC liquidity..."},{key:"saving_config",label:"Saving configuration..."},{key:"done",label:"Complete"}];function pt({step:t,poolAddress:i}){return e.jsxs("div",{children:[e.jsx("h3",{className:"cedros-admin__section-title",style:{marginBottom:"1rem"},children:"Deploying Pool..."}),e.jsx("div",{style:{display:"flex",flexDirection:"column",gap:10},children:ve.map((s,n)=>{const a=ve.findIndex(b=>b.key===t),c=n,y=c<a||t==="done",p=c===a&&t!=="done";return e.jsxs("div",{style:{display:"flex",alignItems:"center",gap:8,fontSize:14},children:[e.jsx("span",{style:{width:20,textAlign:"center",fontWeight:600},children:y?"✓":p?"▶":"○"}),e.jsx("span",{style:{opacity:y||p?1:.4},children:s.label})]},s.key)})}),i&&e.jsxs("div",{style:{marginTop:"1rem",fontSize:13,opacity:.7},children:["Pool: ",e.jsx("code",{style:{fontSize:12},children:i})]})]})}function ae({label:t,met:i}){return e.jsxs("div",{style:{display:"flex",alignItems:"center",gap:8,fontSize:13},children:[e.jsx("span",{style:{color:i?"#16a34a":"#dc2626",fontWeight:600},children:i?"✓":"✗"}),e.jsx("span",{style:{opacity:i?.8:.5},children:t})]})}function ht({serverUrl:t,apiKey:i,authManager:s}){const[n,a]=r.useState(null),[c,y]=r.useState([]),[p,b]=r.useState(!0),[o,d]=r.useState(null),[u,v]=r.useState("mint"),[x,f]=r.useState({treasuryAddress:"",tokenSymbol:"storeUSD",tokenDecimals:2,transferFeeBps:250,maxTransferFee:500}),[j,k]=r.useState(!1),[h,S]=r.useState(!1),[T,l]=r.useState(null),w=r.useCallback(async(C,z)=>{if(s?.isAuthenticated())return s.fetchWithAuth(C,z);const B={"Content-Type":"application/json"};i&&(B["X-API-Key"]=i);const R=await fetch(`${t}${C}`,{...z,headers:{...B,...z?.headers}});if(!R.ok){const M=await R.text().catch(()=>`HTTP ${R.status}`);throw new Error(M)}return R.json()},[t,i,s]),_=r.useCallback(async()=>{try{d(null);const C=await w("/admin/token22/status");a(C)}catch{d("Failed to load Token-22 status")}finally{b(!1)}},[w]),A=r.useCallback(async()=>{try{const C=await w("/admin/gift-card-redemptions?limit=50");y(C.redemptions||[])}catch{y([])}},[w]);r.useEffect(()=>{_(),A()},[_,A]);const g=async C=>{if(C.preventDefault(),!!x.treasuryAddress){k(!0),l(null);try{const z=await w("/admin/token22/initialize",{method:"POST",body:JSON.stringify({treasuryAddress:x.treasuryAddress,tokenSymbol:x.tokenSymbol,tokenDecimals:x.tokenDecimals,transferFeeBps:x.transferFeeBps,maxTransferFee:x.maxTransferFee})});l(`Mint created: ${z.mintAddress}`),_()}catch(z){l(`Error: ${z instanceof Error?z.message:"Failed to initialize"}`)}finally{k(!1)}}},m=async()=>{S(!0),l(null);try{const C=await w("/admin/token22/harvest-fees",{method:"POST"});l(C.message)}catch(C){l(`Error: ${C instanceof Error?C.message:"Failed to harvest"}`)}finally{S(!1)}},N=C=>{try{return new Date(C).toLocaleDateString(void 0,{month:"short",day:"numeric",year:"numeric",hour:"2-digit",minute:"2-digit"})}catch{return C}};return e.jsxs("div",{className:"cedros-admin__page",children:[e.jsx(ze.ErrorBanner,{message:o,onRetry:_}),e.jsx("div",{style:{display:"flex",gap:0,borderBottom:"1px solid rgba(0,0,0,0.1)",marginBottom:"1rem"},children:["mint","inventory","analytics","redemptions","compliance","liquidity","asset-classes","asset-redemptions"].map(C=>{const z={mint:"Token-22 Mint",inventory:"Gift Cards",analytics:"Analytics",redemptions:"Redemptions",compliance:"Compliance",liquidity:"Liquidity","asset-classes":"Asset Classes","asset-redemptions":"Asset Redemptions"};return e.jsx("button",{type:"button",onClick:()=>v(C),style:{padding:"0.5rem 1rem",background:"none",border:"none",borderBottom:u===C?"2px solid currentColor":"2px solid transparent",fontWeight:u===C?600:400,cursor:"pointer",opacity:u===C?1:.6},children:z[C]},C)})}),p?e.jsxs("div",{className:"cedros-admin__loading",children:[Re.Icons.loading," Loading..."]}):u==="mint"?e.jsx(gt,{mintStatus:n,initForm:x,setInitForm:f,isInitializing:j,isHarvesting:h,actionMessage:T,onInitialize:g,onHarvestFees:m,formatDate:N}):u==="inventory"?e.jsx(nt,{serverUrl:t,apiKey:i,authManager:s}):u==="analytics"?e.jsx(tt,{serverUrl:t,apiKey:i,authManager:s}):u==="redemptions"?e.jsx(yt,{redemptions:c,formatDate:N}):u==="compliance"?e.jsx(He,{serverUrl:t,apiKey:i,authManager:s}):u==="liquidity"?e.jsx(ut,{serverUrl:t,authManager:s,mintConfigured:!!n?.configured,mintAddress:n?.mintAddress,tokenDecimals:n?.tokenDecimals}):u==="asset-classes"?e.jsx(Le,{serverUrl:t,apiKey:i,authManager:s,onNavigateToLiquidity:()=>v("liquidity")}):e.jsx(Ye,{serverUrl:t,apiKey:i,authManager:s})]})}function gt({mintStatus:t,initForm:i,setInitForm:s,isInitializing:n,isHarvesting:a,actionMessage:c,onInitialize:y,onHarvestFees:p,formatDate:b}){return t?.configured?e.jsxs("div",{children:[e.jsx("h3",{className:"cedros-admin__section-title",style:{marginBottom:"1rem"},children:"Token-22 Mint Status"}),e.jsxs("div",{style:{display:"grid",gridTemplateColumns:"1fr 1fr",gap:"0.75rem",maxWidth:600},children:[e.jsx(q,{label:"Mint Address",value:t.mintAddress,mono:!0}),e.jsx(q,{label:"Token Symbol",value:t.tokenSymbol}),e.jsx(q,{label:"Decimals",value:String(t.tokenDecimals)}),e.jsx(q,{label:"Transfer Fee",value:`${t.transferFeeBps} bps (${((t.transferFeeBps??0)/100).toFixed(2)}%)`}),e.jsx(q,{label:"Max Transfer Fee",value:String(t.maxTransferFee)}),e.jsx(q,{label:"Treasury",value:t.treasuryAddress,mono:!0}),e.jsx(q,{label:"Authority",value:t.mintAuthority,mono:!0}),e.jsx(q,{label:"Created",value:t.createdAt?b(t.createdAt):"—"})]}),e.jsxs("div",{style:{marginTop:"1.5rem",display:"flex",gap:"0.75rem",alignItems:"center"},children:[e.jsx("button",{className:"cedros-admin__button cedros-admin__button--primary",onClick:p,disabled:a,children:a?"Harvesting...":"Harvest Transfer Fees"}),c&&e.jsx("span",{style:{fontSize:13,opacity:.8},children:c})]})]}):e.jsxs("div",{children:[e.jsx("h3",{className:"cedros-admin__section-title",style:{marginBottom:"0.5rem"},children:"Initialize Token-22 Mint"}),e.jsx("p",{style:{opacity:.7,marginBottom:"1rem",fontSize:14},children:"Create a Token-22 mint with transfer fee extension for the secondary market. This is a one-time operation per tenant."}),e.jsxs("form",{onSubmit:y,children:[e.jsxs("div",{className:"cedros-admin__form-row",children:[e.jsxs("div",{className:"cedros-admin__field",children:[e.jsx("label",{className:"cedros-admin__field-label",children:"Treasury address (Solana)"}),e.jsx("input",{type:"text",className:"cedros-admin__input",value:i.treasuryAddress,onChange:o=>s(d=>({...d,treasuryAddress:o.target.value})),placeholder:"e.g., 7xKX...",required:!0})]}),e.jsxs("div",{className:"cedros-admin__field",children:[e.jsx("label",{className:"cedros-admin__field-label",children:"Token symbol"}),e.jsx("input",{type:"text",className:"cedros-admin__input",value:i.tokenSymbol,onChange:o=>s(d=>({...d,tokenSymbol:o.target.value})),placeholder:"storeUSD"})]})]}),e.jsxs("div",{className:"cedros-admin__form-row",children:[e.jsxs("div",{className:"cedros-admin__field",children:[e.jsx("label",{className:"cedros-admin__field-label",children:"Token decimals"}),e.jsx("input",{type:"number",className:"cedros-admin__input",value:i.tokenDecimals,onChange:o=>s(d=>({...d,tokenDecimals:parseInt(o.target.value)||2})),min:"0",max:"9"})]}),e.jsxs("div",{className:"cedros-admin__field",children:[e.jsx("label",{className:"cedros-admin__field-label",children:"Transfer fee (basis points)"}),e.jsx("input",{type:"number",className:"cedros-admin__input",value:i.transferFeeBps,onChange:o=>s(d=>({...d,transferFeeBps:parseInt(o.target.value)||0})),min:"0",max:"10000"}),e.jsx("div",{style:{marginTop:4,fontSize:12,opacity:.75},children:"e.g., 250 = 2.5% fee on secondary market transfers"})]}),e.jsxs("div",{className:"cedros-admin__field",children:[e.jsx("label",{className:"cedros-admin__field-label",children:"Max transfer fee (atomic)"}),e.jsx("input",{type:"number",className:"cedros-admin__input",value:i.maxTransferFee,onChange:o=>s(d=>({...d,maxTransferFee:parseInt(o.target.value)||0})),min:"0"})]})]}),e.jsxs("div",{className:"cedros-admin__form-actions",style:{marginTop:"1rem"},children:[e.jsx("button",{type:"submit",className:"cedros-admin__button cedros-admin__button--primary",disabled:n,children:n?"Creating Mint...":"Initialize Mint"}),c&&e.jsx("span",{style:{marginLeft:"0.75rem",fontSize:13,opacity:.8},children:c})]})]})]})}function q({label:t,value:i,mono:s}){return e.jsxs(e.Fragment,{children:[e.jsx("div",{style:{fontWeight:500,fontSize:13},children:t}),e.jsx("div",{style:{fontSize:13,fontFamily:s?"monospace":"inherit",wordBreak:s?"break-all":"normal",opacity:i?1:.5},children:i||"—"})]})}function yt({redemptions:t,formatDate:i}){return t.length?e.jsx("div",{className:"cedros-admin__table-container",children:e.jsxs("table",{className:"cedros-admin__table",children:[e.jsx("thead",{children:e.jsxs("tr",{children:[e.jsx("th",{children:"Date"}),e.jsx("th",{children:"Order"}),e.jsx("th",{children:"Product"}),e.jsx("th",{children:"Buyer"}),e.jsx("th",{children:"Recipient"}),e.jsx("th",{children:"Value"}),e.jsx("th",{children:"Token Minted"})]})}),e.jsx("tbody",{children:t.map(s=>e.jsxs("tr",{children:[e.jsx("td",{style:{whiteSpace:"nowrap"},children:i(s.createdAt)}),e.jsx("td",{children:e.jsxs("code",{style:{fontSize:12},children:[s.orderId.slice(0,8),"..."]})}),e.jsx("td",{children:e.jsx("code",{style:{fontSize:12},children:s.productId})}),e.jsx("td",{children:e.jsxs("code",{style:{fontSize:12},children:[s.buyerUserId.slice(0,8),"..."]})}),e.jsx("td",{children:e.jsxs("code",{style:{fontSize:12},children:[s.recipientUserId.slice(0,8),"..."]})}),e.jsxs("td",{children:["$",(s.faceValueCents/100).toFixed(2)," ",s.currency.toUpperCase()]}),e.jsx("td",{children:e.jsx("span",{className:`cedros-admin__badge ${s.tokenMinted?"cedros-admin__badge--success":"cedros-admin__badge--muted"}`,children:s.tokenMinted?"Yes":"No"})})]},s.id))})]})}):e.jsx("div",{style:{padding:"2rem",textAlign:"center",opacity:.6},children:"No gift card redemptions yet."})}exports.Token22Section=ht;
@@ -1,7 +1,7 @@
1
1
  import { jsxs as t, jsx as e, Fragment as O } from "react/jsx-runtime";
2
2
  import { useState as p, useCallback as M, useEffect as H, useRef as Te } from "react";
3
- import { I as Ne } from "./icons-C3yDMnKE.mjs";
4
- import { E as Be } from "./ErrorBanner-lZJhCmDX.mjs";
3
+ import { I as Ne } from "./plugin-BIkt3boU.mjs";
4
+ import { E as Be } from "./ErrorBanner-DAjYj6Dx.mjs";
5
5
  import { C as ae } from "./configApi-BUXZOMWK.mjs";
6
6
  const ke = [
7
7
  { value: "text", label: "Short Text" },
@@ -2,7 +2,7 @@ import { clusterApiUrl as b, Connection as C, Transaction as P, PublicKey as l,
2
2
  import { getAssociatedTokenAddress as T, createTransferInstruction as A } from "@solana/spl-token";
3
3
  import { g as u, b as d } from "./fetchWithTimeout-DmMOwL0Q.mjs";
4
4
  import { b as k } from "./index-BFt38o8Q.mjs";
5
- import { g as v, f as B, k as m, e as g, b as f, l as S } from "./CedrosContext-5Gjveoba.mjs";
5
+ import { g as v, f as B, k as m, e as g, b as f, m as S } from "./CedrosContext-DQc_k5PG.mjs";
6
6
  import { v as M } from "./tokenMintValidator-DAjQld0r.mjs";
7
7
  class Q {
8
8
  connection;
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const o=require("@solana/web3.js"),w=require("@solana/spl-token"),c=require("./fetchWithTimeout-CG0EKbhf.js"),y=require("./index-WcOlBYZJ.js"),n=require("./CedrosContext-CCakH2SZ.js"),E=require("./tokenMintValidator-DNBhoefh.js");class P{connection;cluster;endpoint;allowUnknownMint;rpcRateLimiter=n.createRateLimiter({maxRequests:50,windowMs:6e4});rpcCircuitBreaker=n.createCircuitBreaker({failureThreshold:5,timeout:1e4,name:"solana-rpc"});constructor(r="mainnet-beta",e,t=!1){this.cluster=r,this.endpoint=e,this.allowUnknownMint=t,this.connection=this.createConnection()}createConnection(){const r=this.endpoint??o.clusterApiUrl(this.cluster);return new o.Connection(r,"confirmed")}transformRpcError(r){const e=r instanceof Error?r.message:typeof r=="string"?r:String(r);return e.includes("403")||e.includes("Access forbidden")?new Error("Public Solana RPC access denied. Please configure a custom RPC endpoint (e.g., from Helius, QuickNode, or Alchemy) in your CedrosProvider config using the solanaEndpoint option."):e.includes("429")||e.includes("Too Many Requests")?new Error("Solana RPC rate limit exceeded. Please configure a custom RPC endpoint with higher limits in your CedrosProvider config using the solanaEndpoint option."):r instanceof Error?r:new Error(e)}async buildTransaction(r){const{requirement:e,payerPublicKey:t,blockhash:a}=r;if(!e||!e.payTo)throw new Error("Invalid requirement: missing payTo");c.getLogger().debug("[WalletManager] Building transaction for resource:",e.resource);const i=new o.Transaction,l=this.resolveAmountInMinorUnits(e),u=e.asset;if(!u)throw new Error("asset is required in x402 requirement");const g=E.validateX402Asset(u,e.resource,this.allowUnknownMint);if(!g.isValid&&g.error)throw new Error(g.error);g.warning&&c.getLogger().warn(g.warning);const p=new o.PublicKey(u),d=await w.getAssociatedTokenAddress(p,t);if(!this.rpcRateLimiter.tryConsume())throw new Error("RPC rate limit exceeded. Please try again in a moment.");let f;try{f=await this.rpcCircuitBreaker.execute(async()=>await n.retryWithBackoff(async()=>await this.connection.getAccountInfo(d),{...n.RETRY_PRESETS.QUICK,name:"rpc-get-account-info"}))}catch(s){throw s instanceof n.CircuitBreakerOpenError?new Error("Solana RPC service is temporarily unavailable. Please try again in a few moments."):this.transformRpcError(s)}if(!f)throw new Error("Payer is missing an associated token account for this mint");let h;try{h=e.extra?.recipientTokenAccount?new o.PublicKey(e.extra.recipientTokenAccount):new o.PublicKey(e.payTo)}catch(s){throw c.getLogger().warn("[WalletManager] Failed to resolve recipient address:",s),new Error("We are currently unable to process payment, please try again later")}if(i.add(w.createTransferInstruction(d,h,t,l)),e.extra?.memo){const s=new o.TransactionInstruction({keys:[],programId:new o.PublicKey("MemoSq4gqABAXKb96qnH8TysNcWxMyWCqXgDLGmfcHr"),data:Buffer.from(e.extra.memo,"utf8")});i.add(s)}let m;if(a)m=a;else{if(!this.rpcRateLimiter.tryConsume())throw new Error("RPC rate limit exceeded. Please try again in a moment.");try{m=(await this.rpcCircuitBreaker.execute(async()=>await n.retryWithBackoff(async()=>await this.connection.getLatestBlockhash(),{...n.RETRY_PRESETS.QUICK,name:"rpc-get-blockhash"}))).blockhash}catch(s){throw s instanceof n.CircuitBreakerOpenError?new Error("Solana RPC service is temporarily unavailable. Please try again in a few moments."):this.transformRpcError(s)}}return i.recentBlockhash=m,e.extra?.feePayer?i.feePayer=new o.PublicKey(e.extra.feePayer):i.feePayer=t,i}resolveAmountInMinorUnits(r){const e=r.maxAmountRequired;if(!/^\d+$/.test(e))throw new Error("Invalid maxAmountRequired in requirement: must be a non-negative integer string");const t=BigInt(e);if(t<=0n)throw new Error("Invalid maxAmountRequired in requirement");return t}buildPaymentPayload(r){const{requirement:e,signedTx:t,payerPublicKey:a}=r;return{x402Version:0,scheme:e.scheme,network:e.network,payload:{signature:t.signature,transaction:t.serialized,payer:a.toString(),memo:e.extra?.memo,recipientTokenAccount:e.extra?.recipientTokenAccount}}}async signTransaction(r){const{transaction:e,signTransaction:t}=r;c.getLogger().debug("[WalletManager] Requesting wallet to sign transaction");const a=await t(e),i=a.serialize(),l=a.signatures[0]?.signature;if(!l)throw new Error("Signed transaction missing signature");const u=y.bs58.encode(l);return c.getLogger().debug("[WalletManager] Transaction signed with signature:",u.substring(0,20)+"..."),{serialized:c.gBase64.fromUint8Array(i),signature:u}}deserializeTransaction(r){try{const e=c.gBase64.toUint8Array(r);return o.Transaction.from(e)}catch(e){throw new Error(`Failed to deserialize transaction: ${n.formatError(e,"Unknown error")}`)}}async partiallySignTransaction(r){const{transaction:e,signTransaction:t,blockhash:a}=r;a&&e.recentBlockhash!==a&&(e.recentBlockhash=a);const i=await t(e),l=i.signatures[0]?.signature;if(l){const g=y.bs58.encode(l);c.getLogger().debug("[WalletManager] Partially signed with signature:",g.substring(0,20)+"...")}const u=i.serialize({requireAllSignatures:!1,verifySignatures:!1});return c.gBase64.fromUint8Array(u)}async getBalance(r){if(!this.rpcRateLimiter.tryConsume())throw new Error("RPC rate limit exceeded. Please try again in a moment.");try{return await this.rpcCircuitBreaker.execute(async()=>await n.retryWithBackoff(async()=>await this.connection.getBalance(r),{...n.RETRY_PRESETS.QUICK,name:"rpc-get-balance"}))/o.LAMPORTS_PER_SOL}catch(e){throw e instanceof n.CircuitBreakerOpenError?new Error("Solana RPC service is temporarily unavailable. Please try again in a few moments."):this.transformRpcError(e)}}async verifyTransaction(r){if(!this.rpcRateLimiter.tryConsume())throw new Error("RPC rate limit exceeded for transaction verification");try{return!!(await this.rpcCircuitBreaker.execute(async()=>await n.retryWithBackoff(async()=>await this.connection.getSignatureStatus(r),{...n.RETRY_PRESETS.QUICK,name:"rpc-verify-tx"}))).value?.confirmationStatus}catch(e){return e instanceof n.CircuitBreakerOpenError&&c.getLogger().warn("[WalletManager] Circuit breaker OPEN - cannot verify transaction"),!1}}}exports.WalletManager=P;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const o=require("@solana/web3.js"),w=require("@solana/spl-token"),c=require("./fetchWithTimeout-CG0EKbhf.js"),y=require("./index-WcOlBYZJ.js"),n=require("./CedrosContext-3Dz7_9Ct.js"),E=require("./tokenMintValidator-DNBhoefh.js");class P{connection;cluster;endpoint;allowUnknownMint;rpcRateLimiter=n.createRateLimiter({maxRequests:50,windowMs:6e4});rpcCircuitBreaker=n.createCircuitBreaker({failureThreshold:5,timeout:1e4,name:"solana-rpc"});constructor(r="mainnet-beta",e,t=!1){this.cluster=r,this.endpoint=e,this.allowUnknownMint=t,this.connection=this.createConnection()}createConnection(){const r=this.endpoint??o.clusterApiUrl(this.cluster);return new o.Connection(r,"confirmed")}transformRpcError(r){const e=r instanceof Error?r.message:typeof r=="string"?r:String(r);return e.includes("403")||e.includes("Access forbidden")?new Error("Public Solana RPC access denied. Please configure a custom RPC endpoint (e.g., from Helius, QuickNode, or Alchemy) in your CedrosProvider config using the solanaEndpoint option."):e.includes("429")||e.includes("Too Many Requests")?new Error("Solana RPC rate limit exceeded. Please configure a custom RPC endpoint with higher limits in your CedrosProvider config using the solanaEndpoint option."):r instanceof Error?r:new Error(e)}async buildTransaction(r){const{requirement:e,payerPublicKey:t,blockhash:a}=r;if(!e||!e.payTo)throw new Error("Invalid requirement: missing payTo");c.getLogger().debug("[WalletManager] Building transaction for resource:",e.resource);const i=new o.Transaction,l=this.resolveAmountInMinorUnits(e),u=e.asset;if(!u)throw new Error("asset is required in x402 requirement");const g=E.validateX402Asset(u,e.resource,this.allowUnknownMint);if(!g.isValid&&g.error)throw new Error(g.error);g.warning&&c.getLogger().warn(g.warning);const p=new o.PublicKey(u),d=await w.getAssociatedTokenAddress(p,t);if(!this.rpcRateLimiter.tryConsume())throw new Error("RPC rate limit exceeded. Please try again in a moment.");let f;try{f=await this.rpcCircuitBreaker.execute(async()=>await n.retryWithBackoff(async()=>await this.connection.getAccountInfo(d),{...n.RETRY_PRESETS.QUICK,name:"rpc-get-account-info"}))}catch(s){throw s instanceof n.CircuitBreakerOpenError?new Error("Solana RPC service is temporarily unavailable. Please try again in a few moments."):this.transformRpcError(s)}if(!f)throw new Error("Payer is missing an associated token account for this mint");let h;try{h=e.extra?.recipientTokenAccount?new o.PublicKey(e.extra.recipientTokenAccount):new o.PublicKey(e.payTo)}catch(s){throw c.getLogger().warn("[WalletManager] Failed to resolve recipient address:",s),new Error("We are currently unable to process payment, please try again later")}if(i.add(w.createTransferInstruction(d,h,t,l)),e.extra?.memo){const s=new o.TransactionInstruction({keys:[],programId:new o.PublicKey("MemoSq4gqABAXKb96qnH8TysNcWxMyWCqXgDLGmfcHr"),data:Buffer.from(e.extra.memo,"utf8")});i.add(s)}let m;if(a)m=a;else{if(!this.rpcRateLimiter.tryConsume())throw new Error("RPC rate limit exceeded. Please try again in a moment.");try{m=(await this.rpcCircuitBreaker.execute(async()=>await n.retryWithBackoff(async()=>await this.connection.getLatestBlockhash(),{...n.RETRY_PRESETS.QUICK,name:"rpc-get-blockhash"}))).blockhash}catch(s){throw s instanceof n.CircuitBreakerOpenError?new Error("Solana RPC service is temporarily unavailable. Please try again in a few moments."):this.transformRpcError(s)}}return i.recentBlockhash=m,e.extra?.feePayer?i.feePayer=new o.PublicKey(e.extra.feePayer):i.feePayer=t,i}resolveAmountInMinorUnits(r){const e=r.maxAmountRequired;if(!/^\d+$/.test(e))throw new Error("Invalid maxAmountRequired in requirement: must be a non-negative integer string");const t=BigInt(e);if(t<=0n)throw new Error("Invalid maxAmountRequired in requirement");return t}buildPaymentPayload(r){const{requirement:e,signedTx:t,payerPublicKey:a}=r;return{x402Version:0,scheme:e.scheme,network:e.network,payload:{signature:t.signature,transaction:t.serialized,payer:a.toString(),memo:e.extra?.memo,recipientTokenAccount:e.extra?.recipientTokenAccount}}}async signTransaction(r){const{transaction:e,signTransaction:t}=r;c.getLogger().debug("[WalletManager] Requesting wallet to sign transaction");const a=await t(e),i=a.serialize(),l=a.signatures[0]?.signature;if(!l)throw new Error("Signed transaction missing signature");const u=y.bs58.encode(l);return c.getLogger().debug("[WalletManager] Transaction signed with signature:",u.substring(0,20)+"..."),{serialized:c.gBase64.fromUint8Array(i),signature:u}}deserializeTransaction(r){try{const e=c.gBase64.toUint8Array(r);return o.Transaction.from(e)}catch(e){throw new Error(`Failed to deserialize transaction: ${n.formatError(e,"Unknown error")}`)}}async partiallySignTransaction(r){const{transaction:e,signTransaction:t,blockhash:a}=r;a&&e.recentBlockhash!==a&&(e.recentBlockhash=a);const i=await t(e),l=i.signatures[0]?.signature;if(l){const g=y.bs58.encode(l);c.getLogger().debug("[WalletManager] Partially signed with signature:",g.substring(0,20)+"...")}const u=i.serialize({requireAllSignatures:!1,verifySignatures:!1});return c.gBase64.fromUint8Array(u)}async getBalance(r){if(!this.rpcRateLimiter.tryConsume())throw new Error("RPC rate limit exceeded. Please try again in a moment.");try{return await this.rpcCircuitBreaker.execute(async()=>await n.retryWithBackoff(async()=>await this.connection.getBalance(r),{...n.RETRY_PRESETS.QUICK,name:"rpc-get-balance"}))/o.LAMPORTS_PER_SOL}catch(e){throw e instanceof n.CircuitBreakerOpenError?new Error("Solana RPC service is temporarily unavailable. Please try again in a few moments."):this.transformRpcError(e)}}async verifyTransaction(r){if(!this.rpcRateLimiter.tryConsume())throw new Error("RPC rate limit exceeded for transaction verification");try{return!!(await this.rpcCircuitBreaker.execute(async()=>await n.retryWithBackoff(async()=>await this.connection.getSignatureStatus(r),{...n.RETRY_PRESETS.QUICK,name:"rpc-verify-tx"}))).value?.confirmationStatus}catch(e){return e instanceof n.CircuitBreakerOpenError&&c.getLogger().warn("[WalletManager] Circuit breaker OPEN - cannot verify transaction"),!1}}}exports.WalletManager=P;
@@ -1,7 +1,7 @@
1
1
  import { jsxs as o, jsx as t, Fragment as q } from "react/jsx-runtime";
2
2
  import { useState as r, useCallback as _, useEffect as G } from "react";
3
- import { I as W } from "./icons-C3yDMnKE.mjs";
4
- import { E as C } from "./ErrorBanner-lZJhCmDX.mjs";
3
+ import { I as W } from "./plugin-BIkt3boU.mjs";
4
+ import { E as C } from "./ErrorBanner-DAjYj6Dx.mjs";
5
5
  import { f as N } from "./dateHelpers-yvPkofYQ.mjs";
6
6
  const H = (n) => n === "success" ? "success" : n === "failed" ? "failed" : n === "pending" || n === "processing" ? "pending" : "muted", p = (n, s = 48) => n.length > s ? `${n.slice(0, s)}…` : n;
7
7
  function M({ serverUrl: n, apiKey: s, authManager: y }) {
@@ -0,0 +1 @@
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("react/jsx-runtime"),s=require("react"),q=require("./plugin-Dw8_Q8rE.js"),D=require("./ErrorBanner-DxrRVqwe.js"),E=require("./dateHelpers-BKW_lGND.js"),U=n=>n==="success"?"success":n==="failed"?"failed":n==="pending"||n==="processing"?"pending":"muted",x=(n,d=48)=>n.length>d?`${n.slice(0,d)}…`:n;function O({serverUrl:n,apiKey:d,authManager:j}){const[a,L]=s.useState("active"),[y,p]=s.useState([]),[c,W]=s.useState(0),[h,C]=s.useState("all"),[N,f]=s.useState(!0),[_,g]=s.useState([]),[k,T]=s.useState(0),[F,v]=s.useState(!1),[w,A]=s.useState(!1),[$,l]=s.useState(null),[z,o]=s.useState(null),r=s.useCallback(async(t,i)=>{if(j?.isAuthenticated())return j.fetchWithAuth(t,i);const S={"Content-Type":"application/json"};d&&(S["X-API-Key"]=d);const u=await fetch(`${n}${t}`,{...i,headers:{...S,...i?.headers}});if(!u.ok)throw new Error(`Request failed: ${u.status}`);if(u.status!==204)return u.json()},[n,d,j]),m=s.useCallback(async()=>{f(!0),l(null);try{const t=new URLSearchParams({limit:"100"});h!=="all"&&t.set("status",h);const i=await r(`/admin/webhooks?${t.toString()}`);p(i.webhooks??[]),W(i.count??0)}catch{l("Failed to load webhooks"),p([])}finally{f(!1)}},[r,h]);s.useEffect(()=>{m()},[m]);const b=s.useCallback(async()=>{v(!0),l(null);try{const t=await r("/admin/webhooks/dlq?limit=100");g(t.webhooks??[]),T(t.count??0),A(!0)}catch{l("Failed to load DLQ webhooks"),g([])}finally{v(!1)}},[r]),R=t=>{L(t),l(null),o(null),t==="dlq"&&!w&&b()},I=async t=>{o(null);try{await r(`/admin/webhooks/${encodeURIComponent(t)}/retry`,{method:"POST"}),m()}catch{o("Failed to retry webhook")}},B=async t=>{if(window.confirm("Delete this webhook?")){o(null);try{await r(`/admin/webhooks/${encodeURIComponent(t)}`,{method:"DELETE"}),m()}catch{o("Failed to delete webhook")}}},Q=async t=>{o(null);try{await r(`/admin/webhooks/dlq/${encodeURIComponent(t)}/retry`,{method:"POST"}),b()}catch{o("Failed to retry DLQ webhook")}},P=async t=>{if(window.confirm("Delete this DLQ entry?")){o(null);try{await r(`/admin/webhooks/dlq/${encodeURIComponent(t)}`,{method:"DELETE"}),b()}catch{o("Failed to delete DLQ entry")}}};return e.jsxs("div",{children:[e.jsx("div",{className:"cedros-admin__section-header",children:e.jsx("h3",{className:"cedros-admin__section-title",children:"Webhooks"})}),e.jsx(D.ErrorBanner,{message:$}),e.jsx(D.ErrorBanner,{message:z}),e.jsx("div",{style:{display:"flex",gap:"0.25rem",marginBottom:"1rem",borderBottom:"1px solid var(--cedros-admin-border, #e0e0e0)"},children:["active","dlq"].map(t=>e.jsx("button",{type:"button",onClick:()=>R(t),style:{padding:"0.5rem 1rem",fontSize:"0.85rem",fontWeight:a===t?600:400,background:"none",border:"none",borderBottom:a===t?"2px solid var(--cedros-admin-primary, #000)":"2px solid transparent",cursor:"pointer",color:a===t?"var(--cedros-admin-text, #333)":"var(--cedros-admin-text-muted, #888)",marginBottom:"-1px"},children:t==="active"?`Active Webhooks${c>0?` (${c})`:""}`:`Dead Letter Queue${k>0?` (${k})`:""}`},t))}),a==="active"&&e.jsxs(e.Fragment,{children:[e.jsxs("div",{style:{display:"flex",gap:"0.5rem",marginBottom:"1rem",alignItems:"center"},children:[e.jsxs("select",{className:"cedros-admin__input",value:h,onChange:t=>{C(t.target.value)},style:{width:"auto",fontSize:"0.85rem"},children:[e.jsx("option",{value:"all",children:"All statuses"}),e.jsx("option",{value:"pending",children:"Pending"}),e.jsx("option",{value:"processing",children:"Processing"}),e.jsx("option",{value:"failed",children:"Failed"}),e.jsx("option",{value:"success",children:"Success"})]}),e.jsxs("span",{style:{fontSize:"0.85rem",color:"var(--cedros-admin-text-muted, #888)"},children:[c," webhook",c!==1?"s":""]})]}),N?e.jsxs("div",{className:"cedros-admin__loading",children:[q.Icons.loading," Loading webhooks..."]}):y.length===0?e.jsx("div",{className:"cedros-admin__empty",children:"No webhooks found."}):e.jsx("div",{className:"cedros-admin__table-container",children:e.jsxs("table",{className:"cedros-admin__table",children:[e.jsx("thead",{children:e.jsxs("tr",{children:[e.jsx("th",{children:"URL"}),e.jsx("th",{children:"Event Type"}),e.jsx("th",{children:"Status"}),e.jsx("th",{children:"Attempts"}),e.jsx("th",{children:"Last Error"}),e.jsx("th",{children:"Created"}),e.jsx("th",{})]})}),e.jsx("tbody",{children:y.map(t=>e.jsxs("tr",{children:[e.jsx("td",{style:{maxWidth:"200px"},children:e.jsx("span",{title:t.url,style:{fontSize:"0.8rem",fontFamily:"monospace"},children:x(t.url,40)})}),e.jsx("td",{style:{fontSize:"0.85rem"},children:t.eventType}),e.jsx("td",{children:e.jsx("span",{className:`cedros-admin__badge cedros-admin__badge--${U(t.status)}`,children:t.status})}),e.jsxs("td",{style:{fontSize:"0.85rem"},children:[t.attempts,"/",t.maxAttempts]}),e.jsx("td",{style:{fontSize:"0.8rem",maxWidth:"180px",color:"var(--cedros-admin-text-muted, #888)"},children:t.lastError?e.jsx("span",{title:t.lastError,children:x(t.lastError,40)}):"—"}),e.jsx("td",{style:{fontSize:"0.8rem"},children:E.formatDateTime(t.createdAt)}),e.jsx("td",{children:e.jsxs("div",{style:{display:"flex",gap:"0.25rem"},children:[e.jsx("button",{type:"button",className:"cedros-admin__button cedros-admin__button--ghost cedros-admin__button--sm",onClick:()=>I(t.id),children:"Retry"}),e.jsx("button",{type:"button",className:"cedros-admin__button cedros-admin__button--ghost cedros-admin__button--sm",onClick:()=>B(t.id),style:{color:"var(--cedros-admin-danger, #c00)"},children:"Delete"})]})})]},t.id))})]})})]}),a==="dlq"&&e.jsx(e.Fragment,{children:F?e.jsxs("div",{className:"cedros-admin__loading",children:[q.Icons.loading," Loading DLQ..."]}):_.length===0?e.jsx("div",{className:"cedros-admin__empty",children:"Dead Letter Queue is empty."}):e.jsx("div",{className:"cedros-admin__table-container",children:e.jsxs("table",{className:"cedros-admin__table",children:[e.jsx("thead",{children:e.jsxs("tr",{children:[e.jsx("th",{children:"URL"}),e.jsx("th",{children:"Event Type"}),e.jsx("th",{children:"Attempts"}),e.jsx("th",{children:"Final Error"}),e.jsx("th",{children:"Moved to DLQ"}),e.jsx("th",{})]})}),e.jsx("tbody",{children:_.map(t=>e.jsxs("tr",{children:[e.jsx("td",{style:{maxWidth:"200px"},children:e.jsx("span",{title:t.url,style:{fontSize:"0.8rem",fontFamily:"monospace"},children:x(t.url,40)})}),e.jsx("td",{style:{fontSize:"0.85rem"},children:t.eventType}),e.jsx("td",{style:{fontSize:"0.85rem"},children:t.totalAttempts}),e.jsx("td",{style:{fontSize:"0.8rem",maxWidth:"200px",color:"var(--cedros-admin-text-muted, #888)"},children:e.jsx("span",{title:t.finalError,children:x(t.finalError,40)})}),e.jsx("td",{style:{fontSize:"0.8rem"},children:E.formatDateTime(t.movedToDlqAt)}),e.jsx("td",{children:e.jsxs("div",{style:{display:"flex",gap:"0.25rem"},children:[e.jsx("button",{type:"button",className:"cedros-admin__button cedros-admin__button--ghost cedros-admin__button--sm",onClick:()=>Q(t.id),children:"Retry"}),e.jsx("button",{type:"button",className:"cedros-admin__button cedros-admin__button--ghost cedros-admin__button--sm",onClick:()=>P(t.id),style:{color:"var(--cedros-admin-danger, #c00)"},children:"Delete"})]})})]},t.id))})]})})})]})}exports.WebhooksSection=O;
package/dist/admin.js CHANGED
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const S=require("./sectionIds-D46-_-h-.js");exports.CEDROS_PAY_GROUPS=S.CEDROS_PAY_GROUPS;exports.CEDROS_PAY_SECTIONS=S.CEDROS_PAY_SECTIONS;exports.CEDROS_PAY_SECTION_IDS=S.CEDROS_PAY_SECTION_IDS;exports.cedrosPayPlugin=S.cedrosPayPlugin;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const S=require("./plugin-Dw8_Q8rE.js");exports.CEDROS_PAY_GROUPS=S.CEDROS_PAY_GROUPS;exports.CEDROS_PAY_SECTIONS=S.CEDROS_PAY_SECTIONS;exports.CEDROS_PAY_SECTION_IDS=S.CEDROS_PAY_SECTION_IDS;exports.cedrosPayPlugin=S.cedrosPayPlugin;
package/dist/admin.mjs CHANGED
@@ -1,4 +1,4 @@
1
- import { C as a, a as C, b as O, c as P } from "./sectionIds-YktNxmRt.mjs";
1
+ import { C as a, a as C, b as O, c as P } from "./plugin-BIkt3boU.mjs";
2
2
  export {
3
3
  a as CEDROS_PAY_GROUPS,
4
4
  C as CEDROS_PAY_SECTIONS,
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./styles--fxb3lCl.js"),N=require("./index-Cq9ya93W.js"),l=require("./CedrosContext-CCakH2SZ.js"),f=require("./fetchWithTimeout-CG0EKbhf.js"),ue=require("./CryptoButton-DxFCYDlJ.js"),S=require("react/jsx-runtime"),o=require("react"),$=require("@solana/wallet-adapter-react"),ce=require("@solana/wallet-adapter-base"),xe=require("@solana/wallet-adapter-react-ui"),de=require("./ThemeContext-CFXyYx7A.js"),ge=require("./walletPool-BjTXX6Vn.js"),pe=require("./tokenMintValidator-DNBhoefh.js"),U=require("./sectionIds-D46-_-h-.js"),Te=require("./LazyCedrosPayAdminDashboard-CpfTtOBc.js");function me(){const{subscriptionManager:n,x402Manager:d,walletManager:b}=l.useCedrosContext(),{publicKey:u,signTransaction:k}=$.useWallet(),[h,y]=o.useState({status:"idle",error:null,sessionId:null,subscriptionStatus:null,expiresAt:null}),[_,x]=o.useState(null),T=o.useRef(!1),R=o.useCallback(()=>{if(!u){const i="Wallet not connected";return y(r=>({...r,status:"error",error:i})),{valid:!1,error:i}}if(!k){const i="Wallet does not support signing";return y(r=>({...r,status:"error",error:i})),{valid:!1,error:i}}return{valid:!0}},[u,k]),B=o.useCallback(async i=>{if(!u)return y(r=>({...r,status:"error",error:"Wallet not connected"})),null;y(r=>({...r,status:"checking",error:null}));try{const r=await n.checkSubscriptionStatus({resource:i,userId:u.toString()});return y(a=>({...a,status:r.active?"success":"idle",subscriptionStatus:r.status,expiresAt:r.expiresAt||r.currentPeriodEnd||null})),r}catch(r){const a=l.formatError(r,"Failed to check subscription status");return y(g=>({...g,status:"error",error:a})),null}},[u,n]),W=o.useCallback(async(i,r,a)=>{y(g=>({...g,status:"loading",error:null}));try{const g=await n.requestSubscriptionQuote(i,r,a);return x(g),y(s=>({...s,status:"idle"})),g}catch(g){const s=l.formatError(g,"Failed to get subscription quote");return y(c=>({...c,status:"error",error:s})),null}},[n]),E=o.useCallback(async(i,r,a)=>{if(T.current)return{success:!1,error:"Payment already in progress"};const g=R();if(!g.valid)return{success:!1,error:g.error};T.current=!0,y(s=>({...s,status:"loading",error:null}));try{const s=await n.requestSubscriptionQuote(i,r,a);x(s);const c=s.requirement;if(!d.validateRequirement(c))throw new Error("Invalid subscription quote received from server");const P=!!c.extra?.feePayer;let C;if(P){const{transaction:w,blockhash:q}=await d.buildGaslessTransaction({resourceId:i,userWallet:u.toString(),feePayer:c.extra.feePayer,couponCode:a?.couponCode}),A=b.deserializeTransaction(w),M=await b.partiallySignTransaction({transaction:A,signTransaction:k,blockhash:q});C=await d.submitGaslessTransaction({resource:i,partialTx:M,couponCode:a?.couponCode,resourceType:"regular",requirement:c})}else{const w=await b.buildTransaction({requirement:c,payerPublicKey:u}),q=await b.signTransaction({transaction:w,signTransaction:k}),A=b.buildPaymentPayload({requirement:c,signedTx:q,payerPublicKey:u});C=await d.submitPayment({resource:i,payload:A,couponCode:a?.couponCode,resourceType:"regular"})}if(C.success){const w=await n.checkSubscriptionStatus({resource:i,userId:u.toString()});y({status:"success",error:null,sessionId:C.transactionId||null,subscriptionStatus:w.status,expiresAt:w.expiresAt||w.currentPeriodEnd||null})}else y(w=>({...w,status:"error",error:C.error||"Subscription payment failed"}));return C}catch(s){const c=l.formatError(s,"Subscription payment failed");return y(P=>({...P,status:"error",error:c})),{success:!1,error:c}}finally{T.current=!1}},[R,n,d,b,u,k]),I=o.useCallback(()=>{y({status:"idle",error:null,sessionId:null,subscriptionStatus:null,expiresAt:null}),x(null)},[]);return{...h,quote:_,checkStatus:B,requestQuote:W,processPayment:E,reset:I}}function ke({resource:n,interval:d,intervalDays:b,couponCode:u,label:k,disabled:h=!1,onAttempt:y,onSuccess:_,onError:x,className:T="",testPageUrl:R,hideMessages:B=!1,autoCheckStatus:W=!0}){const{connected:E,connecting:I,connect:i,disconnect:r,select:a,wallets:g,wallet:s,publicKey:c}=$.useWallet(),{status:P,error:C,subscriptionStatus:w,expiresAt:q,checkStatus:A,processPayment:M}=me(),p=de.useCedrosTheme(),{solanaError:v}=l.useCedrosContext(),{t:L,translations:Q}=e.useTranslation(),fe=k||L("ui.subscribe_with_crypto"),V=o.useRef(_),X=o.useRef(x),H=o.useRef(M),J=o.useRef(A);V.current=_,X.current=x,H.current=M,J.current=A;const ye=C&&typeof C!="string"?C?.code??null:null,be=v&&typeof v!="string"?v?.code??null:null,Z=t=>{if(!t||!Q)return"";const m=Q.errors[t];return m?m.action?`${m.message} ${m.action}`:m.message:""},ee=C?typeof C=="string"?C:Z(ye):null,te=v?typeof v=="string"?v:Z(be):null,Ce=o.useMemo(()=>g.map(t=>`${t.adapter.name}-${t.readyState}`).join(","),[g]),z=o.useMemo(()=>g.filter(({readyState:t})=>t===ce.WalletReadyState.Installed||t===ce.WalletReadyState.Loadable),[Ce]);o.useEffect(()=>{W&&E&&c&&(f.getLogger().debug("[CryptoSubscribeButton] Auto-checking subscription status"),J.current(n))},[W,E,c,n]),o.useEffect(()=>{P==="success"&&w==="active"&&(e.emitPaymentSuccess("crypto","subscription-active",n),V.current?.("subscription-active"))},[P,w,n]),o.useEffect(()=>{P==="error"&&C&&(e.emitPaymentError("crypto",C,n),X.current?.(C))},[P,C,n]);const re=typeof window<"u"&&window.top!==window.self,[ne,F]=o.useState(!1),[oe,Y]=o.useState(!1),[ae,O]=o.useState(!1),D=v;o.useEffect(()=>{let t=!1;return t||(async()=>{if(oe&&s&&!E&&!I){f.getLogger().debug("[CryptoSubscribeButton] Wallet detected, attempting auto-connect:",s.adapter.name),Y(!1),e.emitWalletConnect(s.adapter.name);try{await i(),t||f.getLogger().debug("[CryptoSubscribeButton] Auto-connect successful")}catch(K){if(!t){f.getLogger().error("[CryptoSubscribeButton] Auto-connect failed:",K);const Re=K instanceof Error?K.message:"Failed to connect wallet";e.emitWalletError(Re,s.adapter.name),O(!1)}}}})(),()=>{t=!0}},[s,oe,E,I,i]),o.useEffect(()=>{E&&ae&&c&&s&&(e.emitWalletConnected(s.adapter.name,c.toString()),f.getLogger().debug("[CryptoSubscribeButton] Processing pending subscription payment"),O(!1),F(!1),e.emitPaymentProcessing("crypto",n),H.current(n,d,{couponCode:u,intervalDays:b}))},[E,ae,c,s,n,d,u,b]);const se=o.useCallback(async()=>{if(f.getLogger().debug("[CryptoSubscribeButton] executeSubscriptionFlow called",{connected:E,wallet:s?.adapter.name,resource:n,interval:d}),e.emitPaymentStart("crypto",n),y&&y("crypto"),D){f.getLogger().error("[CryptoSubscribeButton] Solana dependencies missing:",D),e.emitPaymentError("crypto",D,n),x&&x(D);return}if(re){const t=R||window.location.href;try{if(new URL(t,window.location.origin).origin!==window.location.origin)throw f.getLogger().error("[CryptoSubscribeButton] Blocked attempt to open external URL:",t),new Error("Cannot open external URLs from embedded context");window.open(t,"_blank","noopener,noreferrer")}catch(m){throw f.getLogger().error("[CryptoSubscribeButton] URL validation failed:",m),m}return}if(E)e.emitPaymentProcessing("crypto",n),await M(n,d,{couponCode:u,intervalDays:b});else{O(!0);try{if(s)f.getLogger().debug("[CryptoSubscribeButton] Wallet already selected, connecting:",s.adapter.name),e.emitWalletConnect(s.adapter.name),await i();else{if(f.getLogger().debug("[CryptoSubscribeButton] No wallet selected, showing selector"),z.length===0){O(!1);const t="No wallets available";throw e.emitWalletError(t),new Error(t)}F(!0)}}catch(t){O(!1);const m=t instanceof Error?t.message:"Failed to connect wallet";f.getLogger().error("[CryptoSubscribeButton] Connection error:",m),e.emitWalletError(m,s?.adapter.name)}}},[E,s,n,d,u,b,re,R,z,i,M,D,y,x]),ie=o.useMemo(()=>`crypto-subscribe-${n}-${d}`,[n,d]),Se=o.useMemo(()=>e.createDedupedClickHandler(ie,se,{cooldownMs:200,deduplicationWindowMs:0}),[ie,se]),le=P==="loading"||P==="checking",j=w==="active"||w==="trialing",Ee=h||le||I||!!D||j;let G=fe;if(le)G=L("ui.processing");else if(j&&q){const t=new Date(q).toLocaleDateString();G=`${L("ui.subscribed_until")} ${t}`}else j&&(G=L("ui.subscribed"));const Pe=o.useCallback(async()=>{try{Y(!1),E&&await r(),a(null),F(!0)}catch(t){f.getLogger().error("Failed to change wallet:",t)}},[E,r,a]),he=o.useCallback(t=>{f.getLogger().debug("[CryptoSubscribeButton] Wallet clicked:",t),F(!1),a(t),Y(!0)},[a]),we=o.useCallback(async()=>{try{if(await r(),O(!1),typeof window<"u"&&window.localStorage)try{window.localStorage.removeItem("walletName")}catch(t){t instanceof Error&&t.name==="QuotaExceededError"?f.getLogger().warn("localStorage quota exceeded when removing wallet preference"):f.getLogger().error("Failed to clear wallet preference from localStorage:",t)}}catch(t){f.getLogger().error("Failed to disconnect wallet:",t)}},[r]);return S.jsxs("div",{className:p.unstyled?T:`${p.className} cedros-theme__crypto-button ${T||""}`,style:p.unstyled?{}:p.style,children:[S.jsx("button",{onClick:Se,disabled:Ee,className:p.unstyled?T:"cedros-theme__button cedros-theme__crypto",type:"button",children:G}),ne&&!B&&S.jsx("div",{className:"cedros-modal-overlay",style:{position:"fixed",top:0,left:0,right:0,bottom:0,backgroundColor:p.tokens.modalOverlay,display:"flex",alignItems:"center",justifyContent:"center",zIndex:9999,padding:"1rem"},onClick:()=>F(!1),children:S.jsxs("div",{className:"cedros-modal-content",style:{backgroundColor:p.tokens.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 ${p.tokens.modalBorder}`},onClick:t=>t.stopPropagation(),children:[S.jsxs("div",{style:{display:"flex",justifyContent:"space-between",alignItems:"center",marginBottom:"1.5rem"},children:[S.jsx("h3",{style:{margin:0,fontSize:"1.25rem",fontWeight:600,color:p.tokens.surfaceText},children:L("wallet.select_wallet")}),S.jsx("button",{onClick:()=>F(!1),style:e.getModalCloseButtonStyles(p.tokens.surfaceText),"aria-label":"Close modal",type:"button",children:"×"})]}),S.jsx("div",{style:{display:"flex",flexDirection:"column",gap:"0.75rem"},children:z.map(t=>S.jsxs("button",{onClick:()=>he(t.adapter.name),style:{width:"100%",padding:"1rem",backgroundColor:p.tokens.surfaceBackground,border:`1px solid ${p.tokens.surfaceBorder}`,borderRadius:"0.5rem",cursor:"pointer",fontSize:"1rem",textAlign:"left",color:p.tokens.surfaceText,display:"flex",alignItems:"center",gap:"1rem",transition:"all 0.2s ease"},onMouseEnter:m=>{m.currentTarget.style.backgroundColor=p.tokens.modalBackground,m.currentTarget.style.borderColor=p.tokens.surfaceText,m.currentTarget.style.transform="translateY(-2px)"},onMouseLeave:m=>{m.currentTarget.style.backgroundColor=p.tokens.surfaceBackground,m.currentTarget.style.borderColor=p.tokens.surfaceBorder,m.currentTarget.style.transform="translateY(0)"},type:"button",children:[S.jsx(xe.WalletIcon,{wallet:t,style:{width:"24px",height:"24px"}}),S.jsx("span",{style:{fontWeight:500},children:t.adapter.name})]},t.adapter.name))})]})}),E&&!B&&!ne&&S.jsxs("div",{style:{display:"flex",justifyContent:"space-between",marginTop:"0.5rem",fontSize:"0.75rem",color:p.tokens.surfaceText,opacity:.7},children:[S.jsx("button",{onClick:Pe,style:{background:"none",border:"none",padding:0,color:"inherit",textDecoration:"none",cursor:"pointer",fontSize:"inherit"},type:"button",children:L("wallet.change")}),S.jsx("button",{onClick:we,style:{background:"none",border:"none",padding:0,color:"inherit",textDecoration:"none",cursor:"pointer",fontSize:"inherit"},type:"button",children:L("ui.disconnect")})]}),!B&&te&&S.jsx("div",{className:p.unstyled?"":"cedros-theme__error",children:te}),!B&&ee&&S.jsx("div",{className:p.unstyled?"":"cedros-theme__error",children:ee}),!B&&j&&S.jsx("div",{className:p.unstyled?"":"cedros-theme__success",children:L("ui.subscription_active")})]})}function _e(){const{x402Manager:n,walletManager:d}=l.useCedrosContext(),{publicKey:b,signTransaction:u}=$.useWallet(),[k,h]=o.useState({status:"idle",error:null,transactionId:null}),[y,_]=o.useState(null),[x,T]=o.useState(null),R=o.useRef(!1),B=o.useCallback(async i=>{try{h(a=>({...a,status:"loading"}));const r=await n.requestQuote({resource:i});if(!n.validateRequirement(r))throw new Error("Invalid refund requirement received from server");return _(r),h(a=>({...a,status:"idle"})),r}catch(r){const a=l.formatError(r,"Failed to fetch refund requirement");throw h({status:"error",error:a,transactionId:null}),r}},[n]),W=o.useCallback(async(i,r)=>{if(R.current)throw new Error("Refund already in progress");if(!b||!u)throw new Error("Wallet not connected");R.current=!0;try{h({status:"loading",error:null,transactionId:null});const a=await n.requestQuote({resource:i,couponCode:r});if(!n.validateRequirement(a))throw new Error("Invalid refund requirement received");_(a);const g=await d.buildTransaction({requirement:a,payerPublicKey:b}),s=await d.signTransaction({transaction:g,signTransaction:u}),c=d.buildPaymentPayload({requirement:a,signedTx:s,payerPublicKey:b}),P=await n.submitPayment({resource:i,payload:c,couponCode:r,metadata:void 0,resourceType:"refund"});return P.settlement&&T(P.settlement),h({status:"success",error:null,transactionId:P.transactionId||s.signature}),P}catch(a){const g=l.formatError(a,"Refund payment failed");throw h({status:"error",error:g,transactionId:null}),a}finally{R.current=!1}},[b,u,n,d]),E=o.useCallback(async i=>{if(R.current)throw new Error("Refund already in progress");if(!b||!u)throw new Error("Wallet not connected");R.current=!0;try{h({status:"loading",error:null,transactionId:null});const r=await n.requestQuote({resource:i});if(!n.validateRequirement(r))throw new Error("Invalid refund requirement received");_(r);const{transaction:a}=await n.buildGaslessTransaction({resourceId:i,userWallet:b.toString(),feePayer:r.extra.feePayer}),g=d.deserializeTransaction(a),s=await d.partiallySignTransaction({transaction:g,signTransaction:u}),c=await n.submitGaslessTransaction({resource:i,partialTx:s,couponCode:void 0,metadata:void 0,resourceType:"refund",requirement:r});return c.settlement&&T(c.settlement),h({status:"success",error:null,transactionId:c.transactionId||"gasless-refund-tx"}),c}catch(r){const a=l.formatError(r,"Gasless refund payment failed");throw h({status:"error",error:a,transactionId:null}),r}finally{R.current=!1}},[b,u,n,d]),I=o.useCallback(()=>{h({status:"idle",error:null,transactionId:null}),_(null),T(null)},[]);return{state:k,requirement:y,settlement:x,fetchRefundQuote:B,processRefund:W,processGaslessRefund:E,reset:I}}exports.CEDROS_EVENTS=e.CEDROS_EVENTS;exports.CSP_PRESETS=e.CSP_PRESETS;exports.CedrosPay=e.CedrosPay;exports.CreditsButton=e.CreditsButton;exports.CreditsSubscribeButton=e.CreditsSubscribeButton;exports.PaymentMethodBadge=e.PaymentMethodBadge;exports.PaymentModal=e.PaymentModal;exports.ProductPrice=e.ProductPrice;exports.PurchaseButton=e.PurchaseButton;exports.RPC_PROVIDERS=e.RPC_PROVIDERS;exports.SECURITY_RECOMMENDATIONS=e.SECURITY_RECOMMENDATIONS;exports.StripeButton=e.StripeButton;exports.SubscribeButton=e.SubscribeButton;exports.SubscriptionManagementPanel=e.SubscriptionManagementPanel;exports.calculateDiscountPercentage=e.calculateDiscountPercentage;exports.createTranslator=e.createTranslator;exports.detectLocale=e.detectLocale;exports.emitPaymentError=e.emitPaymentError;exports.emitPaymentProcessing=e.emitPaymentProcessing;exports.emitPaymentStart=e.emitPaymentStart;exports.emitPaymentSuccess=e.emitPaymentSuccess;exports.emitWalletConnect=e.emitWalletConnect;exports.emitWalletConnected=e.emitWalletConnected;exports.emitWalletError=e.emitWalletError;exports.formatCSP=e.formatCSP;exports.formatCouponCodes=e.formatCouponCodes;exports.generateCSP=e.generateCSP;exports.generateCSPDirectives=e.generateCSPDirectives;exports.getAvailableLocales=e.getAvailableLocales;exports.getLocalizedError=e.getLocalizedError;exports.getUserErrorMessage=e.getUserErrorMessage;exports.isRetryableError=e.isRetryableError;exports.loadLocale=e.loadLocale;exports.logSecurityReport=e.logSecurityReport;exports.parseCouponCodes=e.parseCouponCodes;exports.stackCheckoutCoupons=e.stackCheckoutCoupons;exports.useCreditsPayment=e.useCreditsPayment;exports.useCreditsSubscription=e.useCreditsSubscription;exports.useLocalizedError=e.useLocalizedError;exports.usePaymentMode=e.usePaymentMode;exports.useStripeCheckout=e.useStripeCheckout;exports.useSubscription=e.useSubscription;exports.useSubscriptionManagement=e.useSubscriptionManagement;exports.useTranslation=e.useTranslation;exports.validateSecurity=e.validateSecurity;exports.ComplianceGatePage=N.ComplianceGatePage;exports.CreditsBalance=N.CreditsBalance;exports.ecommerce=N.index;exports.useComplianceCheck=N.useComplianceCheck;exports.useCreditsBalance=N.useCreditsBalance;exports.CIRCUIT_BREAKER_PRESETS=l.CIRCUIT_BREAKER_PRESETS;exports.CedrosProvider=l.CedrosProvider;exports.CircuitBreakerOpenError=l.CircuitBreakerOpenError;exports.CircuitState=l.CircuitState;exports.ERROR_CATEGORIES=l.ERROR_CATEGORIES;exports.FEATURE_FLAG_NAMES=l.FEATURE_FLAG_NAMES;exports.FEATURE_FLAG_REGISTRY=l.FEATURE_FLAG_REGISTRY;exports.RATE_LIMITER_PRESETS=l.RATE_LIMITER_PRESETS;exports.RETRY_PRESETS=l.RETRY_PRESETS;exports.createCircuitBreaker=l.createCircuitBreaker;exports.createRateLimiter=l.createRateLimiter;exports.getFeatureFlagDefinition=l.getFeatureFlagDefinition;exports.getFeatureFlagDefinitions=l.getFeatureFlagDefinitions;exports.isFeatureEnabled=l.isFeatureEnabled;exports.parseFeatureFlagBoolean=l.parseFeatureFlagBoolean;exports.resolveFeatureFlags=l.resolveFeatureFlags;exports.retryWithBackoff=l.retryWithBackoff;exports.useCedrosContext=l.useCedrosContext;exports.validateConfig=l.validateConfig;exports.LogLevel=f.LogLevel;exports.Logger=f.Logger;exports.createLogger=f.createLogger;exports.getLogger=f.getLogger;exports.CryptoButton=ue.CryptoButton;exports.useX402Payment=ue.useX402Payment;exports.useCedrosTheme=de.useCedrosTheme;exports.WalletPool=ge.WalletPool;exports.createWalletPool=ge.createWalletPool;exports.KNOWN_STABLECOINS=pe.KNOWN_STABLECOINS;exports.validateTokenMint=pe.validateTokenMint;exports.CEDROS_PAY_GROUPS=U.CEDROS_PAY_GROUPS;exports.CEDROS_PAY_SECTIONS=U.CEDROS_PAY_SECTIONS;exports.CEDROS_PAY_SECTION_IDS=U.CEDROS_PAY_SECTION_IDS;exports.cedrosPayPlugin=U.cedrosPayPlugin;exports.CedrosPayAdminDashboard=Te.CedrosPayAdminDashboard;exports.CryptoSubscribeButton=ke;exports.useCryptoSubscription=me;exports.useRefundVerification=_e;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./styles-BwaDljnz.js"),N=require("./index-DVxx_62C.js"),i=require("./CedrosContext-3Dz7_9Ct.js"),f=require("./fetchWithTimeout-CG0EKbhf.js"),ue=require("./CryptoButton-BQceZhbn.js"),S=require("react/jsx-runtime"),o=require("react"),$=require("@solana/wallet-adapter-react"),ce=require("@solana/wallet-adapter-base"),Re=require("@solana/wallet-adapter-react-ui"),de=require("./walletPool-BjTXX6Vn.js"),ge=require("./tokenMintValidator-DNBhoefh.js"),U=require("./plugin-Dw8_Q8rE.js");function pe(){const{subscriptionManager:n,x402Manager:d,walletManager:b}=i.useCedrosContext(),{publicKey:u,signTransaction:k}=$.useWallet(),[h,y]=o.useState({status:"idle",error:null,sessionId:null,subscriptionStatus:null,expiresAt:null}),[_,x]=o.useState(null),T=o.useRef(!1),R=o.useCallback(()=>{if(!u){const l="Wallet not connected";return y(r=>({...r,status:"error",error:l})),{valid:!1,error:l}}if(!k){const l="Wallet does not support signing";return y(r=>({...r,status:"error",error:l})),{valid:!1,error:l}}return{valid:!0}},[u,k]),B=o.useCallback(async l=>{if(!u)return y(r=>({...r,status:"error",error:"Wallet not connected"})),null;y(r=>({...r,status:"checking",error:null}));try{const r=await n.checkSubscriptionStatus({resource:l,userId:u.toString()});return y(a=>({...a,status:r.active?"success":"idle",subscriptionStatus:r.status,expiresAt:r.expiresAt||r.currentPeriodEnd||null})),r}catch(r){const a=i.formatError(r,"Failed to check subscription status");return y(g=>({...g,status:"error",error:a})),null}},[u,n]),W=o.useCallback(async(l,r,a)=>{y(g=>({...g,status:"loading",error:null}));try{const g=await n.requestSubscriptionQuote(l,r,a);return x(g),y(s=>({...s,status:"idle"})),g}catch(g){const s=i.formatError(g,"Failed to get subscription quote");return y(c=>({...c,status:"error",error:s})),null}},[n]),E=o.useCallback(async(l,r,a)=>{if(T.current)return{success:!1,error:"Payment already in progress"};const g=R();if(!g.valid)return{success:!1,error:g.error};T.current=!0,y(s=>({...s,status:"loading",error:null}));try{const s=await n.requestSubscriptionQuote(l,r,a);x(s);const c=s.requirement;if(!d.validateRequirement(c))throw new Error("Invalid subscription quote received from server");const P=!!c.extra?.feePayer;let C;if(P){const{transaction:w,blockhash:M}=await d.buildGaslessTransaction({resourceId:l,userWallet:u.toString(),feePayer:c.extra.feePayer,couponCode:a?.couponCode}),q=b.deserializeTransaction(w),A=await b.partiallySignTransaction({transaction:q,signTransaction:k,blockhash:M});C=await d.submitGaslessTransaction({resource:l,partialTx:A,couponCode:a?.couponCode,resourceType:"regular",requirement:c})}else{const w=await b.buildTransaction({requirement:c,payerPublicKey:u}),M=await b.signTransaction({transaction:w,signTransaction:k}),q=b.buildPaymentPayload({requirement:c,signedTx:M,payerPublicKey:u});C=await d.submitPayment({resource:l,payload:q,couponCode:a?.couponCode,resourceType:"regular"})}if(C.success){const w=await n.checkSubscriptionStatus({resource:l,userId:u.toString()});y({status:"success",error:null,sessionId:C.transactionId||null,subscriptionStatus:w.status,expiresAt:w.expiresAt||w.currentPeriodEnd||null})}else y(w=>({...w,status:"error",error:C.error||"Subscription payment failed"}));return C}catch(s){const c=i.formatError(s,"Subscription payment failed");return y(P=>({...P,status:"error",error:c})),{success:!1,error:c}}finally{T.current=!1}},[R,n,d,b,u,k]),v=o.useCallback(()=>{y({status:"idle",error:null,sessionId:null,subscriptionStatus:null,expiresAt:null}),x(null)},[]);return{...h,quote:_,checkStatus:B,requestQuote:W,processPayment:E,reset:v}}function xe({resource:n,interval:d,intervalDays:b,couponCode:u,label:k,disabled:h=!1,onAttempt:y,onSuccess:_,onError:x,className:T="",testPageUrl:R,hideMessages:B=!1,autoCheckStatus:W=!0}){const{connected:E,connecting:v,connect:l,disconnect:r,select:a,wallets:g,wallet:s,publicKey:c}=$.useWallet(),{status:P,error:C,subscriptionStatus:w,expiresAt:M,checkStatus:q,processPayment:A}=pe(),p=i.useCedrosTheme(),{solanaError:I}=i.useCedrosContext(),{t:L,translations:Q}=e.useTranslation(),me=k||L("ui.subscribe_with_crypto"),V=o.useRef(_),X=o.useRef(x),H=o.useRef(A),J=o.useRef(q);V.current=_,X.current=x,H.current=A,J.current=q;const fe=C&&typeof C!="string"?C?.code??null:null,ye=I&&typeof I!="string"?I?.code??null:null,Z=t=>{if(!t||!Q)return"";const m=Q.errors[t];return m?m.action?`${m.message} ${m.action}`:m.message:""},ee=C?typeof C=="string"?C:Z(fe):null,te=I?typeof I=="string"?I:Z(ye):null,be=o.useMemo(()=>g.map(t=>`${t.adapter.name}-${t.readyState}`).join(","),[g]),z=o.useMemo(()=>g.filter(({readyState:t})=>t===ce.WalletReadyState.Installed||t===ce.WalletReadyState.Loadable),[be]);o.useEffect(()=>{W&&E&&c&&(f.getLogger().debug("[CryptoSubscribeButton] Auto-checking subscription status"),J.current(n))},[W,E,c,n]),o.useEffect(()=>{P==="success"&&w==="active"&&(e.emitPaymentSuccess("crypto","subscription-active",n),V.current?.("subscription-active"))},[P,w,n]),o.useEffect(()=>{P==="error"&&C&&(e.emitPaymentError("crypto",C,n),X.current?.(C))},[P,C,n]);const re=typeof window<"u"&&window.top!==window.self,[ne,F]=o.useState(!1),[oe,Y]=o.useState(!1),[ae,O]=o.useState(!1),D=I;o.useEffect(()=>{let t=!1;return t||(async()=>{if(oe&&s&&!E&&!v){f.getLogger().debug("[CryptoSubscribeButton] Wallet detected, attempting auto-connect:",s.adapter.name),Y(!1),e.emitWalletConnect(s.adapter.name);try{await l(),t||f.getLogger().debug("[CryptoSubscribeButton] Auto-connect successful")}catch(K){if(!t){f.getLogger().error("[CryptoSubscribeButton] Auto-connect failed:",K);const we=K instanceof Error?K.message:"Failed to connect wallet";e.emitWalletError(we,s.adapter.name),O(!1)}}}})(),()=>{t=!0}},[s,oe,E,v,l]),o.useEffect(()=>{E&&ae&&c&&s&&(e.emitWalletConnected(s.adapter.name,c.toString()),f.getLogger().debug("[CryptoSubscribeButton] Processing pending subscription payment"),O(!1),F(!1),e.emitPaymentProcessing("crypto",n),H.current(n,d,{couponCode:u,intervalDays:b}))},[E,ae,c,s,n,d,u,b]);const se=o.useCallback(async()=>{if(f.getLogger().debug("[CryptoSubscribeButton] executeSubscriptionFlow called",{connected:E,wallet:s?.adapter.name,resource:n,interval:d}),e.emitPaymentStart("crypto",n),y&&y("crypto"),D){f.getLogger().error("[CryptoSubscribeButton] Solana dependencies missing:",D),e.emitPaymentError("crypto",D,n),x&&x(D);return}if(re){const t=R||window.location.href;try{if(new URL(t,window.location.origin).origin!==window.location.origin)throw f.getLogger().error("[CryptoSubscribeButton] Blocked attempt to open external URL:",t),new Error("Cannot open external URLs from embedded context");window.open(t,"_blank","noopener,noreferrer")}catch(m){throw f.getLogger().error("[CryptoSubscribeButton] URL validation failed:",m),m}return}if(E)e.emitPaymentProcessing("crypto",n),await A(n,d,{couponCode:u,intervalDays:b});else{O(!0);try{if(s)f.getLogger().debug("[CryptoSubscribeButton] Wallet already selected, connecting:",s.adapter.name),e.emitWalletConnect(s.adapter.name),await l();else{if(f.getLogger().debug("[CryptoSubscribeButton] No wallet selected, showing selector"),z.length===0){O(!1);const t="No wallets available";throw e.emitWalletError(t),new Error(t)}F(!0)}}catch(t){O(!1);const m=t instanceof Error?t.message:"Failed to connect wallet";f.getLogger().error("[CryptoSubscribeButton] Connection error:",m),e.emitWalletError(m,s?.adapter.name)}}},[E,s,n,d,u,b,re,R,z,l,A,D,y,x]),ie=o.useMemo(()=>`crypto-subscribe-${n}-${d}`,[n,d]),Ce=o.useMemo(()=>e.createDedupedClickHandler(ie,se,{cooldownMs:200,deduplicationWindowMs:0}),[ie,se]),le=P==="loading"||P==="checking",j=w==="active"||w==="trialing",Se=h||le||v||!!D||j;let G=me;if(le)G=L("ui.processing");else if(j&&M){const t=new Date(M).toLocaleDateString();G=`${L("ui.subscribed_until")} ${t}`}else j&&(G=L("ui.subscribed"));const Ee=o.useCallback(async()=>{try{Y(!1),E&&await r(),a(null),F(!0)}catch(t){f.getLogger().error("Failed to change wallet:",t)}},[E,r,a]),Pe=o.useCallback(t=>{f.getLogger().debug("[CryptoSubscribeButton] Wallet clicked:",t),F(!1),a(t),Y(!0)},[a]),he=o.useCallback(async()=>{try{if(await r(),O(!1),typeof window<"u"&&window.localStorage)try{window.localStorage.removeItem("walletName")}catch(t){t instanceof Error&&t.name==="QuotaExceededError"?f.getLogger().warn("localStorage quota exceeded when removing wallet preference"):f.getLogger().error("Failed to clear wallet preference from localStorage:",t)}}catch(t){f.getLogger().error("Failed to disconnect wallet:",t)}},[r]);return S.jsxs("div",{className:p.unstyled?T:`${p.className} cedros-theme__crypto-button ${T||""}`,style:p.unstyled?{}:p.style,children:[S.jsx("button",{onClick:Ce,disabled:Se,className:p.unstyled?T:"cedros-theme__button cedros-theme__crypto",type:"button",children:G}),ne&&!B&&S.jsx("div",{className:"cedros-modal-overlay",style:{position:"fixed",top:0,left:0,right:0,bottom:0,backgroundColor:p.tokens.modalOverlay,display:"flex",alignItems:"center",justifyContent:"center",zIndex:9999,padding:"1rem"},onClick:()=>F(!1),children:S.jsxs("div",{className:"cedros-modal-content",style:{backgroundColor:p.tokens.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 ${p.tokens.modalBorder}`},onClick:t=>t.stopPropagation(),children:[S.jsxs("div",{style:{display:"flex",justifyContent:"space-between",alignItems:"center",marginBottom:"1.5rem"},children:[S.jsx("h3",{style:{margin:0,fontSize:"1.25rem",fontWeight:600,color:p.tokens.surfaceText},children:L("wallet.select_wallet")}),S.jsx("button",{onClick:()=>F(!1),style:e.getModalCloseButtonStyles(p.tokens.surfaceText),"aria-label":"Close modal",type:"button",children:"×"})]}),S.jsx("div",{style:{display:"flex",flexDirection:"column",gap:"0.75rem"},children:z.map(t=>S.jsxs("button",{onClick:()=>Pe(t.adapter.name),style:{width:"100%",padding:"1rem",backgroundColor:p.tokens.surfaceBackground,border:`1px solid ${p.tokens.surfaceBorder}`,borderRadius:"0.5rem",cursor:"pointer",fontSize:"1rem",textAlign:"left",color:p.tokens.surfaceText,display:"flex",alignItems:"center",gap:"1rem",transition:"all 0.2s ease"},onMouseEnter:m=>{m.currentTarget.style.backgroundColor=p.tokens.modalBackground,m.currentTarget.style.borderColor=p.tokens.surfaceText,m.currentTarget.style.transform="translateY(-2px)"},onMouseLeave:m=>{m.currentTarget.style.backgroundColor=p.tokens.surfaceBackground,m.currentTarget.style.borderColor=p.tokens.surfaceBorder,m.currentTarget.style.transform="translateY(0)"},type:"button",children:[S.jsx(Re.WalletIcon,{wallet:t,style:{width:"24px",height:"24px"}}),S.jsx("span",{style:{fontWeight:500},children:t.adapter.name})]},t.adapter.name))})]})}),E&&!B&&!ne&&S.jsxs("div",{style:{display:"flex",justifyContent:"space-between",marginTop:"0.5rem",fontSize:"0.75rem",color:p.tokens.surfaceText,opacity:.7},children:[S.jsx("button",{onClick:Ee,style:{background:"none",border:"none",padding:0,color:"inherit",textDecoration:"none",cursor:"pointer",fontSize:"inherit"},type:"button",children:L("wallet.change")}),S.jsx("button",{onClick:he,style:{background:"none",border:"none",padding:0,color:"inherit",textDecoration:"none",cursor:"pointer",fontSize:"inherit"},type:"button",children:L("ui.disconnect")})]}),!B&&te&&S.jsx("div",{className:p.unstyled?"":"cedros-theme__error",children:te}),!B&&ee&&S.jsx("div",{className:p.unstyled?"":"cedros-theme__error",children:ee}),!B&&j&&S.jsx("div",{className:p.unstyled?"":"cedros-theme__success",children:L("ui.subscription_active")})]})}function Te(){const{x402Manager:n,walletManager:d}=i.useCedrosContext(),{publicKey:b,signTransaction:u}=$.useWallet(),[k,h]=o.useState({status:"idle",error:null,transactionId:null}),[y,_]=o.useState(null),[x,T]=o.useState(null),R=o.useRef(!1),B=o.useCallback(async l=>{try{h(a=>({...a,status:"loading"}));const r=await n.requestQuote({resource:l});if(!n.validateRequirement(r))throw new Error("Invalid refund requirement received from server");return _(r),h(a=>({...a,status:"idle"})),r}catch(r){const a=i.formatError(r,"Failed to fetch refund requirement");throw h({status:"error",error:a,transactionId:null}),r}},[n]),W=o.useCallback(async(l,r)=>{if(R.current)throw new Error("Refund already in progress");if(!b||!u)throw new Error("Wallet not connected");R.current=!0;try{h({status:"loading",error:null,transactionId:null});const a=await n.requestQuote({resource:l,couponCode:r});if(!n.validateRequirement(a))throw new Error("Invalid refund requirement received");_(a);const g=await d.buildTransaction({requirement:a,payerPublicKey:b}),s=await d.signTransaction({transaction:g,signTransaction:u}),c=d.buildPaymentPayload({requirement:a,signedTx:s,payerPublicKey:b}),P=await n.submitPayment({resource:l,payload:c,couponCode:r,metadata:void 0,resourceType:"refund"});return P.settlement&&T(P.settlement),h({status:"success",error:null,transactionId:P.transactionId||s.signature}),P}catch(a){const g=i.formatError(a,"Refund payment failed");throw h({status:"error",error:g,transactionId:null}),a}finally{R.current=!1}},[b,u,n,d]),E=o.useCallback(async l=>{if(R.current)throw new Error("Refund already in progress");if(!b||!u)throw new Error("Wallet not connected");R.current=!0;try{h({status:"loading",error:null,transactionId:null});const r=await n.requestQuote({resource:l});if(!n.validateRequirement(r))throw new Error("Invalid refund requirement received");_(r);const{transaction:a}=await n.buildGaslessTransaction({resourceId:l,userWallet:b.toString(),feePayer:r.extra.feePayer}),g=d.deserializeTransaction(a),s=await d.partiallySignTransaction({transaction:g,signTransaction:u}),c=await n.submitGaslessTransaction({resource:l,partialTx:s,couponCode:void 0,metadata:void 0,resourceType:"refund",requirement:r});return c.settlement&&T(c.settlement),h({status:"success",error:null,transactionId:c.transactionId||"gasless-refund-tx"}),c}catch(r){const a=i.formatError(r,"Gasless refund payment failed");throw h({status:"error",error:a,transactionId:null}),r}finally{R.current=!1}},[b,u,n,d]),v=o.useCallback(()=>{h({status:"idle",error:null,transactionId:null}),_(null),T(null)},[]);return{state:k,requirement:y,settlement:x,fetchRefundQuote:B,processRefund:W,processGaslessRefund:E,reset:v}}exports.CEDROS_EVENTS=e.CEDROS_EVENTS;exports.CSP_PRESETS=e.CSP_PRESETS;exports.CedrosPay=e.CedrosPay;exports.CreditsButton=e.CreditsButton;exports.CreditsSubscribeButton=e.CreditsSubscribeButton;exports.PaymentMethodBadge=e.PaymentMethodBadge;exports.PaymentModal=e.PaymentModal;exports.ProductPrice=e.ProductPrice;exports.PurchaseButton=e.PurchaseButton;exports.RPC_PROVIDERS=e.RPC_PROVIDERS;exports.SECURITY_RECOMMENDATIONS=e.SECURITY_RECOMMENDATIONS;exports.StripeButton=e.StripeButton;exports.SubscribeButton=e.SubscribeButton;exports.SubscriptionManagementPanel=e.SubscriptionManagementPanel;exports.calculateDiscountPercentage=e.calculateDiscountPercentage;exports.createTranslator=e.createTranslator;exports.detectLocale=e.detectLocale;exports.emitPaymentError=e.emitPaymentError;exports.emitPaymentProcessing=e.emitPaymentProcessing;exports.emitPaymentStart=e.emitPaymentStart;exports.emitPaymentSuccess=e.emitPaymentSuccess;exports.emitWalletConnect=e.emitWalletConnect;exports.emitWalletConnected=e.emitWalletConnected;exports.emitWalletError=e.emitWalletError;exports.formatCSP=e.formatCSP;exports.formatCouponCodes=e.formatCouponCodes;exports.generateCSP=e.generateCSP;exports.generateCSPDirectives=e.generateCSPDirectives;exports.getAvailableLocales=e.getAvailableLocales;exports.getLocalizedError=e.getLocalizedError;exports.getUserErrorMessage=e.getUserErrorMessage;exports.isRetryableError=e.isRetryableError;exports.loadLocale=e.loadLocale;exports.logSecurityReport=e.logSecurityReport;exports.parseCouponCodes=e.parseCouponCodes;exports.stackCheckoutCoupons=e.stackCheckoutCoupons;exports.useCreditsPayment=e.useCreditsPayment;exports.useCreditsSubscription=e.useCreditsSubscription;exports.useLocalizedError=e.useLocalizedError;exports.usePaymentMode=e.usePaymentMode;exports.useStripeCheckout=e.useStripeCheckout;exports.useSubscription=e.useSubscription;exports.useSubscriptionManagement=e.useSubscriptionManagement;exports.useTranslation=e.useTranslation;exports.validateSecurity=e.validateSecurity;exports.ComplianceGatePage=N.ComplianceGatePage;exports.CreditsBalance=N.CreditsBalance;exports.ecommerce=N.index;exports.useComplianceCheck=N.useComplianceCheck;exports.useCreditsBalance=N.useCreditsBalance;exports.CIRCUIT_BREAKER_PRESETS=i.CIRCUIT_BREAKER_PRESETS;exports.CedrosProvider=i.CedrosProvider;exports.CircuitBreakerOpenError=i.CircuitBreakerOpenError;exports.CircuitState=i.CircuitState;exports.ERROR_CATEGORIES=i.ERROR_CATEGORIES;exports.FEATURE_FLAG_NAMES=i.FEATURE_FLAG_NAMES;exports.FEATURE_FLAG_REGISTRY=i.FEATURE_FLAG_REGISTRY;exports.RATE_LIMITER_PRESETS=i.RATE_LIMITER_PRESETS;exports.RETRY_PRESETS=i.RETRY_PRESETS;exports.createCircuitBreaker=i.createCircuitBreaker;exports.createRateLimiter=i.createRateLimiter;exports.getFeatureFlagDefinition=i.getFeatureFlagDefinition;exports.getFeatureFlagDefinitions=i.getFeatureFlagDefinitions;exports.isFeatureEnabled=i.isFeatureEnabled;exports.parseFeatureFlagBoolean=i.parseFeatureFlagBoolean;exports.resolveFeatureFlags=i.resolveFeatureFlags;exports.retryWithBackoff=i.retryWithBackoff;exports.useCedrosContext=i.useCedrosContext;exports.useCedrosTheme=i.useCedrosTheme;exports.validateConfig=i.validateConfig;exports.LogLevel=f.LogLevel;exports.Logger=f.Logger;exports.createLogger=f.createLogger;exports.getLogger=f.getLogger;exports.CryptoButton=ue.CryptoButton;exports.useX402Payment=ue.useX402Payment;exports.WalletPool=de.WalletPool;exports.createWalletPool=de.createWalletPool;exports.KNOWN_STABLECOINS=ge.KNOWN_STABLECOINS;exports.validateTokenMint=ge.validateTokenMint;exports.CEDROS_PAY_GROUPS=U.CEDROS_PAY_GROUPS;exports.CEDROS_PAY_SECTIONS=U.CEDROS_PAY_SECTIONS;exports.CEDROS_PAY_SECTION_IDS=U.CEDROS_PAY_SECTION_IDS;exports.cedrosPayPlugin=U.cedrosPayPlugin;exports.CryptoSubscribeButton=xe;exports.useCryptoSubscription=pe;exports.useRefundVerification=Te;