@credenza3/passport-sui 0.2.4 → 0.3.0

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 (80) hide show
  1. package/README.md +0 -8
  2. package/dist/{App-Drnh90jg.js → App-qMNVa9Bu.js} +18 -18
  3. package/dist/{App-Drnh90jg.js.map → App-qMNVa9Bu.js.map} +1 -1
  4. package/dist/{Button-BwbAl06j.js → Button-ReMR1yO6.js} +4 -4
  5. package/dist/{Button-BwbAl06j.js.map → Button-ReMR1yO6.js.map} +1 -1
  6. package/dist/{ButtonBack-2V8btHHE.js → ButtonBack-D8lM9RC-.js} +4 -4
  7. package/dist/{ButtonBack-2V8btHHE.js.map → ButtonBack-D8lM9RC-.js.map} +1 -1
  8. package/dist/{ButtonLink-CYeDF-q5.js → ButtonLink-BEL4sN7p.js} +3 -3
  9. package/dist/{ButtonLink-CYeDF-q5.js.map → ButtonLink-BEL4sN7p.js.map} +1 -1
  10. package/dist/{ConfirmAccount-CXgxwivy.js → ConfirmAccount-BjEA5Ind.js} +9 -9
  11. package/dist/{ConfirmAccount-CXgxwivy.js.map → ConfirmAccount-BjEA5Ind.js.map} +1 -1
  12. package/dist/{ContentHeader-Bzt4m2P2.js → ContentHeader-C9pYpyAo.js} +3 -3
  13. package/dist/{ContentHeader-Bzt4m2P2.js.map → ContentHeader-C9pYpyAo.js.map} +1 -1
  14. package/dist/{Error-ca34C-yw.js → Error-D_pxzs5w.js} +5 -5
  15. package/dist/{Error-ca34C-yw.js.map → Error-D_pxzs5w.js.map} +1 -1
  16. package/dist/{Input-uaiib1E3.js → Input-DdaMfJIC.js} +4 -4
  17. package/dist/{Input-uaiib1E3.js.map → Input-DdaMfJIC.js.map} +1 -1
  18. package/dist/{Label-CXL16w_q.js → Label-D3FM6__y.js} +3 -3
  19. package/dist/{Label-CXL16w_q.js.map → Label-D3FM6__y.js.map} +1 -1
  20. package/dist/{Loader-DFIi9xwx.js → Loader-ULbmdTqr.js} +3 -3
  21. package/dist/{Loader-DFIi9xwx.js.map → Loader-ULbmdTqr.js.map} +1 -1
  22. package/dist/{Login-i7699gm4.js → Login-DIOARBWz.js} +9 -9
  23. package/dist/{Login-i7699gm4.js.map → Login-DIOARBWz.js.map} +1 -1
  24. package/dist/{Logout-BhbGbpeS.js → Logout-CRCdgD5E.js} +6 -6
  25. package/dist/{Logout-BhbGbpeS.js.map → Logout-CRCdgD5E.js.map} +1 -1
  26. package/dist/{Nav-DjQhprqh.js → Nav-DbAoZKkW.js} +5 -5
  27. package/dist/{Nav-DjQhprqh.js.map → Nav-DbAoZKkW.js.map} +1 -1
  28. package/dist/{PassportId-H0BukUWQ.js → PassportId-DygIldTh.js} +7 -7
  29. package/dist/{PassportId-H0BukUWQ.js.map → PassportId-DygIldTh.js.map} +1 -1
  30. package/dist/{Payment-QdXmFZsK.js → Payment-mUFToEdL.js} +187 -191
  31. package/dist/Payment-mUFToEdL.js.map +1 -0
  32. package/dist/{PaymentResult-Qsgi-ARD.js → PaymentResult-DxVV8-gr.js} +4 -4
  33. package/dist/{PaymentResult-Qsgi-ARD.js.map → PaymentResult-DxVV8-gr.js.map} +1 -1
  34. package/dist/{Profile-DfBS1mAR.js → Profile-B4CQgkI9.js} +33 -33
  35. package/dist/{Profile-DfBS1mAR.js.map → Profile-B4CQgkI9.js.map} +1 -1
  36. package/dist/{ProgressVideo-pUcxTOos.js → ProgressVideo-BUj2ZdrZ.js} +6 -6
  37. package/dist/{ProgressVideo-pUcxTOos.js.map → ProgressVideo-BUj2ZdrZ.js.map} +1 -1
  38. package/dist/{ProgressVideo.service-DUa0a8mZ.js → ProgressVideo.service-DUO2TYvj.js} +2 -2
  39. package/dist/{ProgressVideo.service-DUa0a8mZ.js.map → ProgressVideo.service-DUO2TYvj.js.map} +1 -1
  40. package/dist/{RichAlert-sD_C1nMy.js → RichAlert-ClHZ7u25.js} +5 -5
  41. package/dist/{RichAlert-sD_C1nMy.js.map → RichAlert-ClHZ7u25.js.map} +1 -1
  42. package/dist/{Scanner-7AMriAOE.js → Scanner-CwKhTXEe.js} +7 -7
  43. package/dist/{Scanner-7AMriAOE.js.map → Scanner-CwKhTXEe.js.map} +1 -1
  44. package/dist/SendTokens-D3wHuP8f.js +350 -0
  45. package/dist/SendTokens-D3wHuP8f.js.map +1 -0
  46. package/dist/{Sign-DIUczOq2.js → Sign-6vfvQY62.js} +7 -7
  47. package/dist/{Sign-DIUczOq2.js.map → Sign-6vfvQY62.js.map} +1 -1
  48. package/dist/{Stripe.service-CAFb5yn2.js → Stripe.service-BkR21W_w.js} +3 -3
  49. package/dist/{Stripe.service-CAFb5yn2.js.map → Stripe.service-BkR21W_w.js.map} +1 -1
  50. package/dist/{UpdateProfile-C1JgXXbB.js → UpdateProfile-Bsy2lCeY.js} +10 -10
  51. package/dist/{UpdateProfile-C1JgXXbB.js.map → UpdateProfile-Bsy2lCeY.js.map} +1 -1
  52. package/dist/{UserInfo-COvt0nYz.js → UserInfo-BFsSZlJZ.js} +4 -4
  53. package/dist/{UserInfo-COvt0nYz.js.map → UserInfo-BFsSZlJZ.js.map} +1 -1
  54. package/dist/{Wallet-CLLeUbtT.js → Wallet-C3jPERvZ.js} +8 -8
  55. package/dist/{Wallet-CLLeUbtT.js.map → Wallet-C3jPERvZ.js.map} +1 -1
  56. package/dist/{each-DfuNhFy6.js → each-DotlTdja.js} +2 -2
  57. package/dist/{each-DfuNhFy6.js.map → each-DotlTdja.js.map} +1 -1
  58. package/dist/{html-DDxtrLnm.js → html-CaQyMX88.js} +3 -3
  59. package/dist/{html-DDxtrLnm.js.map → html-CaQyMX88.js.map} +1 -1
  60. package/dist/{index-kGcNqRGJ.js → index-Bgz3eZ-8.js} +4011 -4027
  61. package/dist/{index-kGcNqRGJ.js.map → index-Bgz3eZ-8.js.map} +1 -1
  62. package/dist/{index-client-1rOYJlfv.js → index-client-CKcqeEI8.js} +2 -2
  63. package/dist/{index-client-1rOYJlfv.js.map → index-client-CKcqeEI8.js.map} +1 -1
  64. package/dist/{input-DGESq0UR.js → input-B70Q783D.js} +2 -2
  65. package/dist/{input-DGESq0UR.js.map → input-B70Q783D.js.map} +1 -1
  66. package/dist/{legacy-UOievsK_.js → legacy-y05PUOoK.js} +2 -2
  67. package/dist/{legacy-UOievsK_.js.map → legacy-y05PUOoK.js.map} +1 -1
  68. package/dist/passport.es.js +1 -1
  69. package/dist/passport.umd.js +116 -116
  70. package/dist/passport.umd.js.map +1 -1
  71. package/dist/{socket-io-DiMxoZcO.js → socket-io-Dek9Unxu.js} +2 -2
  72. package/dist/{socket-io-DiMxoZcO.js.map → socket-io-Dek9Unxu.js.map} +1 -1
  73. package/dist/types/Passport.d.ts +1 -1
  74. package/dist/types/passport/auth.d.ts +1 -9
  75. package/package.json +1 -1
  76. package/dist/Payment-QdXmFZsK.js.map +0 -1
  77. package/dist/SendTokens-ZHXHYLq8.js +0 -355
  78. package/dist/SendTokens-ZHXHYLq8.js.map +0 -1
  79. package/dist/strings-B-rKL311.js +0 -5
  80. package/dist/strings-B-rKL311.js.map +0 -1
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Payment-mUFToEdL.js","sources":["../../ui/images/lock.svg","../../ui/main/payment/PaymentSwitchButton.svelte","../../ui/main/payment/Payment.svelte","../../ui/main/payment/Stripe.svelte","../../ui/main/payment/CredenzaBalance.svelte","../src/app/pages/payment/stripe/wallet-pay/WalletPay.svelte","../src/app/pages/payment/stripe/Stripe.styles.ts","../../utils/lib/scripts/scripts.ts","../../utils/lib/orders/index.ts","../src/app/pages/payment/Payment.service.ts","../src/app/pages/payment/stripe/Stripe.svelte","../src/app/pages/payment/credenza-balance/CredenzaBalance.svelte","../src/app/pages/payment/order.service.ts","../src/app/pages/payment/paystack/Paystack.svelte","../src/app/pages/payment/Payment.svelte"],"sourcesContent":["export default \"data:image/svg+xml,%3csvg%20xmlns='http://www.w3.org/2000/svg'%20width='22'%20height='22'%20viewBox='0%200%2024%2024'%3e%3cpath%20fill='%23bbb'%20d='M17%209.761v-4.761c0-2.761-2.238-5-5-5-2.763%200-5%202.239-5%205v4.761c-1.827%201.466-3%203.714-3%206.239%200%204.418%203.582%208%208%208s8-3.582%208-8c0-2.525-1.173-4.773-3-6.239zm-8-4.761c0-1.654%201.346-3%203-3s3%201.346%203%203v3.587c-.927-.376-1.938-.587-3-.587s-2.073.211-3%20.587v-3.587zm4%2011.723v2.277h-2v-2.277c-.596-.347-1-.984-1-1.723%200-1.104.896-2%202-2s2%20.896%202%202c0%20.738-.404%201.376-1%201.723z'/%3e%3c/svg%3e\"","<style>\n .active {\n background-color: #ffff;\n font-weight: 500;\n color: #000;\n }\n .btn-disabled {\n pointer-events: none;\n background-color: #d0d2d5;\n }\n</style>\n\n<script lang=\"ts\">\n import Loader from '../shared/Loader.svelte'\n \n export let onClick: (...args: unknown[]) => unknown\n export let text: string\n export let disabled: boolean = false\n export let isLoading: boolean = false\n export let isActive: boolean = false\n</script>\n\n<button\n type=\"submit\"\n class=\"crtw-flex crtw-justify-center crtw-items-center crtw-w-full crtw-h-[50px] crtw-cursor-pointer crtw-border crtw-border-gray-300\n crtw-rounded crtw-font-['poppins'] crtw-text-gray-600\"\n class:btn-disabled={disabled || isLoading}\n class:active={isActive}\n on:click|preventDefault={onClick}\n>\n {#if isLoading}\n <Loader />\n {:else}\n {text}\n {/if}\n</button>","<script lang=\"ts\">\n import { PaymentViews } from '../../../utils/enums';\n import ButtonBack from '../shared/inputs/button-back/ButtonBack.svelte';\n import LockIcon from '../../images/lock.svg'\n import type { TUser } from '../../../utils/types';\n import PaymentSwitchButton from './PaymentSwitchButton.svelte';\n\n export let isLoading: boolean\n export let options: {\n user: TUser| null\n title: string\n subtitle?: string\n onBackClick: () => void\n isCardDisabled: boolean\n isCredezaValueDisabled: boolean\n }\n \n let { user, title, subtitle, onBackClick, isCardDisabled } = options\n let activeTab = isCardDisabled ? PaymentViews.CREDENZA_BALANCE : PaymentViews.CREDIT_CARD\n\n $: isCredezaValueDisabled = options.isCredezaValueDisabled\n</script>\n\n<div class=\"cpui-payment crtw-text-left crtw-w-full\" class:crtw-hidden={isLoading}>\n <div class=\"crtw-text-right crtw-text-[13px] crtw-text-gray-400 crtw-mb-6\">\n <div class=\"crtw-break-words\">{user?.email || user?.pending?.email || ''}</div>\n <div>{user?.phone || user?.pending?.phone || ''}</div>\n </div>\n <div class=\"crtw-font-bold crtw-text-xl\">{title}</div>\n <div class=\"crtw-flex crtw-justify-between crtw-mb-3 crtw-text-gray-600 crtw-font-bold\">\n {#if subtitle}\n <div>{subtitle}</div>\n {/if}\n </div>\n <div class=\"crtw-flex crtw-bg-gray-200 crtw-rounded-md crtw-p-px\">\n <PaymentSwitchButton\n text=\"Credit Card\"\n onClick={() => (activeTab = PaymentViews.CREDIT_CARD)}\n isActive={activeTab === PaymentViews.CREDIT_CARD}\n disabled={isCardDisabled}\n />\n <PaymentSwitchButton\n text=\"Credenza Balance\"\n onClick={() => (activeTab = PaymentViews.CREDENZA_BALANCE)}\n isActive={activeTab === PaymentViews.CREDENZA_BALANCE}\n disabled={isCredezaValueDisabled}\n />\n </div>\n <hr class=\"crtw-block crtw-border-t-2 crtw-border-gray-200 crtw-w-1/2 crtw-mx-auto crtw-mt-3.5 crtw-mb-[15px]\" />\n {#if activeTab === PaymentViews.CREDIT_CARD}\n <slot name=\"card-provider-switch\" />\n <slot name=\"credit-card\" />\n {:else if activeTab === PaymentViews.CREDENZA_BALANCE}\n <slot name=\"cred-balance\" />\n {/if}\n <div class=\"crtw-flex crtw-w-full crtw-justify-center crtw-items-center\">\n <img src={LockIcon} alt=\"\" /><span class=\"crtw-text-sm crtw-text-gray-400 crtw-ml-1\"\n >Payments are secure and encrypted</span\n >\n </div>\n <div class=\"crtw-mt-1.5\">\n <ButtonBack onClick={onBackClick} />\n </div>\n</div>\n","<script lang=\"ts\">\n import Button from \"../shared/inputs/button/Button.svelte\";\n\n export let options: {\n isCardFocused: boolean\n onPay: () => void\n currencySymbol?: string\n }\n export let isPaymentDisabled: boolean\n export let isLoading: boolean\n export let totalToPay: string\n\n let { isCardFocused, onPay, currencySymbol = '$' } = options\n</script>\n\n<div class=\"crtw-text-base crtw-mb-1.5\">Credit card details</div>\n<div\n id=\"cpui-card-element\"\n class=\"crtw-border crtw-border-gray-300 crtw-rounded crtw-px-2.5 crtw-py-4 crtw-mb-2.5 crtw-w-full\"\n style={isCardFocused ? 'border-color: #121e2b' : ''}\n/>\n<!-- Used to display Element errors. -->\n<div id=\"card-errors\" role=\"alert\" />\n<Button\n text={`Pay ${currencySymbol}${totalToPay}`}\n onClick={onPay}\n disabled={isPaymentDisabled}\n bind:isLoading\n/>","<script lang=\"ts\">\n import Button from \"../shared/inputs/button/Button.svelte\";\n\n export let options: {\n formattedBalance: string\n balance: number\n credAlias: string\n onPay: () => void\n onGetCred: () => void\n totalToPay: string\n isLoading: boolean\n isPaymentDisabled: boolean\n }\n\n let { credAlias, onPay, onGetCred } = options\n\n $: isLoading = options.isLoading\n $: isPaymentDisabled = options.isPaymentDisabled\n $: formattedBalance = options.formattedBalance\n $: totalToPay = options.totalToPay\n $: balance = options.balance\n</script>\n\n<div class=\"crtw-w-full crtw-text-center crtw-my-5\">\n <div class=\"crtw-text-3xl crtw-text-black crtw-font-bold\">\n {#if Number(totalToPay) > balance}\n INSUFFICIENT FUNDS\n {:else}\n {formattedBalance} {credAlias}\n {/if}\n \n </div>\n <div class=\"crtw-mb-5 crtw-text-gray-600\">\n {#if Number(totalToPay) > balance}\n <!-- svelte-ignore a11y-click-events-have-key-events -->\n You do not have enough stored value to make this payment. \n <span\n class=\"crtw-text-black crtw-cursor-pointer\"\n role=\"button\"\n tabindex=\"0\"\n on:click={onGetCred}\n >\n Click to get some {credAlias}\n </span>\n {:else}\n Your balance after purchase\n {/if}\n </div>\n\n <Button\n text={`Pay ${totalToPay} ${credAlias}`}\n onClick={onPay}\n disabled={isPaymentDisabled}\n {isLoading}\n />\n</div>","<script lang=\"ts\">\n import { onMount } from 'svelte'\n import { dispatch, PassportEvents } from '@lib/events/events'\n\n export let doPayment: (stripeTokenId: string) => Promise<void>\n export let stripe: Window['Stripe']\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n export let stripeElements: any\n export let priceCents: number\n export let isLoading: boolean\n\n onMount(async () => {\n const paymentRequest = stripe.paymentRequest({\n country: 'US',\n currency: 'usd',\n total: {\n label: 'Apple/Google payment',\n amount: priceCents / 100,\n },\n requestPayerName: true,\n requestPayerEmail: true,\n })\n const canMakePayment = await paymentRequest.canMakePayment()\n if (!canMakePayment) return\n\n const walletPayElement = document.getElementById('ctui-wallet-pay')\n if (walletPayElement) walletPayElement.style.display = 'crtw-block'\n\n const prButton = stripeElements.create('paymentRequestButton', {\n paymentRequest: paymentRequest,\n style: {\n paymentRequestButton: {\n height: '48px',\n },\n },\n })\n prButton.mount('#ctui-payment-request-button')\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n paymentRequest.on('token', async (event: any) => {\n isLoading = true\n try {\n await doPayment(event.token.id)\n await event.complete('success')\n } catch (err) {\n await event.complete('error')\n dispatch(PassportEvents.ERROR, { error: err })\n }\n isLoading = false\n })\n })\n</script>\n\n<div id=\"ctui-wallet-pay\" class=\"crtw-w-full crtw-my-4\" style=\"dispay: none;\">\n <div id=\"ctui-payment-request-button\"></div>\n</div>\n","export const stripeStyles = {\n base: {\n color: '#121e2b',\n fontSize: '12px',\n '::placeholder': {\n color: '#d9d9d9',\n },\n },\n invalid: {\n color: '#fa755a',\n },\n}\n","export const loadScript = (src: string) => {\n return new Promise((resolve, reject) => {\n const script = document.createElement('script')\n script.src = src\n document.body.appendChild(script)\n script.addEventListener('load', () => resolve(script))\n script.addEventListener('error', () => reject(script))\n })\n}\n","import { get } from \"svelte/store\";\nimport { accessTokenStore } from \"../../../stores\";\nimport type { TPaymentReturn } from \"@packages/utils/types\";\n\nexport const getOrderDetails = async (apiUrl: string, orderId: string): Promise<TPaymentReturn> => {\n const res = await fetch(`${apiUrl}/orders/${orderId}`, {\n headers: {\n \"Content-Type\": \"application/json\",\n Authorization: `Bearer ${get(accessTokenStore)}`,\n },\n method: \"GET\",\n });\n if (!res.ok) throw new Error(\"Failed to get order details\");\n return await res.json();\n}\nexport const getCompmletedOrderDetails = async (\n apiUrl: string,\n orderId: string,\n maxRetries = 5\n) => {\n let attempts = 0;\n\n while (attempts < maxRetries) {\n const res = await fetch(`${apiUrl}/orders/completed/${orderId}`, {\n headers: {\n \"Content-Type\": \"application/json\",\n Authorization: `Bearer ${get(accessTokenStore)}`,\n },\n method: \"GET\",\n });\n\n if (res.status === 204) {\n attempts++;\n if (attempts < maxRetries) {\n continue;\n } else {\n throw new Error(\"No content received after multiple attempts\");\n }\n }\n\n if (!res.ok) throw new Error(\"Failed to get order details\");\n return await res.json();\n }\n};\n\n\nexport const validateTxs = (txs: string[] | null[], message: string) => {\n if (txs.every((item) => item === null)) {\n throw new Error(`All transactions failed. \\n${message}`);\n }\n}\n\nexport const validateOrderItems = (\n orders: TPaymentReturn[\"items\"],\n): string => {\n const errorMessages = orders\n .filter((item) => item.error)\n .map(\n (item) =>\n `Name: ${item.metadata?.name || item.directive.resource_id}, reason: ${item.error}`\n )\n .join(\"\\n\");\n if (orders?.every(item => item.status === \"ERROR\")) {\n throw new Error(`All transactions failed.}`);\n }\n return errorMessages;\n};\n","import { ReceiptTarget, TransactionTypes } from '@packages/utils/enums'\nimport { accessTokenStore } from '@packages/stores'\nimport { get } from 'svelte/store'\nimport { configStore } from '@src/stores/config'\nimport { getClientConfigByClientId } from '@lib/clients'\nimport { initSuiClient } from '@src/libs/sui'\nimport type { TPaymentAsset } from './payment.constants'\nimport { pageOptsStore, pageStore, userStore } from '@packages/stores'\nimport { Pages } from '@packages/utils/enums'\nimport { analytics } from '@lib/mixpanel/mixpanel'\nimport { waitVideoEnded } from '@components/progress/ProgressVideo.service'\nimport { getAddress } from '@src/passport/blockchain'\nimport type { TPaymentReturn } from '@packages/utils/types'\nimport { validateOrderItems, validateTxs } from '@lib/orders'\nimport { dispatch, PassportEvents } from '@lib/events/events'\n\n\nexport const requestSuiReceipt = async ({\n stripeChargeId,\n title,\n digest,\n subtitle,\n amount,\n currency,\n}: {\n stripeChargeId?: string\n digest?: string\n amount?: number\n currency?: string\n title: string\n subtitle: string\n}) => {\n const { credenza, receiptTarget, clientId } = get(configStore)\n\n const targets = !receiptTarget \n ? [ReceiptTarget.EMAIL]\n : receiptTarget.filter(target => {\n const user = get(userStore);\n if(!user) return;\n return user[target]\n }\n );\n\n let successCount = 0;\n \n for (const target of targets) {\n const result = await fetch(`${credenza.suiApiUrl}/tokens/receipt`, {\n method: 'POST',\n body: JSON.stringify({\n ...(stripeChargeId ? { charge_id: stripeChargeId } : {}),\n ...(digest ? { digest } : {}),\n ...(amount ? { amount } : {}),\n ...(currency ? { currency } : {}),\n target,\n title,\n subtitle,\n source: getClientConfigByClientId(clientId).name,\n }),\n headers: {\n Authorization: `Bearer ${get(accessTokenStore)}`,\n 'Content-Type': 'application/json',\n },\n })\n\n if (result.ok) {\n successCount++;\n } else {\n console.warn(`Failed to send receipt to ${target}:`, result.status)\n }\n }\n\n return successCount > 0\n}\n\nexport const afterPaymentProcess = async ({\n res,\n priceCents,\n purchaseConfig\n}: {\n res: TPaymentReturn\n priceCents: number,\n purchaseConfig: { assets: TPaymentAsset[], title: string, subtitle: string }\n}) => {\n const config = get(configStore)\n\n const { chain_txs, items } = res\n const failedOrdersMessage = validateOrderItems(items)\n validateTxs(chain_txs, failedOrdersMessage)\n \n dispatch(PassportEvents.PAYMENT, { type: TransactionTypes.CARD })\n dispatch(PassportEvents.RECHECK_BALANCE)\n const user = get(userStore)\n if (user) {\n analytics.track('cp_payment_fiat', {\n $email: user.email,\n $phone: user.phone,\n suiNetwork: config.suiNetwork,\n clientId: config.clientId,\n address: await getAddress(),\n location: window.location.href,\n assets: purchaseConfig?.assets,\n total: priceCents / 100,\n description: (purchaseConfig?.title ?? '') + `(${purchaseConfig?.subtitle ?? ''})`,\n })\n }\n\n await waitVideoEnded()\n\n if (failedOrdersMessage) {\n pageOptsStore.set({\n title: 'Done!',\n subtitle: 'Your payment was partly successful',\n orders: items,\n })\n }\n pageStore.set(Pages.PAYMENT_RESULT)\n}\n\nexport const enrichAssetsWithMetadata = async (\n items: TPaymentReturn['items'], \n) => {\n for (const item of items) {\n const client = await initSuiClient(item?.asset?.packageId as string)\n \n let metadata = null\n if (item?.asset?.assetId) {\n metadata = await client.CredenzaAssetCollection.getAssetMetadata(+item?.asset?.assetId)\n item.asset.metadata = metadata\n }\n }\n}\n","<script lang=\"ts\">\n import WalletPay from './wallet-pay/WalletPay.svelte'\n import { onMount } from 'svelte'\n import { get } from 'svelte/store'\n import { stripeStyles } from '@pages/payment/stripe/Stripe.styles'\n import { dispatch, PassportEvents } from '@lib/events/events'\n import { loadScript } from '@lib/scripts/scripts'\n import { pageOptsStore, pageStore, fn } from '@packages/stores'\n import { Pages } from '@packages/utils/enums'\n import { Stripe as StripeComponent } from '@packages/ui'\n\n import { configStore } from '@src/stores/config'\n import { getClientConfigByClientId } from '@lib/clients'\n import type { TPaymentAsset } from '../payment.constants'\n import { afterPaymentProcess } from '../Payment.service'\n\n export let priceCents: number\n export let isLoading: boolean\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n export let purchaseConfig: { assets: TPaymentAsset[], title: string, subtitle: string }\n export let isPriceLoading: boolean\n\n const { toastAlert } = get(fn)\n const config = get(configStore)\n\n let Stripe: Window['Stripe']\n let stripe: Window['Stripe']\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n let stripeElements: any\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n let cardElement: any\n let isButtonActive: boolean\n\n let isCardFocused = false\n onMount(async () => {\n try {\n if (!Stripe) {\n if (!window.Stripe) {\n await loadScript('https://js.stripe.com/v3/')\n if (!window.Stripe) throw {}\n }\n Stripe = window.Stripe\n }\n } catch (err) {\n return console.log('Please include stripe to use payments.')\n }\n if (stripe) return\n const clientName = getClientConfigByClientId(config.clientId).name\n stripe = Stripe(config.stripe.pk[clientName] ?? config.stripe.pk.DEFAULT)\n stripeElements = stripe.elements()\n cardElement = stripeElements.create('card', { style: stripeStyles })\n cardElement.mount('#cpui-card-element')\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n cardElement.on('change', (event: any) => {\n isButtonActive = event.complete && !event.error\n })\n cardElement.on('focus', () => (isCardFocused = true))\n cardElement.on('blur', () => (isCardFocused = false))\n })\n\n const handleSubmit = async () => {\n try {\n if (!isButtonActive) return\n isLoading = true\n const result = await stripe.createToken(cardElement)\n if (result.error) throw result.error\n await doPayment(result.token.id)\n } catch (err) {\n dispatch(PassportEvents.ERROR, { error: err })\n }\n isLoading = false\n }\n\n const doPayment = async (tokenId: string) => {\n try {\n const { processPayment } = await import('@pages/payment/stripe/Stripe.service')\n\n const { assets } = purchaseConfig\n if (!assets?.length) throw new Error('No purchase config assets found')\n\n const res = await processPayment(tokenId, assets)\n await afterPaymentProcess({res, priceCents, purchaseConfig})\n } catch (err) {\n toastAlert(`Payment error: ${err.message || err}`, 'failure')\n pageOptsStore.set({ errorMessage: err.message })\n pageStore.set(Pages.ERROR)\n dispatch(PassportEvents.ERROR, { error: err })\n }\n }\n\n $: isPaymentDisabled = !isButtonActive || isLoading || isPriceLoading\n $: totalToPay = (priceCents / 100).toFixed(2)\n</script>\n\n<StripeComponent\n bind:isPaymentDisabled\n bind:isLoading\n bind:totalToPay\n options={{\n isCardFocused,\n onPay: handleSubmit,\n }}\n/>\n\n{#if stripe && stripeElements}\n <WalletPay {doPayment} {stripe} {stripeElements} {priceCents} bind:isLoading />\n{/if}\n","<script lang=\"ts\">\n import { onMount } from 'svelte'\n import { Pages } from '@packages/utils/enums'\n import { pageOptsStore, fn, pageStore, userStore, clientPublicStore } from '@packages/stores'\n import { dispatch, PassportEvents } from '@lib/events/events'\n import { CredenzaBalance } from '@packages/ui'\n import { get } from 'svelte/store'\n import { analytics } from '@lib/mixpanel/mixpanel'\n import { configStore } from '@src/stores/config'\n import { buyWithCred, getAddress, getBalance } from '@src/passport/blockchain'\n import { waitVideoEnded } from '@components/progress/ProgressVideo.service'\n import { requestSuiReceipt } from '../Payment.service'\n\n export let totalPriceToken: number\n export let purchaseConfig: {\n assets: { type: string; packageId: string; assetId?: number; amount?: number }[]\n title: string\n subtitle: string\n }\n export let isLoading: boolean\n export let isPriceLoading: boolean\n export let pricesByAsset: number[] = []\n\n const { toastAlert } = get(fn)\n const config = get(configStore)\n\n let balance = 0\n\n const processPaymentTx = async (\n asset: { type: string; packageId: string; assetId?: number; amount?: number },\n index: number,\n ) => {\n const { type, packageId, assetId, amount } = asset\n const paymentRes = await buyWithCred(type, packageId, { assetId, amount })\n const { title, subtitle } = purchaseConfig\n dispatch(PassportEvents.PAYMENT)\n dispatch(PassportEvents.RECHECK_BALANCE)\n await requestSuiReceipt({\n digest: paymentRes.digest,\n title,\n subtitle,\n amount: pricesByAsset[index],\n currency: 'CRED',\n })\n dispatch(PassportEvents.RECEIPT, { digest: paymentRes.digest })\n }\n\n const payWithCredenza = async () => {\n try {\n if (BigInt(totalPriceToken) > balance) return\n\n isLoading = true\n const { assets } = purchaseConfig\n\n for (const [index, asset] of assets.entries()) {\n await processPaymentTx(asset, index)\n\n await new Promise((resolve) => setTimeout(resolve, 1000))\n }\n\n const user = get(userStore)\n if (user) {\n analytics.track('cp_payment_stored_value', {\n $email: user.email,\n $phone: user.phone,\n suiNetwork: config.suiNetwork,\n clientId: config.clientId,\n location: window.location.href,\n address: await getAddress(),\n assets,\n total: totalPriceToken,\n description: (purchaseConfig?.title ?? '') + `(${purchaseConfig?.subtitle ?? ''})`,\n })\n }\n await waitVideoEnded()\n\n pageStore.set(Pages.PAYMENT_RESULT)\n } catch (err) {\n toastAlert(`Payment error: ${err.message || err}`, 'failure')\n pageOptsStore.set({ errorMessage: err.message })\n pageStore.set(Pages.ERROR)\n dispatch(PassportEvents.ERROR, { error: err })\n } finally {\n isLoading = false\n }\n }\n\n onMount(async () => {\n balance = Number(await getBalance())\n })\n\n $: formattedBalance = `${(balance - totalPriceToken).toFixed(2)}`\n</script>\n\n<CredenzaBalance\n options={{\n formattedBalance,\n balance,\n credAlias:$clientPublicStore.ui_settings.cred_alias,\n onPay: payWithCredenza,\n onGetCred: () => pageStore.set(Pages.WALLET),\n totalToPay: String(totalPriceToken),\n isLoading,\n isPaymentDisabled: !Number(balance) || totalPriceToken > balance || isPriceLoading,\n }}\n/>\n","import { accessTokenStore, pageOptsStore } from \"@packages/stores\"\nimport type { TBasicPaymentData } from \"./oder.types\"\nimport { get } from \"svelte/store\"\nimport { configStore } from \"@src/stores/config\"\nimport type { TPaymentReturn } from \"@packages/utils/types\"\nimport { getCompmletedOrderDetails } from \"@lib/orders\"\nimport { enrichAssetsWithMetadata, requestSuiReceipt } from \"./Payment.service\"\nimport { dispatch, PassportEvents } from \"@lib/events/events\"\nimport type { TPaymentAsset } from \"./payment.constants\"\n\n\nexport const createOrder = async (paymentData: TBasicPaymentData): Promise<string> => {\n const { assets, ...rest } = paymentData\n const assetGroups = mapAssetsToGroups(assets)\n const res = await fetch(get(configStore).credenza.suiApiUrl + '/assets/buy', {\n headers: {\n 'Content-Type': 'application/json',\n Authorization: `Bearer ${get(accessTokenStore)}`,\n },\n method: 'POST',\n body: JSON.stringify({...rest, ...assetGroups}),\n })\n if (!res.ok) throw new Error('Failed to create order')\n const { _id }: { _id: string } = await res.json()\n return _id\n}\n\nexport const processOrder = async (orderId: string): Promise<TPaymentReturn> => {\n const config = get(configStore)\n const { title, subtitle } = get(pageOptsStore)\n const data = (await getCompmletedOrderDetails(config.credenza.generalApiUrl, orderId)) as TPaymentReturn\n if (data.items[0].error) throw new Error(data.items[0].error)\n\n if (data.payment_provider_tx && data.payment_provider !== \"paystack\") {\n await requestSuiReceipt({ stripeChargeId: data.payment_provider_tx, title, subtitle, currency: data.currency })\n dispatch(PassportEvents.RECEIPT, { stripeChargeId: data.payment_provider_tx })\n }\n await enrichAssetsWithMetadata(data.items)\n return data\n}\n\nconst mapAssetsToGroups = (assets: TPaymentAsset[]) => {\n const typeMap: { [key: string]: string } = {\n credenza_asset_collection: \"collection\",\n decom: \"decom\",\n cred: \"coin\",\n membership: \"membership\",\n };\n\n const result = assets.reduce((acc: { [key: string]: { asset_type: string; asset_id?: number; amount?: number }[] }, asset) => {\n const key = typeMap[asset.type];\n if (!key) return acc;\n\n const entry: { asset_type: string; asset_id?: number; amount?: number } = {\n asset_type: `${asset.packageId}::${asset.type}::${asset.type.toUpperCase()}`,\n };\n\n if (asset.assetId) {\n entry.asset_id = +asset.assetId\n }\n if (asset.amount) {\n entry.amount = asset.amount\n }\n\n acc[key] = acc[key] || [];\n acc[key].push(entry);\n\n return acc;\n }, { collection: [], decom: [], coin: [], membership: [] });\n\n return result;\n}","<script lang=\"ts\">\n import { dispatch, PassportEvents } from \"@lib/events/events\"\n import { loadScript } from \"@lib/scripts/scripts\"\n import { pageOptsStore, pageStore } from \"@packages/stores\"\n import { Pages } from \"@packages/utils/enums\"\n import { toastAlert } from \"@src/passport/ui\"\n import { onMount } from \"svelte\"\n import { createOrder, processOrder } from \"../order.service\"\n import { afterPaymentProcess } from \"../Payment.service\"\n import { get } from \"svelte/store\"\n import { configStore } from \"@src/stores/config\"\n import Button from \"@packages/ui/main/shared/inputs/button/Button.svelte\"\n import { getClientConfigByClientId } from \"@lib/clients\"\n import { getOrderDetails } from \"@lib/orders\"\n\n let { priceCents, purchaseConfig, isLoading = $bindable() } = $props()\n\n let Paystack: Window['PaystackPop']\n\n onMount(async () => {\n try {\n if (!Paystack) {\n if (!window.PaystackPop) {\n await loadScript('https://js.paystack.co/v2/inline.js')\n }\n Paystack = window.PaystackPop\n }\n\n await doPayment()\n } catch (err) {\n return console.log('Please include paystack to use payments.')\n }\n })\n\n const externalErrorHandler = (err: Error) => {\n isLoading = false\n toastAlert(`Payment error: ${err.message || err}`, 'failure')\n pageOptsStore.set({ errorMessage: err.message })\n pageStore.set(Pages.ERROR)\n dispatch(PassportEvents.ERROR, { error: err })\n };\n\n const doPayment = async () => {\n try {\n const { assets } = purchaseConfig\n const config = get(configStore)\n if (!assets?.length) throw new Error('No purchase config assets found')\n isLoading = true\n\n const currency = getClientConfigByClientId(get(configStore).clientId).payment.paystack!\n const orderId = await createOrder({assets, payment_provider: \"paystack\", client_id: get(configStore).clientId, currency })\n const res = await getOrderDetails(config.credenza.generalApiUrl, orderId)\n\n if (!res.payment_provider_data?.access_code) throw new Error('Payment is unavailable now')\n const popup = new Paystack()\n \n const result = popup.resumeTransaction(res.payment_provider_data?.access_code)\n result.onSuccess = async () => {\n try {\n const res = await processOrder(orderId);\n await afterPaymentProcess({\n res,\n priceCents,\n purchaseConfig\n });\n } catch (err) {\n externalErrorHandler(err)\n } finally {\n isLoading = false;\n }\n }\n\n result.onError = (err: unknown) => {\n isLoading = false\n throw err\n }\n\n result.onCancel = () => {\n isLoading = false\n throw new Error(\"Payment was not finished\")\n }\n } catch (err) {\n externalErrorHandler(err)\n }\n }\n</script>\n\n\n<div class=\"crtw-w-full crtw-text-center crtw-my-5\">\n <Button\n text={`Pay with Paystack`}\n onClick={doPayment}\n disabled={false}\n isLoading={false}\n />\n</div>\n","<script lang=\"ts\">\n import { Pages } from '@packages/utils/enums'\n import { onDestroy } from 'svelte'\n\n import { pageOptsStore, userStore, pageStore } from '@packages/stores'\n import { dispatch, PassportEvents } from '@lib/events/events'\n import { Payment } from '@packages/ui'\n import Stripe from './stripe/Stripe.svelte'\n import { getSuiCredCoinType, getSellableConfigId, getSuiObject, getAssetPrice } from '@src/utils/blockchain'\n import type { TSuiPaymentItem } from '@app/types'\n import { toastAlert } from '@src/passport/ui'\n import CredenzaBalance from './credenza-balance/CredenzaBalance.svelte'\n import { SUI_CRED_DECIMALS } from '@src/constants/blockchain'\n import { AssetType, CardPaymentProvider } from './payment.constants'\n import { getClientConfigByClientId } from '@lib/clients'\n import { configStore } from '@src/stores/config'\n import { get } from 'svelte/store'\n import Paystack from './paystack/Paystack.svelte'\n import Button from '@packages/ui/main/shared/inputs/button/Button.svelte'\n import { initSuiClient } from '@src/libs/sui'\n\n let isPriceLoading: boolean = false\n let isLoading: boolean = false\n let pricesByAsset: number[] = []\n\n let totalSumCentsUSD: number = 0\n let totalSumCentsGHS: number = 0\n let totalSumCoins: number = 0\n\n let cardPaymentProvider = CardPaymentProvider.STRIPE\n\n const getTokenPrice = async (packageId: string, type: string, assetId?: string): Promise<[number, number]> => {\n if (assetId && type === AssetType.CREDENZA_ASSET_COLLECTION) {\n return await getAssetPrice(packageId, assetId)\n }\n\n const sellableConfigId = await getSellableConfigId(packageId, type)\n const sellableObj = await getSuiObject(sellableConfigId)\n\n const {\n content: {\n fields: { price_fiat, price_coin },\n },\n } = sellableObj\n return [+price_fiat, +price_coin]\n }\n\n const getCredPrice = async (packageId: string, type: string) => {\n const sellableConfigId = await getSellableConfigId(packageId, type)\n const { suiNetwork } = get(configStore)\n const client = await initSuiClient(packageId, suiNetwork)\n\n const priceCentsUSD = await client.Sellable.getPriceFiat(sellableConfigId, \"USD\")\n let priceCentsGHS = 0\n\n if (getClientConfigByClientId(get(configStore).clientId).payment.paystack) {\n priceCentsGHS = await client.Sellable.getPriceFiat(sellableConfigId, \"GHS\")\n }\n return [priceCentsUSD, priceCentsGHS]\n }\n\n const calculateTotalPrice = async (assets: TSuiPaymentItem[]): Promise<void> => {\n try {\n isPriceLoading = true\n\n for (const asset of assets) {\n const { packageId, type, amount, assetId } = asset\n const packageIdWCoinType = `${packageId}::${type}::${type.toUpperCase()}`\n if (packageIdWCoinType === getSuiCredCoinType() && amount) {\n const [priceCentsUSD, priceCentsGHS] = await getCredPrice(packageId, type)\n totalSumCentsUSD += amount * priceCentsUSD\n totalSumCentsGHS += amount * priceCentsGHS\n } else {\n let [cents, coins] = await getTokenPrice(packageId, type, assetId)\n if (amount && amount !== 0) {\n cents *= amount\n coins *= amount\n }\n\n totalSumCentsUSD += cents\n totalSumCoins += coins / SUI_CRED_DECIMALS\n\n pricesByAsset.push(coins / SUI_CRED_DECIMALS)\n }\n }\n } catch (err) {\n console.log(err)\n toastAlert('Error calculating the price', 'failure')\n dispatch(PassportEvents.ERROR, err)\n } finally {\n isPriceLoading = false\n }\n }\n\n const unsub = pageOptsStore.subscribe(async (store) => {\n if (!store?.assets || !store.assets.length) return\n await calculateTotalPrice(store.assets)\n })\n\n const onChangeCardProvider = () => {\n if (cardPaymentProvider === CardPaymentProvider.PAYSTACK) {\n cardPaymentProvider = CardPaymentProvider.STRIPE;\n } else {\n cardPaymentProvider = CardPaymentProvider.PAYSTACK;\n }\n }\n\n onDestroy(unsub)\n</script>\n\n{#if isLoading}\n {#await import('@components/progress/ProgressVideo.svelte') then module}\n <svelte:component this={module.default} />\n {/await}\n{/if}\n\n<Payment\n bind:isLoading\n options={{\n user: $userStore,\n title: $pageOptsStore.title || `Order Summary`,\n subtitle: $pageOptsStore.subtitle,\n onBackClick: () => pageStore.set(Pages.WALLET),\n isCardDisabled: $pageOptsStore.payments?.card?.disabled,\n isCredezaValueDisabled: !totalSumCentsUSD || $pageOptsStore.payments?.credenzaStoredValue?.disabled,\n }}\n>\n <div slot=\"card-provider-switch\" class=\"crtw-mb-[15px]\">\n {#if getClientConfigByClientId(get(configStore).clientId).payment.paystack}\n <Button\n text={`Try another payment provider`}\n onClick={onChangeCardProvider}\n disabled={false}\n isLoading={false}\n />\n {/if}\n </div>\n <div slot=\"credit-card\">\n {#if cardPaymentProvider === CardPaymentProvider.PAYSTACK}\n <Paystack priceCents={totalSumCentsGHS} purchaseConfig={$pageOptsStore} bind:isLoading/>\n {:else if cardPaymentProvider === CardPaymentProvider.STRIPE}\n <Stripe priceCents={totalSumCentsUSD} {isPriceLoading} purchaseConfig={$pageOptsStore} bind:isLoading />\n {/if}\n </div>\n <div slot=\"cred-balance\">\n <CredenzaBalance\n {pricesByAsset}\n totalPriceToken={totalSumCoins}\n {isPriceLoading}\n purchaseConfig={$pageOptsStore}\n bind:isLoading\n />\n </div>\n\n</Payment>\n"],"names":["LockIcon","onClick","$.prop","$$props","text","disabled","isLoading","$$render","consequent","alternate","isActive","$$args","options","user","title","subtitle","onBackClick","isCardDisabled","activeTab","PaymentViews","isCredezaValueDisabled","isPaymentDisabled","totalToPay","isCardFocused","onPay","currencySymbol","credAlias","onGetCred","formattedBalance","balance","$.template_effect","$.set_text","text_1","$.get","__awaiter","thisArg","_arguments","P","generator","onMount","stripe","priceCents","paymentRequest","walletPayElement","stripeElements","event","doPayment","err","dispatch","PassportEvents","stripeStyles","loadScript","src","resolve","reject","script","getOrderDetails","apiUrl","orderId","res","get","accessTokenStore","getCompmletedOrderDetails","maxRetries","attempts","validateTxs","txs","message","item","validateOrderItems","orders","errorMessages","requestSuiReceipt","stripeChargeId","digest","amount","currency","credenza","receiptTarget","clientId","configStore","targets","target","userStore","ReceiptTarget","successCount","result","getClientConfigByClientId","afterPaymentProcess","purchaseConfig","config","chain_txs","items","failedOrdersMessage","TransactionTypes","analytics","getAddress","waitVideoEnded","pageOptsStore","pageStore","Pages","enrichAssetsWithMetadata","client","initSuiClient","metadata","isPriceLoading","fn","Stripe","$.mutable_source","cardElement","isButtonActive","clientName","$.set","_a","handleSubmit","tokenId","processPayment","assets","totalPriceToken","pricesByAsset","asset","index","type","packageId","assetId","paymentRes","buyWithCred","payWithCredenza","_b","toastAlert","getBalance","$clientPublicStore","createOrder","paymentData","rest","assetGroups","mapAssetsToGroups","_id","processOrder","data","typeMap","acc","key","entry","Paystack","externalErrorHandler","totalSumCentsUSD","totalSumCentsGHS","totalSumCoins","cardPaymentProvider","CardPaymentProvider","getTokenPrice","AssetType","getAssetPrice","sellableConfigId","getSellableConfigId","sellableObj","getSuiObject","price_fiat","price_coin","getCredPrice","suiNetwork","priceCentsUSD","priceCentsGHS","getSuiCredCoinType","cents","coins","SUI_CRED_DECIMALS","unsub","store","calculateTotalPrice","onChangeCardProvider","onDestroy","module","$.component","node_2","$$anchor","$$component","$userStore","$pageOptsStore","consequent_1","consequent_3","consequent_2"],"mappings":"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"}
@@ -1,6 +1,6 @@
1
- import { c as ut, p as Ot, h as pt, f as g, i as y, r as d, b as n, d as dt, u as mt, s as nt, a as B, k as Pt, e as jt, t as et, n as Ct, o as Et } from "./legacy-UOievsK_.js";
2
- import { z as ft, M as _t, O as Mt, B as c, C as i, E as _, G as r, D as w, y as wt, u as Yt, x as S, J as t, A as Ft, T as ct, F as it, _ as Nt, K as Ut, Q as Vt } from "./index-kGcNqRGJ.js";
3
- import { e as lt, i as ot } from "./each-DfuNhFy6.js";
1
+ import { c as ut, p as Ot, h as pt, f as g, i as y, r as d, b as n, d as dt, u as mt, s as nt, a as B, k as Pt, e as jt, t as et, n as Ct, o as Et } from "./legacy-y05PUOoK.js";
2
+ import { z as ft, M as _t, O as Mt, B as c, C as i, E as _, G as r, D as w, y as wt, u as Yt, x as S, J as t, A as Ft, T as ct, F as it, _ as Nt, K as Ut, Q as Vt } from "./index-Bgz3eZ-8.js";
3
+ import { e as lt, i as ot } from "./each-DotlTdja.js";
4
4
  function vt(T, o, A, j) {
5
5
  if (A === "sui")
6
6
  return `https://suiscan.xyz/${j}/tx/${o}`;
@@ -255,4 +255,4 @@ function Xt(T, o) {
255
255
  export {
256
256
  Xt as default
257
257
  };
258
- //# sourceMappingURL=PaymentResult-Qsgi-ARD.js.map
258
+ //# sourceMappingURL=PaymentResult-DxVV8-gr.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"PaymentResult-Qsgi-ARD.js","sources":["../../ui/main/payment-result/service.ts","../../ui/main/payment-result/PaymentResult.svelte","../src/app/pages/payment-result/PaymentResult.svelte"],"sourcesContent":["export function getTxUrl(\n item: { chainId: string },\n tx: string,\n chainType: string,\n networkType: string\n ) { \n if (chainType === \"sui\") {\n return `https://suiscan.xyz/${networkType}/tx/${tx}`;\n }\n\n switch (String(item.chainId)) {\n case \"137\":\n return `https://polygonscan.com/tx/${tx}`;\n case \"88888\":\n return `https://chiliscan.com/tx/${tx}`;\n case \"43114\":\n return `https://subnets.avax.network/c-chain/tx/${tx}`;\n case \"80002\":\n return `https://amoy.polygonscan.com/tx/${tx}`;\n case \"88882\":\n return `https://testnet.chiliscan.com/tx/${tx}`;\n case \"43113\":\n return `https://subnets-test.avax.network/c-chain/block/${tx}`;\n default:\n return null;\n }\n }","<script lang=\"ts\">\n import { fn } from \"../../../stores\";\n import { Pages } from \"../../../utils/enums\";\n import type { TPaymentReturn } from \"../../../utils/types\";\n import { get } from \"svelte/store\";\n import { getTxUrl } from \"./service\";\n export let options: {\n title: string;\n isSui?: boolean;\n description: string | undefined;\n subtitle: string;\n orders: TPaymentReturn[\"items\"];\n networkType?: string;\n tokenImage?: string;\n };\n const { openUI } = get(fn);\n let {\n title,\n subtitle,\n orders,\n networkType,\n tokenImage,\n isSui,\n } = options;\n\n const successfulOrders = (orders ?? []).filter((o) => o.tx);\n const failedOrders = (orders ?? []).filter((o) => !o.tx);\n\n function retryPurchase() {\n const hasAssets = failedOrders.some((order) => order.asset);\n if (hasAssets) {\n const assets = failedOrders\n .filter((order) => order.asset)\n .map((order) => ({\n packageId: order.asset!.packageId,\n type: order.asset!.type,\n assetId: order.asset!.assetId,\n amount: order.asset!.amount,\n }));\n if (!assets.length) return;\n\n openUI(Pages.PAYMENT, {\n subtitle: \"Retrying failed orders\",\n payments: {\n credenzaStoredValue: {\n disabled: false,\n },\n },\n assets,\n });\n\n return;\n }\n const tokens: {\n contractAddress: string;\n tokenId: number;\n amount: number;\n }[] = [];\n\n const memberships: {\n contractAddress: string;\n }[] = [];\n\n for (const order of failedOrders) {\n const directive = order.directive;\n if (directive.type !== \"membership\") {\n tokens.push({\n contractAddress: directive.resource_id,\n tokenId: directive.value?.token_id,\n amount: directive.value.amount,\n });\n } else {\n memberships.push({\n contractAddress: directive.resource_id,\n });\n }\n }\n \n if (!tokens.length && !memberships.length) return;\n openUI(Pages.PAYMENT, {\n subtitle: \"Retrying failed orders\",\n payments: {\n credenzaStoredValue: {\n disabled: false,\n },\n },\n tokens,\n memberships,\n });\n }\n</script>\n\n<div>\n <div\n class=\"crtw-text-black-900 crtw-text-xl md:crtw-text-2xl crtw-font-semibold crtw-pt-5 crtw-mb-3.5 crtw-text-center\"\n >\n {title}\n </div>\n <div class=\"crtw-mb-3.5 crtw-text-sm crtw-text-justify\">\n {subtitle}\n </div>\n {#if tokenImage}\n <div class=\"crtw-my-4 flex justify-center\">\n <div\n class=\"crtw-w-64 crtw-h-64 crtw-rounded-xl crtw-shadow-md crtw-bg-white flex items-center justify-center overflow-hidden\"\n >\n <img\n src={tokenImage}\n alt=\"Token\"\n class=\"max-w-full max-h-full object-contain\"\n />\n </div>\n </div>\n {/if}\n\n <div class=\"crtw-mb-3.5 crtw-text-sm crtw-text-justify\">\n {#if orders.length}\n <div class=\"crtw-mt-6\">\n <div class=\"crtw-text-lg crtw-font-semibold crtw-mb-2\">Successful</div>\n {#each successfulOrders as order}\n {#if order.tx}\n <div class=\"crtw-mb-2\">\n <a\n href={getTxUrl(\n { chainId: order.directive?.chain_id || \"\" },\n order.tx,\n order.directive.chain_type,\n networkType || \"\"\n )}\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n class=\"crtw-text-blue-600 crtw-underline\"\n >\n <div class=\"crtw-break-words\">\n {#if order.metadata?.name}\n {order.metadata.name}\n {:else}\n <span>{order.directive.type}</span>\n <span\n class=\"crtw-break-all crtw-whitespace-normal crtw-break-words\"\n >\n ({order.directive.resource_id})\n </span>\n {/if}\n </div>\n </a>\n </div>\n {/if}\n {/each}\n\n <div\n class=\"crtw-text-lg crtw-font-semibold crtw-mt-6 crtw-mb-2\"\n class:hidden={!failedOrders.length}\n >\n Failed\n </div>\n {#if failedOrders.length}\n {#each failedOrders as order}\n <div class=\"crtw-mb-3\">\n <p class=\"crtw-text-red-600 break-words\">\n {#if order.metadata?.name}\n {order.metadata.name}\n {:else if order.directive?.type}\n <span>{order.directive.type} </span>\n <span class=\"text-gray-500 break-all whitespace-normal\">\n ({order.directive.resource_id})\n </span>\n {:else if order.asset?.assetId}\n AssetId {order.asset.assetId} : {order.error}\n {:else}\n <span>{order.asset?.type}</span>\n <span\n class=\"crtw-break-all crtw-whitespace-normal crtw-break-words\"\n >\n ({order.asset?.packageId}) : {order.error}\n </span>\n {/if}\n </p>\n </div>\n {/each}\n {/if}\n <button\n class=\"crtw-bg-black hover:crtw-bg-gray-800 crtw-text-white crtw-px-4 crtw-py-2 crtw-rounded-md crtw-mt-4\"\n on:click={retryPurchase}\n >\n Try Again\n </button>\n </div>\n {:else if isSui}\n If you are not seeing your new token, please contact\n <a href=\"mailto:support@credenza3.com\" class=\"text-blue-600 underline\">\n support@credenza3.com\n </a>.\n {:else}\n Typically, your purchase will be processed within a few seconds. In the\n event of unusually high traffic, you may have to wait as much as a minute\n or so. If several minutes pass and you are not seeing your purchase,\n please contact\n <a class=\"crtw-underline\" href=\"mailto:support@credenza3.com\"\n >support@credenza3.com</a\n >.\n {/if}\n </div>\n</div>\n","<script lang=\"ts\">\n import { get } from 'svelte/store'\n import { pageOptsStore } from '@packages/stores'\n import { PaymentResult } from '@packages/ui'\n import { configStore } from '@src/stores/config'\n\n let config = get(configStore)\n</script>\n\n<PaymentResult\n options={{\n title: config.content?.paymentResult?.title || 'Success!',\n subtitle: $pageOptsStore?.subtitle || config.content?.paymentResult?.subtitle || 'Your payment was successful!',\n description: config.content?.paymentResult?.description,\n orders: $pageOptsStore?.orders || [],\n networkType: config.networkType,\n tokenImage: $pageOptsStore?.tokenImage || '',\n isSui: true\n }}\n/>\n "],"names":["getTxUrl","item","tx","chainType","networkType","options","openUI","get","fn","title","subtitle","orders","isSui","successfulOrders","o","failedOrders","retryPurchase","order","assets","Pages","tokens","memberships","directive","_a","tokenImage","$$render","consequent","$.each","node_2","$.template_effect","$.set_text","text_2","$.get","$.untrack","text_3","consequent_1","alternate","consequent_2","node_6","text_5","text_6","text_9","consequent_5","alternate_1","consequent_4","alternate_2","consequent_3","alternate_3","consequent_6","$0","classes","$.set_class","div_9","consequent_7","alternate_5","config","$pageOptsStore"],"mappings":"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"}
1
+ {"version":3,"file":"PaymentResult-DxVV8-gr.js","sources":["../../ui/main/payment-result/service.ts","../../ui/main/payment-result/PaymentResult.svelte","../src/app/pages/payment-result/PaymentResult.svelte"],"sourcesContent":["export function getTxUrl(\n item: { chainId: string },\n tx: string,\n chainType: string,\n networkType: string\n ) { \n if (chainType === \"sui\") {\n return `https://suiscan.xyz/${networkType}/tx/${tx}`;\n }\n\n switch (String(item.chainId)) {\n case \"137\":\n return `https://polygonscan.com/tx/${tx}`;\n case \"88888\":\n return `https://chiliscan.com/tx/${tx}`;\n case \"43114\":\n return `https://subnets.avax.network/c-chain/tx/${tx}`;\n case \"80002\":\n return `https://amoy.polygonscan.com/tx/${tx}`;\n case \"88882\":\n return `https://testnet.chiliscan.com/tx/${tx}`;\n case \"43113\":\n return `https://subnets-test.avax.network/c-chain/block/${tx}`;\n default:\n return null;\n }\n }","<script lang=\"ts\">\n import { fn } from \"../../../stores\";\n import { Pages } from \"../../../utils/enums\";\n import type { TPaymentReturn } from \"../../../utils/types\";\n import { get } from \"svelte/store\";\n import { getTxUrl } from \"./service\";\n export let options: {\n title: string;\n isSui?: boolean;\n description: string | undefined;\n subtitle: string;\n orders: TPaymentReturn[\"items\"];\n networkType?: string;\n tokenImage?: string;\n };\n const { openUI } = get(fn);\n let {\n title,\n subtitle,\n orders,\n networkType,\n tokenImage,\n isSui,\n } = options;\n\n const successfulOrders = (orders ?? []).filter((o) => o.tx);\n const failedOrders = (orders ?? []).filter((o) => !o.tx);\n\n function retryPurchase() {\n const hasAssets = failedOrders.some((order) => order.asset);\n if (hasAssets) {\n const assets = failedOrders\n .filter((order) => order.asset)\n .map((order) => ({\n packageId: order.asset!.packageId,\n type: order.asset!.type,\n assetId: order.asset!.assetId,\n amount: order.asset!.amount,\n }));\n if (!assets.length) return;\n\n openUI(Pages.PAYMENT, {\n subtitle: \"Retrying failed orders\",\n payments: {\n credenzaStoredValue: {\n disabled: false,\n },\n },\n assets,\n });\n\n return;\n }\n const tokens: {\n contractAddress: string;\n tokenId: number;\n amount: number;\n }[] = [];\n\n const memberships: {\n contractAddress: string;\n }[] = [];\n\n for (const order of failedOrders) {\n const directive = order.directive;\n if (directive.type !== \"membership\") {\n tokens.push({\n contractAddress: directive.resource_id,\n tokenId: directive.value?.token_id,\n amount: directive.value.amount,\n });\n } else {\n memberships.push({\n contractAddress: directive.resource_id,\n });\n }\n }\n \n if (!tokens.length && !memberships.length) return;\n openUI(Pages.PAYMENT, {\n subtitle: \"Retrying failed orders\",\n payments: {\n credenzaStoredValue: {\n disabled: false,\n },\n },\n tokens,\n memberships,\n });\n }\n</script>\n\n<div>\n <div\n class=\"crtw-text-black-900 crtw-text-xl md:crtw-text-2xl crtw-font-semibold crtw-pt-5 crtw-mb-3.5 crtw-text-center\"\n >\n {title}\n </div>\n <div class=\"crtw-mb-3.5 crtw-text-sm crtw-text-justify\">\n {subtitle}\n </div>\n {#if tokenImage}\n <div class=\"crtw-my-4 flex justify-center\">\n <div\n class=\"crtw-w-64 crtw-h-64 crtw-rounded-xl crtw-shadow-md crtw-bg-white flex items-center justify-center overflow-hidden\"\n >\n <img\n src={tokenImage}\n alt=\"Token\"\n class=\"max-w-full max-h-full object-contain\"\n />\n </div>\n </div>\n {/if}\n\n <div class=\"crtw-mb-3.5 crtw-text-sm crtw-text-justify\">\n {#if orders.length}\n <div class=\"crtw-mt-6\">\n <div class=\"crtw-text-lg crtw-font-semibold crtw-mb-2\">Successful</div>\n {#each successfulOrders as order}\n {#if order.tx}\n <div class=\"crtw-mb-2\">\n <a\n href={getTxUrl(\n { chainId: order.directive?.chain_id || \"\" },\n order.tx,\n order.directive.chain_type,\n networkType || \"\"\n )}\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n class=\"crtw-text-blue-600 crtw-underline\"\n >\n <div class=\"crtw-break-words\">\n {#if order.metadata?.name}\n {order.metadata.name}\n {:else}\n <span>{order.directive.type}</span>\n <span\n class=\"crtw-break-all crtw-whitespace-normal crtw-break-words\"\n >\n ({order.directive.resource_id})\n </span>\n {/if}\n </div>\n </a>\n </div>\n {/if}\n {/each}\n\n <div\n class=\"crtw-text-lg crtw-font-semibold crtw-mt-6 crtw-mb-2\"\n class:hidden={!failedOrders.length}\n >\n Failed\n </div>\n {#if failedOrders.length}\n {#each failedOrders as order}\n <div class=\"crtw-mb-3\">\n <p class=\"crtw-text-red-600 break-words\">\n {#if order.metadata?.name}\n {order.metadata.name}\n {:else if order.directive?.type}\n <span>{order.directive.type} </span>\n <span class=\"text-gray-500 break-all whitespace-normal\">\n ({order.directive.resource_id})\n </span>\n {:else if order.asset?.assetId}\n AssetId {order.asset.assetId} : {order.error}\n {:else}\n <span>{order.asset?.type}</span>\n <span\n class=\"crtw-break-all crtw-whitespace-normal crtw-break-words\"\n >\n ({order.asset?.packageId}) : {order.error}\n </span>\n {/if}\n </p>\n </div>\n {/each}\n {/if}\n <button\n class=\"crtw-bg-black hover:crtw-bg-gray-800 crtw-text-white crtw-px-4 crtw-py-2 crtw-rounded-md crtw-mt-4\"\n on:click={retryPurchase}\n >\n Try Again\n </button>\n </div>\n {:else if isSui}\n If you are not seeing your new token, please contact\n <a href=\"mailto:support@credenza3.com\" class=\"text-blue-600 underline\">\n support@credenza3.com\n </a>.\n {:else}\n Typically, your purchase will be processed within a few seconds. In the\n event of unusually high traffic, you may have to wait as much as a minute\n or so. If several minutes pass and you are not seeing your purchase,\n please contact\n <a class=\"crtw-underline\" href=\"mailto:support@credenza3.com\"\n >support@credenza3.com</a\n >.\n {/if}\n </div>\n</div>\n","<script lang=\"ts\">\n import { get } from 'svelte/store'\n import { pageOptsStore } from '@packages/stores'\n import { PaymentResult } from '@packages/ui'\n import { configStore } from '@src/stores/config'\n\n let config = get(configStore)\n</script>\n\n<PaymentResult\n options={{\n title: config.content?.paymentResult?.title || 'Success!',\n subtitle: $pageOptsStore?.subtitle || config.content?.paymentResult?.subtitle || 'Your payment was successful!',\n description: config.content?.paymentResult?.description,\n orders: $pageOptsStore?.orders || [],\n networkType: config.networkType,\n tokenImage: $pageOptsStore?.tokenImage || '',\n isSui: true\n }}\n/>\n "],"names":["getTxUrl","item","tx","chainType","networkType","options","openUI","get","fn","title","subtitle","orders","isSui","successfulOrders","o","failedOrders","retryPurchase","order","assets","Pages","tokens","memberships","directive","_a","tokenImage","$$render","consequent","$.each","node_2","$.template_effect","$.set_text","text_2","$.get","$.untrack","text_3","consequent_1","alternate","consequent_2","node_6","text_5","text_6","text_9","consequent_5","alternate_1","consequent_4","alternate_2","consequent_3","alternate_3","consequent_6","$0","classes","$.set_class","div_9","consequent_7","alternate_5","config","$pageOptsStore"],"mappings":"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"}
@@ -1,34 +1,34 @@
1
- import { c as dA, p as eA, h as ZA, f as H, i as j, b as w, d as NA, u as lA, s as k, r as RA, n as cA, o } from "./legacy-UOievsK_.js";
2
- import { z as kA, v as f, I as z, m as B, A as c, w as SA, x as aA, E as N, B as S, J as A, K as JA, G as T, C as J, y as UA, u as QA, D as L, M as I, _ as x, bI as X, b4 as i, bc as pA, S as AA, T as K, b0 as VA, $ as mA, b1 as MA } from "./index-kGcNqRGJ.js";
3
- import { C as rA } from "./ContentHeader-Bzt4m2P2.js";
4
- import { B as bA } from "./ButtonLink-CYeDF-q5.js";
5
- import { B as XA } from "./Button-BwbAl06j.js";
1
+ import { c as dA, p as eA, h as ZA, f as H, i as j, b as w, d as NA, u as lA, s as k, r as RA, n as cA, o } from "./legacy-y05PUOoK.js";
2
+ import { z as kA, v as f, I as z, m as B, A as c, w as SA, x as aA, E as l, B as S, J as A, K as JA, G as T, C as J, y as UA, u as QA, D as L, M as I, _ as x, bI as X, b4 as i, bc as pA, S as AA, T as K, b0 as VA, $ as mA, b1 as MA } from "./index-Bgz3eZ-8.js";
3
+ import { C as rA } from "./ContentHeader-C9pYpyAo.js";
4
+ import { B as bA } from "./ButtonLink-BEL4sN7p.js";
5
+ import { B as XA } from "./Button-ReMR1yO6.js";
6
6
  import { A as zA } from "./account-BPB9Ucub.js";
7
- import { U as DA } from "./UserInfo-COvt0nYz.js";
7
+ import { U as DA } from "./UserInfo-BFsSZlJZ.js";
8
8
  const s = "";
9
9
  var FA = H('<a target="_blank" title="View on Passport" class="crtw-flex crtw-items-center crtw-justify-start crtw-w-full crtw-border crtw-border-gray-300 crtw-p-2.5 crtw-no-underline crtw-text-gray-600" rel="noreferrer"><img class="crtw-h-7 crtw-mr-14" alt=""/> <div class="crtw-flex crtw-w-full crtw-justify-between"><span>View on Passport</span> <img alt=""/></div></a>'), EA = H('<a target="_blank" title="View in the block explorer" class="crtw-flex crtw-items-center crtw-justify-start crtw-w-full crtw-border crtw-border-gray-300 crtw-p-2.5 crtw-no-underline crtw-text-gray-600" rel="noreferrer"><img class="crtw-h-7 crtw-mr-14" alt=""/> <div class="crtw-flex crtw-w-full crtw-justify-between"><span> </span> <img alt=""/></div></a>'), wA = H('<a target="_blank" title="View assets" class="crtw-flex crtw-items-center crtw-justify-start crtw-w-full crtw-border crtw-border-gray-300 crtw-p-2.5 crtw-no-underline crtw-text-gray-600" rel="noreferrer"><img class="crtw-h-7 crtw-mr-14" alt=""/> <div class="crtw-flex crtw-w-full crtw-justify-between"><span>View assets on OpenSea</span> <img alt=""/></div></a>'), BA = H('<a target="_blank" title="GitBook docs" class="crtw-flex crtw-items-center crtw-justify-start crtw-w-full crtw-border crtw-border-gray-300 crtw-p-2.5 crtw-no-underline crtw-text-gray-600" rel="noreferrer"><img class="crtw-h-7 crtw-mr-14" alt=""/> <div class="crtw-flex crtw-w-full crtw-justify-between"><span>GitBook docs</span> <img alt=""/></div></a>'), HA = H('<!> <div class="crtw-flex crtw-flex-col crtw-w-full crtw-mt-9 crtw-gap-9"><!> <div class="crtw-flex crtw-flex-col crtw-w-full crtw-items-center crtw-gap-2.5"><!> <!> <!> <!></div> <div class="crtw-flex crtw-flex-col crtw-justify-center crtw-items-center crtw-gap-4"><!> <!></div></div>', 1);
10
10
  function WA(n, a) {
11
11
  if (new.target) return dA({ component: WA, ...n });
12
12
  kA(a, !1);
13
13
  const V = B(), u = B(), G = B();
14
- let l = eA(a, "options", 12), {
14
+ let N = eA(a, "options", 12), {
15
15
  gitbookToken: D,
16
16
  onSignOut: C,
17
17
  onUpdateProfile: v,
18
18
  gitbookUrl: b,
19
19
  userAddress: g,
20
20
  storedValueAlias: y
21
- } = l();
22
- f(() => c(l()), () => {
23
- z(V, l().links);
24
- }), f(() => c(l()), () => {
25
- z(u, l().balance);
26
- }), f(() => c(l()), () => {
27
- z(G, l().userData);
21
+ } = N();
22
+ f(() => c(N()), () => {
23
+ z(V, N().links);
24
+ }), f(() => c(N()), () => {
25
+ z(u, N().balance);
26
+ }), f(() => c(N()), () => {
27
+ z(G, N().userData);
28
28
  }), SA(), ZA();
29
29
  var h = HA(), t = aA(h);
30
30
  rA(t, { text: "Account Details" });
31
- var p = N(t, 2), m = S(p);
31
+ var p = l(t, 2), m = S(p);
32
32
  {
33
33
  let d = JA(() => ({
34
34
  userAddress: g,
@@ -42,10 +42,10 @@ function WA(n, a) {
42
42
  }
43
43
  });
44
44
  }
45
- var Q = N(m, 2), P = S(Q);
45
+ var Q = l(m, 2), P = S(Q);
46
46
  {
47
47
  var M = (d) => {
48
- var Z = FA(), U = S(Z), W = N(U, 2), R = N(S(W), 2);
48
+ var Z = FA(), U = S(Z), W = l(U, 2), R = l(S(W), 2);
49
49
  J(W), J(Z), L(() => {
50
50
  k(Z, "href", (A(V), T(() => A(V).passportLink))), k(U, "src", zA), k(R, "src", s);
51
51
  }), w(d, Z);
@@ -54,12 +54,12 @@ function WA(n, a) {
54
54
  A(V), T(() => A(V)?.passportLink) && d(M);
55
55
  });
56
56
  }
57
- var r = N(P, 2);
57
+ var r = l(P, 2);
58
58
  {
59
59
  var O = (d) => {
60
- var Z = EA(), U = S(Z), W = N(U, 2), R = S(W), TA = S(R);
60
+ var Z = EA(), U = S(Z), W = l(U, 2), R = S(W), TA = S(R);
61
61
  J(R);
62
- var nA = N(R, 2);
62
+ var nA = l(R, 2);
63
63
  J(W), J(Z), L(() => {
64
64
  k(Z, "href", (A(V), T(() => A(V).scanLink))), k(U, "src", (A(V), T(() => A(V).scanIcon))), RA(TA, `View in ${A(V), T(() => A(V).scanName || "Etherscan") ?? ""}`), k(nA, "src", s);
65
65
  }), w(d, Z);
@@ -68,10 +68,10 @@ function WA(n, a) {
68
68
  A(V), T(() => A(V)?.scanLink && A(V)?.scanIcon) && d(O);
69
69
  });
70
70
  }
71
- var Y = N(r, 2);
71
+ var Y = l(r, 2);
72
72
  {
73
73
  var F = (d) => {
74
- var Z = wA(), U = S(Z), W = N(U, 2), R = N(S(W), 2);
74
+ var Z = wA(), U = S(Z), W = l(U, 2), R = l(S(W), 2);
75
75
  J(W), J(Z), L(() => {
76
76
  k(Z, "href", (A(V), T(() => A(V).nftsLink))), k(U, "src", (A(V), T(() => A(V).nftsIcon))), k(R, "src", s);
77
77
  }), w(d, Z);
@@ -80,10 +80,10 @@ function WA(n, a) {
80
80
  A(V), T(() => A(V)?.nftsLink && A(V)?.nftsIcon) && d(F);
81
81
  });
82
82
  }
83
- var e = N(Y, 2);
83
+ var e = l(Y, 2);
84
84
  {
85
85
  var E = (d) => {
86
- var Z = BA(), U = S(Z), W = N(U, 2), R = N(S(W), 2);
86
+ var Z = BA(), U = S(Z), W = l(U, 2), R = l(S(W), 2);
87
87
  J(W), J(Z), L(() => {
88
88
  k(Z, "href", `${b}?jwt_token=${D}`), k(U, "src", vA), k(R, "src", s);
89
89
  }), w(d, Z);
@@ -93,14 +93,14 @@ function WA(n, a) {
93
93
  });
94
94
  }
95
95
  J(Q);
96
- var _ = N(Q, 2), $ = S(_);
96
+ var _ = l(Q, 2), $ = S(_);
97
97
  bA($, {
98
98
  text: "Update your account details",
99
99
  get onClick() {
100
100
  return v;
101
101
  }
102
102
  });
103
- var tA = N($, 2);
103
+ var tA = l($, 2);
104
104
  return XA(tA, {
105
105
  text: "Sign Out",
106
106
  get onClick() {
@@ -108,10 +108,10 @@ function WA(n, a) {
108
108
  }
109
109
  }), J(_), J(p), w(n, h), UA({
110
110
  get options() {
111
- return l();
111
+ return N();
112
112
  },
113
113
  set options(d) {
114
- l(d), QA();
114
+ N(d), QA();
115
115
  },
116
116
  $set: lA,
117
117
  $on: (d, Z) => NA(a, d, Z)
@@ -144,7 +144,7 @@ const q = "
144
144
  function GA(n, a) {
145
145
  if (new.target) return dA({ component: GA, ...n });
146
146
  kA(a, !1);
147
- const [V, u] = cA(), G = () => o(x, "$configStore", V), l = () => o(mA, "$clientPublicStore", V), D = () => o(MA, "$userStore", V);
147
+ const [V, u] = cA(), G = () => o(x, "$configStore", V), N = () => o(mA, "$clientPublicStore", V), D = () => o(MA, "$userStore", V);
148
148
  var C = this && this.__awaiter || function(t, p, m, Q) {
149
149
  function P(M) {
150
150
  return M instanceof m ? M : new m(function(r) {
@@ -177,7 +177,7 @@ function GA(n, a) {
177
177
  const t = yield i();
178
178
  if (z(v, uA(t)), G().buyTokens !== !1)
179
179
  try {
180
- z(b, `${yield pA()} cred`);
180
+ z(b, `${yield pA()} ${(N() === null || N() === void 0 ? void 0 : N().ui_settings.cred_alias) || "cred"}`);
181
181
  } catch {
182
182
  z(b, "-");
183
183
  }
@@ -187,14 +187,14 @@ function GA(n, a) {
187
187
  y();
188
188
  }), SA(), ZA();
189
189
  {
190
- let t = JA(() => (A(v), c(I), c(x), c(AA), c(K), c(VA), A(b), l(), D(), c(i), T(() => ({
190
+ let t = JA(() => (A(v), c(I), c(x), c(AA), c(K), c(VA), A(b), N(), D(), c(i), T(() => ({
191
191
  links: A(v),
192
192
  gitbookToken: g,
193
193
  gitbookUrl: I(x).credenza.gitbookUrl,
194
194
  onSignOut: () => AA.set(K.LOGOUT),
195
195
  onUpdateProfile: () => VA.set(K.UPDATE_PROFILE),
196
196
  balance: A(b),
197
- storedValueAlias: l().ui_settings.stored_value_alias,
197
+ storedValueAlias: N().ui_settings.stored_value_alias,
198
198
  userData: D(),
199
199
  userAddress: i()
200
200
  }))));
@@ -213,4 +213,4 @@ function GA(n, a) {
213
213
  export {
214
214
  GA as default
215
215
  };
216
- //# sourceMappingURL=Profile-DfBS1mAR.js.map
216
+ //# sourceMappingURL=Profile-B4CQgkI9.js.map