@monerium/sdk-react-provider 1.3.1 → 1.3.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.d.ts +57 -5
- package/dist/index.js +2 -2
- package/dist/index.mjs +2 -2
- package/package.json +2 -2
package/dist/index.d.ts
CHANGED
|
@@ -2,8 +2,8 @@ import * as react_jsx_runtime from 'react/jsx-runtime';
|
|
|
2
2
|
import * as react from 'react';
|
|
3
3
|
import { ReactNode } from 'react';
|
|
4
4
|
import * as _tanstack_react_query from '@tanstack/react-query';
|
|
5
|
-
import {
|
|
6
|
-
import MoneriumClient, { AuthFlowOptions, AuthFlowSIWEOptions, Chain, CurrencyCode,
|
|
5
|
+
import { UseMutationOptions, UseMutationResult, UseQueryOptions, UseQueryResult } from '@tanstack/react-query';
|
|
6
|
+
import MoneriumClient, { AuthFlowOptions, AuthFlowSIWEOptions, Chain, CurrencyCode, Address, ChainId, AddressesResponse, AuthContext, Currency, Balances, IBAN, IBANsResponse, LinkedAddress, LinkAddress, ResponseStatus, MoveIbanPayload, Order, OrdersResponse, OrderState, NewOrder, Profile, ProfilesResponse, RequestIbanPayload, SignaturesQueryParams, SignaturesResponse, SubmitProfileDetailsPayload, Token } from '@monerium/sdk';
|
|
7
7
|
export { Address, Balances, IBAN, LinkAddress, MoveIbanPayload, NewOrder, Order, Profile, ResponseStatus, SubmitProfileDetailsPayload, Token } from '@monerium/sdk';
|
|
8
8
|
|
|
9
9
|
/**
|
|
@@ -246,6 +246,7 @@ declare const keys: {
|
|
|
246
246
|
requestIban: string[];
|
|
247
247
|
placeOrder: string[];
|
|
248
248
|
linkAddress: string[];
|
|
249
|
+
getSignatures: (filter?: unknown) => {}[];
|
|
249
250
|
};
|
|
250
251
|
/**
|
|
251
252
|
* # Redirect to the Monerium auth flow.
|
|
@@ -631,6 +632,10 @@ declare function useMoveIban({ mutation, }?: {
|
|
|
631
632
|
* When the order has been placed, the orders query will be invalidated and re-fetched.
|
|
632
633
|
*
|
|
633
634
|
* If the order amount is above 15000, a supporting document is required.
|
|
635
|
+
*
|
|
636
|
+
* **Note:** For multi-signature orders, the API returns a 202 Accepted response
|
|
637
|
+
* with `{status: 202, statusText: "Accepted"}` instead of the full Order object.
|
|
638
|
+
*
|
|
634
639
|
* @group Hooks
|
|
635
640
|
* @category Orders
|
|
636
641
|
* @param param
|
|
@@ -652,8 +657,55 @@ declare function useMoveIban({ mutation, }?: {
|
|
|
652
657
|
declare function usePlaceOrder({ supportingDocument, mutation, }?: {
|
|
653
658
|
supportingDocument?: File;
|
|
654
659
|
/** {@inheritDoc MutationOptions} */
|
|
655
|
-
mutation?: MutationOptions<Order, Error, NewOrder>;
|
|
656
|
-
}): MutationResult<'placeOrder', Order, Error, NewOrder>;
|
|
660
|
+
mutation?: MutationOptions<Order | ResponseStatus, Error, NewOrder>;
|
|
661
|
+
}): MutationResult<'placeOrder', Order | ResponseStatus, Error, NewOrder>;
|
|
662
|
+
/**
|
|
663
|
+
* Get pending signatures for the authenticated user.
|
|
664
|
+
*
|
|
665
|
+
* Returns pending signatures that require user action, such as order signatures
|
|
666
|
+
* or link address signatures. Accepts filtering by address, chain, kind, and profile.
|
|
667
|
+
*
|
|
668
|
+
* @group Hooks
|
|
669
|
+
* @category Signatures
|
|
670
|
+
* @param {Object} params
|
|
671
|
+
* @param {SignaturesQueryParams} params.query - Optional query parameters to filter signatures
|
|
672
|
+
*
|
|
673
|
+
* @example
|
|
674
|
+
* ```ts
|
|
675
|
+
* // Get all pending signatures
|
|
676
|
+
* const {
|
|
677
|
+
* data: signatures,
|
|
678
|
+
* isLoading,
|
|
679
|
+
* isError,
|
|
680
|
+
* error,
|
|
681
|
+
* refetch,
|
|
682
|
+
* ...moreUseQueryResults
|
|
683
|
+
* } = useSignatures();
|
|
684
|
+
*
|
|
685
|
+
* // Get pending order signatures for a specific address
|
|
686
|
+
* const { data: orderSignatures } = useSignatures({
|
|
687
|
+
* query: {
|
|
688
|
+
* address: '0x1234...',
|
|
689
|
+
* kind: 'order'
|
|
690
|
+
* }
|
|
691
|
+
* });
|
|
692
|
+
*
|
|
693
|
+
* // Check the kind of signature
|
|
694
|
+
* signatures?.pending.forEach(sig => {
|
|
695
|
+
* if (sig.kind === 'order') {
|
|
696
|
+
* console.log('Order signature:', sig.id, sig.amount);
|
|
697
|
+
* } else {
|
|
698
|
+
* console.log('Link address signature');
|
|
699
|
+
* }
|
|
700
|
+
* });
|
|
701
|
+
* ```
|
|
702
|
+
* @see {@link https://monerium.dev/api-docs-v2#tag/signatures/operation/get-signatures | API Documentation}
|
|
703
|
+
*/
|
|
704
|
+
declare function useSignatures({ query, options, }?: {
|
|
705
|
+
query?: SignaturesQueryParams;
|
|
706
|
+
/** {@inheritDoc QueryOptions} */
|
|
707
|
+
options?: QueryOptions<SignaturesResponse>;
|
|
708
|
+
}): _tanstack_react_query.UseQueryResult<SignaturesResponse, Error>;
|
|
657
709
|
/**
|
|
658
710
|
* # Add address to profile.
|
|
659
711
|
*
|
|
@@ -717,4 +769,4 @@ declare const useSubscribeOrderNotification: ({ state, profile, onMessage, onErr
|
|
|
717
769
|
onError?: ((err: Event) => void) | undefined;
|
|
718
770
|
}) => () => void | undefined;
|
|
719
771
|
|
|
720
|
-
export { MoneriumContext, MoneriumProvider, type MutationOptions, type MutationResult, type QueryOptions, type QueryResult, type SdkInstance, type UseAuthReturn, keys, useAddress, useAddresses, useAuth, useAuthContext, useBalances, useIBAN, useIBANs, useLinkAddress, useMoveIban, useOrder, useOrders, usePlaceOrder, useProfile, useProfiles, useRequestIban, useSubmitProfileDetails, useSubscribeOrderNotification, useTokens };
|
|
772
|
+
export { MoneriumContext, MoneriumProvider, type MutationOptions, type MutationResult, type QueryOptions, type QueryResult, type SdkInstance, type UseAuthReturn, keys, useAddress, useAddresses, useAuth, useAuthContext, useBalances, useIBAN, useIBANs, useLinkAddress, useMoveIban, useOrder, useOrders, usePlaceOrder, useProfile, useProfiles, useRequestIban, useSignatures, useSubmitProfileDetails, useSubscribeOrderNotification, useTokens };
|
package/dist/index.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
'use strict';var react=require('react'),reactQuery=require('@tanstack/react-query'),sdk=require('@monerium/sdk'),jsxRuntime=require('react/jsx-runtime');var w=react.createContext(null);var J=({children:e,clientId:r,redirectUri:n,environment:t="sandbox",refreshToken:i,onRefreshTokenUpdate:a,debug:u=false})=>{let s=reactQuery.useQueryClient(),[o]=react.useState(()=>new sdk.MoneriumClient({environment:t,clientId:r,redirectUri:n,debug:u})),[f,p]=react.useState(false),[v,E]=react.useState(null),[k,I]=react.useState(true);react.useEffect(()=>((async()=>{if(o)try{p(await o.getAccess());}catch(h){console.error("Failed to get access:",h);}finally{I(false),o?.bearerProfile&&a?.(o.bearerProfile.refresh_token);}})(),()=>{o&&o.disconnect();}),[]),react.useEffect(()=>{i&&!f&&!k&&(async()=>{if(o)try{p(await o.getAccess(i));}catch(h){console.error("Failed to get access:",h);}finally{o?.bearerProfile&&a?.(o.bearerProfile.refresh_token);}})();},[i]);let x=react.useCallback(async m=>{try{o&&await o.authorize(m);}catch(h){console.error("Error during authorization:",h),E(h);}},[o]),C=react.useCallback(async m=>{try{o&&await o.siwe(m);}catch(h){console.error("Error during sign in with ethereum:",h),E(h);}},[o]),z=async()=>{try{o&&await o.revokeAccess();}catch(m){console.error("Error during revoking access:",m),E(m);}finally{s.clear(),p(false);}};return jsxRuntime.jsx(w.Provider,{value:{sdk:o,authorize:x,siwe:C,isAuthorized:f,isLoading:k,error:v,disconnect:async()=>o?.disconnect(),revokeAccess:async()=>z()},children:e})};var d={getAll:["monerium"],getAuthContext:["monerium","auth-context"],getProfile:e=>["monerium","profile",...e?[e]:[]],getProfiles:["monerium","profiles"],getAddress:e=>["monerium","address",[e]],getAddresses:e=>["monerium","addresses",...e?[e]:[]],getBalances:(e,r,n)=>["monerium","balances",{currencies:n?[...n]:[],chain:r,address:e}],getIban:e=>["monerium","iban",e],getIbans:e=>["monerium","ibans",...e?[e]:[]],getTokens:["monerium","tokens"],getOrder:e=>["monerium","order",e],getOrders:e=>["monerium","orders",...e?[e]:[]],submitProfileDetails:["monerium","submit-profile-details"],moveIban:["monerium","move-iban"],requestIban:["monerium","request-iban"],placeOrder:["monerium","place-order"],linkAddress:["monerium","link-address"]};function c(){let e=react.useContext(w);if(e===null)throw new Error("useSdk must be used within a MoneriumProvider");return e?.sdk}function l(){let e=react.useContext(w);if(e===null)throw new Error("useAuth must be used within a MoneriumProvider");return {isAuthorized:e.isAuthorized,authorize:e.authorize,siwe:e.siwe,isLoading:e.isLoading,error:e.error,disconnect:e.disconnect,revokeAccess:e.revokeAccess}}function Se({query:e}={}){let{isAuthorized:r}=l(),n=c();return reactQuery.useQuery({...e,queryKey:d.getAuthContext,queryFn:async()=>{if(!n)throw new Error("No SDK instance available");if(!r)throw new Error("User not authorized");return n.getAuthContext()},enabled:!!(n&&r&&(e?.enabled??true))})}function Pe({profile:e,query:r}={}){let{isAuthorized:n}=l(),t=c(),{data:i}=B(),a=e||i?.profiles?.[0]?.id;return reactQuery.useQuery({...r,queryKey:d.getProfile(a),queryFn:async()=>{if(!t)throw new Error("No SDK instance available");if(!n)throw new Error("User not authorized");if(!a)throw new Error("Profile Id is required");return t.getProfile(a)},enabled:!!(t&&n&&a&&(r?.enabled??true))})}function B({query:e}={}){let{isAuthorized:r}=l(),n=c();return reactQuery.useQuery({...e,queryKey:d.getProfiles,queryFn:async()=>{if(!n)throw new Error("No SDK instance available");if(!r)throw new Error("User not authorized");return n.getProfiles()},enabled:!!(n&&r&&(e?.enabled??true))})}function qe({query:e}={}){let r=c(),{isAuthorized:n}=l();return reactQuery.useQuery({...e,queryKey:d.getTokens,queryFn:async()=>{if(!r)throw new Error("No SDK instance available");if(!n)throw new Error("User not authorized");return r.getTokens()},enabled:!!(r&&n&&(e?.enabled??true))})}function ve({address:e,query:r={}}){let n=c(),{isAuthorized:t}=l();return reactQuery.useQuery({...r,queryKey:d.getAddress(e),queryFn:async()=>{if(!n)throw new Error("No SDK instance available");if(!t)throw new Error("User not authorized");if(!e)throw new Error("Address is required");return n.getAddress(e)},enabled:!!(n&&t&&e&&(r?.enabled??true))})}function Ie({profile:e,chain:r,query:n={}}={}){let t=c(),{isAuthorized:i}=l();return reactQuery.useQuery({...n,queryKey:d.getAddresses({profile:e,chain:r?sdk.parseChain(r):undefined}),queryFn:async()=>{if(!t)throw new Error("No SDK instance available");if(!i)throw new Error("User not authorized");return t.getAddresses({profile:e,chain:r})},enabled:!!(t&&i&&(n?.enabled??true))})}function xe({address:e,chain:r,currencies:n,query:t}){let i=c(),{isAuthorized:a}=l();return reactQuery.useQuery({...t,queryKey:d.getBalances(e,sdk.parseChain(r),n),staleTime:1e3*60*5,queryFn:async()=>{if(!i)throw new Error("No SDK instance available");if(!a)throw new Error("User not authorized");return i.getBalances(e,r,n)},enabled:!!(i&&a&&(t?.enabled??true))})}function Ce({iban:e,query:r}){let n=c(),{isAuthorized:t}=l();return reactQuery.useQuery({...r,queryKey:d.getIban(e),queryFn:async()=>{if(!n)throw new Error("No SDK instance available");if(!t)throw new Error("User not authorized");return n.getIban(e)},enabled:!!(n&&t&&e&&(r?.enabled??true))})}function ze({profile:e,chain:r,query:n={}}={}){let t=c(),{isAuthorized:i}=l();return reactQuery.useQuery({...n,queryKey:d.getIbans({profile:e,chain:r}),queryFn:async()=>{if(!t)throw new Error("No SDK instance available");if(!i)throw new Error("User not authorized");return t.getIbans({profile:e,chain:r})},enabled:!!(t&&i&&(n?.enabled??true))})}function Ke({orderId:e,query:r={}}){let n=c(),{isAuthorized:t}=l();return reactQuery.useQuery({...r,queryKey:d.getOrder(e),queryFn:async()=>{if(!n)throw new Error("No SDK instance available");if(!t)throw new Error("User not authorized");if(!e)throw new Error("Order id is required");return n.getOrder(e)},enabled:!!(n&&t&&e&&(r.enabled??true))})}function Ne({query:e={},...r}={}){let n=c(),{isAuthorized:t}=l();return reactQuery.useQuery({...e,queryKey:d.getOrders(r),queryFn:async()=>{if(!n)throw new Error("No SDK instance available");if(!t)throw new Error("User not authorized");return n.getOrders(r)},enabled:!!(n&&t&&(e.enabled??true))})}function Re({profile:e,mutation:r={}}){let n=c(),{isAuthorized:t}=l(),i=reactQuery.useQueryClient(),{mutateAsync:a,...u}=reactQuery.useMutation({...r,mutationKey:d.submitProfileDetails,mutationFn:async s=>{if(!n)throw new Error("No SDK instance available");if(!t)throw new Error("User not authorized");return n.submitProfileDetails(e,s)},onSuccess(s,o,f){i.invalidateQueries({queryKey:d.getProfile(e)}),r?.onSuccess?.(s,o,f);},onError(s,o,f){throw r?.onError?.(s,o,f),s}});return {submitProfileDetails:a,...u}}function Me({mutation:e={}}={}){let r=c(),{isAuthorized:n}=l(),{mutateAsync:t,...i}=reactQuery.useMutation({...e,mutationKey:d.requestIban,mutationFn:async({address:a,chain:u,emailNotifications:s})=>{if(!r)throw new Error("No SDK instance available");if(!n)throw new Error("User not authorized");return r.requestIban({address:a,chain:u,emailNotifications:s})},onSuccess(a,u,s){e?.onSuccess?.(a,u,s);},onError(a,u,s){throw e?.onError?.(a,u,s),a}});return {requestIban:t,...i}}function De({mutation:e={}}={}){let r=c(),{isAuthorized:n}=l(),t=reactQuery.useQueryClient(),{mutateAsync:i,...a}=reactQuery.useMutation({...e,mutationKey:d.moveIban,mutationFn:async({iban:u,address:s,chain:o})=>{if(!r)throw new Error("No SDK instance available");if(!n)throw new Error("User not authorized");return r.moveIban(u,{address:s,chain:o})},onSuccess(u,s,o){t.invalidateQueries({queryKey:d.getIban(s.iban)}),t.invalidateQueries({queryKey:d.getIbans()}),t.invalidateQueries({queryKey:d.getAddress(s.address)}),e?.onSuccess?.(u,s,o);},onError(u,s,o){throw e?.onError?.(u,s,o),u}});return {moveIban:i,...a}}function Be({supportingDocument:e,mutation:r}={}){let n=c(),{isAuthorized:t}=l(),i=reactQuery.useQueryClient(),{mutateAsync:a,...u}=reactQuery.useMutation({...r,mutationKey:d.placeOrder,mutationFn:async s=>{if(!n)throw new Error("No SDK instance available");if(!t)throw new Error("User not authorized");let o;if(parseInt(s.amount)>15e3){if(!e)throw new Error("Supporting document is required for orders above 15000");o=(await n.uploadSupportingDocument(e)).id;}let f={...s,documentId:o};return n.placeOrder(f)},onSuccess(s,o,f){i.invalidateQueries({queryKey:d.getOrders()}),i.invalidateQueries({queryKey:d.getBalances(s.address,s.chain)}),r?.onSuccess?.(s,o,f);},onError(s,o,f){throw r?.onError?.(s,o,f),s}});return {placeOrder:a,...u}}function Fe({mutation:e}={}){let r=c(),{isAuthorized:n}=l(),t=reactQuery.useQueryClient(),{mutateAsync:i,...a}=reactQuery.useMutation({...e,mutationKey:d.linkAddress,mutationFn:async u=>{if(!r)throw new Error("No SDK instance available");if(!n)throw new Error("User not authorized");return r.linkAddress(u)},onSuccess(u,s,o){t.invalidateQueries({queryKey:d.getAddresses()}),s.profile&&t.invalidateQueries({queryKey:d.getProfile(s.profile)}),e?.onSuccess?.(u,s,o);},onError(u,s,o){throw e?.onError?.(u,s,o),u}});return {linkAddress:i,...a}}var Qe=({state:e,profile:r,onMessage:n,onError:t})=>{let i=c();return react.useEffect(()=>(i&&i.subscribeOrderNotifications({filter:{state:e,profile:r},onMessage:n,onError:t}),()=>{i&&i?.unsubscribeOrderNotifications({state:e,profile:r});}),[i,r,e]),()=>i?.unsubscribeOrderNotifications({state:e,profile:r})};exports.MoneriumContext=w;exports.MoneriumProvider=J;exports.keys=d;exports.useAddress=ve;exports.useAddresses=Ie;exports.useAuth=l;exports.useAuthContext=Se;exports.useBalances=xe;exports.useIBAN=Ce;exports.useIBANs=ze;exports.useLinkAddress=Fe;exports.useMoveIban=De;exports.useOrder=Ke;exports.useOrders=Ne;exports.usePlaceOrder=Be;exports.useProfile=Pe;exports.useProfiles=B;exports.useRequestIban=Me;exports.useSubmitProfileDetails=Re;exports.useSubscribeOrderNotification=Qe;exports.useTokens=qe;//# sourceMappingURL=index.js.map
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/lib/context.tsx","../src/lib/provider.tsx","../src/lib/hooks.tsx"],"names":["MoneriumContext","createContext","MoneriumProvider","children","clientId","redirectUri","environment","refreshToken","onRefreshTokenUpdate","debug","queryClient","useQueryClient","sdk","useState","MoneriumClient","isAuthorized","setIsAuthorized","error","setError","loadingAuth","setLoadingAuth","useEffect","authorize","useCallback","params","err","siwe","revokeAccess","jsx","keys","profile","address","filter","chain","currencies","iban","orderId","useSdk","context","useContext","useAuth","useAuthContext","query","useQuery","useProfile","data","useProfiles","profileToUse","useTokens","useAddress","useAddresses","parseChain","useBalances","useIBAN","useIBANs","useOrder","useOrders","filters","useSubmitProfileDetails","mutation","mutateAsync","rest","useMutation","body","variables","vars","useRequestIban","emailNotifications","useMoveIban","usePlaceOrder","supportingDocument","documentId","newBody","useLinkAddress","useSubscribeOrderNotification","state","onMessage","onError"],"mappings":"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","file":"index.js","sourcesContent":["import { createContext } from 'react';\n\nimport { SdkInstance, UseAuthReturn } from './types';\n\nexport const MoneriumContext = createContext<\n  (UseAuthReturn & SdkInstance) | null\n>(null);\n","import { ReactNode, useCallback, useEffect, useState } from 'react';\nimport { useQueryClient } from '@tanstack/react-query';\n\nimport {\n  AuthFlowOptions,\n  AuthFlowSIWEOptions,\n  MoneriumClient,\n} from '@monerium/sdk';\n\nimport { MoneriumContext } from './context';\n\n/**\n * Wrap your application with the Monerium provider.\n * @group Provider\n * @param params\n * @param params.children - Rest of the application.\n * @param params.clientId - Monerium auth flow client id.\n * @param params.redirectUri - Monerium auth flow redirect url.\n * @param params.environment - Monerium environment.\n * @param params.onRefreshTokenUpdate - Callback that is called when the refresh token is updated. Store it securely.\n * @param params.refreshToken - Provide the securely stored refresh token to reconnect.\n * @param params.debug - Enable debug mode.\n * @returns\n */\nexport const MoneriumProvider = ({\n  children,\n  clientId,\n  redirectUri,\n  environment = 'sandbox',\n  refreshToken,\n  onRefreshTokenUpdate,\n  debug = false,\n}: {\n  children: ReactNode;\n  clientId: string;\n  redirectUri: string;\n  /** @deprecated use redirectUri */\n  redirectUrl?: string;\n  environment?: 'sandbox' | 'production';\n  refreshToken?: string;\n  onRefreshTokenUpdate?: (token: string) => void;\n  debug?: boolean;\n}) => {\n  const queryClient = useQueryClient();\n\n  const [sdk] = useState(() => {\n    // Initialize the SDK\n    return new MoneriumClient({\n      environment,\n      clientId,\n      redirectUri,\n      debug: debug,\n    });\n  });\n\n  const [isAuthorized, setIsAuthorized] = useState<boolean>(false);\n  const [error, setError] = useState<Error | unknown | null>(null);\n  const [loadingAuth, setLoadingAuth] = useState(true);\n\n  useEffect(() => {\n    const connect = async () => {\n      if (sdk) {\n        try {\n          setIsAuthorized(await sdk.getAccess());\n        } catch (error) {\n          console.error('Failed to get access:', error);\n        } finally {\n          setLoadingAuth(false);\n          if (sdk?.bearerProfile) {\n            onRefreshTokenUpdate?.(sdk.bearerProfile.refresh_token);\n          }\n        }\n      }\n    };\n\n    connect();\n\n    return () => {\n      if (sdk) {\n        sdk.disconnect();\n      }\n    };\n  }, []);\n\n  useEffect(() => {\n    const reconnect = async () => {\n      if (sdk) {\n        try {\n          setIsAuthorized(await sdk.getAccess(refreshToken));\n        } catch (error) {\n          console.error('Failed to get access:', error);\n        } finally {\n          if (sdk?.bearerProfile) {\n            onRefreshTokenUpdate?.(sdk.bearerProfile.refresh_token);\n          }\n        }\n      }\n    };\n    if (refreshToken && !isAuthorized && !loadingAuth) {\n      reconnect();\n    }\n  }, [refreshToken]);\n\n  const authorize = useCallback(\n    async (params?: AuthFlowOptions) => {\n      try {\n        if (sdk) {\n          await sdk.authorize(params);\n        }\n      } catch (err) {\n        console.error('Error during authorization:', err);\n        setError(err);\n      }\n    },\n    [sdk]\n  );\n\n  const siwe = useCallback(\n    async (params: AuthFlowSIWEOptions) => {\n      try {\n        if (sdk) {\n          await sdk.siwe(params);\n        }\n      } catch (err) {\n        console.error('Error during sign in with ethereum:', err);\n        setError(err);\n      }\n    },\n    [sdk]\n  );\n\n  const revokeAccess = async () => {\n    try {\n      if (sdk) {\n        await sdk.revokeAccess();\n      }\n    } catch (err) {\n      console.error('Error during revoking access:', err);\n      setError(err);\n    } finally {\n      queryClient.clear();\n      setIsAuthorized(false);\n    }\n  };\n\n  return (\n    <MoneriumContext.Provider\n      value={{\n        sdk,\n        authorize,\n        siwe,\n        isAuthorized,\n        isLoading: loadingAuth,\n        error,\n        disconnect: async () => sdk?.disconnect(),\n        revokeAccess: async () => revokeAccess(),\n      }}\n    >\n      {children}\n    </MoneriumContext.Provider>\n  );\n};\n","import { useContext, useEffect } from 'react';\nimport { useMutation, useQuery, useQueryClient } from '@tanstack/react-query';\n\nimport MoneriumClient, {\n  Address,\n  AddressesResponse,\n  AuthContext,\n  Balances,\n  Chain,\n  ChainId,\n  Currency,\n  CurrencyCode,\n  IBAN,\n  IBANsResponse,\n  LinkAddress,\n  LinkedAddress,\n  MoveIbanPayload,\n  NewOrder,\n  Order,\n  OrdersResponse,\n  OrderState,\n  parseChain,\n  Profile,\n  ProfilesResponse,\n  RequestIbanPayload,\n  ResponseStatus,\n  SubmitProfileDetailsPayload,\n  Token,\n} from '@monerium/sdk';\n\nimport { MoneriumContext } from './context';\nimport {\n  MutationOptions,\n  MutationResult,\n  QueryOptions,\n  UseAuthReturn,\n} from './types';\n\n/**\n * @internal\n * Query keys for React query\n * */\nexport const keys = {\n  getAll: ['monerium'],\n  getAuthContext: ['monerium', 'auth-context'],\n  getProfile: (profile: string) => [\n    'monerium',\n    'profile',\n    ...(profile ? [profile] : []),\n  ],\n  getProfiles: ['monerium', 'profiles'],\n  getAddress: (address: string) => ['monerium', 'address', [address]],\n  getAddresses: (filter?: unknown) => [\n    'monerium',\n    'addresses',\n    ...(filter ? [filter] : []),\n  ],\n  getBalances: (\n    address: string,\n    chain: Chain,\n    currencies?: CurrencyCode | CurrencyCode[]\n  ) => [\n    'monerium',\n    'balances',\n    {\n      currencies: currencies ? [...currencies] : [],\n      chain,\n      address,\n    },\n  ],\n  getIban: (iban: string) => ['monerium', 'iban', iban],\n  getIbans: (filter?: unknown) => [\n    'monerium',\n    'ibans',\n    ...(filter ? [filter] : []),\n  ],\n  getTokens: ['monerium', 'tokens'],\n  getOrder: (orderId: string) => ['monerium', 'order', orderId],\n  getOrders: (filter?: unknown) => [\n    'monerium',\n    'orders',\n    ...(filter ? [filter] : []),\n  ],\n  submitProfileDetails: ['monerium', 'submit-profile-details'],\n  moveIban: ['monerium', 'move-iban'],\n  requestIban: ['monerium', 'request-iban'],\n  placeOrder: ['monerium', 'place-order'],\n  linkAddress: ['monerium', 'link-address'],\n};\n\n/** Internal hook to use SDK */\nfunction useSdk(): MoneriumClient | undefined {\n  const context = useContext(MoneriumContext);\n\n  if (context === null) {\n    throw new Error('useSdk must be used within a MoneriumProvider');\n  }\n  return context?.sdk;\n}\n\n/**\n * # Redirect to the Monerium auth flow.\n * @group Hooks\n * @category Authentication\n * @example\n * ```ts\n * const { authorize, isAuthorized, isLoading, error } = useAuth();\n *\n * authorize(); // Redirects to the Monerium auth flow.\n *\n * // Opt-in to automated wallet linking with these parameters.\n * authorize({ address, signature, chain }).\n * ```\n *\n * @returns {UseAuthReturn}\n * - `authorize`  - Redirects to the Monerium auth flow.\n * - `siwe`       - Sign in with Ethereum. https://monerium.com/siwe\n * - `isAuthorized` - Whether the user is authorized.\n * - `isLoading` - Whether the auth flow is loading.\n * - `error` - Error message if the auth flow fails.\n * - `disconnect` - Disconnect the user.\n * - `revokeAccess` - Revoke the user's access.\n */\nexport function useAuth(): UseAuthReturn {\n  const context = useContext(MoneriumContext);\n\n  if (context === null) {\n    throw new Error('useAuth must be used within a MoneriumProvider');\n  }\n\n  return {\n    isAuthorized: context.isAuthorized,\n    authorize: context.authorize,\n    siwe: context.siwe,\n    isLoading: context.isLoading,\n    error: context.error,\n    disconnect: context.disconnect,\n    revokeAccess: context.revokeAccess,\n  };\n}\n\n/**\n * @group Hooks\n * @category Authentication\n * @param {Object} params\n *\n * @example\n * ```ts\n * const {\n *    data\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useAuthContext();\n * ```\n\n * @see {@link https://monerium.dev/api-docs/v2#tag/auth/operation/auth-context | API Documentation}\n */\nexport function useAuthContext({\n  query,\n}: {\n  /** {@inheritDoc QueryOptions} */\n  query?: QueryOptions<AuthContext>;\n} = {}) {\n  const { isAuthorized } = useAuth();\n  const sdk = useSdk();\n\n  return useQuery({\n    ...query,\n    queryKey: keys.getAuthContext,\n    queryFn: async () => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n\n      return sdk.getAuthContext();\n    },\n    enabled: Boolean(sdk && isAuthorized && (query?.enabled ?? true)),\n  });\n}\n/**\n * If no `profile` id is provided, the default profile is used.\n * @group Hooks\n * @category Profiles\n * @param {Object} params\n *\n * @example\n * ```ts\n * const {\n *    data\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useProfile();\n * ```\n\n * @see {@link https://monerium.dev/api-docs#operation/profile | API Documentation}\n */\nexport function useProfile({\n  profile,\n  query,\n}: {\n  /** The id of the profile */\n  profile?: string;\n  /** {@inheritDoc QueryOptions} */\n  query?: QueryOptions<Profile>;\n} = {}) {\n  const { isAuthorized } = useAuth();\n  const sdk = useSdk();\n\n  const { data } = useProfiles();\n\n  const profileToUse = profile || (data?.profiles?.[0]?.id as string);\n\n  return useQuery({\n    ...query,\n    queryKey: keys.getProfile(profileToUse),\n    queryFn: async () => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n      if (!profileToUse) {\n        throw new Error('Profile Id is required');\n      }\n\n      return sdk.getProfile(profileToUse);\n    },\n    enabled: Boolean(\n      sdk && isAuthorized && profileToUse && (query?.enabled ?? true)\n    ),\n  });\n}\n/**\n * # Get profiles\n * @group Hooks\n * @category Profiles\n *\n * @param {Object} [params] No required parameters.\n *\n * @example\n * ```ts\n * const {\n *    data,\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useProfiles();\n * ```\n * @see {@link https://monerium.dev/api-docs#operation/profiles | API Documentation}\n */\nexport function useProfiles({\n  query,\n}: {\n  /** {@inheritDoc QueryOptions} */\n  query?: QueryOptions<ProfilesResponse>;\n} = {}) {\n  const { isAuthorized } = useAuth();\n  const sdk = useSdk();\n\n  return useQuery({\n    ...query,\n    queryKey: keys.getProfiles,\n    queryFn: async () => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n      return sdk.getProfiles();\n    },\n    enabled: Boolean(sdk && isAuthorized && (query?.enabled ?? true)),\n  });\n}\n/**\n * @group Hooks\n * @param {Object} [params] No required parameters.\n *\n * @example\n * ```ts\n * const {\n *    data,\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useTokens();\n * ```\n\n * @see {@link https://monerium.dev/api-docs#operation/tokens | API Documentation}\n */\nexport function useTokens({\n  query,\n}: {\n  /** {@inheritDoc QueryOptions} */\n  query?: QueryOptions<Token[]>;\n} = {}) {\n  const sdk = useSdk();\n  const { isAuthorized } = useAuth();\n  return useQuery({\n    ...query,\n    queryKey: keys.getTokens,\n    queryFn: async () => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n      return sdk.getTokens();\n    },\n    enabled: Boolean(sdk && isAuthorized && (query?.enabled ?? true)),\n  });\n}\n\n/**\n * @group Hooks\n * @category Addresses\n * @param {Object} params \n\n * @example\n * ```ts\n * const {\n *    data,\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useAddress();\n * ```\n * @see {@link https://monerium.dev/api-docs-v2#tag/addresses/operation/address | API Documentation}\n */\nexport function useAddress({\n  address,\n  query = {},\n}: {\n  /** Fetch a specific address. */\n  address: string;\n  /** {@inheritDoc QueryOptions} */\n  query?: QueryOptions<Address>;\n}) {\n  const sdk = useSdk();\n  const { isAuthorized } = useAuth();\n\n  return useQuery({\n    ...query,\n    queryKey: keys.getAddress(address),\n    queryFn: async () => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n\n      if (!address) {\n        throw new Error('Address is required');\n      }\n\n      return sdk.getAddress(address);\n    },\n    enabled: Boolean(\n      sdk && isAuthorized && address && (query?.enabled ?? true)\n    ),\n  });\n}\n/**\n * @group Hooks\n * @category Addresses\n * @param {Object} [params] No required parameters.\n * @param {Object} [params.profile] Filter based on profile id.\n * @param {Object} [params.chain] Filter based on chain - CURRENTLY RETURNS AN ERROR.\n * @example\n * ```ts\n * const {\n *    data,\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useAddresses();\n * ```\n * @see {@link https://monerium.dev/api-docs-v2#tag/addresses/operation/addresses | API Documentation}\n */\nexport function useAddresses({\n  profile,\n  chain,\n  query = {},\n}: {\n  profile?: string;\n  chain?: Chain | ChainId;\n  /** {@inheritDoc QueryOptions} */\n  query?: QueryOptions<AddressesResponse>;\n} = {}) {\n  const sdk = useSdk();\n\n  const { isAuthorized } = useAuth();\n\n  return useQuery({\n    ...query,\n    queryKey: keys.getAddresses({\n      profile,\n      chain: chain ? parseChain(chain) : undefined,\n    }),\n    queryFn: async () => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n      return sdk.getAddresses({ profile, chain });\n    },\n    enabled: Boolean(sdk && isAuthorized && (query?.enabled ?? true)),\n  });\n}\n/**\n * # Get balance for a an address on a give chain\n * @group Hooks\n * @category Addresses\n * @param {Object} params\n * @param {QueryOptions<Balances>} params.address The address to fetch the balance for.\n * @param {QueryOptions<Balances>} params.chain The chain to fetch the balance for.\n * @param {QueryOptions<Balances>} [params.currencies] One or many: `eur`, `usd`, `gbp`, `isk`\n * @example\n * ```ts\n * const {\n *    data,\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useBalances();\n * ```\n * @see {@link https://monerium.dev/api-docs/v2#tag/addresses/operation/balances | API Documentation}\n *\n */\nexport function useBalances({\n  address,\n  chain,\n  currencies,\n  query,\n}: {\n  address: string;\n  chain: Chain | ChainId;\n  currencies?: Currency | Currency[];\n  /** {@inheritDoc QueryOptions} */\n  query?: QueryOptions<Balances>;\n}) {\n  const sdk = useSdk();\n  const { isAuthorized } = useAuth();\n\n  return useQuery({\n    ...query,\n    queryKey: keys.getBalances(address, parseChain(chain), currencies),\n    staleTime: 1000 * 60 * 5,\n    queryFn: async () => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n      return sdk.getBalances(address, chain, currencies);\n    },\n    enabled: Boolean(sdk && isAuthorized && (query?.enabled ?? true)),\n  });\n}\n\n/**\n * @group Hooks\n * @category IBANs\n * @param {Object} params\n * @example\n * ```ts\n * const {\n *    data,\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useIBAN();\n * ```\n * @see {@link https://monerium.dev/api-docs-v2#tag/ibans/operation/iban | API Documentation}\n */\nexport function useIBAN({\n  iban,\n  query,\n}: {\n  /** Fetch a specific IBAN */\n  iban: string;\n  /** {@inheritDoc QueryOptions} */\n  query?: QueryOptions<IBAN>;\n}) {\n  const sdk = useSdk();\n  const { isAuthorized } = useAuth();\n\n  return useQuery({\n    ...query,\n    queryKey: keys.getIban(iban),\n    queryFn: async () => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n\n      return sdk.getIban(iban);\n    },\n    enabled: Boolean(sdk && isAuthorized && iban && (query?.enabled ?? true)),\n  });\n}\n/**\n * @group Hooks\n * @category IBANs\n * @param {Object} [params] No required parameters.\n * @example\n * ```ts\n * const {\n *    data,\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useIBANs();\n * ```\n * @see {@link https://monerium.dev/api-docs-v2#tag/ibans/operation/ibans | API Documentation}\n */\nexport function useIBANs({\n  profile,\n  chain,\n  query = {},\n}: {\n  /** Fetch IBANs for a specific profile. */\n  profile?: string;\n  /** Fetch IBANs for a specific chain. */\n  chain?: Chain | ChainId;\n  /** {@inheritDoc QueryOptions} */\n  query?: QueryOptions<IBANsResponse>;\n} = {}) {\n  const sdk = useSdk();\n  const { isAuthorized } = useAuth();\n\n  return useQuery({\n    ...query,\n    queryKey: keys.getIbans({ profile, chain }),\n    queryFn: async () => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n\n      return sdk.getIbans({ profile, chain });\n    },\n    enabled: Boolean(sdk && isAuthorized && (query?.enabled ?? true)),\n  });\n}\n\n/**\n * @group Hooks\n * @category Orders\n * @param {Object} params\n * @example\n * ```ts\n * const {\n *    data,\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useOrder();\n * ```\n * @see {@link https://monerium.dev/api-docs#operation/order| API Documentation}\n */\nexport function useOrder({\n  orderId,\n  query = {},\n}: {\n  /**  The id of the order. */\n  orderId: string;\n  /** {@inheritDoc QueryOptions} */\n  query?: QueryOptions<Order>;\n}) {\n  const sdk = useSdk();\n  const { isAuthorized } = useAuth();\n  return useQuery({\n    ...query,\n    queryKey: keys.getOrder(orderId),\n    queryFn: async () => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n      if (!orderId) {\n        throw new Error('Order id is required');\n      }\n\n      return sdk.getOrder(orderId);\n    },\n    enabled: Boolean(sdk && isAuthorized && orderId && (query.enabled ?? true)),\n  });\n}\n\n/**\n * @group Hooks\n * @category Orders\n * @param {Object} [params] No required parameters.\n * @param {Object} [params.address] Filter based on the blockchain address associated with the order.\n * @param {Object} [params.memo] Filter by the payment memo/reference..\n * @param {Object} [params.profile] Filter based on the profile ID associated with the order.\n * @param {Object} [params.state] Filter based on the state of the order.\n * @param {Object} [params.txHash] Filter based on the blockchain transaction hash.\n *\n * @example\n * ```ts\n * const {\n *    data,\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useOrders();\n * ```\n * @see {@link https://monerium.dev/api-docs#operation/orders | API Documentation}\n */\nexport function useOrders({\n  query = {},\n  ...filters\n}: {\n  /** {@inheritDoc QueryOptions} */\n  query?: QueryOptions<OrdersResponse>;\n  address?: string;\n  txHash?: string;\n  profile?: string;\n  memo?: string;\n  state?: OrderState;\n} = {}) {\n  const sdk = useSdk();\n  const { isAuthorized } = useAuth();\n  return useQuery({\n    ...query,\n    queryKey: keys.getOrders(filters),\n    queryFn: async () => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n\n      return sdk.getOrders(filters);\n    },\n    enabled: Boolean(sdk && isAuthorized && (query.enabled ?? true)),\n  });\n}\n\n/**\n * Submit the required compliance information to onboard the customer.\n *\n * Note that you won't be able to change the profile \"kind\" from personal to corporate or vice versa once the profile has been approved.\n * @group Hooks\n * @category Profiles\n * @param param\n * @param {string} param.profile The id of the profile to submit to.\n *\n * @example\n * ```ts\n * const {\n *    submitProfileDetails, // useMutation's `mutateAsync` property\n *    isPending,\n *    isError,\n *    error,\n *    status,\n *    ...moreUseMutationResults\n * } = useSubmitProfileDetails();\n * ```\n * @see {@link https://monerium.dev/api-docs-v2#tag/profiles/operation/profile-details | API Documentation}}\n */\n\nexport function useSubmitProfileDetails({\n  profile,\n  mutation = {},\n}: {\n  profile: string;\n  /** {@inheritDoc MutationOptions} */\n  mutation?: MutationOptions<\n    ResponseStatus,\n    Error,\n    SubmitProfileDetailsPayload\n  >;\n}): MutationResult<\n  'submitProfileDetails',\n  ResponseStatus,\n  Error,\n  SubmitProfileDetailsPayload\n> {\n  const sdk = useSdk();\n  const { isAuthorized } = useAuth();\n  const queryClient = useQueryClient();\n\n  const { mutateAsync, ...rest } = useMutation({\n    ...mutation,\n    mutationKey: keys.submitProfileDetails,\n    mutationFn: async (body: SubmitProfileDetailsPayload) => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n\n      return sdk.submitProfileDetails(profile, body);\n    },\n    onSuccess(data, variables, context) {\n      // Refetch all orders on success.\n      queryClient.invalidateQueries({\n        queryKey: keys.getProfile(profile),\n      });\n      // Allow the caller to add custom logic on success.\n      mutation?.onSuccess?.(data, variables, context);\n    },\n    onError(error, vars, context) {\n      // Allow the caller to add custom logic on error.\n      mutation?.onError?.(error, vars, context);\n      throw error;\n    },\n  });\n  return {\n    submitProfileDetails: mutateAsync,\n    ...rest,\n  };\n}\n/**\n * Create an IBAN for a specified address and chain.\n * All incoming EUR payments will automatically be routed to the linked address on that chain.\n * Any linked address can use this IBAN for outgoing payments.\n * @group Hooks\n * @category IBANs\n * @param {Object} [params] No required parameters.\n *\n * @example\n * ```ts\n * const {\n *    requestIban, // useMutation's `mutateAsync` property\n *    isPending,\n *    isError,\n *    error,\n *    status,\n *    ...moreUseMutationResults\n * } = useRequestIban();\n * ```\n * @see {@link https://monerium.dev/api-docs-v2#tag/ibans/operation/request-iban | API Documentation}}\n */\n\nexport function useRequestIban({\n  mutation = {},\n}: {\n  /** {@inheritDoc MutationOptions} */\n  mutation?: MutationOptions<ResponseStatus, Error, RequestIbanPayload>;\n} = {}): MutationResult<\n  'requestIban',\n  ResponseStatus,\n  Error,\n  RequestIbanPayload\n> {\n  const sdk = useSdk();\n  const { isAuthorized } = useAuth();\n\n  const { mutateAsync, ...rest } = useMutation({\n    ...mutation,\n    mutationKey: keys.requestIban,\n    mutationFn: async ({\n      address,\n      chain,\n      emailNotifications,\n    }: RequestIbanPayload) => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n\n      return sdk.requestIban({ address, chain, emailNotifications });\n    },\n    onSuccess(data, variables, context) {\n      // Allow the caller to add custom logic on success.\n      mutation?.onSuccess?.(data, variables, context);\n    },\n    onError(error, vars, context) {\n      // Allow the caller to add custom logic on error.\n      mutation?.onError?.(error, vars, context);\n      throw error;\n    },\n  });\n  return {\n    requestIban: mutateAsync,\n    ...rest,\n  };\n}\n/**\n * Move an existing IBAN to a specified address an chain.\n * All incoming EUR payments will automatically be routed to the address on that chain.\n * @group Hooks\n * @category IBANs\n * @param {Object} [params] No required parameters.\n *\n * @example\n * ```ts\n * const {\n *    moveIban, // useMutation's `mutateAsync` property\n *    isPending,\n *    isError,\n *    error,\n *    status,\n *    ...moreUseMutationResults\n * } = useMoveIban();\n * ```\n * @see {@link https://monerium.dev/api-docs/v2#tag/ibans/operation/move-iban | API Documentation}\n */\n\nexport function useMoveIban({\n  mutation = {},\n}: {\n  /** {@inheritDoc MutationOptions} */\n  mutation?: MutationOptions<\n    ResponseStatus,\n    Error,\n    MoveIbanPayload & { iban: string }\n  >;\n} = {}): MutationResult<\n  'moveIban',\n  ResponseStatus,\n  Error,\n  MoveIbanPayload & { iban: string }\n> {\n  const sdk = useSdk();\n  const { isAuthorized } = useAuth();\n  const queryClient = useQueryClient();\n\n  const { mutateAsync, ...rest } = useMutation({\n    ...mutation,\n    mutationKey: keys.moveIban,\n    mutationFn: async ({\n      iban,\n      address,\n      chain,\n    }: MoveIbanPayload & { iban: string }) => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n\n      return sdk.moveIban(iban, { address, chain });\n    },\n    onSuccess(data, variables, context) {\n      // Refetch all orders on success.\n      queryClient.invalidateQueries({\n        queryKey: keys.getIban(variables.iban),\n      });\n      queryClient.invalidateQueries({\n        queryKey: keys.getIbans(),\n      });\n      queryClient.invalidateQueries({\n        queryKey: keys.getAddress(variables.address),\n      });\n      // Allow the caller to add custom logic on success.\n      mutation?.onSuccess?.(data, variables, context);\n    },\n    onError(error, vars, context) {\n      // Allow the caller to add custom logic on error.\n      mutation?.onError?.(error, vars, context);\n      throw error;\n    },\n  });\n  return {\n    moveIban: mutateAsync,\n    ...rest,\n  };\n}\n/**\n * When the order has been placed, the orders query will be invalidated and re-fetched.\n *\n * If the order amount is above 15000, a supporting document is required.\n * @group Hooks\n * @category Orders\n * @param param\n * @param {File} param.supportingDocument Supporting document file.\n *\n * @example\n * ```ts\n * const {\n *    placeOrder, // useMutation's `mutateAsync` property\n *    isPending,\n *    isError,\n *    error,\n *    status,\n *    ...moreUseMutationResults\n * } = usePlaceOrder();\n * ```\n * @see {@link https://monerium.dev/api-docs#operation/post-orders| API Documentation}\n */\n\nexport function usePlaceOrder({\n  supportingDocument,\n  mutation,\n}: {\n  supportingDocument?: File;\n  /** {@inheritDoc MutationOptions} */\n  mutation?: MutationOptions<Order, Error, NewOrder>;\n} = {}): MutationResult<'placeOrder', Order, Error, NewOrder> {\n  const sdk = useSdk();\n  const { isAuthorized } = useAuth();\n  const queryClient = useQueryClient();\n\n  const { mutateAsync, ...rest } = useMutation({\n    ...mutation,\n    mutationKey: keys.placeOrder,\n    mutationFn: async (body: NewOrder) => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n      let documentId;\n      if (parseInt(body.amount) > 15000) {\n        if (!supportingDocument) {\n          throw new Error(\n            'Supporting document is required for orders above 15000'\n          );\n        }\n        const uploadedDocument =\n          await sdk.uploadSupportingDocument(supportingDocument);\n        documentId = uploadedDocument.id;\n      }\n\n      const newBody = {\n        ...body,\n        documentId: documentId,\n      };\n\n      return sdk.placeOrder(newBody);\n    },\n    onSuccess(data, variables, context) {\n      // Refetch all orders on success.\n      queryClient.invalidateQueries({\n        queryKey: keys.getOrders(),\n      });\n      queryClient.invalidateQueries({\n        queryKey: keys.getBalances(data.address, data.chain),\n      });\n      // Allow the caller to add custom logic on success.\n      mutation?.onSuccess?.(data, variables, context);\n    },\n    onError(error, vars, context) {\n      // Allow the caller to add custom logic on error.\n      mutation?.onError?.(error, vars, context);\n      throw error;\n    },\n  });\n  return {\n    placeOrder: mutateAsync,\n    ...rest,\n  };\n}\n/**\n * # Add address to profile.\n *\n * @group Hooks\n * @category Profiles\n * @param {Object} [params] No required parameters.\n *\n * @example\n * ```ts\n * const {\n *    linkAddress, // useMutation's `mutateAsync` property\n *    isPending,\n *    isError,\n *    error,\n *    status,\n *    ...moreUseMutationResults\n * } = useLinkAddress();\n * ```\n * @see {@link https://monerium.dev/api-docs#operation/profile-addresses | API Documentation}\n */\n\nexport function useLinkAddress({\n  mutation,\n}: {\n  /** {@inheritDoc MutationOptions} */\n  mutation?: MutationOptions<LinkedAddress, Error, LinkAddress>;\n} = {}): MutationResult<'linkAddress', LinkedAddress, Error, LinkAddress> {\n  const sdk = useSdk();\n  const { isAuthorized } = useAuth();\n  const queryClient = useQueryClient();\n\n  const { mutateAsync, ...rest } = useMutation({\n    ...mutation,\n    mutationKey: keys.linkAddress,\n    mutationFn: async (body: LinkAddress) => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n      return sdk.linkAddress(body);\n    },\n    onSuccess(data, variables, context) {\n      // Refetch all orders on success.\n      queryClient.invalidateQueries({\n        queryKey: keys.getAddresses(),\n      });\n      if (variables.profile) {\n        queryClient.invalidateQueries({\n          queryKey: keys.getProfile(variables.profile),\n        });\n      }\n      // Allow the caller to add custom logic on success.\n      mutation?.onSuccess?.(data, variables, context);\n    },\n    onError(error, vars, context) {\n      // Allow the caller to add custom logic on error.\n      mutation?.onError?.(error, vars, context);\n      throw error;\n    },\n  });\n  return {\n    linkAddress: mutateAsync,\n    ...rest,\n  };\n}\n\n/**\n * API consumers have the option to subscribe to a WebSocket for real-time order notifications. This WebSocket complies with the standard WebSocket Protocol, allowing the use of standard WebSocket libraries for subscription.\n *\n * The WebSocket emits an event when a order changes state:\n *\n * `placed`: The order has been created but not yet processed.\n *\n * `pending`: The order is awaiting fulfillment (e.g., review, minting/burning tokens, or sending/receiving SEPA payment).\n *\n * `processed`: The order has been completed successfully.\n *\n * `rejected`: The order was rejected, possibly due to compliance reasons or insufficient funds.\n * @group Hooks\n * @category Orders\n * @param {Object} params\n * @param {OrderState} [params.state] Filter based on the state of the order.\n * @param {string} [params.profile] Filter based on the profile id of the order.\n * @param {Function} params.onMessage Callback function to handle the order notification.\n * @param {Function} [params.onError] Callback function to handle the error notification.\n *\n * @example\n * ```ts\n * const {\n *    state,\n *    profile,\n *    onMessage,\n *    onError\n * } = useSubscribeOrderNotification();\n * ```\n * @see {@link https://monerium.dev/api-docs/v1#operation/orders-notifications| API Documentation}\n * @returns {Function} Unsubscribe from order notifications.\n */\n\nexport const useSubscribeOrderNotification = ({\n  state,\n  profile,\n  onMessage,\n  onError,\n}: {\n  state?: OrderState;\n  profile?: string;\n  onMessage: (order: Order) => void;\n  onError?: ((err: Event) => void) | undefined;\n}) => {\n  const sdk = useSdk();\n\n  useEffect(() => {\n    if (sdk) {\n      sdk.subscribeOrderNotifications({\n        filter: {\n          state: state,\n          profile: profile,\n        },\n        onMessage: onMessage,\n        onError: onError,\n      });\n    }\n    return () => {\n      /**\n       * Note that in development mode, React Strict mode will cause this\n       * cleanup function to be called twice on client side route changes.\n       * So a socket will be immediately closed and opened again.\n       * This is not an issue in production mode.\n       */\n      if (sdk) {\n        sdk?.unsubscribeOrderNotifications({ state: state, profile: profile });\n      }\n    };\n  }, [sdk, profile, state]);\n\n  return () =>\n    sdk?.unsubscribeOrderNotifications({ state: state, profile: profile });\n};\n\n/** Export types for documentation */\nexport type {\n  Address,\n  Balances,\n  IBAN,\n  MoveIbanPayload,\n  LinkAddress,\n  Profile,\n  Token,\n  SubmitProfileDetailsPayload,\n  NewOrder,\n  ResponseStatus,\n  Order,\n};\n"]}
|
|
1
|
+
'use strict';var react=require('react'),reactQuery=require('@tanstack/react-query'),sdk=require('@monerium/sdk'),jsxRuntime=require('react/jsx-runtime');var g=react.createContext(null);var J=({children:e,clientId:r,redirectUri:n,environment:t="sandbox",refreshToken:i,onRefreshTokenUpdate:a,debug:u=false})=>{let s=reactQuery.useQueryClient(),[o]=react.useState(()=>new sdk.MoneriumClient({environment:t,clientId:r,redirectUri:n,debug:u})),[c,y]=react.useState(false),[p,b]=react.useState(null),[k,I]=react.useState(true);react.useEffect(()=>((async()=>{if(o)try{y(await o.getAccess());}catch(m){b(m);}finally{I(false),o?.bearerProfile&&a?.(o.bearerProfile.refresh_token);}})(),()=>{o&&o.disconnect();}),[]),react.useEffect(()=>{i&&!c&&!k&&(async()=>{if(o)try{y(await o.getAccess(i));}catch(m){b(m);}finally{o?.bearerProfile&&a?.(o.bearerProfile.refresh_token);}})();},[i]);let x=react.useCallback(async w=>{try{o&&await o.authorize(w);}catch(m){console.error("Error during authorization:",m),b(m);}},[o]),z=react.useCallback(async w=>{try{o&&await o.siwe(w);}catch(m){console.error("Error during sign in with ethereum:",m),b(m);}},[o]),C=async()=>{try{o&&await o.revokeAccess();}catch(w){console.error("Error during revoking access:",w),b(w);}finally{s.clear(),y(false);}};return jsxRuntime.jsx(g.Provider,{value:{sdk:o,authorize:x,siwe:z,isAuthorized:c,isLoading:k,error:p,disconnect:async()=>o?.disconnect(),revokeAccess:async()=>C()},children:e})};var d={getAll:["monerium"],getAuthContext:["monerium","auth-context"],getProfile:e=>["monerium","profile",...e?[e]:[]],getProfiles:["monerium","profiles"],getAddress:e=>["monerium","address",[e]],getAddresses:e=>["monerium","addresses",...e?[e]:[]],getBalances:(e,r,n)=>["monerium","balances",{currencies:n?[...n]:[],chain:r,address:e}],getIban:e=>["monerium","iban",e],getIbans:e=>["monerium","ibans",...e?[e]:[]],getTokens:["monerium","tokens"],getOrder:e=>["monerium","order",e],getOrders:e=>["monerium","orders",...e?[e]:[]],submitProfileDetails:["monerium","submit-profile-details"],moveIban:["monerium","move-iban"],requestIban:["monerium","request-iban"],placeOrder:["monerium","place-order"],linkAddress:["monerium","link-address"],getSignatures:e=>["monerium","signatures",...e?[e]:[]]};function l(){let e=react.useContext(g);if(e===null)throw new Error("useSdk must be used within a MoneriumProvider");return e?.sdk}function f(){let e=react.useContext(g);if(e===null)throw new Error("useAuth must be used within a MoneriumProvider");return {isAuthorized:e.isAuthorized,authorize:e.authorize,siwe:e.siwe,isLoading:e.isLoading,error:e.error,disconnect:e.disconnect,revokeAccess:e.revokeAccess}}function qe({query:e}={}){let{isAuthorized:r}=f(),n=l();return reactQuery.useQuery({...e,queryKey:d.getAuthContext,queryFn:async()=>{if(!n)throw new Error("No SDK instance available");if(!r)throw new Error("User not authorized");return n.getAuthContext()},enabled:!!(n&&r&&(e?.enabled??true))})}function ve({profile:e,query:r}={}){let{isAuthorized:n}=f(),t=l(),{data:i}=B(),a=e||i?.profiles?.[0]?.id;return reactQuery.useQuery({...r,queryKey:d.getProfile(a),queryFn:async()=>{if(!t)throw new Error("No SDK instance available");if(!n)throw new Error("User not authorized");if(!a)throw new Error("Profile Id is required");return t.getProfile(a)},enabled:!!(t&&n&&a&&(r?.enabled??true))})}function B({query:e}={}){let{isAuthorized:r}=f(),n=l();return reactQuery.useQuery({...e,queryKey:d.getProfiles,queryFn:async()=>{if(!n)throw new Error("No SDK instance available");if(!r)throw new Error("User not authorized");return n.getProfiles()},enabled:!!(n&&r&&(e?.enabled??true))})}function Ie({query:e}={}){let r=l(),{isAuthorized:n}=f();return reactQuery.useQuery({...e,queryKey:d.getTokens,queryFn:async()=>{if(!r)throw new Error("No SDK instance available");if(!n)throw new Error("User not authorized");return r.getTokens()},enabled:!!(r&&n&&(e?.enabled??true))})}function xe({address:e,query:r={}}){let n=l(),{isAuthorized:t}=f();return reactQuery.useQuery({...r,queryKey:d.getAddress(e),queryFn:async()=>{if(!n)throw new Error("No SDK instance available");if(!t)throw new Error("User not authorized");if(!e)throw new Error("Address is required");return n.getAddress(e)},enabled:!!(n&&t&&e&&(r?.enabled??true))})}function ze({profile:e,chain:r,query:n={}}={}){let t=l(),{isAuthorized:i}=f();return reactQuery.useQuery({...n,queryKey:d.getAddresses({profile:e,chain:r?sdk.parseChain(r):void 0}),queryFn:async()=>{if(!t)throw new Error("No SDK instance available");if(!i)throw new Error("User not authorized");return t.getAddresses({profile:e,chain:r})},enabled:!!(t&&i&&(n?.enabled??true))})}function Ce({address:e,chain:r,currencies:n,query:t}){let i=l(),{isAuthorized:a}=f();return reactQuery.useQuery({...t,queryKey:d.getBalances(e,sdk.parseChain(r),n),staleTime:1e3*60*5,queryFn:async()=>{if(!i)throw new Error("No SDK instance available");if(!a)throw new Error("User not authorized");return i.getBalances(e,r,n)},enabled:!!(i&&a&&(t?.enabled??true))})}function Ke({iban:e,query:r}){let n=l(),{isAuthorized:t}=f();return reactQuery.useQuery({...r,queryKey:d.getIban(e),queryFn:async()=>{if(!n)throw new Error("No SDK instance available");if(!t)throw new Error("User not authorized");return n.getIban(e)},enabled:!!(n&&t&&e&&(r?.enabled??true))})}function Re({profile:e,chain:r,query:n={}}={}){let t=l(),{isAuthorized:i}=f();return reactQuery.useQuery({...n,queryKey:d.getIbans({profile:e,chain:r}),queryFn:async()=>{if(!t)throw new Error("No SDK instance available");if(!i)throw new Error("User not authorized");return t.getIbans({profile:e,chain:r})},enabled:!!(t&&i&&(n?.enabled??true))})}function Ne({orderId:e,query:r={}}){let n=l(),{isAuthorized:t}=f();return reactQuery.useQuery({...r,queryKey:d.getOrder(e),queryFn:async()=>{if(!n)throw new Error("No SDK instance available");if(!t)throw new Error("User not authorized");if(!e)throw new Error("Order id is required");return n.getOrder(e)},enabled:!!(n&&t&&e&&(r.enabled??true))})}function De({query:e={},...r}={}){let n=l(),{isAuthorized:t}=f();return reactQuery.useQuery({...e,queryKey:d.getOrders(r),queryFn:async()=>{if(!n)throw new Error("No SDK instance available");if(!t)throw new Error("User not authorized");return n.getOrders(r)},enabled:!!(n&&t&&(e.enabled??true))})}function Me({profile:e,mutation:r={}}){let n=l(),{isAuthorized:t}=f(),i=reactQuery.useQueryClient(),{mutateAsync:a,...u}=reactQuery.useMutation({...r,mutationKey:d.submitProfileDetails,mutationFn:async s=>{if(!n)throw new Error("No SDK instance available");if(!t)throw new Error("User not authorized");return n.submitProfileDetails(e,s)},onSuccess(s,o,c,y){i.invalidateQueries({queryKey:d.getProfile(e)}),r?.onSuccess?.(s,o,c,y);},onError(s,o,c,y){throw r?.onError?.(s,o,c,y),s}});return {submitProfileDetails:a,...u}}function Be({mutation:e={}}={}){let r=l(),{isAuthorized:n}=f(),{mutateAsync:t,...i}=reactQuery.useMutation({...e,mutationKey:d.requestIban,mutationFn:async({address:a,chain:u,emailNotifications:s})=>{if(!r)throw new Error("No SDK instance available");if(!n)throw new Error("User not authorized");return r.requestIban({address:a,chain:u,emailNotifications:s})},onSuccess(a,u,s,o){e?.onSuccess?.(a,u,s,o);},onError(a,u,s,o){throw e?.onError?.(a,u,s,o),a}});return {requestIban:t,...i}}function Qe({mutation:e={}}={}){let r=l(),{isAuthorized:n}=f(),t=reactQuery.useQueryClient(),{mutateAsync:i,...a}=reactQuery.useMutation({...e,mutationKey:d.moveIban,mutationFn:async({iban:u,address:s,chain:o})=>{if(!r)throw new Error("No SDK instance available");if(!n)throw new Error("User not authorized");return r.moveIban(u,{address:s,chain:o})},onSuccess(u,s,o,c){t.invalidateQueries({queryKey:d.getIban(s.iban)}),t.invalidateQueries({queryKey:d.getIbans()}),t.invalidateQueries({queryKey:d.getAddress(s.address)}),e?.onSuccess?.(u,s,o,c);},onError(u,s,o,c){throw e?.onError?.(u,s,o,c),u}});return {moveIban:i,...a}}function Ue({supportingDocument:e,mutation:r}={}){let n=l(),{isAuthorized:t}=f(),i=reactQuery.useQueryClient(),{mutateAsync:a,...u}=reactQuery.useMutation({...r,mutationKey:d.placeOrder,mutationFn:async s=>{if(!n)throw new Error("No SDK instance available");if(!t)throw new Error("User not authorized");let o;if(parseInt(s.amount)>15e3){if(!e)throw new Error("Supporting document is required for orders above 15000");o=(await n.uploadSupportingDocument(e)).id;}let c={...s,documentId:o};return n.placeOrder(c)},onSuccess(s,o,c,y){i.invalidateQueries({queryKey:d.getOrders()});let p=s;p.address&&p?.chain&&i.invalidateQueries({queryKey:d.getBalances(p.address,p.chain)}),r?.onSuccess?.(s,o,c,y);},onError(s,o,c,y){throw r?.onError?.(s,o,c,y),s}});return {placeOrder:a,...u}}function Fe({query:e,options:r}={}){let n=l(),{isAuthorized:t}=f();return reactQuery.useQuery({...r,queryKey:d.getSignatures(e),queryFn:()=>{if(!n)throw new Error("No SDK instance available");return n.getSignatures(e)},enabled:!!(n&&t&&(r?.enabled??true))})}function Le({mutation:e}={}){let r=l(),{isAuthorized:n}=f(),t=reactQuery.useQueryClient(),{mutateAsync:i,...a}=reactQuery.useMutation({...e,mutationKey:d.linkAddress,mutationFn:async u=>{if(!r)throw new Error("No SDK instance available");if(!n)throw new Error("User not authorized");return r.linkAddress(u)},onSuccess(u,s,o,c){t.invalidateQueries({queryKey:d.getAddresses()}),s.profile&&t.invalidateQueries({queryKey:d.getProfile(s.profile)}),e?.onSuccess?.(u,s,o,c);},onError(u,s,o,c){throw e?.onError?.(u,s,o,c),u}});return {linkAddress:i,...a}}var Te=({state:e,profile:r,onMessage:n,onError:t})=>{let i=l();return react.useEffect(()=>(i&&i.subscribeOrderNotifications({filter:{state:e,profile:r},onMessage:n,onError:t}),()=>{i&&i?.unsubscribeOrderNotifications({state:e,profile:r});}),[i,r,e]),()=>i?.unsubscribeOrderNotifications({state:e,profile:r})};exports.MoneriumContext=g;exports.MoneriumProvider=J;exports.keys=d;exports.useAddress=xe;exports.useAddresses=ze;exports.useAuth=f;exports.useAuthContext=qe;exports.useBalances=Ce;exports.useIBAN=Ke;exports.useIBANs=Re;exports.useLinkAddress=Le;exports.useMoveIban=Qe;exports.useOrder=Ne;exports.useOrders=De;exports.usePlaceOrder=Ue;exports.useProfile=ve;exports.useProfiles=B;exports.useRequestIban=Be;exports.useSignatures=Fe;exports.useSubmitProfileDetails=Me;exports.useSubscribeOrderNotification=Te;exports.useTokens=Ie;//# sourceMappingURL=index.js.map
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/lib/context.tsx","../src/lib/provider.tsx","../src/lib/hooks.tsx"],"names":["MoneriumContext","createContext","MoneriumProvider","children","clientId","redirectUri","environment","refreshToken","onRefreshTokenUpdate","debug","queryClient","useQueryClient","sdk","useState","MoneriumClient","isAuthorized","setIsAuthorized","error","setError","loadingAuth","setLoadingAuth","useEffect","authorize","useCallback","params","err","siwe","revokeAccess","jsx","keys","profile","address","filter","chain","currencies","iban","orderId","useSdk","context","useContext","useAuth","useAuthContext","query","useQuery","useProfile","data","useProfiles","profileToUse","useTokens","useAddress","useAddresses","parseChain","useBalances","useIBAN","useIBANs","useOrder","useOrders","filters","useSubmitProfileDetails","mutation","mutateAsync","rest","useMutation","body","variables","mutationContext","vars","useRequestIban","emailNotifications","useMoveIban","usePlaceOrder","supportingDocument","documentId","newBody","orderData","useSignatures","options","useLinkAddress","useSubscribeOrderNotification","state","onMessage","onError"],"mappings":"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","file":"index.js","sourcesContent":["import { createContext } from 'react';\n\nimport { SdkInstance, UseAuthReturn } from './types';\n\nexport const MoneriumContext = createContext<\n  (UseAuthReturn & SdkInstance) | null\n>(null);\n","import { ReactNode, useCallback, useEffect, useState } from 'react';\nimport { useQueryClient } from '@tanstack/react-query';\n\nimport {\n  AuthFlowOptions,\n  AuthFlowSIWEOptions,\n  MoneriumClient,\n} from '@monerium/sdk';\n\nimport { MoneriumContext } from './context';\n\n/**\n * Wrap your application with the Monerium provider.\n * @group Provider\n * @param params\n * @param params.children - Rest of the application.\n * @param params.clientId - Monerium auth flow client id.\n * @param params.redirectUri - Monerium auth flow redirect url.\n * @param params.environment - Monerium environment.\n * @param params.onRefreshTokenUpdate - Callback that is called when the refresh token is updated. Store it securely.\n * @param params.refreshToken - Provide the securely stored refresh token to reconnect.\n * @param params.debug - Enable debug mode.\n * @returns\n */\nexport const MoneriumProvider = ({\n  children,\n  clientId,\n  redirectUri,\n  environment = 'sandbox',\n  refreshToken,\n  onRefreshTokenUpdate,\n  debug = false,\n}: {\n  children: ReactNode;\n  clientId: string;\n  redirectUri: string;\n  /** @deprecated use redirectUri */\n  redirectUrl?: string;\n  environment?: 'sandbox' | 'production';\n  refreshToken?: string;\n  onRefreshTokenUpdate?: (token: string) => void;\n  debug?: boolean;\n}) => {\n  const queryClient = useQueryClient();\n\n  const [sdk] = useState(() => {\n    // Initialize the SDK\n    return new MoneriumClient({\n      environment,\n      clientId,\n      redirectUri,\n      debug: debug,\n    });\n  });\n\n  const [isAuthorized, setIsAuthorized] = useState<boolean>(false);\n  const [error, setError] = useState<Error | unknown | null>(null);\n  const [loadingAuth, setLoadingAuth] = useState(true);\n\n  useEffect(() => {\n    const connect = async () => {\n      if (sdk) {\n        try {\n          setIsAuthorized(await sdk.getAccess());\n        } catch (error) {\n          setError(error);\n        } finally {\n          setLoadingAuth(false);\n          if (sdk?.bearerProfile) {\n            onRefreshTokenUpdate?.(sdk.bearerProfile.refresh_token);\n          }\n        }\n      }\n    };\n\n    connect();\n\n    return () => {\n      if (sdk) {\n        sdk.disconnect();\n      }\n    };\n  }, []);\n\n  useEffect(() => {\n    const reconnect = async () => {\n      if (sdk) {\n        try {\n          setIsAuthorized(await sdk.getAccess(refreshToken));\n        } catch (error) {\n          setError(error);\n        } finally {\n          if (sdk?.bearerProfile) {\n            onRefreshTokenUpdate?.(sdk.bearerProfile.refresh_token);\n          }\n        }\n      }\n    };\n    if (refreshToken && !isAuthorized && !loadingAuth) {\n      reconnect();\n    }\n  }, [refreshToken]);\n\n  const authorize = useCallback(\n    async (params?: AuthFlowOptions) => {\n      try {\n        if (sdk) {\n          await sdk.authorize(params);\n        }\n      } catch (err) {\n        console.error('Error during authorization:', err);\n        setError(err);\n      }\n    },\n    [sdk]\n  );\n\n  const siwe = useCallback(\n    async (params: AuthFlowSIWEOptions) => {\n      try {\n        if (sdk) {\n          await sdk.siwe(params);\n        }\n      } catch (err) {\n        console.error('Error during sign in with ethereum:', err);\n        setError(err);\n      }\n    },\n    [sdk]\n  );\n\n  const revokeAccess = async () => {\n    try {\n      if (sdk) {\n        await sdk.revokeAccess();\n      }\n    } catch (err) {\n      console.error('Error during revoking access:', err);\n      setError(err);\n    } finally {\n      queryClient.clear();\n      setIsAuthorized(false);\n    }\n  };\n\n  return (\n    <MoneriumContext.Provider\n      value={{\n        sdk,\n        authorize,\n        siwe,\n        isAuthorized,\n        isLoading: loadingAuth,\n        error,\n        disconnect: async () => sdk?.disconnect(),\n        revokeAccess: async () => revokeAccess(),\n      }}\n    >\n      {children}\n    </MoneriumContext.Provider>\n  );\n};\n","import { useContext, useEffect } from 'react';\nimport { useMutation, useQuery, useQueryClient } from '@tanstack/react-query';\n\nimport MoneriumClient, {\n  Address,\n  AddressesResponse,\n  AuthContext,\n  Balances,\n  Chain,\n  ChainId,\n  Currency,\n  CurrencyCode,\n  IBAN,\n  IBANsResponse,\n  LinkAddress,\n  LinkedAddress,\n  MoveIbanPayload,\n  NewOrder,\n  Order,\n  OrdersResponse,\n  OrderState,\n  parseChain,\n  Profile,\n  ProfilesResponse,\n  RequestIbanPayload,\n  ResponseStatus,\n  SignaturesQueryParams,\n  SignaturesResponse,\n  SubmitProfileDetailsPayload,\n  Token,\n} from '@monerium/sdk';\n\nimport { MoneriumContext } from './context';\nimport {\n  MutationOptions,\n  MutationResult,\n  QueryOptions,\n  UseAuthReturn,\n} from './types';\n\n/**\n * @internal\n * Query keys for React query\n * */\nexport const keys = {\n  getAll: ['monerium'],\n  getAuthContext: ['monerium', 'auth-context'],\n  getProfile: (profile: string) => [\n    'monerium',\n    'profile',\n    ...(profile ? [profile] : []),\n  ],\n  getProfiles: ['monerium', 'profiles'],\n  getAddress: (address: string) => ['monerium', 'address', [address]],\n  getAddresses: (filter?: unknown) => [\n    'monerium',\n    'addresses',\n    ...(filter ? [filter] : []),\n  ],\n  getBalances: (\n    address: string,\n    chain: Chain,\n    currencies?: CurrencyCode | CurrencyCode[]\n  ) => [\n    'monerium',\n    'balances',\n    {\n      currencies: currencies ? [...currencies] : [],\n      chain,\n      address,\n    },\n  ],\n  getIban: (iban: string) => ['monerium', 'iban', iban],\n  getIbans: (filter?: unknown) => [\n    'monerium',\n    'ibans',\n    ...(filter ? [filter] : []),\n  ],\n  getTokens: ['monerium', 'tokens'],\n  getOrder: (orderId: string) => ['monerium', 'order', orderId],\n  getOrders: (filter?: unknown) => [\n    'monerium',\n    'orders',\n    ...(filter ? [filter] : []),\n  ],\n  submitProfileDetails: ['monerium', 'submit-profile-details'],\n  moveIban: ['monerium', 'move-iban'],\n  requestIban: ['monerium', 'request-iban'],\n  placeOrder: ['monerium', 'place-order'],\n  linkAddress: ['monerium', 'link-address'],\n  getSignatures: (filter?: unknown) => [\n    'monerium',\n    'signatures',\n    ...(filter ? [filter] : []),\n  ],\n};\n\n/** Internal hook to use SDK */\nfunction useSdk(): MoneriumClient | undefined {\n  const context = useContext(MoneriumContext);\n\n  if (context === null) {\n    throw new Error('useSdk must be used within a MoneriumProvider');\n  }\n  return context?.sdk;\n}\n\n/**\n * # Redirect to the Monerium auth flow.\n * @group Hooks\n * @category Authentication\n * @example\n * ```ts\n * const { authorize, isAuthorized, isLoading, error } = useAuth();\n *\n * authorize(); // Redirects to the Monerium auth flow.\n *\n * // Opt-in to automated wallet linking with these parameters.\n * authorize({ address, signature, chain }).\n * ```\n *\n * @returns {UseAuthReturn}\n * - `authorize`  - Redirects to the Monerium auth flow.\n * - `siwe`       - Sign in with Ethereum. https://monerium.com/siwe\n * - `isAuthorized` - Whether the user is authorized.\n * - `isLoading` - Whether the auth flow is loading.\n * - `error` - Error message if the auth flow fails.\n * - `disconnect` - Disconnect the user.\n * - `revokeAccess` - Revoke the user's access.\n */\nexport function useAuth(): UseAuthReturn {\n  const context = useContext(MoneriumContext);\n\n  if (context === null) {\n    throw new Error('useAuth must be used within a MoneriumProvider');\n  }\n\n  return {\n    isAuthorized: context.isAuthorized,\n    authorize: context.authorize,\n    siwe: context.siwe,\n    isLoading: context.isLoading,\n    error: context.error,\n    disconnect: context.disconnect,\n    revokeAccess: context.revokeAccess,\n  };\n}\n\n/**\n * @group Hooks\n * @category Authentication\n * @param {Object} params\n *\n * @example\n * ```ts\n * const {\n *    data\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useAuthContext();\n * ```\n\n * @see {@link https://monerium.dev/api-docs/v2#tag/auth/operation/auth-context | API Documentation}\n */\nexport function useAuthContext({\n  query,\n}: {\n  /** {@inheritDoc QueryOptions} */\n  query?: QueryOptions<AuthContext>;\n} = {}) {\n  const { isAuthorized } = useAuth();\n  const sdk = useSdk();\n\n  return useQuery({\n    ...query,\n    queryKey: keys.getAuthContext,\n    queryFn: async () => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n\n      return sdk.getAuthContext();\n    },\n    enabled: Boolean(sdk && isAuthorized && (query?.enabled ?? true)),\n  });\n}\n/**\n * If no `profile` id is provided, the default profile is used.\n * @group Hooks\n * @category Profiles\n * @param {Object} params\n *\n * @example\n * ```ts\n * const {\n *    data\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useProfile();\n * ```\n\n * @see {@link https://monerium.dev/api-docs#operation/profile | API Documentation}\n */\nexport function useProfile({\n  profile,\n  query,\n}: {\n  /** The id of the profile */\n  profile?: string;\n  /** {@inheritDoc QueryOptions} */\n  query?: QueryOptions<Profile>;\n} = {}) {\n  const { isAuthorized } = useAuth();\n  const sdk = useSdk();\n\n  const { data } = useProfiles();\n\n  const profileToUse = profile || (data?.profiles?.[0]?.id as string);\n\n  return useQuery({\n    ...query,\n    queryKey: keys.getProfile(profileToUse),\n    queryFn: async () => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n      if (!profileToUse) {\n        throw new Error('Profile Id is required');\n      }\n\n      return sdk.getProfile(profileToUse);\n    },\n    enabled: Boolean(\n      sdk && isAuthorized && profileToUse && (query?.enabled ?? true)\n    ),\n  });\n}\n/**\n * # Get profiles\n * @group Hooks\n * @category Profiles\n *\n * @param {Object} [params] No required parameters.\n *\n * @example\n * ```ts\n * const {\n *    data,\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useProfiles();\n * ```\n * @see {@link https://monerium.dev/api-docs#operation/profiles | API Documentation}\n */\nexport function useProfiles({\n  query,\n}: {\n  /** {@inheritDoc QueryOptions} */\n  query?: QueryOptions<ProfilesResponse>;\n} = {}) {\n  const { isAuthorized } = useAuth();\n  const sdk = useSdk();\n\n  return useQuery({\n    ...query,\n    queryKey: keys.getProfiles,\n    queryFn: async () => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n      return sdk.getProfiles();\n    },\n    enabled: Boolean(sdk && isAuthorized && (query?.enabled ?? true)),\n  });\n}\n/**\n * @group Hooks\n * @param {Object} [params] No required parameters.\n *\n * @example\n * ```ts\n * const {\n *    data,\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useTokens();\n * ```\n\n * @see {@link https://monerium.dev/api-docs#operation/tokens | API Documentation}\n */\nexport function useTokens({\n  query,\n}: {\n  /** {@inheritDoc QueryOptions} */\n  query?: QueryOptions<Token[]>;\n} = {}) {\n  const sdk = useSdk();\n  const { isAuthorized } = useAuth();\n  return useQuery({\n    ...query,\n    queryKey: keys.getTokens,\n    queryFn: async () => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n      return sdk.getTokens();\n    },\n    enabled: Boolean(sdk && isAuthorized && (query?.enabled ?? true)),\n  });\n}\n\n/**\n * @group Hooks\n * @category Addresses\n * @param {Object} params\n\n * @example\n * ```ts\n * const {\n *    data,\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useAddress();\n * ```\n * @see {@link https://monerium.dev/api-docs-v2#tag/addresses/operation/address | API Documentation}\n */\nexport function useAddress({\n  address,\n  query = {},\n}: {\n  /** Fetch a specific address. */\n  address: string;\n  /** {@inheritDoc QueryOptions} */\n  query?: QueryOptions<Address>;\n}) {\n  const sdk = useSdk();\n  const { isAuthorized } = useAuth();\n\n  return useQuery({\n    ...query,\n    queryKey: keys.getAddress(address),\n    queryFn: async () => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n\n      if (!address) {\n        throw new Error('Address is required');\n      }\n\n      return sdk.getAddress(address);\n    },\n    enabled: Boolean(\n      sdk && isAuthorized && address && (query?.enabled ?? true)\n    ),\n  });\n}\n/**\n * @group Hooks\n * @category Addresses\n * @param {Object} [params] No required parameters.\n * @param {Object} [params.profile] Filter based on profile id.\n * @param {Object} [params.chain] Filter based on chain - CURRENTLY RETURNS AN ERROR.\n * @example\n * ```ts\n * const {\n *    data,\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useAddresses();\n * ```\n * @see {@link https://monerium.dev/api-docs-v2#tag/addresses/operation/addresses | API Documentation}\n */\nexport function useAddresses({\n  profile,\n  chain,\n  query = {},\n}: {\n  profile?: string;\n  chain?: Chain | ChainId;\n  /** {@inheritDoc QueryOptions} */\n  query?: QueryOptions<AddressesResponse>;\n} = {}) {\n  const sdk = useSdk();\n\n  const { isAuthorized } = useAuth();\n\n  return useQuery({\n    ...query,\n    queryKey: keys.getAddresses({\n      profile,\n      chain: chain ? parseChain(chain) : undefined,\n    }),\n    queryFn: async () => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n      return sdk.getAddresses({ profile, chain });\n    },\n    enabled: Boolean(sdk && isAuthorized && (query?.enabled ?? true)),\n  });\n}\n/**\n * # Get balance for a an address on a give chain\n * @group Hooks\n * @category Addresses\n * @param {Object} params\n * @param {QueryOptions<Balances>} params.address The address to fetch the balance for.\n * @param {QueryOptions<Balances>} params.chain The chain to fetch the balance for.\n * @param {QueryOptions<Balances>} [params.currencies] One or many: `eur`, `usd`, `gbp`, `isk`\n * @example\n * ```ts\n * const {\n *    data,\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useBalances();\n * ```\n * @see {@link https://monerium.dev/api-docs/v2#tag/addresses/operation/balances | API Documentation}\n *\n */\nexport function useBalances({\n  address,\n  chain,\n  currencies,\n  query,\n}: {\n  address: string;\n  chain: Chain | ChainId;\n  currencies?: Currency | Currency[];\n  /** {@inheritDoc QueryOptions} */\n  query?: QueryOptions<Balances>;\n}) {\n  const sdk = useSdk();\n  const { isAuthorized } = useAuth();\n\n  return useQuery({\n    ...query,\n    queryKey: keys.getBalances(address, parseChain(chain), currencies),\n    staleTime: 1000 * 60 * 5,\n    queryFn: async () => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n      return sdk.getBalances(address, chain, currencies);\n    },\n    enabled: Boolean(sdk && isAuthorized && (query?.enabled ?? true)),\n  });\n}\n\n/**\n * @group Hooks\n * @category IBANs\n * @param {Object} params\n * @example\n * ```ts\n * const {\n *    data,\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useIBAN();\n * ```\n * @see {@link https://monerium.dev/api-docs-v2#tag/ibans/operation/iban | API Documentation}\n */\nexport function useIBAN({\n  iban,\n  query,\n}: {\n  /** Fetch a specific IBAN */\n  iban: string;\n  /** {@inheritDoc QueryOptions} */\n  query?: QueryOptions<IBAN>;\n}) {\n  const sdk = useSdk();\n  const { isAuthorized } = useAuth();\n\n  return useQuery({\n    ...query,\n    queryKey: keys.getIban(iban),\n    queryFn: async () => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n\n      return sdk.getIban(iban);\n    },\n    enabled: Boolean(sdk && isAuthorized && iban && (query?.enabled ?? true)),\n  });\n}\n/**\n * @group Hooks\n * @category IBANs\n * @param {Object} [params] No required parameters.\n * @example\n * ```ts\n * const {\n *    data,\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useIBANs();\n * ```\n * @see {@link https://monerium.dev/api-docs-v2#tag/ibans/operation/ibans | API Documentation}\n */\nexport function useIBANs({\n  profile,\n  chain,\n  query = {},\n}: {\n  /** Fetch IBANs for a specific profile. */\n  profile?: string;\n  /** Fetch IBANs for a specific chain. */\n  chain?: Chain | ChainId;\n  /** {@inheritDoc QueryOptions} */\n  query?: QueryOptions<IBANsResponse>;\n} = {}) {\n  const sdk = useSdk();\n  const { isAuthorized } = useAuth();\n\n  return useQuery({\n    ...query,\n    queryKey: keys.getIbans({ profile, chain }),\n    queryFn: async () => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n\n      return sdk.getIbans({ profile, chain });\n    },\n    enabled: Boolean(sdk && isAuthorized && (query?.enabled ?? true)),\n  });\n}\n\n/**\n * @group Hooks\n * @category Orders\n * @param {Object} params\n * @example\n * ```ts\n * const {\n *    data,\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useOrder();\n * ```\n * @see {@link https://monerium.dev/api-docs#operation/order| API Documentation}\n */\nexport function useOrder({\n  orderId,\n  query = {},\n}: {\n  /**  The id of the order. */\n  orderId: string;\n  /** {@inheritDoc QueryOptions} */\n  query?: QueryOptions<Order>;\n}) {\n  const sdk = useSdk();\n  const { isAuthorized } = useAuth();\n  return useQuery({\n    ...query,\n    queryKey: keys.getOrder(orderId),\n    queryFn: async () => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n      if (!orderId) {\n        throw new Error('Order id is required');\n      }\n\n      return sdk.getOrder(orderId);\n    },\n    enabled: Boolean(sdk && isAuthorized && orderId && (query.enabled ?? true)),\n  });\n}\n\n/**\n * @group Hooks\n * @category Orders\n * @param {Object} [params] No required parameters.\n * @param {Object} [params.address] Filter based on the blockchain address associated with the order.\n * @param {Object} [params.memo] Filter by the payment memo/reference..\n * @param {Object} [params.profile] Filter based on the profile ID associated with the order.\n * @param {Object} [params.state] Filter based on the state of the order.\n * @param {Object} [params.txHash] Filter based on the blockchain transaction hash.\n *\n * @example\n * ```ts\n * const {\n *    data,\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useOrders();\n * ```\n * @see {@link https://monerium.dev/api-docs#operation/orders | API Documentation}\n */\nexport function useOrders({\n  query = {},\n  ...filters\n}: {\n  /** {@inheritDoc QueryOptions} */\n  query?: QueryOptions<OrdersResponse>;\n  address?: string;\n  txHash?: string;\n  profile?: string;\n  memo?: string;\n  state?: OrderState;\n} = {}) {\n  const sdk = useSdk();\n  const { isAuthorized } = useAuth();\n  return useQuery({\n    ...query,\n    queryKey: keys.getOrders(filters),\n    queryFn: async () => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n\n      return sdk.getOrders(filters);\n    },\n    enabled: Boolean(sdk && isAuthorized && (query.enabled ?? true)),\n  });\n}\n\n/**\n * Submit the required compliance information to onboard the customer.\n *\n * Note that you won't be able to change the profile \"kind\" from personal to corporate or vice versa once the profile has been approved.\n * @group Hooks\n * @category Profiles\n * @param param\n * @param {string} param.profile The id of the profile to submit to.\n *\n * @example\n * ```ts\n * const {\n *    submitProfileDetails, // useMutation's `mutateAsync` property\n *    isPending,\n *    isError,\n *    error,\n *    status,\n *    ...moreUseMutationResults\n * } = useSubmitProfileDetails();\n * ```\n * @see {@link https://monerium.dev/api-docs-v2#tag/profiles/operation/profile-details | API Documentation}}\n */\n\nexport function useSubmitProfileDetails({\n  profile,\n  mutation = {},\n}: {\n  profile: string;\n  /** {@inheritDoc MutationOptions} */\n  mutation?: MutationOptions<\n    ResponseStatus,\n    Error,\n    SubmitProfileDetailsPayload\n  >;\n}): MutationResult<\n  'submitProfileDetails',\n  ResponseStatus,\n  Error,\n  SubmitProfileDetailsPayload\n> {\n  const sdk = useSdk();\n  const { isAuthorized } = useAuth();\n  const queryClient = useQueryClient();\n\n  const { mutateAsync, ...rest } = useMutation({\n    ...mutation,\n    mutationKey: keys.submitProfileDetails,\n    mutationFn: async (body: SubmitProfileDetailsPayload) => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n\n      return sdk.submitProfileDetails(profile, body);\n    },\n    onSuccess(data, variables, context, mutationContext) {\n      // Refetch all orders on success.\n      queryClient.invalidateQueries({\n        queryKey: keys.getProfile(profile),\n      });\n      // Allow the caller to add custom logic on success.\n      mutation?.onSuccess?.(data, variables, context, mutationContext);\n    },\n    onError(error, vars, context, mutationContext) {\n      // Allow the caller to add custom logic on error.\n      mutation?.onError?.(error, vars, context, mutationContext);\n      throw error;\n    },\n  });\n  return {\n    submitProfileDetails: mutateAsync,\n    ...rest,\n  };\n}\n/**\n * Create an IBAN for a specified address and chain.\n * All incoming EUR payments will automatically be routed to the linked address on that chain.\n * Any linked address can use this IBAN for outgoing payments.\n * @group Hooks\n * @category IBANs\n * @param {Object} [params] No required parameters.\n *\n * @example\n * ```ts\n * const {\n *    requestIban, // useMutation's `mutateAsync` property\n *    isPending,\n *    isError,\n *    error,\n *    status,\n *    ...moreUseMutationResults\n * } = useRequestIban();\n * ```\n * @see {@link https://monerium.dev/api-docs-v2#tag/ibans/operation/request-iban | API Documentation}}\n */\n\nexport function useRequestIban({\n  mutation = {},\n}: {\n  /** {@inheritDoc MutationOptions} */\n  mutation?: MutationOptions<ResponseStatus, Error, RequestIbanPayload>;\n} = {}): MutationResult<\n  'requestIban',\n  ResponseStatus,\n  Error,\n  RequestIbanPayload\n> {\n  const sdk = useSdk();\n  const { isAuthorized } = useAuth();\n\n  const { mutateAsync, ...rest } = useMutation({\n    ...mutation,\n    mutationKey: keys.requestIban,\n    mutationFn: async ({\n      address,\n      chain,\n      emailNotifications,\n    }: RequestIbanPayload) => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n\n      return sdk.requestIban({ address, chain, emailNotifications });\n    },\n    onSuccess(data, variables, context, mutationContext) {\n      // Allow the caller to add custom logic on success.\n      mutation?.onSuccess?.(data, variables, context, mutationContext);\n    },\n    onError(error, vars, context, mutationContext) {\n      // Allow the caller to add custom logic on error.\n      mutation?.onError?.(error, vars, context, mutationContext);\n      throw error;\n    },\n  });\n  return {\n    requestIban: mutateAsync,\n    ...rest,\n  };\n}\n/**\n * Move an existing IBAN to a specified address an chain.\n * All incoming EUR payments will automatically be routed to the address on that chain.\n * @group Hooks\n * @category IBANs\n * @param {Object} [params] No required parameters.\n *\n * @example\n * ```ts\n * const {\n *    moveIban, // useMutation's `mutateAsync` property\n *    isPending,\n *    isError,\n *    error,\n *    status,\n *    ...moreUseMutationResults\n * } = useMoveIban();\n * ```\n * @see {@link https://monerium.dev/api-docs/v2#tag/ibans/operation/move-iban | API Documentation}\n */\n\nexport function useMoveIban({\n  mutation = {},\n}: {\n  /** {@inheritDoc MutationOptions} */\n  mutation?: MutationOptions<\n    ResponseStatus,\n    Error,\n    MoveIbanPayload & { iban: string }\n  >;\n} = {}): MutationResult<\n  'moveIban',\n  ResponseStatus,\n  Error,\n  MoveIbanPayload & { iban: string }\n> {\n  const sdk = useSdk();\n  const { isAuthorized } = useAuth();\n  const queryClient = useQueryClient();\n\n  const { mutateAsync, ...rest } = useMutation({\n    ...mutation,\n    mutationKey: keys.moveIban,\n    mutationFn: async ({\n      iban,\n      address,\n      chain,\n    }: MoveIbanPayload & { iban: string }) => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n\n      return sdk.moveIban(iban, { address, chain });\n    },\n    onSuccess(data, variables, context, mutationContext) {\n      // Refetch the iban on success.\n      queryClient.invalidateQueries({\n        queryKey: keys.getIban(variables.iban),\n      });\n      queryClient.invalidateQueries({\n        queryKey: keys.getIbans(),\n      });\n      queryClient.invalidateQueries({\n        queryKey: keys.getAddress(variables.address),\n      });\n      // Allow the caller to add custom logic on success.\n      mutation?.onSuccess?.(data, variables, context, mutationContext);\n    },\n    onError(error, vars, context, mutationContext) {\n      // Allow the caller to add custom logic on error.\n      mutation?.onError?.(error, vars, context, mutationContext);\n      throw error;\n    },\n  });\n  return {\n    moveIban: mutateAsync,\n    ...rest,\n  };\n}\n/**\n * When the order has been placed, the orders query will be invalidated and re-fetched.\n *\n * If the order amount is above 15000, a supporting document is required.\n *\n * **Note:** For multi-signature orders, the API returns a 202 Accepted response\n * with `{status: 202, statusText: \"Accepted\"}` instead of the full Order object.\n *\n * @group Hooks\n * @category Orders\n * @param param\n * @param {File} param.supportingDocument Supporting document file.\n *\n * @example\n * ```ts\n * const {\n *    placeOrder, // useMutation's `mutateAsync` property\n *    isPending,\n *    isError,\n *    error,\n *    status,\n *    ...moreUseMutationResults\n * } = usePlaceOrder();\n * ```\n * @see {@link https://monerium.dev/api-docs#operation/post-orders| API Documentation}\n */\n\nexport function usePlaceOrder({\n  supportingDocument,\n  mutation,\n}: {\n  supportingDocument?: File;\n  /** {@inheritDoc MutationOptions} */\n  mutation?: MutationOptions<Order | ResponseStatus, Error, NewOrder>;\n} = {}): MutationResult<'placeOrder', Order | ResponseStatus, Error, NewOrder> {\n  const sdk = useSdk();\n  const { isAuthorized } = useAuth();\n  const queryClient = useQueryClient();\n\n  const { mutateAsync, ...rest } = useMutation({\n    ...mutation,\n    mutationKey: keys.placeOrder,\n    mutationFn: async (body: NewOrder) => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n      let documentId;\n      if (parseInt(body.amount) > 15000) {\n        if (!supportingDocument) {\n          throw new Error(\n            'Supporting document is required for orders above 15000'\n          );\n        }\n        const uploadedDocument =\n          await sdk.uploadSupportingDocument(supportingDocument);\n        documentId = uploadedDocument.id;\n      }\n\n      const newBody = {\n        ...body,\n        documentId: documentId,\n      };\n\n      return sdk.placeOrder(newBody);\n    },\n    onSuccess(data, variables, context, mutationContext) {\n      // Refetch all orders on success.\n      queryClient.invalidateQueries({\n        queryKey: keys.getOrders(),\n      });\n      // Only invalidate balances if we got a full Order response (not a 202 multi-sig response)\n      const orderData = data as Order;\n      if (orderData.address && orderData?.chain) {\n        queryClient.invalidateQueries({\n          queryKey: keys.getBalances(orderData.address, orderData.chain),\n        });\n      }\n      // Allow the caller to add custom logic on success.\n      mutation?.onSuccess?.(data, variables, context, mutationContext);\n    },\n    onError(error, vars, context, mutationContext) {\n      // Allow the caller to add custom logic on error.\n      mutation?.onError?.(error, vars, context, mutationContext);\n      throw error;\n    },\n  });\n  return {\n    placeOrder: mutateAsync,\n    ...rest,\n  };\n}\n/**\n * Get pending signatures for the authenticated user.\n *\n * Returns pending signatures that require user action, such as order signatures\n * or link address signatures. Accepts filtering by address, chain, kind, and profile.\n *\n * @group Hooks\n * @category Signatures\n * @param {Object} params\n * @param {SignaturesQueryParams} params.query - Optional query parameters to filter signatures\n *\n * @example\n * ```ts\n * // Get all pending signatures\n * const {\n *    data: signatures,\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useSignatures();\n *\n * // Get pending order signatures for a specific address\n * const { data: orderSignatures } = useSignatures({\n *   query: {\n *     address: '0x1234...',\n *     kind: 'order'\n *   }\n * });\n *\n * // Check the kind of signature\n * signatures?.pending.forEach(sig => {\n *   if (sig.kind === 'order') {\n *     console.log('Order signature:', sig.id, sig.amount);\n *   } else {\n *     console.log('Link address signature');\n *   }\n * });\n * ```\n * @see {@link https://monerium.dev/api-docs-v2#tag/signatures/operation/get-signatures | API Documentation}\n */\nexport function useSignatures({\n  query,\n  options,\n}: {\n  query?: SignaturesQueryParams;\n  /** {@inheritDoc QueryOptions} */\n  options?: QueryOptions<SignaturesResponse>;\n} = {}) {\n  const sdk = useSdk();\n  const { isAuthorized } = useAuth();\n\n  return useQuery<SignaturesResponse>({\n    ...options,\n    queryKey: keys.getSignatures(query),\n    queryFn: () => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      return sdk.getSignatures(query);\n    },\n    enabled: Boolean(sdk && isAuthorized && (options?.enabled ?? true)),\n  });\n}\n\n/**\n * # Add address to profile.\n *\n * @group Hooks\n * @category Profiles\n * @param {Object} [params] No required parameters.\n *\n * @example\n * ```ts\n * const {\n *    linkAddress, // useMutation's `mutateAsync` property\n *    isPending,\n *    isError,\n *    error,\n *    status,\n *    ...moreUseMutationResults\n * } = useLinkAddress();\n * ```\n * @see {@link https://monerium.dev/api-docs#operation/profile-addresses | API Documentation}\n */\n\nexport function useLinkAddress({\n  mutation,\n}: {\n  /** {@inheritDoc MutationOptions} */\n  mutation?: MutationOptions<LinkedAddress, Error, LinkAddress>;\n} = {}): MutationResult<'linkAddress', LinkedAddress, Error, LinkAddress> {\n  const sdk = useSdk();\n  const { isAuthorized } = useAuth();\n  const queryClient = useQueryClient();\n\n  const { mutateAsync, ...rest } = useMutation({\n    ...mutation,\n    mutationKey: keys.linkAddress,\n    mutationFn: async (body: LinkAddress) => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n      return sdk.linkAddress(body);\n    },\n    onSuccess(data, variables, context, mutationContext) {\n      // Refetch all orders on success.\n      queryClient.invalidateQueries({\n        queryKey: keys.getAddresses(),\n      });\n      if (variables.profile) {\n        queryClient.invalidateQueries({\n          queryKey: keys.getProfile(variables.profile),\n        });\n      }\n      // Allow the caller to add custom logic on success.\n      mutation?.onSuccess?.(data, variables, context, mutationContext);\n    },\n    onError(error, vars, context, mutationContext) {\n      // Allow the caller to add custom logic on error.\n      mutation?.onError?.(error, vars, context, mutationContext);\n      throw error;\n    },\n  });\n  return {\n    linkAddress: mutateAsync,\n    ...rest,\n  };\n}\n\n/**\n * API consumers have the option to subscribe to a WebSocket for real-time order notifications. This WebSocket complies with the standard WebSocket Protocol, allowing the use of standard WebSocket libraries for subscription.\n *\n * The WebSocket emits an event when a order changes state:\n *\n * `placed`: The order has been created but not yet processed.\n *\n * `pending`: The order is awaiting fulfillment (e.g., review, minting/burning tokens, or sending/receiving SEPA payment).\n *\n * `processed`: The order has been completed successfully.\n *\n * `rejected`: The order was rejected, possibly due to compliance reasons or insufficient funds.\n * @group Hooks\n * @category Orders\n * @param {Object} params\n * @param {OrderState} [params.state] Filter based on the state of the order.\n * @param {string} [params.profile] Filter based on the profile id of the order.\n * @param {Function} params.onMessage Callback function to handle the order notification.\n * @param {Function} [params.onError] Callback function to handle the error notification.\n *\n * @example\n * ```ts\n * const {\n *    state,\n *    profile,\n *    onMessage,\n *    onError\n * } = useSubscribeOrderNotification();\n * ```\n * @see {@link https://monerium.dev/api-docs/v1#operation/orders-notifications| API Documentation}\n * @returns {Function} Unsubscribe from order notifications.\n */\n\nexport const useSubscribeOrderNotification = ({\n  state,\n  profile,\n  onMessage,\n  onError,\n}: {\n  state?: OrderState;\n  profile?: string;\n  onMessage: (order: Order) => void;\n  onError?: ((err: Event) => void) | undefined;\n}) => {\n  const sdk = useSdk();\n\n  useEffect(() => {\n    if (sdk) {\n      sdk.subscribeOrderNotifications({\n        filter: {\n          state: state,\n          profile: profile,\n        },\n        onMessage: onMessage,\n        onError: onError,\n      });\n    }\n    return () => {\n      /**\n       * Note that in development mode, React Strict mode will cause this\n       * cleanup function to be called twice on client side route changes.\n       * So a socket will be immediately closed and opened again.\n       * This is not an issue in production mode.\n       */\n      if (sdk) {\n        sdk?.unsubscribeOrderNotifications({ state: state, profile: profile });\n      }\n    };\n  }, [sdk, profile, state]);\n\n  return () =>\n    sdk?.unsubscribeOrderNotifications({ state: state, profile: profile });\n};\n\n/** Export types for documentation */\nexport type {\n  Address,\n  Balances,\n  IBAN,\n  MoveIbanPayload,\n  LinkAddress,\n  Profile,\n  Token,\n  SubmitProfileDetailsPayload,\n  NewOrder,\n  ResponseStatus,\n  Order,\n};\n"]}
|
package/dist/index.mjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import {createContext,useState,useEffect,useCallback,useContext}from'react';import {useQueryClient,useQuery,useMutation}from'@tanstack/react-query';import {MoneriumClient,parseChain}from'@monerium/sdk';import {jsx}from'react/jsx-runtime';var w=createContext(null);var J=({children:e,clientId:r,redirectUri:n,environment:t="sandbox",refreshToken:i,onRefreshTokenUpdate:a,debug:u=false})=>{let s=useQueryClient(),[o]=useState(()=>new MoneriumClient({environment:t,clientId:r,redirectUri:n,debug:u})),[f,p]=useState(false),[v,E]=useState(null),[k,I]=useState(true);useEffect(()=>((async()=>{if(o)try{p(await o.getAccess());}catch(h){console.error("Failed to get access:",h);}finally{I(false),o?.bearerProfile&&a?.(o.bearerProfile.refresh_token);}})(),()=>{o&&o.disconnect();}),[]),useEffect(()=>{i&&!f&&!k&&(async()=>{if(o)try{p(await o.getAccess(i));}catch(h){console.error("Failed to get access:",h);}finally{o?.bearerProfile&&a?.(o.bearerProfile.refresh_token);}})();},[i]);let x=useCallback(async m=>{try{o&&await o.authorize(m);}catch(h){console.error("Error during authorization:",h),E(h);}},[o]),C=useCallback(async m=>{try{o&&await o.siwe(m);}catch(h){console.error("Error during sign in with ethereum:",h),E(h);}},[o]),z=async()=>{try{o&&await o.revokeAccess();}catch(m){console.error("Error during revoking access:",m),E(m);}finally{s.clear(),p(false);}};return jsx(w.Provider,{value:{sdk:o,authorize:x,siwe:C,isAuthorized:f,isLoading:k,error:v,disconnect:async()=>o?.disconnect(),revokeAccess:async()=>z()},children:e})};var d={getAll:["monerium"],getAuthContext:["monerium","auth-context"],getProfile:e=>["monerium","profile",...e?[e]:[]],getProfiles:["monerium","profiles"],getAddress:e=>["monerium","address",[e]],getAddresses:e=>["monerium","addresses",...e?[e]:[]],getBalances:(e,r,n)=>["monerium","balances",{currencies:n?[...n]:[],chain:r,address:e}],getIban:e=>["monerium","iban",e],getIbans:e=>["monerium","ibans",...e?[e]:[]],getTokens:["monerium","tokens"],getOrder:e=>["monerium","order",e],getOrders:e=>["monerium","orders",...e?[e]:[]],submitProfileDetails:["monerium","submit-profile-details"],moveIban:["monerium","move-iban"],requestIban:["monerium","request-iban"],placeOrder:["monerium","place-order"],linkAddress:["monerium","link-address"]};function c(){let e=useContext(w);if(e===null)throw new Error("useSdk must be used within a MoneriumProvider");return e?.sdk}function l(){let e=useContext(w);if(e===null)throw new Error("useAuth must be used within a MoneriumProvider");return {isAuthorized:e.isAuthorized,authorize:e.authorize,siwe:e.siwe,isLoading:e.isLoading,error:e.error,disconnect:e.disconnect,revokeAccess:e.revokeAccess}}function Se({query:e}={}){let{isAuthorized:r}=l(),n=c();return useQuery({...e,queryKey:d.getAuthContext,queryFn:async()=>{if(!n)throw new Error("No SDK instance available");if(!r)throw new Error("User not authorized");return n.getAuthContext()},enabled:!!(n&&r&&(e?.enabled??true))})}function Pe({profile:e,query:r}={}){let{isAuthorized:n}=l(),t=c(),{data:i}=B(),a=e||i?.profiles?.[0]?.id;return useQuery({...r,queryKey:d.getProfile(a),queryFn:async()=>{if(!t)throw new Error("No SDK instance available");if(!n)throw new Error("User not authorized");if(!a)throw new Error("Profile Id is required");return t.getProfile(a)},enabled:!!(t&&n&&a&&(r?.enabled??true))})}function B({query:e}={}){let{isAuthorized:r}=l(),n=c();return useQuery({...e,queryKey:d.getProfiles,queryFn:async()=>{if(!n)throw new Error("No SDK instance available");if(!r)throw new Error("User not authorized");return n.getProfiles()},enabled:!!(n&&r&&(e?.enabled??true))})}function qe({query:e}={}){let r=c(),{isAuthorized:n}=l();return useQuery({...e,queryKey:d.getTokens,queryFn:async()=>{if(!r)throw new Error("No SDK instance available");if(!n)throw new Error("User not authorized");return r.getTokens()},enabled:!!(r&&n&&(e?.enabled??true))})}function ve({address:e,query:r={}}){let n=c(),{isAuthorized:t}=l();return useQuery({...r,queryKey:d.getAddress(e),queryFn:async()=>{if(!n)throw new Error("No SDK instance available");if(!t)throw new Error("User not authorized");if(!e)throw new Error("Address is required");return n.getAddress(e)},enabled:!!(n&&t&&e&&(r?.enabled??true))})}function Ie({profile:e,chain:r,query:n={}}={}){let t=c(),{isAuthorized:i}=l();return useQuery({...n,queryKey:d.getAddresses({profile:e,chain:r?parseChain(r):undefined}),queryFn:async()=>{if(!t)throw new Error("No SDK instance available");if(!i)throw new Error("User not authorized");return t.getAddresses({profile:e,chain:r})},enabled:!!(t&&i&&(n?.enabled??true))})}function xe({address:e,chain:r,currencies:n,query:t}){let i=c(),{isAuthorized:a}=l();return useQuery({...t,queryKey:d.getBalances(e,parseChain(r),n),staleTime:1e3*60*5,queryFn:async()=>{if(!i)throw new Error("No SDK instance available");if(!a)throw new Error("User not authorized");return i.getBalances(e,r,n)},enabled:!!(i&&a&&(t?.enabled??true))})}function Ce({iban:e,query:r}){let n=c(),{isAuthorized:t}=l();return useQuery({...r,queryKey:d.getIban(e),queryFn:async()=>{if(!n)throw new Error("No SDK instance available");if(!t)throw new Error("User not authorized");return n.getIban(e)},enabled:!!(n&&t&&e&&(r?.enabled??true))})}function ze({profile:e,chain:r,query:n={}}={}){let t=c(),{isAuthorized:i}=l();return useQuery({...n,queryKey:d.getIbans({profile:e,chain:r}),queryFn:async()=>{if(!t)throw new Error("No SDK instance available");if(!i)throw new Error("User not authorized");return t.getIbans({profile:e,chain:r})},enabled:!!(t&&i&&(n?.enabled??true))})}function Ke({orderId:e,query:r={}}){let n=c(),{isAuthorized:t}=l();return useQuery({...r,queryKey:d.getOrder(e),queryFn:async()=>{if(!n)throw new Error("No SDK instance available");if(!t)throw new Error("User not authorized");if(!e)throw new Error("Order id is required");return n.getOrder(e)},enabled:!!(n&&t&&e&&(r.enabled??true))})}function Ne({query:e={},...r}={}){let n=c(),{isAuthorized:t}=l();return useQuery({...e,queryKey:d.getOrders(r),queryFn:async()=>{if(!n)throw new Error("No SDK instance available");if(!t)throw new Error("User not authorized");return n.getOrders(r)},enabled:!!(n&&t&&(e.enabled??true))})}function Re({profile:e,mutation:r={}}){let n=c(),{isAuthorized:t}=l(),i=useQueryClient(),{mutateAsync:a,...u}=useMutation({...r,mutationKey:d.submitProfileDetails,mutationFn:async s=>{if(!n)throw new Error("No SDK instance available");if(!t)throw new Error("User not authorized");return n.submitProfileDetails(e,s)},onSuccess(s,o,f){i.invalidateQueries({queryKey:d.getProfile(e)}),r?.onSuccess?.(s,o,f);},onError(s,o,f){throw r?.onError?.(s,o,f),s}});return {submitProfileDetails:a,...u}}function Me({mutation:e={}}={}){let r=c(),{isAuthorized:n}=l(),{mutateAsync:t,...i}=useMutation({...e,mutationKey:d.requestIban,mutationFn:async({address:a,chain:u,emailNotifications:s})=>{if(!r)throw new Error("No SDK instance available");if(!n)throw new Error("User not authorized");return r.requestIban({address:a,chain:u,emailNotifications:s})},onSuccess(a,u,s){e?.onSuccess?.(a,u,s);},onError(a,u,s){throw e?.onError?.(a,u,s),a}});return {requestIban:t,...i}}function De({mutation:e={}}={}){let r=c(),{isAuthorized:n}=l(),t=useQueryClient(),{mutateAsync:i,...a}=useMutation({...e,mutationKey:d.moveIban,mutationFn:async({iban:u,address:s,chain:o})=>{if(!r)throw new Error("No SDK instance available");if(!n)throw new Error("User not authorized");return r.moveIban(u,{address:s,chain:o})},onSuccess(u,s,o){t.invalidateQueries({queryKey:d.getIban(s.iban)}),t.invalidateQueries({queryKey:d.getIbans()}),t.invalidateQueries({queryKey:d.getAddress(s.address)}),e?.onSuccess?.(u,s,o);},onError(u,s,o){throw e?.onError?.(u,s,o),u}});return {moveIban:i,...a}}function Be({supportingDocument:e,mutation:r}={}){let n=c(),{isAuthorized:t}=l(),i=useQueryClient(),{mutateAsync:a,...u}=useMutation({...r,mutationKey:d.placeOrder,mutationFn:async s=>{if(!n)throw new Error("No SDK instance available");if(!t)throw new Error("User not authorized");let o;if(parseInt(s.amount)>15e3){if(!e)throw new Error("Supporting document is required for orders above 15000");o=(await n.uploadSupportingDocument(e)).id;}let f={...s,documentId:o};return n.placeOrder(f)},onSuccess(s,o,f){i.invalidateQueries({queryKey:d.getOrders()}),i.invalidateQueries({queryKey:d.getBalances(s.address,s.chain)}),r?.onSuccess?.(s,o,f);},onError(s,o,f){throw r?.onError?.(s,o,f),s}});return {placeOrder:a,...u}}function Fe({mutation:e}={}){let r=c(),{isAuthorized:n}=l(),t=useQueryClient(),{mutateAsync:i,...a}=useMutation({...e,mutationKey:d.linkAddress,mutationFn:async u=>{if(!r)throw new Error("No SDK instance available");if(!n)throw new Error("User not authorized");return r.linkAddress(u)},onSuccess(u,s,o){t.invalidateQueries({queryKey:d.getAddresses()}),s.profile&&t.invalidateQueries({queryKey:d.getProfile(s.profile)}),e?.onSuccess?.(u,s,o);},onError(u,s,o){throw e?.onError?.(u,s,o),u}});return {linkAddress:i,...a}}var Qe=({state:e,profile:r,onMessage:n,onError:t})=>{let i=c();return useEffect(()=>(i&&i.subscribeOrderNotifications({filter:{state:e,profile:r},onMessage:n,onError:t}),()=>{i&&i?.unsubscribeOrderNotifications({state:e,profile:r});}),[i,r,e]),()=>i?.unsubscribeOrderNotifications({state:e,profile:r})};export{w as MoneriumContext,J as MoneriumProvider,d as keys,ve as useAddress,Ie as useAddresses,l as useAuth,Se as useAuthContext,xe as useBalances,Ce as useIBAN,ze as useIBANs,Fe as useLinkAddress,De as useMoveIban,Ke as useOrder,Ne as useOrders,Be as usePlaceOrder,Pe as useProfile,B as useProfiles,Me as useRequestIban,Re as useSubmitProfileDetails,Qe as useSubscribeOrderNotification,qe as useTokens};//# sourceMappingURL=index.mjs.map
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/lib/context.tsx","../src/lib/provider.tsx","../src/lib/hooks.tsx"],"names":["MoneriumContext","createContext","MoneriumProvider","children","clientId","redirectUri","environment","refreshToken","onRefreshTokenUpdate","debug","queryClient","useQueryClient","sdk","useState","MoneriumClient","isAuthorized","setIsAuthorized","error","setError","loadingAuth","setLoadingAuth","useEffect","authorize","useCallback","params","err","siwe","revokeAccess","jsx","keys","profile","address","filter","chain","currencies","iban","orderId","useSdk","context","useContext","useAuth","useAuthContext","query","useQuery","useProfile","data","useProfiles","profileToUse","useTokens","useAddress","useAddresses","parseChain","useBalances","useIBAN","useIBANs","useOrder","useOrders","filters","useSubmitProfileDetails","mutation","mutateAsync","rest","useMutation","body","variables","vars","useRequestIban","emailNotifications","useMoveIban","usePlaceOrder","supportingDocument","documentId","newBody","useLinkAddress","useSubscribeOrderNotification","state","onMessage","onError"],"mappings":"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","file":"index.mjs","sourcesContent":["import { createContext } from 'react';\n\nimport { SdkInstance, UseAuthReturn } from './types';\n\nexport const MoneriumContext = createContext<\n  (UseAuthReturn & SdkInstance) | null\n>(null);\n","import { ReactNode, useCallback, useEffect, useState } from 'react';\nimport { useQueryClient } from '@tanstack/react-query';\n\nimport {\n  AuthFlowOptions,\n  AuthFlowSIWEOptions,\n  MoneriumClient,\n} from '@monerium/sdk';\n\nimport { MoneriumContext } from './context';\n\n/**\n * Wrap your application with the Monerium provider.\n * @group Provider\n * @param params\n * @param params.children - Rest of the application.\n * @param params.clientId - Monerium auth flow client id.\n * @param params.redirectUri - Monerium auth flow redirect url.\n * @param params.environment - Monerium environment.\n * @param params.onRefreshTokenUpdate - Callback that is called when the refresh token is updated. Store it securely.\n * @param params.refreshToken - Provide the securely stored refresh token to reconnect.\n * @param params.debug - Enable debug mode.\n * @returns\n */\nexport const MoneriumProvider = ({\n  children,\n  clientId,\n  redirectUri,\n  environment = 'sandbox',\n  refreshToken,\n  onRefreshTokenUpdate,\n  debug = false,\n}: {\n  children: ReactNode;\n  clientId: string;\n  redirectUri: string;\n  /** @deprecated use redirectUri */\n  redirectUrl?: string;\n  environment?: 'sandbox' | 'production';\n  refreshToken?: string;\n  onRefreshTokenUpdate?: (token: string) => void;\n  debug?: boolean;\n}) => {\n  const queryClient = useQueryClient();\n\n  const [sdk] = useState(() => {\n    // Initialize the SDK\n    return new MoneriumClient({\n      environment,\n      clientId,\n      redirectUri,\n      debug: debug,\n    });\n  });\n\n  const [isAuthorized, setIsAuthorized] = useState<boolean>(false);\n  const [error, setError] = useState<Error | unknown | null>(null);\n  const [loadingAuth, setLoadingAuth] = useState(true);\n\n  useEffect(() => {\n    const connect = async () => {\n      if (sdk) {\n        try {\n          setIsAuthorized(await sdk.getAccess());\n        } catch (error) {\n          console.error('Failed to get access:', error);\n        } finally {\n          setLoadingAuth(false);\n          if (sdk?.bearerProfile) {\n            onRefreshTokenUpdate?.(sdk.bearerProfile.refresh_token);\n          }\n        }\n      }\n    };\n\n    connect();\n\n    return () => {\n      if (sdk) {\n        sdk.disconnect();\n      }\n    };\n  }, []);\n\n  useEffect(() => {\n    const reconnect = async () => {\n      if (sdk) {\n        try {\n          setIsAuthorized(await sdk.getAccess(refreshToken));\n        } catch (error) {\n          console.error('Failed to get access:', error);\n        } finally {\n          if (sdk?.bearerProfile) {\n            onRefreshTokenUpdate?.(sdk.bearerProfile.refresh_token);\n          }\n        }\n      }\n    };\n    if (refreshToken && !isAuthorized && !loadingAuth) {\n      reconnect();\n    }\n  }, [refreshToken]);\n\n  const authorize = useCallback(\n    async (params?: AuthFlowOptions) => {\n      try {\n        if (sdk) {\n          await sdk.authorize(params);\n        }\n      } catch (err) {\n        console.error('Error during authorization:', err);\n        setError(err);\n      }\n    },\n    [sdk]\n  );\n\n  const siwe = useCallback(\n    async (params: AuthFlowSIWEOptions) => {\n      try {\n        if (sdk) {\n          await sdk.siwe(params);\n        }\n      } catch (err) {\n        console.error('Error during sign in with ethereum:', err);\n        setError(err);\n      }\n    },\n    [sdk]\n  );\n\n  const revokeAccess = async () => {\n    try {\n      if (sdk) {\n        await sdk.revokeAccess();\n      }\n    } catch (err) {\n      console.error('Error during revoking access:', err);\n      setError(err);\n    } finally {\n      queryClient.clear();\n      setIsAuthorized(false);\n    }\n  };\n\n  return (\n    <MoneriumContext.Provider\n      value={{\n        sdk,\n        authorize,\n        siwe,\n        isAuthorized,\n        isLoading: loadingAuth,\n        error,\n        disconnect: async () => sdk?.disconnect(),\n        revokeAccess: async () => revokeAccess(),\n      }}\n    >\n      {children}\n    </MoneriumContext.Provider>\n  );\n};\n","import { useContext, useEffect } from 'react';\nimport { useMutation, useQuery, useQueryClient } from '@tanstack/react-query';\n\nimport MoneriumClient, {\n  Address,\n  AddressesResponse,\n  AuthContext,\n  Balances,\n  Chain,\n  ChainId,\n  Currency,\n  CurrencyCode,\n  IBAN,\n  IBANsResponse,\n  LinkAddress,\n  LinkedAddress,\n  MoveIbanPayload,\n  NewOrder,\n  Order,\n  OrdersResponse,\n  OrderState,\n  parseChain,\n  Profile,\n  ProfilesResponse,\n  RequestIbanPayload,\n  ResponseStatus,\n  SubmitProfileDetailsPayload,\n  Token,\n} from '@monerium/sdk';\n\nimport { MoneriumContext } from './context';\nimport {\n  MutationOptions,\n  MutationResult,\n  QueryOptions,\n  UseAuthReturn,\n} from './types';\n\n/**\n * @internal\n * Query keys for React query\n * */\nexport const keys = {\n  getAll: ['monerium'],\n  getAuthContext: ['monerium', 'auth-context'],\n  getProfile: (profile: string) => [\n    'monerium',\n    'profile',\n    ...(profile ? [profile] : []),\n  ],\n  getProfiles: ['monerium', 'profiles'],\n  getAddress: (address: string) => ['monerium', 'address', [address]],\n  getAddresses: (filter?: unknown) => [\n    'monerium',\n    'addresses',\n    ...(filter ? [filter] : []),\n  ],\n  getBalances: (\n    address: string,\n    chain: Chain,\n    currencies?: CurrencyCode | CurrencyCode[]\n  ) => [\n    'monerium',\n    'balances',\n    {\n      currencies: currencies ? [...currencies] : [],\n      chain,\n      address,\n    },\n  ],\n  getIban: (iban: string) => ['monerium', 'iban', iban],\n  getIbans: (filter?: unknown) => [\n    'monerium',\n    'ibans',\n    ...(filter ? [filter] : []),\n  ],\n  getTokens: ['monerium', 'tokens'],\n  getOrder: (orderId: string) => ['monerium', 'order', orderId],\n  getOrders: (filter?: unknown) => [\n    'monerium',\n    'orders',\n    ...(filter ? [filter] : []),\n  ],\n  submitProfileDetails: ['monerium', 'submit-profile-details'],\n  moveIban: ['monerium', 'move-iban'],\n  requestIban: ['monerium', 'request-iban'],\n  placeOrder: ['monerium', 'place-order'],\n  linkAddress: ['monerium', 'link-address'],\n};\n\n/** Internal hook to use SDK */\nfunction useSdk(): MoneriumClient | undefined {\n  const context = useContext(MoneriumContext);\n\n  if (context === null) {\n    throw new Error('useSdk must be used within a MoneriumProvider');\n  }\n  return context?.sdk;\n}\n\n/**\n * # Redirect to the Monerium auth flow.\n * @group Hooks\n * @category Authentication\n * @example\n * ```ts\n * const { authorize, isAuthorized, isLoading, error } = useAuth();\n *\n * authorize(); // Redirects to the Monerium auth flow.\n *\n * // Opt-in to automated wallet linking with these parameters.\n * authorize({ address, signature, chain }).\n * ```\n *\n * @returns {UseAuthReturn}\n * - `authorize`  - Redirects to the Monerium auth flow.\n * - `siwe`       - Sign in with Ethereum. https://monerium.com/siwe\n * - `isAuthorized` - Whether the user is authorized.\n * - `isLoading` - Whether the auth flow is loading.\n * - `error` - Error message if the auth flow fails.\n * - `disconnect` - Disconnect the user.\n * - `revokeAccess` - Revoke the user's access.\n */\nexport function useAuth(): UseAuthReturn {\n  const context = useContext(MoneriumContext);\n\n  if (context === null) {\n    throw new Error('useAuth must be used within a MoneriumProvider');\n  }\n\n  return {\n    isAuthorized: context.isAuthorized,\n    authorize: context.authorize,\n    siwe: context.siwe,\n    isLoading: context.isLoading,\n    error: context.error,\n    disconnect: context.disconnect,\n    revokeAccess: context.revokeAccess,\n  };\n}\n\n/**\n * @group Hooks\n * @category Authentication\n * @param {Object} params\n *\n * @example\n * ```ts\n * const {\n *    data\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useAuthContext();\n * ```\n\n * @see {@link https://monerium.dev/api-docs/v2#tag/auth/operation/auth-context | API Documentation}\n */\nexport function useAuthContext({\n  query,\n}: {\n  /** {@inheritDoc QueryOptions} */\n  query?: QueryOptions<AuthContext>;\n} = {}) {\n  const { isAuthorized } = useAuth();\n  const sdk = useSdk();\n\n  return useQuery({\n    ...query,\n    queryKey: keys.getAuthContext,\n    queryFn: async () => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n\n      return sdk.getAuthContext();\n    },\n    enabled: Boolean(sdk && isAuthorized && (query?.enabled ?? true)),\n  });\n}\n/**\n * If no `profile` id is provided, the default profile is used.\n * @group Hooks\n * @category Profiles\n * @param {Object} params\n *\n * @example\n * ```ts\n * const {\n *    data\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useProfile();\n * ```\n\n * @see {@link https://monerium.dev/api-docs#operation/profile | API Documentation}\n */\nexport function useProfile({\n  profile,\n  query,\n}: {\n  /** The id of the profile */\n  profile?: string;\n  /** {@inheritDoc QueryOptions} */\n  query?: QueryOptions<Profile>;\n} = {}) {\n  const { isAuthorized } = useAuth();\n  const sdk = useSdk();\n\n  const { data } = useProfiles();\n\n  const profileToUse = profile || (data?.profiles?.[0]?.id as string);\n\n  return useQuery({\n    ...query,\n    queryKey: keys.getProfile(profileToUse),\n    queryFn: async () => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n      if (!profileToUse) {\n        throw new Error('Profile Id is required');\n      }\n\n      return sdk.getProfile(profileToUse);\n    },\n    enabled: Boolean(\n      sdk && isAuthorized && profileToUse && (query?.enabled ?? true)\n    ),\n  });\n}\n/**\n * # Get profiles\n * @group Hooks\n * @category Profiles\n *\n * @param {Object} [params] No required parameters.\n *\n * @example\n * ```ts\n * const {\n *    data,\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useProfiles();\n * ```\n * @see {@link https://monerium.dev/api-docs#operation/profiles | API Documentation}\n */\nexport function useProfiles({\n  query,\n}: {\n  /** {@inheritDoc QueryOptions} */\n  query?: QueryOptions<ProfilesResponse>;\n} = {}) {\n  const { isAuthorized } = useAuth();\n  const sdk = useSdk();\n\n  return useQuery({\n    ...query,\n    queryKey: keys.getProfiles,\n    queryFn: async () => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n      return sdk.getProfiles();\n    },\n    enabled: Boolean(sdk && isAuthorized && (query?.enabled ?? true)),\n  });\n}\n/**\n * @group Hooks\n * @param {Object} [params] No required parameters.\n *\n * @example\n * ```ts\n * const {\n *    data,\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useTokens();\n * ```\n\n * @see {@link https://monerium.dev/api-docs#operation/tokens | API Documentation}\n */\nexport function useTokens({\n  query,\n}: {\n  /** {@inheritDoc QueryOptions} */\n  query?: QueryOptions<Token[]>;\n} = {}) {\n  const sdk = useSdk();\n  const { isAuthorized } = useAuth();\n  return useQuery({\n    ...query,\n    queryKey: keys.getTokens,\n    queryFn: async () => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n      return sdk.getTokens();\n    },\n    enabled: Boolean(sdk && isAuthorized && (query?.enabled ?? true)),\n  });\n}\n\n/**\n * @group Hooks\n * @category Addresses\n * @param {Object} params \n\n * @example\n * ```ts\n * const {\n *    data,\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useAddress();\n * ```\n * @see {@link https://monerium.dev/api-docs-v2#tag/addresses/operation/address | API Documentation}\n */\nexport function useAddress({\n  address,\n  query = {},\n}: {\n  /** Fetch a specific address. */\n  address: string;\n  /** {@inheritDoc QueryOptions} */\n  query?: QueryOptions<Address>;\n}) {\n  const sdk = useSdk();\n  const { isAuthorized } = useAuth();\n\n  return useQuery({\n    ...query,\n    queryKey: keys.getAddress(address),\n    queryFn: async () => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n\n      if (!address) {\n        throw new Error('Address is required');\n      }\n\n      return sdk.getAddress(address);\n    },\n    enabled: Boolean(\n      sdk && isAuthorized && address && (query?.enabled ?? true)\n    ),\n  });\n}\n/**\n * @group Hooks\n * @category Addresses\n * @param {Object} [params] No required parameters.\n * @param {Object} [params.profile] Filter based on profile id.\n * @param {Object} [params.chain] Filter based on chain - CURRENTLY RETURNS AN ERROR.\n * @example\n * ```ts\n * const {\n *    data,\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useAddresses();\n * ```\n * @see {@link https://monerium.dev/api-docs-v2#tag/addresses/operation/addresses | API Documentation}\n */\nexport function useAddresses({\n  profile,\n  chain,\n  query = {},\n}: {\n  profile?: string;\n  chain?: Chain | ChainId;\n  /** {@inheritDoc QueryOptions} */\n  query?: QueryOptions<AddressesResponse>;\n} = {}) {\n  const sdk = useSdk();\n\n  const { isAuthorized } = useAuth();\n\n  return useQuery({\n    ...query,\n    queryKey: keys.getAddresses({\n      profile,\n      chain: chain ? parseChain(chain) : undefined,\n    }),\n    queryFn: async () => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n      return sdk.getAddresses({ profile, chain });\n    },\n    enabled: Boolean(sdk && isAuthorized && (query?.enabled ?? true)),\n  });\n}\n/**\n * # Get balance for a an address on a give chain\n * @group Hooks\n * @category Addresses\n * @param {Object} params\n * @param {QueryOptions<Balances>} params.address The address to fetch the balance for.\n * @param {QueryOptions<Balances>} params.chain The chain to fetch the balance for.\n * @param {QueryOptions<Balances>} [params.currencies] One or many: `eur`, `usd`, `gbp`, `isk`\n * @example\n * ```ts\n * const {\n *    data,\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useBalances();\n * ```\n * @see {@link https://monerium.dev/api-docs/v2#tag/addresses/operation/balances | API Documentation}\n *\n */\nexport function useBalances({\n  address,\n  chain,\n  currencies,\n  query,\n}: {\n  address: string;\n  chain: Chain | ChainId;\n  currencies?: Currency | Currency[];\n  /** {@inheritDoc QueryOptions} */\n  query?: QueryOptions<Balances>;\n}) {\n  const sdk = useSdk();\n  const { isAuthorized } = useAuth();\n\n  return useQuery({\n    ...query,\n    queryKey: keys.getBalances(address, parseChain(chain), currencies),\n    staleTime: 1000 * 60 * 5,\n    queryFn: async () => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n      return sdk.getBalances(address, chain, currencies);\n    },\n    enabled: Boolean(sdk && isAuthorized && (query?.enabled ?? true)),\n  });\n}\n\n/**\n * @group Hooks\n * @category IBANs\n * @param {Object} params\n * @example\n * ```ts\n * const {\n *    data,\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useIBAN();\n * ```\n * @see {@link https://monerium.dev/api-docs-v2#tag/ibans/operation/iban | API Documentation}\n */\nexport function useIBAN({\n  iban,\n  query,\n}: {\n  /** Fetch a specific IBAN */\n  iban: string;\n  /** {@inheritDoc QueryOptions} */\n  query?: QueryOptions<IBAN>;\n}) {\n  const sdk = useSdk();\n  const { isAuthorized } = useAuth();\n\n  return useQuery({\n    ...query,\n    queryKey: keys.getIban(iban),\n    queryFn: async () => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n\n      return sdk.getIban(iban);\n    },\n    enabled: Boolean(sdk && isAuthorized && iban && (query?.enabled ?? true)),\n  });\n}\n/**\n * @group Hooks\n * @category IBANs\n * @param {Object} [params] No required parameters.\n * @example\n * ```ts\n * const {\n *    data,\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useIBANs();\n * ```\n * @see {@link https://monerium.dev/api-docs-v2#tag/ibans/operation/ibans | API Documentation}\n */\nexport function useIBANs({\n  profile,\n  chain,\n  query = {},\n}: {\n  /** Fetch IBANs for a specific profile. */\n  profile?: string;\n  /** Fetch IBANs for a specific chain. */\n  chain?: Chain | ChainId;\n  /** {@inheritDoc QueryOptions} */\n  query?: QueryOptions<IBANsResponse>;\n} = {}) {\n  const sdk = useSdk();\n  const { isAuthorized } = useAuth();\n\n  return useQuery({\n    ...query,\n    queryKey: keys.getIbans({ profile, chain }),\n    queryFn: async () => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n\n      return sdk.getIbans({ profile, chain });\n    },\n    enabled: Boolean(sdk && isAuthorized && (query?.enabled ?? true)),\n  });\n}\n\n/**\n * @group Hooks\n * @category Orders\n * @param {Object} params\n * @example\n * ```ts\n * const {\n *    data,\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useOrder();\n * ```\n * @see {@link https://monerium.dev/api-docs#operation/order| API Documentation}\n */\nexport function useOrder({\n  orderId,\n  query = {},\n}: {\n  /**  The id of the order. */\n  orderId: string;\n  /** {@inheritDoc QueryOptions} */\n  query?: QueryOptions<Order>;\n}) {\n  const sdk = useSdk();\n  const { isAuthorized } = useAuth();\n  return useQuery({\n    ...query,\n    queryKey: keys.getOrder(orderId),\n    queryFn: async () => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n      if (!orderId) {\n        throw new Error('Order id is required');\n      }\n\n      return sdk.getOrder(orderId);\n    },\n    enabled: Boolean(sdk && isAuthorized && orderId && (query.enabled ?? true)),\n  });\n}\n\n/**\n * @group Hooks\n * @category Orders\n * @param {Object} [params] No required parameters.\n * @param {Object} [params.address] Filter based on the blockchain address associated with the order.\n * @param {Object} [params.memo] Filter by the payment memo/reference..\n * @param {Object} [params.profile] Filter based on the profile ID associated with the order.\n * @param {Object} [params.state] Filter based on the state of the order.\n * @param {Object} [params.txHash] Filter based on the blockchain transaction hash.\n *\n * @example\n * ```ts\n * const {\n *    data,\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useOrders();\n * ```\n * @see {@link https://monerium.dev/api-docs#operation/orders | API Documentation}\n */\nexport function useOrders({\n  query = {},\n  ...filters\n}: {\n  /** {@inheritDoc QueryOptions} */\n  query?: QueryOptions<OrdersResponse>;\n  address?: string;\n  txHash?: string;\n  profile?: string;\n  memo?: string;\n  state?: OrderState;\n} = {}) {\n  const sdk = useSdk();\n  const { isAuthorized } = useAuth();\n  return useQuery({\n    ...query,\n    queryKey: keys.getOrders(filters),\n    queryFn: async () => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n\n      return sdk.getOrders(filters);\n    },\n    enabled: Boolean(sdk && isAuthorized && (query.enabled ?? true)),\n  });\n}\n\n/**\n * Submit the required compliance information to onboard the customer.\n *\n * Note that you won't be able to change the profile \"kind\" from personal to corporate or vice versa once the profile has been approved.\n * @group Hooks\n * @category Profiles\n * @param param\n * @param {string} param.profile The id of the profile to submit to.\n *\n * @example\n * ```ts\n * const {\n *    submitProfileDetails, // useMutation's `mutateAsync` property\n *    isPending,\n *    isError,\n *    error,\n *    status,\n *    ...moreUseMutationResults\n * } = useSubmitProfileDetails();\n * ```\n * @see {@link https://monerium.dev/api-docs-v2#tag/profiles/operation/profile-details | API Documentation}}\n */\n\nexport function useSubmitProfileDetails({\n  profile,\n  mutation = {},\n}: {\n  profile: string;\n  /** {@inheritDoc MutationOptions} */\n  mutation?: MutationOptions<\n    ResponseStatus,\n    Error,\n    SubmitProfileDetailsPayload\n  >;\n}): MutationResult<\n  'submitProfileDetails',\n  ResponseStatus,\n  Error,\n  SubmitProfileDetailsPayload\n> {\n  const sdk = useSdk();\n  const { isAuthorized } = useAuth();\n  const queryClient = useQueryClient();\n\n  const { mutateAsync, ...rest } = useMutation({\n    ...mutation,\n    mutationKey: keys.submitProfileDetails,\n    mutationFn: async (body: SubmitProfileDetailsPayload) => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n\n      return sdk.submitProfileDetails(profile, body);\n    },\n    onSuccess(data, variables, context) {\n      // Refetch all orders on success.\n      queryClient.invalidateQueries({\n        queryKey: keys.getProfile(profile),\n      });\n      // Allow the caller to add custom logic on success.\n      mutation?.onSuccess?.(data, variables, context);\n    },\n    onError(error, vars, context) {\n      // Allow the caller to add custom logic on error.\n      mutation?.onError?.(error, vars, context);\n      throw error;\n    },\n  });\n  return {\n    submitProfileDetails: mutateAsync,\n    ...rest,\n  };\n}\n/**\n * Create an IBAN for a specified address and chain.\n * All incoming EUR payments will automatically be routed to the linked address on that chain.\n * Any linked address can use this IBAN for outgoing payments.\n * @group Hooks\n * @category IBANs\n * @param {Object} [params] No required parameters.\n *\n * @example\n * ```ts\n * const {\n *    requestIban, // useMutation's `mutateAsync` property\n *    isPending,\n *    isError,\n *    error,\n *    status,\n *    ...moreUseMutationResults\n * } = useRequestIban();\n * ```\n * @see {@link https://monerium.dev/api-docs-v2#tag/ibans/operation/request-iban | API Documentation}}\n */\n\nexport function useRequestIban({\n  mutation = {},\n}: {\n  /** {@inheritDoc MutationOptions} */\n  mutation?: MutationOptions<ResponseStatus, Error, RequestIbanPayload>;\n} = {}): MutationResult<\n  'requestIban',\n  ResponseStatus,\n  Error,\n  RequestIbanPayload\n> {\n  const sdk = useSdk();\n  const { isAuthorized } = useAuth();\n\n  const { mutateAsync, ...rest } = useMutation({\n    ...mutation,\n    mutationKey: keys.requestIban,\n    mutationFn: async ({\n      address,\n      chain,\n      emailNotifications,\n    }: RequestIbanPayload) => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n\n      return sdk.requestIban({ address, chain, emailNotifications });\n    },\n    onSuccess(data, variables, context) {\n      // Allow the caller to add custom logic on success.\n      mutation?.onSuccess?.(data, variables, context);\n    },\n    onError(error, vars, context) {\n      // Allow the caller to add custom logic on error.\n      mutation?.onError?.(error, vars, context);\n      throw error;\n    },\n  });\n  return {\n    requestIban: mutateAsync,\n    ...rest,\n  };\n}\n/**\n * Move an existing IBAN to a specified address an chain.\n * All incoming EUR payments will automatically be routed to the address on that chain.\n * @group Hooks\n * @category IBANs\n * @param {Object} [params] No required parameters.\n *\n * @example\n * ```ts\n * const {\n *    moveIban, // useMutation's `mutateAsync` property\n *    isPending,\n *    isError,\n *    error,\n *    status,\n *    ...moreUseMutationResults\n * } = useMoveIban();\n * ```\n * @see {@link https://monerium.dev/api-docs/v2#tag/ibans/operation/move-iban | API Documentation}\n */\n\nexport function useMoveIban({\n  mutation = {},\n}: {\n  /** {@inheritDoc MutationOptions} */\n  mutation?: MutationOptions<\n    ResponseStatus,\n    Error,\n    MoveIbanPayload & { iban: string }\n  >;\n} = {}): MutationResult<\n  'moveIban',\n  ResponseStatus,\n  Error,\n  MoveIbanPayload & { iban: string }\n> {\n  const sdk = useSdk();\n  const { isAuthorized } = useAuth();\n  const queryClient = useQueryClient();\n\n  const { mutateAsync, ...rest } = useMutation({\n    ...mutation,\n    mutationKey: keys.moveIban,\n    mutationFn: async ({\n      iban,\n      address,\n      chain,\n    }: MoveIbanPayload & { iban: string }) => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n\n      return sdk.moveIban(iban, { address, chain });\n    },\n    onSuccess(data, variables, context) {\n      // Refetch all orders on success.\n      queryClient.invalidateQueries({\n        queryKey: keys.getIban(variables.iban),\n      });\n      queryClient.invalidateQueries({\n        queryKey: keys.getIbans(),\n      });\n      queryClient.invalidateQueries({\n        queryKey: keys.getAddress(variables.address),\n      });\n      // Allow the caller to add custom logic on success.\n      mutation?.onSuccess?.(data, variables, context);\n    },\n    onError(error, vars, context) {\n      // Allow the caller to add custom logic on error.\n      mutation?.onError?.(error, vars, context);\n      throw error;\n    },\n  });\n  return {\n    moveIban: mutateAsync,\n    ...rest,\n  };\n}\n/**\n * When the order has been placed, the orders query will be invalidated and re-fetched.\n *\n * If the order amount is above 15000, a supporting document is required.\n * @group Hooks\n * @category Orders\n * @param param\n * @param {File} param.supportingDocument Supporting document file.\n *\n * @example\n * ```ts\n * const {\n *    placeOrder, // useMutation's `mutateAsync` property\n *    isPending,\n *    isError,\n *    error,\n *    status,\n *    ...moreUseMutationResults\n * } = usePlaceOrder();\n * ```\n * @see {@link https://monerium.dev/api-docs#operation/post-orders| API Documentation}\n */\n\nexport function usePlaceOrder({\n  supportingDocument,\n  mutation,\n}: {\n  supportingDocument?: File;\n  /** {@inheritDoc MutationOptions} */\n  mutation?: MutationOptions<Order, Error, NewOrder>;\n} = {}): MutationResult<'placeOrder', Order, Error, NewOrder> {\n  const sdk = useSdk();\n  const { isAuthorized } = useAuth();\n  const queryClient = useQueryClient();\n\n  const { mutateAsync, ...rest } = useMutation({\n    ...mutation,\n    mutationKey: keys.placeOrder,\n    mutationFn: async (body: NewOrder) => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n      let documentId;\n      if (parseInt(body.amount) > 15000) {\n        if (!supportingDocument) {\n          throw new Error(\n            'Supporting document is required for orders above 15000'\n          );\n        }\n        const uploadedDocument =\n          await sdk.uploadSupportingDocument(supportingDocument);\n        documentId = uploadedDocument.id;\n      }\n\n      const newBody = {\n        ...body,\n        documentId: documentId,\n      };\n\n      return sdk.placeOrder(newBody);\n    },\n    onSuccess(data, variables, context) {\n      // Refetch all orders on success.\n      queryClient.invalidateQueries({\n        queryKey: keys.getOrders(),\n      });\n      queryClient.invalidateQueries({\n        queryKey: keys.getBalances(data.address, data.chain),\n      });\n      // Allow the caller to add custom logic on success.\n      mutation?.onSuccess?.(data, variables, context);\n    },\n    onError(error, vars, context) {\n      // Allow the caller to add custom logic on error.\n      mutation?.onError?.(error, vars, context);\n      throw error;\n    },\n  });\n  return {\n    placeOrder: mutateAsync,\n    ...rest,\n  };\n}\n/**\n * # Add address to profile.\n *\n * @group Hooks\n * @category Profiles\n * @param {Object} [params] No required parameters.\n *\n * @example\n * ```ts\n * const {\n *    linkAddress, // useMutation's `mutateAsync` property\n *    isPending,\n *    isError,\n *    error,\n *    status,\n *    ...moreUseMutationResults\n * } = useLinkAddress();\n * ```\n * @see {@link https://monerium.dev/api-docs#operation/profile-addresses | API Documentation}\n */\n\nexport function useLinkAddress({\n  mutation,\n}: {\n  /** {@inheritDoc MutationOptions} */\n  mutation?: MutationOptions<LinkedAddress, Error, LinkAddress>;\n} = {}): MutationResult<'linkAddress', LinkedAddress, Error, LinkAddress> {\n  const sdk = useSdk();\n  const { isAuthorized } = useAuth();\n  const queryClient = useQueryClient();\n\n  const { mutateAsync, ...rest } = useMutation({\n    ...mutation,\n    mutationKey: keys.linkAddress,\n    mutationFn: async (body: LinkAddress) => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n      return sdk.linkAddress(body);\n    },\n    onSuccess(data, variables, context) {\n      // Refetch all orders on success.\n      queryClient.invalidateQueries({\n        queryKey: keys.getAddresses(),\n      });\n      if (variables.profile) {\n        queryClient.invalidateQueries({\n          queryKey: keys.getProfile(variables.profile),\n        });\n      }\n      // Allow the caller to add custom logic on success.\n      mutation?.onSuccess?.(data, variables, context);\n    },\n    onError(error, vars, context) {\n      // Allow the caller to add custom logic on error.\n      mutation?.onError?.(error, vars, context);\n      throw error;\n    },\n  });\n  return {\n    linkAddress: mutateAsync,\n    ...rest,\n  };\n}\n\n/**\n * API consumers have the option to subscribe to a WebSocket for real-time order notifications. This WebSocket complies with the standard WebSocket Protocol, allowing the use of standard WebSocket libraries for subscription.\n *\n * The WebSocket emits an event when a order changes state:\n *\n * `placed`: The order has been created but not yet processed.\n *\n * `pending`: The order is awaiting fulfillment (e.g., review, minting/burning tokens, or sending/receiving SEPA payment).\n *\n * `processed`: The order has been completed successfully.\n *\n * `rejected`: The order was rejected, possibly due to compliance reasons or insufficient funds.\n * @group Hooks\n * @category Orders\n * @param {Object} params\n * @param {OrderState} [params.state] Filter based on the state of the order.\n * @param {string} [params.profile] Filter based on the profile id of the order.\n * @param {Function} params.onMessage Callback function to handle the order notification.\n * @param {Function} [params.onError] Callback function to handle the error notification.\n *\n * @example\n * ```ts\n * const {\n *    state,\n *    profile,\n *    onMessage,\n *    onError\n * } = useSubscribeOrderNotification();\n * ```\n * @see {@link https://monerium.dev/api-docs/v1#operation/orders-notifications| API Documentation}\n * @returns {Function} Unsubscribe from order notifications.\n */\n\nexport const useSubscribeOrderNotification = ({\n  state,\n  profile,\n  onMessage,\n  onError,\n}: {\n  state?: OrderState;\n  profile?: string;\n  onMessage: (order: Order) => void;\n  onError?: ((err: Event) => void) | undefined;\n}) => {\n  const sdk = useSdk();\n\n  useEffect(() => {\n    if (sdk) {\n      sdk.subscribeOrderNotifications({\n        filter: {\n          state: state,\n          profile: profile,\n        },\n        onMessage: onMessage,\n        onError: onError,\n      });\n    }\n    return () => {\n      /**\n       * Note that in development mode, React Strict mode will cause this\n       * cleanup function to be called twice on client side route changes.\n       * So a socket will be immediately closed and opened again.\n       * This is not an issue in production mode.\n       */\n      if (sdk) {\n        sdk?.unsubscribeOrderNotifications({ state: state, profile: profile });\n      }\n    };\n  }, [sdk, profile, state]);\n\n  return () =>\n    sdk?.unsubscribeOrderNotifications({ state: state, profile: profile });\n};\n\n/** Export types for documentation */\nexport type {\n  Address,\n  Balances,\n  IBAN,\n  MoveIbanPayload,\n  LinkAddress,\n  Profile,\n  Token,\n  SubmitProfileDetailsPayload,\n  NewOrder,\n  ResponseStatus,\n  Order,\n};\n"]}
|
|
1
|
+
import {createContext,useState,useEffect,useCallback,useContext}from'react';import {useQueryClient,useQuery,useMutation}from'@tanstack/react-query';import {MoneriumClient,parseChain}from'@monerium/sdk';import {jsx}from'react/jsx-runtime';var g=createContext(null);var J=({children:e,clientId:r,redirectUri:n,environment:t="sandbox",refreshToken:i,onRefreshTokenUpdate:a,debug:u=false})=>{let s=useQueryClient(),[o]=useState(()=>new MoneriumClient({environment:t,clientId:r,redirectUri:n,debug:u})),[c,y]=useState(false),[p,b]=useState(null),[k,I]=useState(true);useEffect(()=>((async()=>{if(o)try{y(await o.getAccess());}catch(m){b(m);}finally{I(false),o?.bearerProfile&&a?.(o.bearerProfile.refresh_token);}})(),()=>{o&&o.disconnect();}),[]),useEffect(()=>{i&&!c&&!k&&(async()=>{if(o)try{y(await o.getAccess(i));}catch(m){b(m);}finally{o?.bearerProfile&&a?.(o.bearerProfile.refresh_token);}})();},[i]);let x=useCallback(async w=>{try{o&&await o.authorize(w);}catch(m){console.error("Error during authorization:",m),b(m);}},[o]),z=useCallback(async w=>{try{o&&await o.siwe(w);}catch(m){console.error("Error during sign in with ethereum:",m),b(m);}},[o]),C=async()=>{try{o&&await o.revokeAccess();}catch(w){console.error("Error during revoking access:",w),b(w);}finally{s.clear(),y(false);}};return jsx(g.Provider,{value:{sdk:o,authorize:x,siwe:z,isAuthorized:c,isLoading:k,error:p,disconnect:async()=>o?.disconnect(),revokeAccess:async()=>C()},children:e})};var d={getAll:["monerium"],getAuthContext:["monerium","auth-context"],getProfile:e=>["monerium","profile",...e?[e]:[]],getProfiles:["monerium","profiles"],getAddress:e=>["monerium","address",[e]],getAddresses:e=>["monerium","addresses",...e?[e]:[]],getBalances:(e,r,n)=>["monerium","balances",{currencies:n?[...n]:[],chain:r,address:e}],getIban:e=>["monerium","iban",e],getIbans:e=>["monerium","ibans",...e?[e]:[]],getTokens:["monerium","tokens"],getOrder:e=>["monerium","order",e],getOrders:e=>["monerium","orders",...e?[e]:[]],submitProfileDetails:["monerium","submit-profile-details"],moveIban:["monerium","move-iban"],requestIban:["monerium","request-iban"],placeOrder:["monerium","place-order"],linkAddress:["monerium","link-address"],getSignatures:e=>["monerium","signatures",...e?[e]:[]]};function l(){let e=useContext(g);if(e===null)throw new Error("useSdk must be used within a MoneriumProvider");return e?.sdk}function f(){let e=useContext(g);if(e===null)throw new Error("useAuth must be used within a MoneriumProvider");return {isAuthorized:e.isAuthorized,authorize:e.authorize,siwe:e.siwe,isLoading:e.isLoading,error:e.error,disconnect:e.disconnect,revokeAccess:e.revokeAccess}}function qe({query:e}={}){let{isAuthorized:r}=f(),n=l();return useQuery({...e,queryKey:d.getAuthContext,queryFn:async()=>{if(!n)throw new Error("No SDK instance available");if(!r)throw new Error("User not authorized");return n.getAuthContext()},enabled:!!(n&&r&&(e?.enabled??true))})}function ve({profile:e,query:r}={}){let{isAuthorized:n}=f(),t=l(),{data:i}=B(),a=e||i?.profiles?.[0]?.id;return useQuery({...r,queryKey:d.getProfile(a),queryFn:async()=>{if(!t)throw new Error("No SDK instance available");if(!n)throw new Error("User not authorized");if(!a)throw new Error("Profile Id is required");return t.getProfile(a)},enabled:!!(t&&n&&a&&(r?.enabled??true))})}function B({query:e}={}){let{isAuthorized:r}=f(),n=l();return useQuery({...e,queryKey:d.getProfiles,queryFn:async()=>{if(!n)throw new Error("No SDK instance available");if(!r)throw new Error("User not authorized");return n.getProfiles()},enabled:!!(n&&r&&(e?.enabled??true))})}function Ie({query:e}={}){let r=l(),{isAuthorized:n}=f();return useQuery({...e,queryKey:d.getTokens,queryFn:async()=>{if(!r)throw new Error("No SDK instance available");if(!n)throw new Error("User not authorized");return r.getTokens()},enabled:!!(r&&n&&(e?.enabled??true))})}function xe({address:e,query:r={}}){let n=l(),{isAuthorized:t}=f();return useQuery({...r,queryKey:d.getAddress(e),queryFn:async()=>{if(!n)throw new Error("No SDK instance available");if(!t)throw new Error("User not authorized");if(!e)throw new Error("Address is required");return n.getAddress(e)},enabled:!!(n&&t&&e&&(r?.enabled??true))})}function ze({profile:e,chain:r,query:n={}}={}){let t=l(),{isAuthorized:i}=f();return useQuery({...n,queryKey:d.getAddresses({profile:e,chain:r?parseChain(r):void 0}),queryFn:async()=>{if(!t)throw new Error("No SDK instance available");if(!i)throw new Error("User not authorized");return t.getAddresses({profile:e,chain:r})},enabled:!!(t&&i&&(n?.enabled??true))})}function Ce({address:e,chain:r,currencies:n,query:t}){let i=l(),{isAuthorized:a}=f();return useQuery({...t,queryKey:d.getBalances(e,parseChain(r),n),staleTime:1e3*60*5,queryFn:async()=>{if(!i)throw new Error("No SDK instance available");if(!a)throw new Error("User not authorized");return i.getBalances(e,r,n)},enabled:!!(i&&a&&(t?.enabled??true))})}function Ke({iban:e,query:r}){let n=l(),{isAuthorized:t}=f();return useQuery({...r,queryKey:d.getIban(e),queryFn:async()=>{if(!n)throw new Error("No SDK instance available");if(!t)throw new Error("User not authorized");return n.getIban(e)},enabled:!!(n&&t&&e&&(r?.enabled??true))})}function Re({profile:e,chain:r,query:n={}}={}){let t=l(),{isAuthorized:i}=f();return useQuery({...n,queryKey:d.getIbans({profile:e,chain:r}),queryFn:async()=>{if(!t)throw new Error("No SDK instance available");if(!i)throw new Error("User not authorized");return t.getIbans({profile:e,chain:r})},enabled:!!(t&&i&&(n?.enabled??true))})}function Ne({orderId:e,query:r={}}){let n=l(),{isAuthorized:t}=f();return useQuery({...r,queryKey:d.getOrder(e),queryFn:async()=>{if(!n)throw new Error("No SDK instance available");if(!t)throw new Error("User not authorized");if(!e)throw new Error("Order id is required");return n.getOrder(e)},enabled:!!(n&&t&&e&&(r.enabled??true))})}function De({query:e={},...r}={}){let n=l(),{isAuthorized:t}=f();return useQuery({...e,queryKey:d.getOrders(r),queryFn:async()=>{if(!n)throw new Error("No SDK instance available");if(!t)throw new Error("User not authorized");return n.getOrders(r)},enabled:!!(n&&t&&(e.enabled??true))})}function Me({profile:e,mutation:r={}}){let n=l(),{isAuthorized:t}=f(),i=useQueryClient(),{mutateAsync:a,...u}=useMutation({...r,mutationKey:d.submitProfileDetails,mutationFn:async s=>{if(!n)throw new Error("No SDK instance available");if(!t)throw new Error("User not authorized");return n.submitProfileDetails(e,s)},onSuccess(s,o,c,y){i.invalidateQueries({queryKey:d.getProfile(e)}),r?.onSuccess?.(s,o,c,y);},onError(s,o,c,y){throw r?.onError?.(s,o,c,y),s}});return {submitProfileDetails:a,...u}}function Be({mutation:e={}}={}){let r=l(),{isAuthorized:n}=f(),{mutateAsync:t,...i}=useMutation({...e,mutationKey:d.requestIban,mutationFn:async({address:a,chain:u,emailNotifications:s})=>{if(!r)throw new Error("No SDK instance available");if(!n)throw new Error("User not authorized");return r.requestIban({address:a,chain:u,emailNotifications:s})},onSuccess(a,u,s,o){e?.onSuccess?.(a,u,s,o);},onError(a,u,s,o){throw e?.onError?.(a,u,s,o),a}});return {requestIban:t,...i}}function Qe({mutation:e={}}={}){let r=l(),{isAuthorized:n}=f(),t=useQueryClient(),{mutateAsync:i,...a}=useMutation({...e,mutationKey:d.moveIban,mutationFn:async({iban:u,address:s,chain:o})=>{if(!r)throw new Error("No SDK instance available");if(!n)throw new Error("User not authorized");return r.moveIban(u,{address:s,chain:o})},onSuccess(u,s,o,c){t.invalidateQueries({queryKey:d.getIban(s.iban)}),t.invalidateQueries({queryKey:d.getIbans()}),t.invalidateQueries({queryKey:d.getAddress(s.address)}),e?.onSuccess?.(u,s,o,c);},onError(u,s,o,c){throw e?.onError?.(u,s,o,c),u}});return {moveIban:i,...a}}function Ue({supportingDocument:e,mutation:r}={}){let n=l(),{isAuthorized:t}=f(),i=useQueryClient(),{mutateAsync:a,...u}=useMutation({...r,mutationKey:d.placeOrder,mutationFn:async s=>{if(!n)throw new Error("No SDK instance available");if(!t)throw new Error("User not authorized");let o;if(parseInt(s.amount)>15e3){if(!e)throw new Error("Supporting document is required for orders above 15000");o=(await n.uploadSupportingDocument(e)).id;}let c={...s,documentId:o};return n.placeOrder(c)},onSuccess(s,o,c,y){i.invalidateQueries({queryKey:d.getOrders()});let p=s;p.address&&p?.chain&&i.invalidateQueries({queryKey:d.getBalances(p.address,p.chain)}),r?.onSuccess?.(s,o,c,y);},onError(s,o,c,y){throw r?.onError?.(s,o,c,y),s}});return {placeOrder:a,...u}}function Fe({query:e,options:r}={}){let n=l(),{isAuthorized:t}=f();return useQuery({...r,queryKey:d.getSignatures(e),queryFn:()=>{if(!n)throw new Error("No SDK instance available");return n.getSignatures(e)},enabled:!!(n&&t&&(r?.enabled??true))})}function Le({mutation:e}={}){let r=l(),{isAuthorized:n}=f(),t=useQueryClient(),{mutateAsync:i,...a}=useMutation({...e,mutationKey:d.linkAddress,mutationFn:async u=>{if(!r)throw new Error("No SDK instance available");if(!n)throw new Error("User not authorized");return r.linkAddress(u)},onSuccess(u,s,o,c){t.invalidateQueries({queryKey:d.getAddresses()}),s.profile&&t.invalidateQueries({queryKey:d.getProfile(s.profile)}),e?.onSuccess?.(u,s,o,c);},onError(u,s,o,c){throw e?.onError?.(u,s,o,c),u}});return {linkAddress:i,...a}}var Te=({state:e,profile:r,onMessage:n,onError:t})=>{let i=l();return useEffect(()=>(i&&i.subscribeOrderNotifications({filter:{state:e,profile:r},onMessage:n,onError:t}),()=>{i&&i?.unsubscribeOrderNotifications({state:e,profile:r});}),[i,r,e]),()=>i?.unsubscribeOrderNotifications({state:e,profile:r})};export{g as MoneriumContext,J as MoneriumProvider,d as keys,xe as useAddress,ze as useAddresses,f as useAuth,qe as useAuthContext,Ce as useBalances,Ke as useIBAN,Re as useIBANs,Le as useLinkAddress,Qe as useMoveIban,Ne as useOrder,De as useOrders,Ue as usePlaceOrder,ve as useProfile,B as useProfiles,Be as useRequestIban,Fe as useSignatures,Me as useSubmitProfileDetails,Te as useSubscribeOrderNotification,Ie as useTokens};//# sourceMappingURL=index.mjs.map
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/lib/context.tsx","../src/lib/provider.tsx","../src/lib/hooks.tsx"],"names":["MoneriumContext","createContext","MoneriumProvider","children","clientId","redirectUri","environment","refreshToken","onRefreshTokenUpdate","debug","queryClient","useQueryClient","sdk","useState","MoneriumClient","isAuthorized","setIsAuthorized","error","setError","loadingAuth","setLoadingAuth","useEffect","authorize","useCallback","params","err","siwe","revokeAccess","jsx","keys","profile","address","filter","chain","currencies","iban","orderId","useSdk","context","useContext","useAuth","useAuthContext","query","useQuery","useProfile","data","useProfiles","profileToUse","useTokens","useAddress","useAddresses","parseChain","useBalances","useIBAN","useIBANs","useOrder","useOrders","filters","useSubmitProfileDetails","mutation","mutateAsync","rest","useMutation","body","variables","mutationContext","vars","useRequestIban","emailNotifications","useMoveIban","usePlaceOrder","supportingDocument","documentId","newBody","orderData","useSignatures","options","useLinkAddress","useSubscribeOrderNotification","state","onMessage","onError"],"mappings":"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","file":"index.mjs","sourcesContent":["import { createContext } from 'react';\n\nimport { SdkInstance, UseAuthReturn } from './types';\n\nexport const MoneriumContext = createContext<\n  (UseAuthReturn & SdkInstance) | null\n>(null);\n","import { ReactNode, useCallback, useEffect, useState } from 'react';\nimport { useQueryClient } from '@tanstack/react-query';\n\nimport {\n  AuthFlowOptions,\n  AuthFlowSIWEOptions,\n  MoneriumClient,\n} from '@monerium/sdk';\n\nimport { MoneriumContext } from './context';\n\n/**\n * Wrap your application with the Monerium provider.\n * @group Provider\n * @param params\n * @param params.children - Rest of the application.\n * @param params.clientId - Monerium auth flow client id.\n * @param params.redirectUri - Monerium auth flow redirect url.\n * @param params.environment - Monerium environment.\n * @param params.onRefreshTokenUpdate - Callback that is called when the refresh token is updated. Store it securely.\n * @param params.refreshToken - Provide the securely stored refresh token to reconnect.\n * @param params.debug - Enable debug mode.\n * @returns\n */\nexport const MoneriumProvider = ({\n  children,\n  clientId,\n  redirectUri,\n  environment = 'sandbox',\n  refreshToken,\n  onRefreshTokenUpdate,\n  debug = false,\n}: {\n  children: ReactNode;\n  clientId: string;\n  redirectUri: string;\n  /** @deprecated use redirectUri */\n  redirectUrl?: string;\n  environment?: 'sandbox' | 'production';\n  refreshToken?: string;\n  onRefreshTokenUpdate?: (token: string) => void;\n  debug?: boolean;\n}) => {\n  const queryClient = useQueryClient();\n\n  const [sdk] = useState(() => {\n    // Initialize the SDK\n    return new MoneriumClient({\n      environment,\n      clientId,\n      redirectUri,\n      debug: debug,\n    });\n  });\n\n  const [isAuthorized, setIsAuthorized] = useState<boolean>(false);\n  const [error, setError] = useState<Error | unknown | null>(null);\n  const [loadingAuth, setLoadingAuth] = useState(true);\n\n  useEffect(() => {\n    const connect = async () => {\n      if (sdk) {\n        try {\n          setIsAuthorized(await sdk.getAccess());\n        } catch (error) {\n          setError(error);\n        } finally {\n          setLoadingAuth(false);\n          if (sdk?.bearerProfile) {\n            onRefreshTokenUpdate?.(sdk.bearerProfile.refresh_token);\n          }\n        }\n      }\n    };\n\n    connect();\n\n    return () => {\n      if (sdk) {\n        sdk.disconnect();\n      }\n    };\n  }, []);\n\n  useEffect(() => {\n    const reconnect = async () => {\n      if (sdk) {\n        try {\n          setIsAuthorized(await sdk.getAccess(refreshToken));\n        } catch (error) {\n          setError(error);\n        } finally {\n          if (sdk?.bearerProfile) {\n            onRefreshTokenUpdate?.(sdk.bearerProfile.refresh_token);\n          }\n        }\n      }\n    };\n    if (refreshToken && !isAuthorized && !loadingAuth) {\n      reconnect();\n    }\n  }, [refreshToken]);\n\n  const authorize = useCallback(\n    async (params?: AuthFlowOptions) => {\n      try {\n        if (sdk) {\n          await sdk.authorize(params);\n        }\n      } catch (err) {\n        console.error('Error during authorization:', err);\n        setError(err);\n      }\n    },\n    [sdk]\n  );\n\n  const siwe = useCallback(\n    async (params: AuthFlowSIWEOptions) => {\n      try {\n        if (sdk) {\n          await sdk.siwe(params);\n        }\n      } catch (err) {\n        console.error('Error during sign in with ethereum:', err);\n        setError(err);\n      }\n    },\n    [sdk]\n  );\n\n  const revokeAccess = async () => {\n    try {\n      if (sdk) {\n        await sdk.revokeAccess();\n      }\n    } catch (err) {\n      console.error('Error during revoking access:', err);\n      setError(err);\n    } finally {\n      queryClient.clear();\n      setIsAuthorized(false);\n    }\n  };\n\n  return (\n    <MoneriumContext.Provider\n      value={{\n        sdk,\n        authorize,\n        siwe,\n        isAuthorized,\n        isLoading: loadingAuth,\n        error,\n        disconnect: async () => sdk?.disconnect(),\n        revokeAccess: async () => revokeAccess(),\n      }}\n    >\n      {children}\n    </MoneriumContext.Provider>\n  );\n};\n","import { useContext, useEffect } from 'react';\nimport { useMutation, useQuery, useQueryClient } from '@tanstack/react-query';\n\nimport MoneriumClient, {\n  Address,\n  AddressesResponse,\n  AuthContext,\n  Balances,\n  Chain,\n  ChainId,\n  Currency,\n  CurrencyCode,\n  IBAN,\n  IBANsResponse,\n  LinkAddress,\n  LinkedAddress,\n  MoveIbanPayload,\n  NewOrder,\n  Order,\n  OrdersResponse,\n  OrderState,\n  parseChain,\n  Profile,\n  ProfilesResponse,\n  RequestIbanPayload,\n  ResponseStatus,\n  SignaturesQueryParams,\n  SignaturesResponse,\n  SubmitProfileDetailsPayload,\n  Token,\n} from '@monerium/sdk';\n\nimport { MoneriumContext } from './context';\nimport {\n  MutationOptions,\n  MutationResult,\n  QueryOptions,\n  UseAuthReturn,\n} from './types';\n\n/**\n * @internal\n * Query keys for React query\n * */\nexport const keys = {\n  getAll: ['monerium'],\n  getAuthContext: ['monerium', 'auth-context'],\n  getProfile: (profile: string) => [\n    'monerium',\n    'profile',\n    ...(profile ? [profile] : []),\n  ],\n  getProfiles: ['monerium', 'profiles'],\n  getAddress: (address: string) => ['monerium', 'address', [address]],\n  getAddresses: (filter?: unknown) => [\n    'monerium',\n    'addresses',\n    ...(filter ? [filter] : []),\n  ],\n  getBalances: (\n    address: string,\n    chain: Chain,\n    currencies?: CurrencyCode | CurrencyCode[]\n  ) => [\n    'monerium',\n    'balances',\n    {\n      currencies: currencies ? [...currencies] : [],\n      chain,\n      address,\n    },\n  ],\n  getIban: (iban: string) => ['monerium', 'iban', iban],\n  getIbans: (filter?: unknown) => [\n    'monerium',\n    'ibans',\n    ...(filter ? [filter] : []),\n  ],\n  getTokens: ['monerium', 'tokens'],\n  getOrder: (orderId: string) => ['monerium', 'order', orderId],\n  getOrders: (filter?: unknown) => [\n    'monerium',\n    'orders',\n    ...(filter ? [filter] : []),\n  ],\n  submitProfileDetails: ['monerium', 'submit-profile-details'],\n  moveIban: ['monerium', 'move-iban'],\n  requestIban: ['monerium', 'request-iban'],\n  placeOrder: ['monerium', 'place-order'],\n  linkAddress: ['monerium', 'link-address'],\n  getSignatures: (filter?: unknown) => [\n    'monerium',\n    'signatures',\n    ...(filter ? [filter] : []),\n  ],\n};\n\n/** Internal hook to use SDK */\nfunction useSdk(): MoneriumClient | undefined {\n  const context = useContext(MoneriumContext);\n\n  if (context === null) {\n    throw new Error('useSdk must be used within a MoneriumProvider');\n  }\n  return context?.sdk;\n}\n\n/**\n * # Redirect to the Monerium auth flow.\n * @group Hooks\n * @category Authentication\n * @example\n * ```ts\n * const { authorize, isAuthorized, isLoading, error } = useAuth();\n *\n * authorize(); // Redirects to the Monerium auth flow.\n *\n * // Opt-in to automated wallet linking with these parameters.\n * authorize({ address, signature, chain }).\n * ```\n *\n * @returns {UseAuthReturn}\n * - `authorize`  - Redirects to the Monerium auth flow.\n * - `siwe`       - Sign in with Ethereum. https://monerium.com/siwe\n * - `isAuthorized` - Whether the user is authorized.\n * - `isLoading` - Whether the auth flow is loading.\n * - `error` - Error message if the auth flow fails.\n * - `disconnect` - Disconnect the user.\n * - `revokeAccess` - Revoke the user's access.\n */\nexport function useAuth(): UseAuthReturn {\n  const context = useContext(MoneriumContext);\n\n  if (context === null) {\n    throw new Error('useAuth must be used within a MoneriumProvider');\n  }\n\n  return {\n    isAuthorized: context.isAuthorized,\n    authorize: context.authorize,\n    siwe: context.siwe,\n    isLoading: context.isLoading,\n    error: context.error,\n    disconnect: context.disconnect,\n    revokeAccess: context.revokeAccess,\n  };\n}\n\n/**\n * @group Hooks\n * @category Authentication\n * @param {Object} params\n *\n * @example\n * ```ts\n * const {\n *    data\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useAuthContext();\n * ```\n\n * @see {@link https://monerium.dev/api-docs/v2#tag/auth/operation/auth-context | API Documentation}\n */\nexport function useAuthContext({\n  query,\n}: {\n  /** {@inheritDoc QueryOptions} */\n  query?: QueryOptions<AuthContext>;\n} = {}) {\n  const { isAuthorized } = useAuth();\n  const sdk = useSdk();\n\n  return useQuery({\n    ...query,\n    queryKey: keys.getAuthContext,\n    queryFn: async () => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n\n      return sdk.getAuthContext();\n    },\n    enabled: Boolean(sdk && isAuthorized && (query?.enabled ?? true)),\n  });\n}\n/**\n * If no `profile` id is provided, the default profile is used.\n * @group Hooks\n * @category Profiles\n * @param {Object} params\n *\n * @example\n * ```ts\n * const {\n *    data\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useProfile();\n * ```\n\n * @see {@link https://monerium.dev/api-docs#operation/profile | API Documentation}\n */\nexport function useProfile({\n  profile,\n  query,\n}: {\n  /** The id of the profile */\n  profile?: string;\n  /** {@inheritDoc QueryOptions} */\n  query?: QueryOptions<Profile>;\n} = {}) {\n  const { isAuthorized } = useAuth();\n  const sdk = useSdk();\n\n  const { data } = useProfiles();\n\n  const profileToUse = profile || (data?.profiles?.[0]?.id as string);\n\n  return useQuery({\n    ...query,\n    queryKey: keys.getProfile(profileToUse),\n    queryFn: async () => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n      if (!profileToUse) {\n        throw new Error('Profile Id is required');\n      }\n\n      return sdk.getProfile(profileToUse);\n    },\n    enabled: Boolean(\n      sdk && isAuthorized && profileToUse && (query?.enabled ?? true)\n    ),\n  });\n}\n/**\n * # Get profiles\n * @group Hooks\n * @category Profiles\n *\n * @param {Object} [params] No required parameters.\n *\n * @example\n * ```ts\n * const {\n *    data,\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useProfiles();\n * ```\n * @see {@link https://monerium.dev/api-docs#operation/profiles | API Documentation}\n */\nexport function useProfiles({\n  query,\n}: {\n  /** {@inheritDoc QueryOptions} */\n  query?: QueryOptions<ProfilesResponse>;\n} = {}) {\n  const { isAuthorized } = useAuth();\n  const sdk = useSdk();\n\n  return useQuery({\n    ...query,\n    queryKey: keys.getProfiles,\n    queryFn: async () => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n      return sdk.getProfiles();\n    },\n    enabled: Boolean(sdk && isAuthorized && (query?.enabled ?? true)),\n  });\n}\n/**\n * @group Hooks\n * @param {Object} [params] No required parameters.\n *\n * @example\n * ```ts\n * const {\n *    data,\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useTokens();\n * ```\n\n * @see {@link https://monerium.dev/api-docs#operation/tokens | API Documentation}\n */\nexport function useTokens({\n  query,\n}: {\n  /** {@inheritDoc QueryOptions} */\n  query?: QueryOptions<Token[]>;\n} = {}) {\n  const sdk = useSdk();\n  const { isAuthorized } = useAuth();\n  return useQuery({\n    ...query,\n    queryKey: keys.getTokens,\n    queryFn: async () => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n      return sdk.getTokens();\n    },\n    enabled: Boolean(sdk && isAuthorized && (query?.enabled ?? true)),\n  });\n}\n\n/**\n * @group Hooks\n * @category Addresses\n * @param {Object} params\n\n * @example\n * ```ts\n * const {\n *    data,\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useAddress();\n * ```\n * @see {@link https://monerium.dev/api-docs-v2#tag/addresses/operation/address | API Documentation}\n */\nexport function useAddress({\n  address,\n  query = {},\n}: {\n  /** Fetch a specific address. */\n  address: string;\n  /** {@inheritDoc QueryOptions} */\n  query?: QueryOptions<Address>;\n}) {\n  const sdk = useSdk();\n  const { isAuthorized } = useAuth();\n\n  return useQuery({\n    ...query,\n    queryKey: keys.getAddress(address),\n    queryFn: async () => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n\n      if (!address) {\n        throw new Error('Address is required');\n      }\n\n      return sdk.getAddress(address);\n    },\n    enabled: Boolean(\n      sdk && isAuthorized && address && (query?.enabled ?? true)\n    ),\n  });\n}\n/**\n * @group Hooks\n * @category Addresses\n * @param {Object} [params] No required parameters.\n * @param {Object} [params.profile] Filter based on profile id.\n * @param {Object} [params.chain] Filter based on chain - CURRENTLY RETURNS AN ERROR.\n * @example\n * ```ts\n * const {\n *    data,\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useAddresses();\n * ```\n * @see {@link https://monerium.dev/api-docs-v2#tag/addresses/operation/addresses | API Documentation}\n */\nexport function useAddresses({\n  profile,\n  chain,\n  query = {},\n}: {\n  profile?: string;\n  chain?: Chain | ChainId;\n  /** {@inheritDoc QueryOptions} */\n  query?: QueryOptions<AddressesResponse>;\n} = {}) {\n  const sdk = useSdk();\n\n  const { isAuthorized } = useAuth();\n\n  return useQuery({\n    ...query,\n    queryKey: keys.getAddresses({\n      profile,\n      chain: chain ? parseChain(chain) : undefined,\n    }),\n    queryFn: async () => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n      return sdk.getAddresses({ profile, chain });\n    },\n    enabled: Boolean(sdk && isAuthorized && (query?.enabled ?? true)),\n  });\n}\n/**\n * # Get balance for a an address on a give chain\n * @group Hooks\n * @category Addresses\n * @param {Object} params\n * @param {QueryOptions<Balances>} params.address The address to fetch the balance for.\n * @param {QueryOptions<Balances>} params.chain The chain to fetch the balance for.\n * @param {QueryOptions<Balances>} [params.currencies] One or many: `eur`, `usd`, `gbp`, `isk`\n * @example\n * ```ts\n * const {\n *    data,\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useBalances();\n * ```\n * @see {@link https://monerium.dev/api-docs/v2#tag/addresses/operation/balances | API Documentation}\n *\n */\nexport function useBalances({\n  address,\n  chain,\n  currencies,\n  query,\n}: {\n  address: string;\n  chain: Chain | ChainId;\n  currencies?: Currency | Currency[];\n  /** {@inheritDoc QueryOptions} */\n  query?: QueryOptions<Balances>;\n}) {\n  const sdk = useSdk();\n  const { isAuthorized } = useAuth();\n\n  return useQuery({\n    ...query,\n    queryKey: keys.getBalances(address, parseChain(chain), currencies),\n    staleTime: 1000 * 60 * 5,\n    queryFn: async () => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n      return sdk.getBalances(address, chain, currencies);\n    },\n    enabled: Boolean(sdk && isAuthorized && (query?.enabled ?? true)),\n  });\n}\n\n/**\n * @group Hooks\n * @category IBANs\n * @param {Object} params\n * @example\n * ```ts\n * const {\n *    data,\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useIBAN();\n * ```\n * @see {@link https://monerium.dev/api-docs-v2#tag/ibans/operation/iban | API Documentation}\n */\nexport function useIBAN({\n  iban,\n  query,\n}: {\n  /** Fetch a specific IBAN */\n  iban: string;\n  /** {@inheritDoc QueryOptions} */\n  query?: QueryOptions<IBAN>;\n}) {\n  const sdk = useSdk();\n  const { isAuthorized } = useAuth();\n\n  return useQuery({\n    ...query,\n    queryKey: keys.getIban(iban),\n    queryFn: async () => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n\n      return sdk.getIban(iban);\n    },\n    enabled: Boolean(sdk && isAuthorized && iban && (query?.enabled ?? true)),\n  });\n}\n/**\n * @group Hooks\n * @category IBANs\n * @param {Object} [params] No required parameters.\n * @example\n * ```ts\n * const {\n *    data,\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useIBANs();\n * ```\n * @see {@link https://monerium.dev/api-docs-v2#tag/ibans/operation/ibans | API Documentation}\n */\nexport function useIBANs({\n  profile,\n  chain,\n  query = {},\n}: {\n  /** Fetch IBANs for a specific profile. */\n  profile?: string;\n  /** Fetch IBANs for a specific chain. */\n  chain?: Chain | ChainId;\n  /** {@inheritDoc QueryOptions} */\n  query?: QueryOptions<IBANsResponse>;\n} = {}) {\n  const sdk = useSdk();\n  const { isAuthorized } = useAuth();\n\n  return useQuery({\n    ...query,\n    queryKey: keys.getIbans({ profile, chain }),\n    queryFn: async () => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n\n      return sdk.getIbans({ profile, chain });\n    },\n    enabled: Boolean(sdk && isAuthorized && (query?.enabled ?? true)),\n  });\n}\n\n/**\n * @group Hooks\n * @category Orders\n * @param {Object} params\n * @example\n * ```ts\n * const {\n *    data,\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useOrder();\n * ```\n * @see {@link https://monerium.dev/api-docs#operation/order| API Documentation}\n */\nexport function useOrder({\n  orderId,\n  query = {},\n}: {\n  /**  The id of the order. */\n  orderId: string;\n  /** {@inheritDoc QueryOptions} */\n  query?: QueryOptions<Order>;\n}) {\n  const sdk = useSdk();\n  const { isAuthorized } = useAuth();\n  return useQuery({\n    ...query,\n    queryKey: keys.getOrder(orderId),\n    queryFn: async () => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n      if (!orderId) {\n        throw new Error('Order id is required');\n      }\n\n      return sdk.getOrder(orderId);\n    },\n    enabled: Boolean(sdk && isAuthorized && orderId && (query.enabled ?? true)),\n  });\n}\n\n/**\n * @group Hooks\n * @category Orders\n * @param {Object} [params] No required parameters.\n * @param {Object} [params.address] Filter based on the blockchain address associated with the order.\n * @param {Object} [params.memo] Filter by the payment memo/reference..\n * @param {Object} [params.profile] Filter based on the profile ID associated with the order.\n * @param {Object} [params.state] Filter based on the state of the order.\n * @param {Object} [params.txHash] Filter based on the blockchain transaction hash.\n *\n * @example\n * ```ts\n * const {\n *    data,\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useOrders();\n * ```\n * @see {@link https://monerium.dev/api-docs#operation/orders | API Documentation}\n */\nexport function useOrders({\n  query = {},\n  ...filters\n}: {\n  /** {@inheritDoc QueryOptions} */\n  query?: QueryOptions<OrdersResponse>;\n  address?: string;\n  txHash?: string;\n  profile?: string;\n  memo?: string;\n  state?: OrderState;\n} = {}) {\n  const sdk = useSdk();\n  const { isAuthorized } = useAuth();\n  return useQuery({\n    ...query,\n    queryKey: keys.getOrders(filters),\n    queryFn: async () => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n\n      return sdk.getOrders(filters);\n    },\n    enabled: Boolean(sdk && isAuthorized && (query.enabled ?? true)),\n  });\n}\n\n/**\n * Submit the required compliance information to onboard the customer.\n *\n * Note that you won't be able to change the profile \"kind\" from personal to corporate or vice versa once the profile has been approved.\n * @group Hooks\n * @category Profiles\n * @param param\n * @param {string} param.profile The id of the profile to submit to.\n *\n * @example\n * ```ts\n * const {\n *    submitProfileDetails, // useMutation's `mutateAsync` property\n *    isPending,\n *    isError,\n *    error,\n *    status,\n *    ...moreUseMutationResults\n * } = useSubmitProfileDetails();\n * ```\n * @see {@link https://monerium.dev/api-docs-v2#tag/profiles/operation/profile-details | API Documentation}}\n */\n\nexport function useSubmitProfileDetails({\n  profile,\n  mutation = {},\n}: {\n  profile: string;\n  /** {@inheritDoc MutationOptions} */\n  mutation?: MutationOptions<\n    ResponseStatus,\n    Error,\n    SubmitProfileDetailsPayload\n  >;\n}): MutationResult<\n  'submitProfileDetails',\n  ResponseStatus,\n  Error,\n  SubmitProfileDetailsPayload\n> {\n  const sdk = useSdk();\n  const { isAuthorized } = useAuth();\n  const queryClient = useQueryClient();\n\n  const { mutateAsync, ...rest } = useMutation({\n    ...mutation,\n    mutationKey: keys.submitProfileDetails,\n    mutationFn: async (body: SubmitProfileDetailsPayload) => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n\n      return sdk.submitProfileDetails(profile, body);\n    },\n    onSuccess(data, variables, context, mutationContext) {\n      // Refetch all orders on success.\n      queryClient.invalidateQueries({\n        queryKey: keys.getProfile(profile),\n      });\n      // Allow the caller to add custom logic on success.\n      mutation?.onSuccess?.(data, variables, context, mutationContext);\n    },\n    onError(error, vars, context, mutationContext) {\n      // Allow the caller to add custom logic on error.\n      mutation?.onError?.(error, vars, context, mutationContext);\n      throw error;\n    },\n  });\n  return {\n    submitProfileDetails: mutateAsync,\n    ...rest,\n  };\n}\n/**\n * Create an IBAN for a specified address and chain.\n * All incoming EUR payments will automatically be routed to the linked address on that chain.\n * Any linked address can use this IBAN for outgoing payments.\n * @group Hooks\n * @category IBANs\n * @param {Object} [params] No required parameters.\n *\n * @example\n * ```ts\n * const {\n *    requestIban, // useMutation's `mutateAsync` property\n *    isPending,\n *    isError,\n *    error,\n *    status,\n *    ...moreUseMutationResults\n * } = useRequestIban();\n * ```\n * @see {@link https://monerium.dev/api-docs-v2#tag/ibans/operation/request-iban | API Documentation}}\n */\n\nexport function useRequestIban({\n  mutation = {},\n}: {\n  /** {@inheritDoc MutationOptions} */\n  mutation?: MutationOptions<ResponseStatus, Error, RequestIbanPayload>;\n} = {}): MutationResult<\n  'requestIban',\n  ResponseStatus,\n  Error,\n  RequestIbanPayload\n> {\n  const sdk = useSdk();\n  const { isAuthorized } = useAuth();\n\n  const { mutateAsync, ...rest } = useMutation({\n    ...mutation,\n    mutationKey: keys.requestIban,\n    mutationFn: async ({\n      address,\n      chain,\n      emailNotifications,\n    }: RequestIbanPayload) => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n\n      return sdk.requestIban({ address, chain, emailNotifications });\n    },\n    onSuccess(data, variables, context, mutationContext) {\n      // Allow the caller to add custom logic on success.\n      mutation?.onSuccess?.(data, variables, context, mutationContext);\n    },\n    onError(error, vars, context, mutationContext) {\n      // Allow the caller to add custom logic on error.\n      mutation?.onError?.(error, vars, context, mutationContext);\n      throw error;\n    },\n  });\n  return {\n    requestIban: mutateAsync,\n    ...rest,\n  };\n}\n/**\n * Move an existing IBAN to a specified address an chain.\n * All incoming EUR payments will automatically be routed to the address on that chain.\n * @group Hooks\n * @category IBANs\n * @param {Object} [params] No required parameters.\n *\n * @example\n * ```ts\n * const {\n *    moveIban, // useMutation's `mutateAsync` property\n *    isPending,\n *    isError,\n *    error,\n *    status,\n *    ...moreUseMutationResults\n * } = useMoveIban();\n * ```\n * @see {@link https://monerium.dev/api-docs/v2#tag/ibans/operation/move-iban | API Documentation}\n */\n\nexport function useMoveIban({\n  mutation = {},\n}: {\n  /** {@inheritDoc MutationOptions} */\n  mutation?: MutationOptions<\n    ResponseStatus,\n    Error,\n    MoveIbanPayload & { iban: string }\n  >;\n} = {}): MutationResult<\n  'moveIban',\n  ResponseStatus,\n  Error,\n  MoveIbanPayload & { iban: string }\n> {\n  const sdk = useSdk();\n  const { isAuthorized } = useAuth();\n  const queryClient = useQueryClient();\n\n  const { mutateAsync, ...rest } = useMutation({\n    ...mutation,\n    mutationKey: keys.moveIban,\n    mutationFn: async ({\n      iban,\n      address,\n      chain,\n    }: MoveIbanPayload & { iban: string }) => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n\n      return sdk.moveIban(iban, { address, chain });\n    },\n    onSuccess(data, variables, context, mutationContext) {\n      // Refetch the iban on success.\n      queryClient.invalidateQueries({\n        queryKey: keys.getIban(variables.iban),\n      });\n      queryClient.invalidateQueries({\n        queryKey: keys.getIbans(),\n      });\n      queryClient.invalidateQueries({\n        queryKey: keys.getAddress(variables.address),\n      });\n      // Allow the caller to add custom logic on success.\n      mutation?.onSuccess?.(data, variables, context, mutationContext);\n    },\n    onError(error, vars, context, mutationContext) {\n      // Allow the caller to add custom logic on error.\n      mutation?.onError?.(error, vars, context, mutationContext);\n      throw error;\n    },\n  });\n  return {\n    moveIban: mutateAsync,\n    ...rest,\n  };\n}\n/**\n * When the order has been placed, the orders query will be invalidated and re-fetched.\n *\n * If the order amount is above 15000, a supporting document is required.\n *\n * **Note:** For multi-signature orders, the API returns a 202 Accepted response\n * with `{status: 202, statusText: \"Accepted\"}` instead of the full Order object.\n *\n * @group Hooks\n * @category Orders\n * @param param\n * @param {File} param.supportingDocument Supporting document file.\n *\n * @example\n * ```ts\n * const {\n *    placeOrder, // useMutation's `mutateAsync` property\n *    isPending,\n *    isError,\n *    error,\n *    status,\n *    ...moreUseMutationResults\n * } = usePlaceOrder();\n * ```\n * @see {@link https://monerium.dev/api-docs#operation/post-orders| API Documentation}\n */\n\nexport function usePlaceOrder({\n  supportingDocument,\n  mutation,\n}: {\n  supportingDocument?: File;\n  /** {@inheritDoc MutationOptions} */\n  mutation?: MutationOptions<Order | ResponseStatus, Error, NewOrder>;\n} = {}): MutationResult<'placeOrder', Order | ResponseStatus, Error, NewOrder> {\n  const sdk = useSdk();\n  const { isAuthorized } = useAuth();\n  const queryClient = useQueryClient();\n\n  const { mutateAsync, ...rest } = useMutation({\n    ...mutation,\n    mutationKey: keys.placeOrder,\n    mutationFn: async (body: NewOrder) => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n      let documentId;\n      if (parseInt(body.amount) > 15000) {\n        if (!supportingDocument) {\n          throw new Error(\n            'Supporting document is required for orders above 15000'\n          );\n        }\n        const uploadedDocument =\n          await sdk.uploadSupportingDocument(supportingDocument);\n        documentId = uploadedDocument.id;\n      }\n\n      const newBody = {\n        ...body,\n        documentId: documentId,\n      };\n\n      return sdk.placeOrder(newBody);\n    },\n    onSuccess(data, variables, context, mutationContext) {\n      // Refetch all orders on success.\n      queryClient.invalidateQueries({\n        queryKey: keys.getOrders(),\n      });\n      // Only invalidate balances if we got a full Order response (not a 202 multi-sig response)\n      const orderData = data as Order;\n      if (orderData.address && orderData?.chain) {\n        queryClient.invalidateQueries({\n          queryKey: keys.getBalances(orderData.address, orderData.chain),\n        });\n      }\n      // Allow the caller to add custom logic on success.\n      mutation?.onSuccess?.(data, variables, context, mutationContext);\n    },\n    onError(error, vars, context, mutationContext) {\n      // Allow the caller to add custom logic on error.\n      mutation?.onError?.(error, vars, context, mutationContext);\n      throw error;\n    },\n  });\n  return {\n    placeOrder: mutateAsync,\n    ...rest,\n  };\n}\n/**\n * Get pending signatures for the authenticated user.\n *\n * Returns pending signatures that require user action, such as order signatures\n * or link address signatures. Accepts filtering by address, chain, kind, and profile.\n *\n * @group Hooks\n * @category Signatures\n * @param {Object} params\n * @param {SignaturesQueryParams} params.query - Optional query parameters to filter signatures\n *\n * @example\n * ```ts\n * // Get all pending signatures\n * const {\n *    data: signatures,\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useSignatures();\n *\n * // Get pending order signatures for a specific address\n * const { data: orderSignatures } = useSignatures({\n *   query: {\n *     address: '0x1234...',\n *     kind: 'order'\n *   }\n * });\n *\n * // Check the kind of signature\n * signatures?.pending.forEach(sig => {\n *   if (sig.kind === 'order') {\n *     console.log('Order signature:', sig.id, sig.amount);\n *   } else {\n *     console.log('Link address signature');\n *   }\n * });\n * ```\n * @see {@link https://monerium.dev/api-docs-v2#tag/signatures/operation/get-signatures | API Documentation}\n */\nexport function useSignatures({\n  query,\n  options,\n}: {\n  query?: SignaturesQueryParams;\n  /** {@inheritDoc QueryOptions} */\n  options?: QueryOptions<SignaturesResponse>;\n} = {}) {\n  const sdk = useSdk();\n  const { isAuthorized } = useAuth();\n\n  return useQuery<SignaturesResponse>({\n    ...options,\n    queryKey: keys.getSignatures(query),\n    queryFn: () => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      return sdk.getSignatures(query);\n    },\n    enabled: Boolean(sdk && isAuthorized && (options?.enabled ?? true)),\n  });\n}\n\n/**\n * # Add address to profile.\n *\n * @group Hooks\n * @category Profiles\n * @param {Object} [params] No required parameters.\n *\n * @example\n * ```ts\n * const {\n *    linkAddress, // useMutation's `mutateAsync` property\n *    isPending,\n *    isError,\n *    error,\n *    status,\n *    ...moreUseMutationResults\n * } = useLinkAddress();\n * ```\n * @see {@link https://monerium.dev/api-docs#operation/profile-addresses | API Documentation}\n */\n\nexport function useLinkAddress({\n  mutation,\n}: {\n  /** {@inheritDoc MutationOptions} */\n  mutation?: MutationOptions<LinkedAddress, Error, LinkAddress>;\n} = {}): MutationResult<'linkAddress', LinkedAddress, Error, LinkAddress> {\n  const sdk = useSdk();\n  const { isAuthorized } = useAuth();\n  const queryClient = useQueryClient();\n\n  const { mutateAsync, ...rest } = useMutation({\n    ...mutation,\n    mutationKey: keys.linkAddress,\n    mutationFn: async (body: LinkAddress) => {\n      if (!sdk) {\n        throw new Error('No SDK instance available');\n      }\n      if (!isAuthorized) {\n        throw new Error('User not authorized');\n      }\n      return sdk.linkAddress(body);\n    },\n    onSuccess(data, variables, context, mutationContext) {\n      // Refetch all orders on success.\n      queryClient.invalidateQueries({\n        queryKey: keys.getAddresses(),\n      });\n      if (variables.profile) {\n        queryClient.invalidateQueries({\n          queryKey: keys.getProfile(variables.profile),\n        });\n      }\n      // Allow the caller to add custom logic on success.\n      mutation?.onSuccess?.(data, variables, context, mutationContext);\n    },\n    onError(error, vars, context, mutationContext) {\n      // Allow the caller to add custom logic on error.\n      mutation?.onError?.(error, vars, context, mutationContext);\n      throw error;\n    },\n  });\n  return {\n    linkAddress: mutateAsync,\n    ...rest,\n  };\n}\n\n/**\n * API consumers have the option to subscribe to a WebSocket for real-time order notifications. This WebSocket complies with the standard WebSocket Protocol, allowing the use of standard WebSocket libraries for subscription.\n *\n * The WebSocket emits an event when a order changes state:\n *\n * `placed`: The order has been created but not yet processed.\n *\n * `pending`: The order is awaiting fulfillment (e.g., review, minting/burning tokens, or sending/receiving SEPA payment).\n *\n * `processed`: The order has been completed successfully.\n *\n * `rejected`: The order was rejected, possibly due to compliance reasons or insufficient funds.\n * @group Hooks\n * @category Orders\n * @param {Object} params\n * @param {OrderState} [params.state] Filter based on the state of the order.\n * @param {string} [params.profile] Filter based on the profile id of the order.\n * @param {Function} params.onMessage Callback function to handle the order notification.\n * @param {Function} [params.onError] Callback function to handle the error notification.\n *\n * @example\n * ```ts\n * const {\n *    state,\n *    profile,\n *    onMessage,\n *    onError\n * } = useSubscribeOrderNotification();\n * ```\n * @see {@link https://monerium.dev/api-docs/v1#operation/orders-notifications| API Documentation}\n * @returns {Function} Unsubscribe from order notifications.\n */\n\nexport const useSubscribeOrderNotification = ({\n  state,\n  profile,\n  onMessage,\n  onError,\n}: {\n  state?: OrderState;\n  profile?: string;\n  onMessage: (order: Order) => void;\n  onError?: ((err: Event) => void) | undefined;\n}) => {\n  const sdk = useSdk();\n\n  useEffect(() => {\n    if (sdk) {\n      sdk.subscribeOrderNotifications({\n        filter: {\n          state: state,\n          profile: profile,\n        },\n        onMessage: onMessage,\n        onError: onError,\n      });\n    }\n    return () => {\n      /**\n       * Note that in development mode, React Strict mode will cause this\n       * cleanup function to be called twice on client side route changes.\n       * So a socket will be immediately closed and opened again.\n       * This is not an issue in production mode.\n       */\n      if (sdk) {\n        sdk?.unsubscribeOrderNotifications({ state: state, profile: profile });\n      }\n    };\n  }, [sdk, profile, state]);\n\n  return () =>\n    sdk?.unsubscribeOrderNotifications({ state: state, profile: profile });\n};\n\n/** Export types for documentation */\nexport type {\n  Address,\n  Balances,\n  IBAN,\n  MoveIbanPayload,\n  LinkAddress,\n  Profile,\n  Token,\n  SubmitProfileDetailsPayload,\n  NewOrder,\n  ResponseStatus,\n  Order,\n};\n"]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@monerium/sdk-react-provider",
|
|
3
|
-
"version": "1.3.
|
|
3
|
+
"version": "1.3.4",
|
|
4
4
|
"private": false,
|
|
5
5
|
"description": "React provider for the Monerium SDK.",
|
|
6
6
|
"repository": {
|
|
@@ -44,7 +44,7 @@
|
|
|
44
44
|
},
|
|
45
45
|
"scripts": {
|
|
46
46
|
"build": "tsup",
|
|
47
|
-
"dev": "tsup --watch
|
|
47
|
+
"dev": "tsup --watch",
|
|
48
48
|
"typedoc": "typedoc",
|
|
49
49
|
"lint": "eslint . --fix",
|
|
50
50
|
"pub:pre": "pnpm publish --no-git-checks --dry-run",
|