@monerium/sdk-react-provider 0.1.2 → 0.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +114 -16
- package/dist/index.d.ts +537 -26
- package/dist/index.js +17 -6
- package/dist/index.mjs +5 -4
- package/package.json +12 -7
package/README.md
CHANGED
|
@@ -1,50 +1,104 @@
|
|
|
1
|
+
| [Monerium.com](https://monerium.com/) | [Monerium.app](https://monerium.app/) | [Monerium.dev](https://monerium.dev/) |
|
|
2
|
+
| ------------------------------------- | ------------------------------------- | ------------------------------------- |
|
|
3
|
+
|
|
1
4
|
# Monerium SDK React Provider
|
|
2
5
|
|
|
6
|
+
<a href="https://monerium.dev/">
|
|
7
|
+
<picture>
|
|
8
|
+
<source media="(prefers-color-scheme: dark)" srcset="https://img.shields.io/badge/Developer_portal-2c6ca7">
|
|
9
|
+
<img src="https://img.shields.io/badge/Developer_portal-2c6ca7" alt="Static Badge">
|
|
10
|
+
</picture>
|
|
11
|
+
</a>
|
|
12
|
+
<a href="https://monerium.dev/api-docs">
|
|
13
|
+
<picture>
|
|
14
|
+
<source media="(prefers-color-scheme: dark)" srcset="https://img.shields.io/badge/API_documentation-2c6ca7">
|
|
15
|
+
<img src="https://img.shields.io/badge/API_documentation-2c6ca7" alt="Static Badge">
|
|
16
|
+
</picture>
|
|
17
|
+
</a>
|
|
18
|
+
</br>
|
|
19
|
+
<a href="https://www.npmjs.com/package/@monerium/sdk-react-provider">
|
|
20
|
+
<picture>
|
|
21
|
+
<source media="(prefers-color-scheme: dark)" srcset="https://img.shields.io/npm/v/%40monerium%2Fsdk-react-provider?colorA=2c6ca7&colorB=21262d">
|
|
22
|
+
<img src="https://img.shields.io/npm/v/%40monerium%2Fsdk-react-provider?colorA=f6f8fa&colorB=f6f8fa" alt="Version">
|
|
23
|
+
</picture>
|
|
24
|
+
</a>
|
|
25
|
+
<a href="https://github.com/monerium/js-monorepo/issues>
|
|
26
|
+
<picture>
|
|
27
|
+
<source media="(prefers-color-scheme: dark)" srcset="https://img.shields.io/github/issues/monerium/js-monorepo?colorA=2c6ca7&colorB=21262d">
|
|
28
|
+
<img src="https://img.shields.io/github/issues/monerium/js-monorepo?colorA=2c6ca7&colorB=21262d" alt="Version">
|
|
29
|
+
</picture>
|
|
30
|
+
</a>
|
|
31
|
+
|
|
3
32
|
## Installation
|
|
4
33
|
|
|
5
34
|
```
|
|
6
|
-
pnpm add @monerium/sdk-react-provider
|
|
35
|
+
pnpm add @monerium/sdk-react-provider @tanstack/react-query
|
|
7
36
|
```
|
|
8
37
|
|
|
9
|
-
|
|
38
|
+
- [TanStack Query](https://tanstack.com/query/v5) is an async state manager that handles requests, caching, and more.
|
|
39
|
+
|
|
40
|
+
### Wrap App in Context Provider
|
|
10
41
|
|
|
11
|
-
Wrap
|
|
42
|
+
Wrap your app in the `QueryClientProvider` React Context Provider and pass a new `QueryClient` instance to the `client` property
|
|
43
|
+
|
|
44
|
+
Inside the `QueryClientProvider`, wrap your app in the `MoneriumProvider` React Context Provider and pass the auth flow's `clientId`, `redirectUri`, and `environment` configuration.
|
|
12
45
|
|
|
13
46
|
```tsx
|
|
14
47
|
import { StrictMode } from 'react';
|
|
15
48
|
import { createRoot } from 'react-dom/client';
|
|
16
49
|
import { MoneriumProvider } from '@monerium/sdk-react-provider';
|
|
50
|
+
import { QueryClient, QueryClientProvider } from '@tanstack/react-query';
|
|
17
51
|
|
|
18
52
|
import App from './App';
|
|
19
53
|
|
|
20
54
|
const rootElement = document.getElementById('root');
|
|
21
55
|
const root = createRoot(rootElement);
|
|
22
56
|
|
|
57
|
+
const queryClient = new QueryClient();
|
|
58
|
+
|
|
23
59
|
root.render(
|
|
24
60
|
<StrictMode>
|
|
25
|
-
<
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
61
|
+
<QueryClientProvider client={queryClient}>
|
|
62
|
+
<MoneriumProvider
|
|
63
|
+
clientId="f99e629b-6dca-11ee-8aa6-5273f65ed05b"
|
|
64
|
+
redirectUri="https://pntvgs.csb.app/"
|
|
65
|
+
environment="sandbox"
|
|
66
|
+
>
|
|
67
|
+
<App />
|
|
68
|
+
</MoneriumProvider>
|
|
69
|
+
</QueryClientProvider>
|
|
32
70
|
</StrictMode>
|
|
33
71
|
);
|
|
34
72
|
```
|
|
35
73
|
|
|
36
|
-
|
|
74
|
+
## Hooks
|
|
75
|
+
|
|
76
|
+
The following hooks are now available within your application:
|
|
77
|
+
|
|
78
|
+
- [useAuth](./docs/generated/functions/useAuth.md)</br>
|
|
79
|
+
- [useAuthContext](./docs/generated/functions/useAuthContext.md)</br>
|
|
80
|
+
- [useBalances](./docs/generated/functions/useBalances.md)</br>
|
|
81
|
+
- [useLinkAddress](./docs/generated/functions/useLinkAddress.md)</br>
|
|
82
|
+
- [useOrder](./docs/generated/functions/useOrder.md)</br>
|
|
83
|
+
- [useOrders](./docs/generated/functions/useOrders.md)</br>
|
|
84
|
+
- [usePlaceOrder](./docs/generated/functions/usePlaceOrder.md)</br>
|
|
85
|
+
- [useProfile](./docs/generated/functions/useProfile.md)</br>
|
|
86
|
+
- [useProfiles](./docs/generated/functions/useProfiles.md)</br>
|
|
87
|
+
- [useTokens](./docs/generated/functions/useTokens.md)</br>
|
|
88
|
+
|
|
89
|
+
### Example
|
|
37
90
|
|
|
38
91
|
```tsx
|
|
39
|
-
import {
|
|
92
|
+
import { useAuth, useProfile } from '@monerium/sdk-react-provider';
|
|
40
93
|
|
|
41
94
|
export default function App() {
|
|
42
|
-
const { authorize, isAuthorized
|
|
43
|
-
|
|
95
|
+
const { authorize, isAuthorized } = useAuth();
|
|
96
|
+
const { profile } = useProfile();
|
|
97
|
+
|
|
44
98
|
return (
|
|
45
99
|
<div className="App">
|
|
46
100
|
{!isAuthorized && <button onClick={authorize}>Authorize</button>}
|
|
47
|
-
|
|
101
|
+
{profile ? <h1>{profile?.email}</h1> : <h1>No profile</h1>}
|
|
48
102
|
</div>
|
|
49
103
|
);
|
|
50
104
|
}
|
|
@@ -59,8 +113,52 @@ Hook used to access the SDK: https://codesandbox.io/s/monerium-sdk-react-provide
|
|
|
59
113
|
The application is wrapped with MoneriumProvider
|
|
60
114
|
https://codesandbox.io/s/monerium-sdk-react-provider-pntvgs?file=/src/index.js
|
|
61
115
|
|
|
116
|
+
# Development
|
|
117
|
+
|
|
62
118
|
## Running unit tests
|
|
63
119
|
|
|
64
120
|
Run `turbo --filter @monerium/sdk-react-provider test` to execute the unit tests
|
|
65
121
|
|
|
66
|
-
|
|
122
|
+
## Documentation
|
|
123
|
+
|
|
124
|
+
We use [TypeDoc](https://typedoc.org/) to generate the documentation.
|
|
125
|
+
|
|
126
|
+
There are a few caveats to keep in mind when documenting the code:
|
|
127
|
+
|
|
128
|
+
- Use `@group` to group functions in the entry file. E.g. `@group Hooks`.
|
|
129
|
+
- To specifically mark `@param` as optional, use square brackets, e.g. `[param]`. Useful for optional destructed parameters.
|
|
130
|
+
- For optional destructed parameters, use inline typing to improve readability.
|
|
131
|
+
|
|
132
|
+
```diff
|
|
133
|
+
+ @param {Object} [param] - Optional parameter.
|
|
134
|
+
+ @param {MyQueryType} [param.query] - Description.
|
|
135
|
+
+
|
|
136
|
+
+ function useMyHook(
|
|
137
|
+
+ { query }:
|
|
138
|
+
+ { query?: MyQueryType } = {}
|
|
139
|
+
+ ) {}
|
|
140
|
+
```
|
|
141
|
+
|
|
142
|
+
Document output:
|
|
143
|
+
|
|
144
|
+
```ts
|
|
145
|
+
param?: Object
|
|
146
|
+
param?.query MyQueryType
|
|
147
|
+
```
|
|
148
|
+
|
|
149
|
+
Instead of:
|
|
150
|
+
|
|
151
|
+
```diff
|
|
152
|
+
- type UseMyHookParams = {
|
|
153
|
+
- query?: MyQueryType
|
|
154
|
+
- }
|
|
155
|
+
- function useMyHook(params?: UseHookParams) {}
|
|
156
|
+
```
|
|
157
|
+
|
|
158
|
+
Document output:
|
|
159
|
+
|
|
160
|
+
```ts
|
|
161
|
+
params?: UseMyHookParams
|
|
162
|
+
```
|
|
163
|
+
|
|
164
|
+
> This would require the viewer to navigate into the `UseMyHookParams` type to see the optional `query` property.
|
package/dist/index.d.ts
CHANGED
|
@@ -1,35 +1,546 @@
|
|
|
1
|
+
import * as react_jsx_runtime from 'react/jsx-runtime';
|
|
1
2
|
import * as react from 'react';
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
3
|
+
import { ReactNode } from 'react';
|
|
4
|
+
import { UseQueryOptions, UseQueryResult, UseMutationOptions, UseMutationResult } from '@tanstack/react-query';
|
|
5
|
+
import MoneriumClient, { ChainId, AuthContext, Profile, Token, Balances, Order, OrderState, NewOrder, LinkedAddress, LinkAddress } from '@monerium/sdk';
|
|
6
|
+
export { AuthContext, Balances, LinkAddress, Order, OrderState, Profile, Token } from '@monerium/sdk';
|
|
4
7
|
|
|
5
|
-
|
|
8
|
+
/**
|
|
9
|
+
* Place this provider at the root of your application.
|
|
10
|
+
* @group Provider
|
|
11
|
+
* @param params
|
|
12
|
+
* @param params.children - Rest of the application.
|
|
13
|
+
* @param params.clientId - Monerium auth flow client id.
|
|
14
|
+
* @param params.redirectUri - Monerium auth flow redirect url.
|
|
15
|
+
* @param params.environment - Monerium environment.
|
|
16
|
+
* @returns
|
|
17
|
+
*/
|
|
18
|
+
declare const MoneriumProvider: ({ children, clientId, redirectUrl, redirectUri, environment, }: {
|
|
6
19
|
children: ReactNode;
|
|
7
|
-
clientId
|
|
20
|
+
clientId: string;
|
|
21
|
+
redirectUri: string;
|
|
22
|
+
/** @deprecated use redirectUri */
|
|
8
23
|
redirectUrl?: string;
|
|
9
|
-
environment?:
|
|
10
|
-
}
|
|
11
|
-
declare const MoneriumProvider: FC<MoneriumProviderProps>;
|
|
24
|
+
environment?: "sandbox" | "production";
|
|
25
|
+
}) => react_jsx_runtime.JSX.Element;
|
|
12
26
|
|
|
13
|
-
|
|
14
|
-
|
|
27
|
+
type SdkInstance = {
|
|
28
|
+
/** Monerium SDK instance. */
|
|
29
|
+
sdk?: MoneriumClient;
|
|
30
|
+
};
|
|
31
|
+
type AuthorizeParams = {
|
|
32
|
+
address: string;
|
|
33
|
+
signature: string;
|
|
34
|
+
chainId?: ChainId;
|
|
35
|
+
} | {
|
|
36
|
+
state?: string;
|
|
37
|
+
scope?: string;
|
|
38
|
+
} | {};
|
|
39
|
+
type UseAuthReturn = {
|
|
40
|
+
/**
|
|
41
|
+
* Constructs the url and redirects to the Monerium auth flow.
|
|
42
|
+
*/
|
|
43
|
+
authorize: (params?: AuthorizeParams) => Promise<void>;
|
|
44
|
+
/**
|
|
45
|
+
* Indicates whether the SDK is authorized.
|
|
46
|
+
*/
|
|
15
47
|
isAuthorized: boolean;
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
loadingLinkAddress: boolean;
|
|
21
|
-
loadingBalances: boolean;
|
|
22
|
-
getBalances: () => Promise<void>;
|
|
23
|
-
linkAddress: (addressDetails: LinkAddress) => Promise<unknown>;
|
|
24
|
-
placeOrder: (orderDetails: NewOrder, supportingDocument?: File) => Promise<void>;
|
|
25
|
-
orders: Order[];
|
|
26
|
-
tokens: Token[];
|
|
48
|
+
/**
|
|
49
|
+
* Indicates whether the SDK authorization is loading.
|
|
50
|
+
*/
|
|
51
|
+
isLoading: boolean;
|
|
27
52
|
error: unknown;
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
}
|
|
31
|
-
|
|
53
|
+
disconnect: () => Promise<void>;
|
|
54
|
+
revokeAccess: () => Promise<void>;
|
|
55
|
+
};
|
|
56
|
+
/**
|
|
57
|
+
* See [Tanstack Query - useQuery](https://tanstack.com/query/latest/docs/framework/react/reference/useQuery) options.
|
|
58
|
+
* @see # [Tanstack Query - useQuery](https://tanstack.com/query/latest/docs/framework/react/reference/useQuery)
|
|
59
|
+
* @template {Object} TData - The data returned.
|
|
60
|
+
*
|
|
61
|
+
* @options
|
|
62
|
+
* > `queryKey` and `queryFn` are used internally and therefore not included in the options.
|
|
63
|
+
* ```diff
|
|
64
|
+
* query: {
|
|
65
|
+
* - queryKey,
|
|
66
|
+
* - queryFn,
|
|
67
|
+
* gcTime,
|
|
68
|
+
* enabled,
|
|
69
|
+
* networkMode,
|
|
70
|
+
* initialData,
|
|
71
|
+
* initialDataUpdatedAt,
|
|
72
|
+
* meta,
|
|
73
|
+
* notifyOnChangeProps,
|
|
74
|
+
* placeholderData,
|
|
75
|
+
* queryKeyHashFn,
|
|
76
|
+
* refetchInterval,
|
|
77
|
+
* refetchIntervalInBackground,
|
|
78
|
+
* refetchOnMount,
|
|
79
|
+
* refetchOnReconnect,
|
|
80
|
+
* refetchOnWindowFocus,
|
|
81
|
+
* retry,
|
|
82
|
+
* retryOnMount,
|
|
83
|
+
* retryDelay,
|
|
84
|
+
* select,
|
|
85
|
+
* staleTime,
|
|
86
|
+
* structuralSharing,
|
|
87
|
+
* throwOnError
|
|
88
|
+
* }
|
|
89
|
+
* ```
|
|
90
|
+
* @example
|
|
91
|
+
* ```ts
|
|
92
|
+
* useQueryHook({
|
|
93
|
+
* query: {
|
|
94
|
+
* enabled: isReady,
|
|
95
|
+
* staleTime: 1000,
|
|
96
|
+
* placeHolderData: { foo: 'bar' },
|
|
97
|
+
* }
|
|
98
|
+
* })
|
|
99
|
+
* ```
|
|
100
|
+
* @usedBy
|
|
101
|
+
* {@link useAuthContext}
|
|
102
|
+
*
|
|
103
|
+
* {@link useBalances}
|
|
104
|
+
*
|
|
105
|
+
* {@link useOrders}
|
|
106
|
+
*
|
|
107
|
+
* {@link useProfile}
|
|
108
|
+
*
|
|
109
|
+
* {@link useTokens}
|
|
110
|
+
*/
|
|
111
|
+
type QueryOptions<TData = unknown> = Omit<UseQueryOptions<TData>, 'queryKey' | 'queryFn'>;
|
|
112
|
+
/**
|
|
113
|
+
* See [Tanstack Query - useQuery](https://tanstack.com/query/latest/docs/framework/react/reference/useQuery) returns.
|
|
114
|
+
* @see # [Tanstack Query - useQuery](https://tanstack.com/query/latest/docs/framework/react/reference/useQuery)
|
|
115
|
+
*
|
|
116
|
+
* @template {string} TVarName - The name of the variable that returns the data.
|
|
117
|
+
* @template {Object} TData - The data returned.
|
|
118
|
+
*
|
|
119
|
+
* @example
|
|
120
|
+
* > `data` is renamed according to the `TVarName` and therefore not included in the result.
|
|
121
|
+
* ```diff
|
|
122
|
+
* {
|
|
123
|
+
* - data,
|
|
124
|
+
* dataUpdatedAt,
|
|
125
|
+
* error,
|
|
126
|
+
* errorUpdatedAt,
|
|
127
|
+
* failureCount,
|
|
128
|
+
* failureReason,
|
|
129
|
+
* fetchStatus,
|
|
130
|
+
* isError,
|
|
131
|
+
* isFetched,
|
|
132
|
+
* isFetchedAfterMount,
|
|
133
|
+
* isFetching,
|
|
134
|
+
* isInitialLoading,
|
|
135
|
+
* isLoading,
|
|
136
|
+
* isLoadingError,
|
|
137
|
+
* isPaused,
|
|
138
|
+
* isPending,
|
|
139
|
+
* isPlaceholderData,
|
|
140
|
+
* isRefetchError,
|
|
141
|
+
* isRefetching,
|
|
142
|
+
* isStale,
|
|
143
|
+
* isSuccess,
|
|
144
|
+
* refetch,
|
|
145
|
+
* status,
|
|
146
|
+
*}
|
|
147
|
+
* ```
|
|
148
|
+
* @usedBy
|
|
149
|
+
* {@link useAuthContext}
|
|
150
|
+
*
|
|
151
|
+
* {@link useBalances}
|
|
152
|
+
*
|
|
153
|
+
* {@link useOrders}
|
|
154
|
+
*
|
|
155
|
+
* {@link useProfile}
|
|
156
|
+
*
|
|
157
|
+
* {@link useTokens}
|
|
158
|
+
*
|
|
159
|
+
*/
|
|
160
|
+
type QueryResult<TVarName extends string, TData = unknown> = Omit<UseQueryResult<TData>, 'data'> & {
|
|
161
|
+
[P in TVarName]: UseQueryResult<TData>['data'];
|
|
162
|
+
};
|
|
163
|
+
/**
|
|
164
|
+
* See [Tanstack Query - useMutation](https://tanstack.com/query/latest/docs/framework/react/reference/useMutation) options.
|
|
165
|
+
* @see # [Tanstack Query - useMutation](https://tanstack.com/query/latest/docs/framework/react/reference/useMutation)
|
|
166
|
+
*
|
|
167
|
+
* @template {Object} TData - The data returned.
|
|
168
|
+
* @template {Object} TError - The error returned.
|
|
169
|
+
* @template {Object} TVariables - The variables used in the mutation.
|
|
170
|
+
*
|
|
171
|
+
* @options
|
|
172
|
+
* > `mutationKey` and `mutationFn` are used internally and therefore not included in the options.
|
|
173
|
+
* ```diff
|
|
174
|
+
* mutation: {
|
|
175
|
+
* gcTime,
|
|
176
|
+
* meta,
|
|
177
|
+
* - mutationFn,
|
|
178
|
+
* - mutationKey,
|
|
179
|
+
* networkMode,
|
|
180
|
+
* onError,
|
|
181
|
+
* onMutate,
|
|
182
|
+
* onSettled,
|
|
183
|
+
* onSuccess,
|
|
184
|
+
* retry,
|
|
185
|
+
* retryDelay,
|
|
186
|
+
* scope,
|
|
187
|
+
* throwOnError,
|
|
188
|
+
* }
|
|
189
|
+
* ```
|
|
190
|
+
* @example
|
|
191
|
+
* ```ts
|
|
192
|
+
* useMutationHook({
|
|
193
|
+
* mutation: {
|
|
194
|
+
* onSuccess: (data, variables) => {
|
|
195
|
+
* console.log('onSuccess callback', data, variables);
|
|
196
|
+
* },
|
|
197
|
+
* onError: (error) => {
|
|
198
|
+
* console.log('onError callback', error);
|
|
199
|
+
* },
|
|
200
|
+
* },
|
|
201
|
+
* })
|
|
202
|
+
* ```
|
|
203
|
+
*
|
|
204
|
+
* @usedBy
|
|
205
|
+
* {@link useLinkAddress}
|
|
206
|
+
*
|
|
207
|
+
* {@link usePlaceOrder}
|
|
208
|
+
*/
|
|
209
|
+
type MutationOptions<TData = unknown, TError = unknown, TVariables = unknown> = Omit<UseMutationOptions<TData, TError, TVariables>, 'mutationKey' | 'mutationFn'>;
|
|
210
|
+
/**
|
|
211
|
+
* See [Tanstack Query - useMutation](https://tanstack.com/query/latest/docs/framework/react/reference/useMutation) returns.
|
|
212
|
+
* @see # [Tanstack Query - useMutation](https://tanstack.com/query/latest/docs/framework/react/reference/useMutation)
|
|
213
|
+
*
|
|
214
|
+
* @template {string} TFuncName - The name of the function that mutates.
|
|
215
|
+
* @template {Object} TData - The data returned.
|
|
216
|
+
* @template {Object} TError - The error returned.
|
|
217
|
+
* @template {Object} TVariables - The variables used in the mutation.
|
|
218
|
+
* @template {Object} TContext - The context used in the mutation.
|
|
219
|
+
*
|
|
220
|
+
* @example
|
|
221
|
+
* > `mutateAsync` is renamed according to the `TFuncName` and therefore not included in the result.
|
|
222
|
+
* ```diff
|
|
223
|
+
* const {
|
|
224
|
+
* data,
|
|
225
|
+
* error,
|
|
226
|
+
* isError,
|
|
227
|
+
* isIdle,
|
|
228
|
+
* isPending,
|
|
229
|
+
* isPaused,
|
|
230
|
+
* isSuccess,
|
|
231
|
+
* failureCount,
|
|
232
|
+
* failureReason,
|
|
233
|
+
* mutate,
|
|
234
|
+
* - mutateAsync,
|
|
235
|
+
* reset,
|
|
236
|
+
* status,
|
|
237
|
+
* submittedAt,
|
|
238
|
+
* variables,
|
|
239
|
+
* } = useMutationHook();
|
|
240
|
+
* ```
|
|
241
|
+
* @usedBy
|
|
242
|
+
* {@link useLinkAddress}
|
|
243
|
+
*
|
|
244
|
+
* {@link usePlaceOrder}
|
|
245
|
+
*/
|
|
246
|
+
type MutationResult<TFuncName extends string, TData, TError, TVariables, TContext = unknown> = Omit<UseMutationResult<TData, TError, TVariables, TContext>, 'mutateAsync'> & {
|
|
247
|
+
[P in TFuncName]: UseMutationResult<TData, TError, TVariables, TContext>['mutateAsync'];
|
|
248
|
+
};
|
|
32
249
|
|
|
33
|
-
declare
|
|
250
|
+
declare const MoneriumContext: react.Context<(UseAuthReturn & SdkInstance) | null>;
|
|
34
251
|
|
|
35
|
-
|
|
252
|
+
/**
|
|
253
|
+
* @internal
|
|
254
|
+
* Query keys
|
|
255
|
+
* */
|
|
256
|
+
declare const keys: {
|
|
257
|
+
getAll: string[];
|
|
258
|
+
getAuthContext: string[];
|
|
259
|
+
getProfile: (profileId: string) => string[];
|
|
260
|
+
getProfiles: string[];
|
|
261
|
+
getBalances: (profileId?: string) => string[];
|
|
262
|
+
getTokens: string[];
|
|
263
|
+
getOrder: (orderId: string) => string[];
|
|
264
|
+
getOrders: (filter?: unknown) => {}[];
|
|
265
|
+
placeOrder: string[];
|
|
266
|
+
linkAddress: string[];
|
|
267
|
+
};
|
|
268
|
+
/**
|
|
269
|
+
* # Redirect to the Monerium auth flow.
|
|
270
|
+
* @group Hooks
|
|
271
|
+
* @example
|
|
272
|
+
* ```ts
|
|
273
|
+
* const { authorize, isAuthorized, isLoading, error } = useAuth();
|
|
274
|
+
*
|
|
275
|
+
* authorize(); // Redirects to the Monerium auth flow.
|
|
276
|
+
*
|
|
277
|
+
* // To opt-in to automated wallet linking, pass the address, signature and chain.
|
|
278
|
+
* authorize({ address, signature, chain }).
|
|
279
|
+
* ```
|
|
280
|
+
*
|
|
281
|
+
* @returns {UseAuthReturn}
|
|
282
|
+
* - `authorize` - Redirects to the Monerium auth flow.
|
|
283
|
+
* - `isAuthorized` - Whether the user is authorized.
|
|
284
|
+
* - `isLoading` - Whether the auth flow is loading.
|
|
285
|
+
* - `error` - Error message if the auth flow fails.
|
|
286
|
+
* - `disconnect` - Disconnect the user.
|
|
287
|
+
* - `revokeAccess` - Revoke the user's access.
|
|
288
|
+
*/
|
|
289
|
+
declare function useAuth(): UseAuthReturn;
|
|
290
|
+
/**
|
|
291
|
+
* # Get the authentication context.
|
|
292
|
+
* @group Hooks
|
|
293
|
+
*
|
|
294
|
+
* @param {Object} [params] No required parameters.
|
|
295
|
+
* @param {QueryOptions<AuthContext>} [params.query] {@inheritDoc QueryOptions}
|
|
296
|
+
*
|
|
297
|
+
* @example
|
|
298
|
+
* ```ts
|
|
299
|
+
* const {
|
|
300
|
+
* authContext, // useQuery's `data` property
|
|
301
|
+
* isLoading,
|
|
302
|
+
* isError,
|
|
303
|
+
* error,
|
|
304
|
+
* refetch,
|
|
305
|
+
* ...moreUseQueryResults
|
|
306
|
+
* } = useAuthContext();
|
|
307
|
+
* ```
|
|
308
|
+
*
|
|
309
|
+
* @see
|
|
310
|
+
* [API Documentation](https://monerium.dev/api-docs#operation/auth-context)
|
|
311
|
+
*
|
|
312
|
+
* [AuthContext interface](https://github.com/monerium/js-monorepo/blob/main/packages/sdk/docs/generated/interfaces/AuthContext.md)
|
|
313
|
+
*/
|
|
314
|
+
declare function useAuthContext({ query, }?: {
|
|
315
|
+
query?: QueryOptions<AuthContext>;
|
|
316
|
+
}): QueryResult<'authContext', AuthContext>;
|
|
317
|
+
/**
|
|
318
|
+
* # Get single profile
|
|
319
|
+
* If no `profileId` is provided, the default profile is used.
|
|
320
|
+
* @group Hooks
|
|
321
|
+
* @param {Object} params
|
|
322
|
+
* @param {string} [params.profileId] The id of the profile.
|
|
323
|
+
* @param {QueryOptions<Profile>} [params.query] {@inheritDoc QueryOptions}
|
|
324
|
+
*
|
|
325
|
+
* @example
|
|
326
|
+
* ```ts
|
|
327
|
+
* const {
|
|
328
|
+
* profile, // useQuery's `data` property
|
|
329
|
+
* isLoading,
|
|
330
|
+
* isError,
|
|
331
|
+
* error,
|
|
332
|
+
* refetch,
|
|
333
|
+
* ...moreUseQueryResults
|
|
334
|
+
* } = useProfile();
|
|
335
|
+
* ```
|
|
336
|
+
|
|
337
|
+
* @see
|
|
338
|
+
* [API Documentation](https://monerium.dev/api-docs#operation/profile)
|
|
339
|
+
*
|
|
340
|
+
* [Profile interface](https://github.com/monerium/js-monorepo/blob/main/packages/sdk/docs/generated/interfaces/Profile.md)
|
|
341
|
+
*/
|
|
342
|
+
declare function useProfile({ profileId, query, }?: {
|
|
343
|
+
profileId?: string;
|
|
344
|
+
query?: QueryOptions<Profile>;
|
|
345
|
+
}): QueryResult<'profile', Profile>;
|
|
346
|
+
/**
|
|
347
|
+
* # Get profiles
|
|
348
|
+
* @group Hooks
|
|
349
|
+
* @param {Object} [params] No required parameters.
|
|
350
|
+
* @param {QueryOptions<Profile[]>} [params.query] {@inheritDoc QueryOptions}
|
|
351
|
+
*
|
|
352
|
+
* @example
|
|
353
|
+
* ```ts
|
|
354
|
+
* const {
|
|
355
|
+
* profiles, // useQuery's `data` property
|
|
356
|
+
* isLoading,
|
|
357
|
+
* isError,
|
|
358
|
+
* error,
|
|
359
|
+
* refetch,
|
|
360
|
+
* ...moreUseQueryResults
|
|
361
|
+
* } = useProfiles();
|
|
362
|
+
* ```
|
|
363
|
+
|
|
364
|
+
* @see
|
|
365
|
+
* [API Documentation](https://monerium.dev/api-docs#operation/profiles)
|
|
366
|
+
*
|
|
367
|
+
* [Profile interface](https://github.com/monerium/js-monorepo/blob/main/packages/sdk/docs/generated/interfaces/Profile.md)
|
|
368
|
+
*/
|
|
369
|
+
declare function useProfiles({ query, }?: {
|
|
370
|
+
query?: QueryOptions<Profile[]>;
|
|
371
|
+
}): QueryResult<'profiles', Profile[]>;
|
|
372
|
+
/**
|
|
373
|
+
* # Get tokens
|
|
374
|
+
* @group Hooks
|
|
375
|
+
* @param {Object} [params] No required parameters.
|
|
376
|
+
* @param {QueryOptions<Token[]>} [params.query] {@inheritDoc QueryOptions}
|
|
377
|
+
*
|
|
378
|
+
* @example
|
|
379
|
+
* ```ts
|
|
380
|
+
* const {
|
|
381
|
+
* tokens, // useQuery's `data` property
|
|
382
|
+
* isLoading,
|
|
383
|
+
* isError,
|
|
384
|
+
* error,
|
|
385
|
+
* refetch,
|
|
386
|
+
* ...moreUseQueryResults
|
|
387
|
+
* } = useTokens();
|
|
388
|
+
* ```
|
|
389
|
+
|
|
390
|
+
* @see
|
|
391
|
+
* [API Documentation](https://monerium.dev/api-docs#operation/tokens)
|
|
392
|
+
*
|
|
393
|
+
* [Token interface](https://github.com/monerium/js-monorepo/blob/main/packages/sdk/docs/generated/interfaces/Token.md)
|
|
394
|
+
*/
|
|
395
|
+
declare function useTokens({ query, }?: {
|
|
396
|
+
query?: QueryOptions<Token[]>;
|
|
397
|
+
}): QueryResult<'tokens', Token[]>;
|
|
398
|
+
/**
|
|
399
|
+
* # Get balances
|
|
400
|
+
* @group Hooks
|
|
401
|
+
* @param {Object} [params] No required parameters.
|
|
402
|
+
* @param {QueryOptions<Balances[]>} [params.profileId] Fetch balances for a specific profile.
|
|
403
|
+
* @param {QueryOptions<Balances[]>} [params.query] {@inheritDoc QueryOptions}
|
|
404
|
+
|
|
405
|
+
* @example
|
|
406
|
+
* ```ts
|
|
407
|
+
* const {
|
|
408
|
+
* balances, // useQuery's `data` property
|
|
409
|
+
* isLoading,
|
|
410
|
+
* isError,
|
|
411
|
+
* error,
|
|
412
|
+
* refetch,
|
|
413
|
+
* ...moreUseQueryResults
|
|
414
|
+
* } = useBalances();
|
|
415
|
+
* ```
|
|
416
|
+
* @see
|
|
417
|
+
* [API Documentation](https://monerium.dev/api-docs#operation/profile-balances)
|
|
418
|
+
*
|
|
419
|
+
* [Balances interface](https://github.com/monerium/js-monorepo/blob/main/packages/sdk/docs/generated/interfaces/Balances.md)
|
|
420
|
+
*/
|
|
421
|
+
declare function useBalances({ profileId, query, }?: {
|
|
422
|
+
profileId?: string;
|
|
423
|
+
query?: QueryOptions<Balances[]>;
|
|
424
|
+
}): QueryResult<'balances', Balances[]>;
|
|
425
|
+
/**
|
|
426
|
+
* # Get single order
|
|
427
|
+
* @group Hooks
|
|
428
|
+
* @param {Object} params
|
|
429
|
+
* @param {Object} params.orderId The id of the order.
|
|
430
|
+
* @param {QueryOptions<Order>} [params.query] {@inheritDoc QueryOptions}
|
|
431
|
+
* @example
|
|
432
|
+
* ```ts
|
|
433
|
+
* const {
|
|
434
|
+
* order, // useQuery's `data` property
|
|
435
|
+
* isLoading,
|
|
436
|
+
* isError,
|
|
437
|
+
* error,
|
|
438
|
+
* refetch,
|
|
439
|
+
* ...moreUseQueryResults
|
|
440
|
+
* } = useOrder();
|
|
441
|
+
* ```
|
|
442
|
+
* @see
|
|
443
|
+
* [API Documentation](https://monerium.dev/api-docs#operation/order)
|
|
444
|
+
*
|
|
445
|
+
* [Order interface](https://github.com/monerium/js-monorepo/blob/main/packages/sdk/docs/generated/interfaces/Order.md)
|
|
446
|
+
*/
|
|
447
|
+
declare function useOrder({ orderId, query, }: {
|
|
448
|
+
orderId: string;
|
|
449
|
+
query?: QueryOptions<Order>;
|
|
450
|
+
}): QueryResult<'order', Order>;
|
|
451
|
+
/**
|
|
452
|
+
* # Get orders
|
|
453
|
+
* @group Hooks
|
|
454
|
+
* @param {Object} [params] No required parameters.
|
|
455
|
+
* @param {Object} [params.address] Filter based on the blockchain address associated with the order.
|
|
456
|
+
* @param {Object} [params.memo] Filter by the payment memo/reference..
|
|
457
|
+
* @param {Object} [params.profile] Filter based on the profile ID associated with the order.
|
|
458
|
+
* @param {Object} [params.state] Filter based on the state of the order.
|
|
459
|
+
* @param {Object} [params.txHash] Filter based on the blockchain transaction hash.
|
|
460
|
+
* @param {QueryOptions<Order[]>} [params.query] {@inheritDoc QueryOptions}
|
|
461
|
+
*
|
|
462
|
+
* @example
|
|
463
|
+
* ```ts
|
|
464
|
+
* const {
|
|
465
|
+
* orders, // useQuery's `data` property
|
|
466
|
+
* isLoading,
|
|
467
|
+
* isError,
|
|
468
|
+
* error,
|
|
469
|
+
* refetch,
|
|
470
|
+
* ...moreUseQueryResults
|
|
471
|
+
* } = useOrders();
|
|
472
|
+
* ```
|
|
473
|
+
* @see
|
|
474
|
+
* [API Documentation](https://monerium.dev/api-docs#operation/orders)
|
|
475
|
+
*
|
|
476
|
+
* [Order interface](https://github.com/monerium/js-monorepo/blob/main/packages/sdk/docs/generated/interfaces/Order.md)
|
|
477
|
+
*/
|
|
478
|
+
declare function useOrders({ query, ...filters }?: {
|
|
479
|
+
query?: QueryOptions<Order[]>;
|
|
480
|
+
address?: string;
|
|
481
|
+
txHash?: string;
|
|
482
|
+
profile?: string;
|
|
483
|
+
memo?: string;
|
|
484
|
+
state?: OrderState;
|
|
485
|
+
}): QueryResult<'orders', Order[]>;
|
|
486
|
+
/**
|
|
487
|
+
* # Place an order.
|
|
488
|
+
* When the order has been placed, the orders query will be invalidated and re-fetched.
|
|
489
|
+
*
|
|
490
|
+
* If the order amount is above 15000, a supporting document is required.
|
|
491
|
+
* @group Hooks
|
|
492
|
+
* @param param
|
|
493
|
+
* @param {File} param.supportingDocument Supporting document file.
|
|
494
|
+
* @param {Object} param.mutation {@inheritDoc MutationOptions}
|
|
495
|
+
*
|
|
496
|
+
* @example
|
|
497
|
+
* ```ts
|
|
498
|
+
* const {
|
|
499
|
+
* placeOrder, // useMutation's `mutateAsync` property
|
|
500
|
+
* isPending,
|
|
501
|
+
* isError,
|
|
502
|
+
* error,
|
|
503
|
+
* status,
|
|
504
|
+
* ...moreUseMutationResults
|
|
505
|
+
* } = usePlaceOrder();
|
|
506
|
+
* ```
|
|
507
|
+
* @see
|
|
508
|
+
* [API Documentation](https://monerium.dev/api-docs#operation/post-orders)
|
|
509
|
+
*
|
|
510
|
+
* [NewOrder type](https://github.com/monerium/js-monorepo/blob/main/packages/sdk/docs/generated/type-aliases/NewOrder.md)
|
|
511
|
+
*/
|
|
512
|
+
declare function usePlaceOrder({ supportingDocument, mutation, }?: {
|
|
513
|
+
supportingDocument?: File;
|
|
514
|
+
mutation?: MutationOptions<Order, Error, NewOrder>;
|
|
515
|
+
}): MutationResult<'placeOrder', Order, Error, NewOrder>;
|
|
516
|
+
/**
|
|
517
|
+
* # Add address to profile.
|
|
518
|
+
* When the address has been linked, the relevant profile query will be invalidated and re-fetched.
|
|
519
|
+
*
|
|
520
|
+
* @group Hooks
|
|
521
|
+
* @param param
|
|
522
|
+
* @param {File} param.profileId Which profile to link the address.
|
|
523
|
+
* @param {Object} param.mutation {@inheritDoc MutationOptions}
|
|
524
|
+
*
|
|
525
|
+
* @example
|
|
526
|
+
* ```ts
|
|
527
|
+
* const {
|
|
528
|
+
* linkAddress, // useMutation's `mutateAsync` property
|
|
529
|
+
* isPending,
|
|
530
|
+
* isError,
|
|
531
|
+
* error,
|
|
532
|
+
* status,
|
|
533
|
+
* ...moreUseMutationResults
|
|
534
|
+
* } = useLinkAddress();
|
|
535
|
+
* ```
|
|
536
|
+
* @see
|
|
537
|
+
* [API Documentation](https://monerium.dev/api-docs#operation/profile-addresses)
|
|
538
|
+
*
|
|
539
|
+
* [LinkAddress interface](https://github.com/monerium/js-monorepo/blob/main/packages/sdk/docs/generated/interfaces/LinkAddress.md)
|
|
540
|
+
*/
|
|
541
|
+
declare function useLinkAddress({ profileId, mutation, }: {
|
|
542
|
+
profileId: string;
|
|
543
|
+
mutation?: MutationOptions<LinkedAddress, Error, LinkAddress>;
|
|
544
|
+
}): MutationResult<'linkAddress', LinkedAddress, Error, LinkAddress>;
|
|
545
|
+
|
|
546
|
+
export { type AuthorizeParams, MoneriumContext, MoneriumProvider, type MutationOptions, type MutationResult, type QueryOptions, type QueryResult, type SdkInstance, type UseAuthReturn, keys, useAuth, useAuthContext, useBalances, useLinkAddress, useOrder, useOrders, usePlaceOrder, useProfile, useProfiles, useTokens };
|
package/dist/index.js
CHANGED
|
@@ -1,13 +1,24 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
3
|
var react = require('react');
|
|
4
|
+
var reactQuery = require('@tanstack/react-query');
|
|
4
5
|
var sdk = require('@monerium/sdk');
|
|
5
6
|
var jsxRuntime = require('react/jsx-runtime');
|
|
6
7
|
|
|
7
|
-
var
|
|
8
|
+
var y=react.createContext(null);var T=({children:e,clientId:t,redirectUrl:r,redirectUri:o,environment:n="sandbox"})=>{let u=reactQuery.useQueryClient(),[s,i]=react.useState(),[a,d]=react.useState(!1),[A,g]=react.useState(null),[b,z]=react.useState(!0);react.useEffect(()=>{let h=new sdk.MoneriumClient({environment:n,clientId:t,redirectUri:o||r});i(h);},[]),react.useEffect(()=>((async()=>{if(s)try{d(await s.getAccess());}catch(p){console.error("Failed to get access:",p);}finally{z(!1);}})(),()=>{s&&s.disconnect();}),[s]);let v=react.useCallback(async h=>{try{s&&await s.authorize(h);}catch(p){console.error("Error during authorization:",p),g(p);}},[s]),C=async()=>{try{s&&await s.revokeAccess();}catch(h){console.error("Error during revoking access:",h),g(h);}finally{u.clear(),d(!1);}};return jsxRuntime.jsx(y.Provider,{value:{sdk:s,authorize:v,isAuthorized:a,isLoading:b,error:A,disconnect:async()=>s?.disconnect(),revokeAccess:async()=>C()},children:e})};var c={getAll:["monerium"],getAuthContext:["monerium","auth-context"],getProfile:e=>["monerium","profile",...e?[e]:[]],getProfiles:["monerium","profiles"],getBalances:e=>["monerium","balances",...e?[e]:[]],getTokens:["monerium","tokens"],getOrder:e=>["monerium","order",e],getOrders:e=>["monerium","orders",...e?[e]:[]],placeOrder:["monerium","place-order"],linkAddress:["monerium","link-address"]};function l(){let e=react.useContext(y);if(e===null)throw new Error("useSdk must be used within a MoneriumProvider");return e?.sdk}function f(){let e=react.useContext(y);if(e===null)throw new Error("useAuth must be used within a MoneriumProvider");return {isAuthorized:e.isAuthorized,authorize:e.authorize,isLoading:e.isLoading,error:e.error,disconnect:e.disconnect,revokeAccess:e.revokeAccess}}function M({query:e}={}){let{isAuthorized:t}=f(),r=l(),{data:o,...n}=reactQuery.useQuery({...e,queryKey:c.getAuthContext,queryFn:async()=>{if(!r)throw new Error("No SDK instance available");if(!t)throw new Error("User not authorized");return r.getAuthContext()},enabled:!!(r&&t&&(e?.enabled??!0))});return {authContext:o,...n}}function W({profileId:e,query:t}={}){let{isAuthorized:r}=f(),o=l(),{authContext:n}=M(),u=e||n?.defaultProfile,{data:s,...i}=reactQuery.useQuery({...t,queryKey:c.getProfile(u),queryFn:async()=>{if(!o)throw new Error("No SDK instance available");if(!r)throw new Error("User not authorized");if(!u)throw new Error("Profile Id is required");return o.getProfile(u)},enabled:!!(o&&r&&u&&(t?.enabled??!0))});return {profile:s,...i}}function X({query:e}={}){let{isAuthorized:t}=f(),r=l(),{data:o,...n}=reactQuery.useQuery({...e,queryKey:c.getProfiles,queryFn:async()=>{if(!r)throw new Error("No SDK instance available");if(!t)throw new Error("User not authorized");return r.getProfiles()},enabled:!!(r&&t&&(e?.enabled??!0))});return {profiles:o,...n}}function Y({query:e}={}){let t=l(),{isAuthorized:r}=f(),{data:o,...n}=reactQuery.useQuery({...e,queryKey:c.getTokens,queryFn:async()=>{if(!t)throw new Error("No SDK instance available");if(!r)throw new Error("User not authorized");return t.getTokens()},enabled:!!(t&&r&&(e?.enabled??!0))});return {tokens:o,...n}}function Z({profileId:e,query:t}={}){let r=l(),{isAuthorized:o}=f(),{data:n,...u}=reactQuery.useQuery({...t,queryKey:c.getBalances(e),queryFn:async()=>{if(!r)throw new Error("No SDK instance available");if(!o)throw new Error("User not authorized");return r.getBalances(e)},enabled:!!(r&&o&&(t?.enabled??!0))});return {balances:n,...u}}function _({orderId:e,query:t={}}){let r=l(),{isAuthorized:o}=f(),{data:n,...u}=reactQuery.useQuery({...t,queryKey:c.getOrder(e),queryFn:async()=>{if(!r)throw new Error("No SDK instance available");if(!o)throw new Error("User not authorized");if(!e)throw new Error("Order id is required");return r.getOrder(e)},enabled:!!(r&&o&&e&&(t.enabled??!0))});return {order:n,...u}}function $({query:e={},...t}={}){let r=l(),{isAuthorized:o}=f(),{data:n,...u}=reactQuery.useQuery({...e,queryKey:c.getOrders(t),queryFn:async()=>{if(!r)throw new Error("No SDK instance available");if(!o)throw new Error("User not authorized");return r.getOrders(t)},enabled:!!(r&&o&&(e.enabled??!0))});return {orders:n,...u}}function j({supportingDocument:e,mutation:t}={}){let r=l(),{isAuthorized:o}=f(),n=reactQuery.useQueryClient(),{mutateAsync:u,...s}=reactQuery.useMutation({...t,mutationKey:c.placeOrder,mutationFn:async i=>{if(!r)throw new Error("No SDK instance available");if(!o)throw new Error("User not authorized");let a;if(parseInt(i.amount)>15e3){if(!e)throw new Error("Supporting document is required for orders above 15000");a=(await r.uploadSupportingDocument(e)).id;}let d={...i,documentId:a};return r.placeOrder(d)},onSuccess(i,a,d){n.invalidateQueries({queryKey:c.getOrders()}),t?.onSuccess?.(i,a,d);},onError(i,a,d){throw t?.onError?.(i,a,d),i}});return {placeOrder:u,...s}}function ee({profileId:e,mutation:t}){let r=l(),{isAuthorized:o}=f(),n=reactQuery.useQueryClient(),{mutateAsync:u,...s}=reactQuery.useMutation({...t,mutationKey:c.linkAddress,mutationFn:async i=>{if(!r)throw new Error("No SDK instance available");if(!o)throw new Error("User not authorized");return r.linkAddress(e,i)},onSuccess(i,a,d){n.invalidateQueries({queryKey:c.getProfile(e)}),t?.onSuccess?.(i,a,d);},onError(i,a,d){throw t?.onError?.(i,a,d),i}});return {linkAddress:u,...s}}
|
|
8
9
|
|
|
9
|
-
exports.MoneriumContext =
|
|
10
|
-
exports.MoneriumProvider =
|
|
11
|
-
exports.
|
|
12
|
-
|
|
13
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/lib/provider.tsx","../src/lib/context.tsx","../src/lib/hook.tsx"],"names":["useCallback","useEffect","useState","MoneriumClient","createContext","MoneriumContext","jsx","MoneriumProvider","children","clientId","redirectUrl","environment","monerium","setMonerium","isAuthorized","setIsAuthorized","profile","setProfile","balances","setBalances","loading","setLoading","loadingPlaceOrder","setLoadingPlaceOrder","loadingLinkAddress","setLoadingLinkAddress","loadingBalances","setLoadingBalances","error","setError","orders","setOrders","tokens","setTokens","loadingAuth","setLoadingAuth","sdk","authCtx","getBalances","profileData","tokensData","ordersData","err","authorize","placeOrder","orderDetails","supportingDocument","documentId","newOrderDetails","newOrder","prevOrders","linkAddress","addressDetails","useContext","useMonerium","context"],"mappings":"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","sourcesContent":["import { FC, ReactNode, useCallback, useEffect, useState } from 'react';\n\nimport {\n  Balances,\n  LinkAddress,\n  MoneriumClient,\n  NewOrder,\n  Order,\n  Profile,\n  Token,\n} from '@monerium/sdk';\n\nimport { MoneriumContext } from './context';\n\ninterface MoneriumProviderProps {\n  children: ReactNode;\n  clientId?: string;\n  redirectUrl?: string;\n  environment?: 'sandbox' | 'production';\n}\n\nexport const MoneriumProvider: FC<MoneriumProviderProps> = ({\n  children,\n  clientId = 'f99e629b-6dca-11ee-8aa6-5273f65ed05b',\n  redirectUrl = 'http://localhost:5173',\n  environment = 'sandbox',\n}) => {\n  const [monerium, setMonerium] = useState<MoneriumClient>();\n  const [isAuthorized, setIsAuthorized] = useState<boolean>(false);\n  const [profile, setProfile] = useState<Profile | null>(null);\n  const [balances, setBalances] = useState<Balances[] | null>(null);\n  const [loading, setLoading] = useState(false);\n  const [loadingPlaceOrder, setLoadingPlaceOrder] = useState(false);\n  const [loadingLinkAddress, setLoadingLinkAddress] = useState(false);\n  const [loadingBalances, setLoadingBalances] = useState(false);\n  const [error, setError] = useState<Error | unknown | null>(null);\n  const [orders, setOrders] = useState<Order[]>([]);\n  const [tokens, setTokens] = useState<Token[]>([]);\n  const [loadingAuth, setLoadingAuth] = useState(true);\n\n  // Initialize the SDK\n  useEffect(() => {\n    const sdk = new MoneriumClient({\n      environment: environment,\n      clientId,\n      redirectUrl,\n    });\n    setMonerium(sdk);\n  }, []);\n\n  useEffect(() => {\n    const connect = async () => {\n      if (monerium) {\n        try {\n          setIsAuthorized(await monerium.getAccess());\n        } catch (error) {\n          console.error('Failed to get access:', error);\n        } finally {\n          setLoadingAuth(false);\n        }\n      }\n    };\n\n    connect();\n\n    return () => {\n      if (monerium) {\n        monerium.disconnect();\n      }\n    };\n  }, [monerium]);\n\n  useEffect(() => {\n    const fetchData = async () => {\n      if (monerium && isAuthorized) {\n        try {\n          setLoading(true);\n          const [authCtx] = await Promise.all([\n            monerium.getAuthContext(),\n            getBalances(),\n          ]);\n\n          const [profileData, tokensData] = await Promise.all([\n            monerium.getProfile(authCtx.defaultProfile),\n            monerium.getTokens(),\n          ]);\n\n          const ordersData = await monerium.getOrders();\n\n          setProfile(profileData);\n          setOrders(ordersData);\n          setTokens(tokensData);\n        } catch (err) {\n          console.error('Error fetching data:', err);\n          setError(err);\n        } finally {\n          setLoading(false);\n        }\n      }\n    };\n\n    fetchData();\n  }, [monerium, isAuthorized]);\n\n  const authorize = useCallback(async () => {\n    try {\n      if (monerium) {\n        await monerium.authorize();\n      }\n    } catch (err) {\n      console.error('Error during authorization:', err);\n      setError(err);\n    }\n  }, [monerium]);\n\n  const getBalances = useCallback(async () => {\n    if (monerium && isAuthorized) {\n      try {\n        setLoadingBalances(true);\n        const balances = await monerium.getBalances();\n        setBalances(balances);\n      } catch (err) {\n        console.error('Error getting balances:', err);\n        setError(err);\n      } finally {\n        setLoadingBalances(false);\n      }\n    }\n  }, [monerium, isAuthorized]);\n\n  const placeOrder = useCallback(\n    async (orderDetails: NewOrder, supportingDocument?: File) => {\n      if (monerium && isAuthorized) {\n        try {\n          setLoadingPlaceOrder(true);\n\n          let documentId;\n          if (parseInt(orderDetails.amount) > 15000 && supportingDocument) {\n            const uploadedDocument =\n              await monerium.uploadSupportingDocument(supportingDocument);\n            documentId = uploadedDocument.id;\n          }\n\n          const newOrderDetails = {\n            ...orderDetails,\n            documentId: documentId,\n          };\n\n          const newOrder = await monerium.placeOrder(newOrderDetails);\n          setOrders((prevOrders) => [...prevOrders, newOrder]);\n        } catch (err) {\n          console.error('Error placing order:', err);\n          setError(err);\n        } finally {\n          setLoadingPlaceOrder(false);\n        }\n      }\n    },\n    [monerium, isAuthorized]\n  );\n\n  const linkAddress = useCallback(\n    async (addressDetails: LinkAddress) => {\n      if (monerium && isAuthorized && profile) {\n        try {\n          setLoadingLinkAddress(true);\n          return await monerium.linkAddress(profile.id, addressDetails);\n\n          // Update your state or do something with linkedAddress\n        } catch (err) {\n          console.error('Error linking address:', err);\n          setError(err);\n        } finally {\n          setLoadingLinkAddress(false);\n        }\n      }\n    },\n    [monerium, isAuthorized, profile]\n  );\n\n  //\n\n  return (\n    <MoneriumContext.Provider\n      value={{\n        authorize,\n        isAuthorized,\n        profile,\n        balances,\n        loading,\n        loadingPlaceOrder,\n        loadingLinkAddress,\n        loadingBalances,\n        getBalances,\n        linkAddress,\n        placeOrder,\n        orders,\n        tokens,\n        error,\n        loadingAuth,\n      }}\n    >\n      {children}\n    </MoneriumContext.Provider>\n  );\n};\n","import { createContext } from 'react';\n\nimport {\n  Balances,\n  LinkAddress,\n  NewOrder,\n  Order,\n  Profile,\n  Token,\n} from '@monerium/sdk';\n\nexport interface MoneriumContextValue {\n  authorize: () => Promise<void>;\n  isAuthorized: boolean;\n  profile: Profile | null;\n  balances: Balances[] | null;\n  loading: boolean;\n  loadingPlaceOrder: boolean;\n  loadingLinkAddress: boolean;\n  loadingBalances: boolean;\n  getBalances: () => Promise<void>;\n  linkAddress: (addressDetails: LinkAddress) => Promise<unknown>;\n  placeOrder: (\n    orderDetails: NewOrder,\n    supportingDocument?: File\n  ) => Promise<void>;\n  orders: Order[];\n  tokens: Token[];\n  error: unknown;\n  /** Is still checking if there is an active session */\n  loadingAuth: boolean;\n}\n\nexport const MoneriumContext = createContext<MoneriumContextValue | null>(null);\n","import { useContext } from 'react';\n\nimport { MoneriumContext, MoneriumContextValue } from './context';\n\nexport function useMonerium(): MoneriumContextValue {\n  const context = useContext(MoneriumContext);\n\n  if (context === null) {\n    throw new Error('useMonerium must be used within a MoneriumProvider');\n  }\n  return context;\n}\n"]}
|
|
10
|
+
exports.MoneriumContext = y;
|
|
11
|
+
exports.MoneriumProvider = T;
|
|
12
|
+
exports.keys = c;
|
|
13
|
+
exports.useAuth = f;
|
|
14
|
+
exports.useAuthContext = M;
|
|
15
|
+
exports.useBalances = Z;
|
|
16
|
+
exports.useLinkAddress = ee;
|
|
17
|
+
exports.useOrder = _;
|
|
18
|
+
exports.useOrders = $;
|
|
19
|
+
exports.usePlaceOrder = j;
|
|
20
|
+
exports.useProfile = W;
|
|
21
|
+
exports.useProfiles = X;
|
|
22
|
+
exports.useTokens = Y;
|
|
23
|
+
//# sourceMappingURL=index.js.map
|
|
24
|
+
//# 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","redirectUrl","redirectUri","environment","queryClient","useQueryClient","sdk","setSdk","useState","isAuthorized","setIsAuthorized","error","setError","loadingAuth","setLoadingAuth","useEffect","sdkInstance","MoneriumClient","authorize","useCallback","params","err","revokeAccess","jsx","keys","profileId","orderId","filter","useSdk","context","useContext","useAuth","useAuthContext","query","data","rest","useQuery","useProfile","authContext","profileIdToUse","useProfiles","useTokens","useBalances","useOrder","useOrders","filters","usePlaceOrder","supportingDocument","mutation","mutateAsync","useMutation","body","documentId","newBody","variables","vars","useLinkAddress"],"mappings":";;;;;;;AAIO,IAAMA,CAAkBC,CAAAA,mBAAAA,CAE7B,IAAI,MCYOC,CAAmB,CAAA,CAAC,CAC/B,QAAA,CAAAC,EACA,QAAAC,CAAAA,CAAAA,CACA,WAAAC,CAAAA,CAAAA,CACA,WAAAC,CAAAA,CAAAA,CACA,WAAAC,CAAAA,CAAAA,CAAc,SAChB,CAOM,GAAA,CACJ,IAAMC,CAAAA,CAAcC,yBAAe,EAAA,CAE7B,CAACC,CAAAA,CAAKC,CAAM,CAAIC,CAAAA,cAAAA,EAChB,CAAA,CAACC,CAAcC,CAAAA,CAAe,CAAIF,CAAAA,cAAAA,CAAkB,EAAK,CACzD,CAAA,CAACG,CAAOC,CAAAA,CAAQ,EAAIJ,cAAiC,CAAA,IAAI,CACzD,CAAA,CAACK,EAAaC,CAAc,CAAA,CAAIN,cAAS,CAAA,CAAA,CAAI,CAGnDO,CAAAA,eAAAA,CAAU,IAAM,CACd,IAAMC,CAAc,CAAA,IAAIC,kBAAe,CAAA,CACrC,WAAad,CAAAA,CAAAA,CACb,QAAAH,CAAAA,CAAAA,CACA,YAAaE,CAAeD,EAAAA,CAC9B,CAAC,CAAA,CACDM,CAAOS,CAAAA,CAAW,EACpB,CAAA,CAAG,EAAE,CAAA,CAELD,eAAU,CAAA,KAAA,CACQ,SAAY,CAC1B,GAAIT,CACF,CAAA,GAAI,CACFI,CAAgB,CAAA,MAAMJ,CAAI,CAAA,SAAA,EAAW,EACvC,CAASK,MAAAA,CAAAA,CAAO,CACd,OAAQ,CAAA,KAAA,CAAM,uBAAyBA,CAAAA,CAAK,EAC9C,CAAE,OAAA,CACAG,CAAe,CAAA,CAAA,CAAK,EACtB,CAEJ,CAAA,GAIO,CAAA,IAAM,CACPR,CAAAA,EACFA,CAAI,CAAA,UAAA,GAER,CACC,CAAA,CAAA,CAACA,CAAG,CAAC,EAER,IAAMY,CAAAA,CAAYC,iBAChB,CAAA,MAAOC,GAA6B,CAClC,GAAI,CACEd,CAAAA,EACF,MAAMA,CAAAA,CAAI,SAAUc,CAAAA,CAAM,EAE9B,CAASC,MAAAA,CAAAA,CAAK,CACZ,OAAA,CAAQ,KAAM,CAAA,6BAAA,CAA+BA,CAAG,CAAA,CAChDT,EAASS,CAAG,EACd,CACF,CAAA,CACA,CAACf,CAAG,CACN,CAAA,CAEMgB,EAAe,SAAY,CAC/B,GAAI,CACEhB,GACF,MAAMA,CAAAA,CAAI,YAAa,GAE3B,OAASe,CAAK,CAAA,CACZ,OAAQ,CAAA,KAAA,CAAM,+BAAiCA,CAAAA,CAAG,CAClDT,CAAAA,CAAAA,CAASS,CAAG,EACd,CAAA,OAAE,CACAjB,CAAAA,CAAY,KAAM,EAAA,CAClBM,CAAgB,CAAA,CAAA,CAAK,EACvB,CACF,CAAA,CAEA,OACEa,cAAAA,CAAC3B,CAAgB,CAAA,QAAA,CAAhB,CACC,KAAA,CAAO,CACL,GAAAU,CAAAA,CAAAA,CACA,SAAAY,CAAAA,CAAAA,CACA,aAAAT,CACA,CAAA,SAAA,CAAWI,CACX,CAAA,KAAA,CAAAF,EACA,UAAY,CAAA,SAAYL,CAAK,EAAA,UAAA,EAC7B,CAAA,YAAA,CAAc,SAAYgB,CAAAA,EAC5B,CAEC,CAAA,QAAA,CAAAvB,CACH,CAAA,CAEJ,MCtFayB,CAAO,CAAA,CAClB,MAAQ,CAAA,CAAC,UAAU,CACnB,CAAA,cAAA,CAAgB,CAAC,UAAA,CAAY,cAAc,CAC3C,CAAA,UAAA,CAAaC,CAAsB,EAAA,CACjC,UACA,CAAA,SAAA,CACA,GAAIA,CAAAA,CAAY,CAACA,CAAS,CAAA,CAAI,EAChC,EACA,WAAa,CAAA,CAAC,UAAY,CAAA,UAAU,EACpC,WAAcA,CAAAA,CAAAA,EAAuB,CACnC,UAAA,CACA,UACA,CAAA,GAAIA,CAAY,CAAA,CAACA,CAAS,CAAI,CAAA,EAChC,CAAA,CACA,UAAW,CAAC,UAAA,CAAY,QAAQ,CAAA,CAChC,SAAWC,CAAoB,EAAA,CAAC,UAAY,CAAA,OAAA,CAASA,CAAO,CAAA,CAC5D,SAAYC,CAAAA,CAAAA,EAAqB,CAC/B,UACA,CAAA,QAAA,CACA,GAAIA,CAAAA,CAAS,CAACA,CAAM,CAAI,CAAA,EAC1B,CACA,CAAA,UAAA,CAAY,CAAC,UAAA,CAAY,aAAa,CAAA,CACtC,WAAa,CAAA,CAAC,WAAY,cAAc,CAC1C,EAGA,SAASC,GAAqC,CAC5C,IAAMC,CAAUC,CAAAA,gBAAAA,CAAWlC,CAAe,CAE1C,CAAA,GAAIiC,CAAY,GAAA,IAAA,CACd,MAAM,IAAI,KAAM,CAAA,+CAA+C,EAEjE,OAAOA,CAAAA,EAAS,GAClB,CAuBO,SAASE,CAAAA,EAAyB,CACvC,IAAMF,EAAUC,gBAAWlC,CAAAA,CAAe,CAE1C,CAAA,GAAIiC,CAAY,GAAA,IAAA,CACd,MAAM,IAAI,MAAM,gDAAgD,CAAA,CAElE,OAAO,CACL,aAAcA,CAAQ,CAAA,YAAA,CACtB,SAAWA,CAAAA,CAAAA,CAAQ,UACnB,SAAWA,CAAAA,CAAAA,CAAQ,SACnB,CAAA,KAAA,CAAOA,CAAQ,CAAA,KAAA,CACf,UAAYA,CAAAA,CAAAA,CAAQ,WACpB,YAAcA,CAAAA,CAAAA,CAAQ,YACxB,CACF,CA0BO,SAASG,CAAe,CAAA,CAC7B,MAAAC,CACF,CAAA,CAEI,EAAC,CAA4C,CAC/C,GAAM,CAAE,YAAA,CAAAxB,CAAa,CAAIsB,CAAAA,CAAAA,EACnBzB,CAAAA,CAAAA,CAAMsB,GAEN,CAAA,CAAE,IAAAM,CAAAA,CAAAA,CAAM,GAAGC,CAAK,CAAA,CAAIC,mBAAS,CAAA,CACjC,GAAGH,CAAAA,CACH,QAAUT,CAAAA,CAAAA,CAAK,eACf,OAAS,CAAA,SAAY,CACnB,GAAI,CAAClB,CACH,CAAA,MAAM,IAAI,KAAA,CAAM,2BAA2B,CAE7C,CAAA,GAAI,CAACG,CAAAA,CACH,MAAM,IAAI,KAAM,CAAA,qBAAqB,EAEvC,OAAOH,CAAAA,CAAI,cAAe,EAC5B,EACA,OAAS,CAAA,CAAA,EAAQA,CAAOG,EAAAA,CAAAA,GAAiBwB,GAAO,OAAW,EAAA,CAAA,CAAA,CAAA,CAC7D,CAAC,CAAA,CACD,OAAO,CACL,WAAaC,CAAAA,CAAAA,CACb,GAAGC,CACL,CACF,CA2BO,SAASE,CAAW,CAAA,CACzB,SAAAZ,CAAAA,CAAAA,CACA,MAAAQ,CACF,CAAA,CAGI,EAAC,CAAoC,CACvC,GAAM,CAAE,YAAA,CAAAxB,CAAa,CAAIsB,CAAAA,CAAAA,EACnBzB,CAAAA,CAAAA,CAAMsB,GACN,CAAA,CAAE,WAAAU,CAAAA,CAAY,EAAIN,CAAe,EAAA,CAEjCO,CAAiBd,CAAAA,CAAAA,EAAca,CAAa,EAAA,cAAA,CAE5C,CAAE,IAAA,CAAAJ,EAAM,GAAGC,CAAK,CAAIC,CAAAA,mBAAAA,CAAS,CACjC,GAAGH,CAAAA,CACH,QAAUT,CAAAA,CAAAA,CAAK,WAAWe,CAAc,CAAA,CACxC,OAAS,CAAA,SAAY,CACnB,GAAI,CAACjC,CAAAA,CACH,MAAM,IAAI,KAAA,CAAM,2BAA2B,CAAA,CAE7C,GAAI,CAACG,CAAAA,CACH,MAAM,IAAI,MAAM,qBAAqB,CAAA,CAEvC,GAAI,CAAC8B,CACH,CAAA,MAAM,IAAI,KAAA,CAAM,wBAAwB,CAG1C,CAAA,OAAOjC,CAAI,CAAA,UAAA,CAAWiC,CAAc,CACtC,CACA,CAAA,OAAA,CAAS,GACPjC,CAAOG,EAAAA,CAAAA,EAAgB8B,CAAmBN,GAAAA,CAAAA,EAAO,OAAW,EAAA,CAAA,CAAA,CAAA,CAEhE,CAAC,CAAA,CACD,OAAO,CACL,OAAA,CAASC,CACT,CAAA,GAAGC,CACL,CACF,CAwBO,SAASK,CAAAA,CAAY,CAC1B,KAAAP,CAAAA,CACF,CAEI,CAAA,EAAwC,CAAA,CAC1C,GAAM,CAAE,aAAAxB,CAAa,CAAA,CAAIsB,CAAQ,EAAA,CAC3BzB,EAAMsB,CAAO,EAAA,CAEb,CAAE,IAAA,CAAAM,EAAM,GAAGC,CAAK,CAAIC,CAAAA,mBAAAA,CAAS,CACjC,GAAGH,CACH,CAAA,QAAA,CAAUT,EAAK,WACf,CAAA,OAAA,CAAS,SAAY,CACnB,GAAI,CAAClB,CAAAA,CACH,MAAM,IAAI,MAAM,2BAA2B,CAAA,CAE7C,GAAI,CAACG,CACH,CAAA,MAAM,IAAI,KAAA,CAAM,qBAAqB,CAEvC,CAAA,OAAOH,CAAI,CAAA,WAAA,EACb,CAAA,CACA,OAAS,CAAA,CAAA,EAAQA,GAAOG,CAAiBwB,GAAAA,CAAAA,EAAO,OAAW,EAAA,CAAA,CAAA,CAAA,CAC7D,CAAC,CAAA,CACD,OAAO,CACL,SAAUC,CACV,CAAA,GAAGC,CACL,CACF,CAwBO,SAASM,CAAAA,CAAU,CACxB,KAAA,CAAAR,CACF,CAAuC,CAAA,EAAoC,CAAA,CACzE,IAAM3B,CAAAA,CAAMsB,CAAO,EAAA,CACb,CAAE,YAAAnB,CAAAA,CAAa,CAAIsB,CAAAA,CAAAA,EACnB,CAAA,CAAE,IAAAG,CAAAA,CAAAA,CAAM,GAAGC,CAAK,CAAA,CAAIC,mBAAS,CAAA,CACjC,GAAGH,CAAAA,CACH,QAAUT,CAAAA,CAAAA,CAAK,UACf,OAAS,CAAA,SAAY,CACnB,GAAI,CAAClB,CACH,CAAA,MAAM,IAAI,KAAA,CAAM,2BAA2B,CAE7C,CAAA,GAAI,CAACG,CAAAA,CACH,MAAM,IAAI,KAAM,CAAA,qBAAqB,EAEvC,OAAOH,CAAAA,CAAI,SAAU,EACvB,CACA,CAAA,OAAA,CAAS,CAAQA,EAAAA,CAAAA,EAAOG,IAAiBwB,CAAO,EAAA,OAAA,EAAW,CAC7D,CAAA,CAAA,CAAA,CAAC,CACD,CAAA,OAAO,CACL,MAAA,CAAQC,EACR,GAAGC,CACL,CACF,CAyBO,SAASO,CAAY,CAAA,CAC1B,SAAAjB,CAAAA,CAAAA,CACA,MAAAQ,CACF,CAAA,CAGI,EAAC,CAAwC,CAC3C,IAAM3B,CAAMsB,CAAAA,CAAAA,GACN,CAAE,YAAA,CAAAnB,CAAa,CAAA,CAAIsB,GAEnB,CAAA,CAAE,IAAAG,CAAAA,CAAAA,CAAM,GAAGC,CAAK,CAAA,CAAIC,mBAAS,CAAA,CACjC,GAAGH,CAAAA,CACH,QAAUT,CAAAA,CAAAA,CAAK,YAAYC,CAAS,CAAA,CACpC,OAAS,CAAA,SAAY,CACnB,GAAI,CAACnB,CACH,CAAA,MAAM,IAAI,KAAM,CAAA,2BAA2B,CAE7C,CAAA,GAAI,CAACG,CAAAA,CACH,MAAM,IAAI,MAAM,qBAAqB,CAAA,CAEvC,OAAOH,CAAAA,CAAI,WAAYmB,CAAAA,CAAS,CAClC,CAAA,CACA,QAAS,CAAQnB,EAAAA,CAAAA,EAAOG,CAAiBwB,GAAAA,CAAAA,EAAO,OAAW,EAAA,CAAA,CAAA,CAAA,CAC7D,CAAC,CAAA,CACD,OAAO,CACL,QAAA,CAAUC,CACV,CAAA,GAAGC,CACL,CACF,CAwBO,SAASQ,CAAAA,CAAS,CACvB,OAAAjB,CAAAA,CAAAA,CACA,KAAAO,CAAAA,CAAAA,CAAQ,EACV,CAGgC,CAAA,CAC9B,IAAM3B,CAAMsB,CAAAA,CAAAA,EACN,CAAA,CAAE,YAAAnB,CAAAA,CAAa,CAAIsB,CAAAA,CAAAA,GACnB,CAAE,IAAA,CAAAG,CAAM,CAAA,GAAGC,CAAK,CAAA,CAAIC,mBAAS,CAAA,CACjC,GAAGH,CACH,CAAA,QAAA,CAAUT,CAAK,CAAA,QAAA,CAASE,CAAO,CAC/B,CAAA,OAAA,CAAS,SAAY,CACnB,GAAI,CAACpB,CAAAA,CACH,MAAM,IAAI,KAAM,CAAA,2BAA2B,CAE7C,CAAA,GAAI,CAACG,CACH,CAAA,MAAM,IAAI,KAAA,CAAM,qBAAqB,CAAA,CAEvC,GAAI,CAACiB,EACH,MAAM,IAAI,KAAM,CAAA,sBAAsB,CAGxC,CAAA,OAAOpB,CAAI,CAAA,QAAA,CAASoB,CAAO,CAC7B,CAAA,CACA,OAAS,CAAA,CAAA,EAAQpB,GAAOG,CAAgBiB,EAAAA,CAAAA,GAAYO,CAAM,CAAA,OAAA,EAAW,IACvE,CAAC,CAAA,CACD,OAAO,CACL,KAAOC,CAAAA,CAAAA,CACP,GAAGC,CACL,CACF,CA6BO,SAASS,CAAU,CAAA,CACxB,MAAAX,CAAQ,CAAA,EACR,CAAA,GAAGY,CACL,CAOI,CAAA,EAAoC,CAAA,CACtC,IAAMvC,CAAAA,CAAMsB,CAAO,EAAA,CACb,CAAE,YAAAnB,CAAAA,CAAa,CAAIsB,CAAAA,CAAAA,GACnB,CAAE,IAAA,CAAAG,CAAM,CAAA,GAAGC,CAAK,CAAIC,CAAAA,mBAAAA,CAAS,CACjC,GAAGH,CACH,CAAA,QAAA,CAAUT,CAAK,CAAA,SAAA,CAAUqB,CAAO,CAChC,CAAA,OAAA,CAAS,SAAY,CACnB,GAAI,CAACvC,CACH,CAAA,MAAM,IAAI,KAAM,CAAA,2BAA2B,CAE7C,CAAA,GAAI,CAACG,CAAAA,CACH,MAAM,IAAI,MAAM,qBAAqB,CAAA,CAGvC,OAAOH,CAAAA,CAAI,UAAUuC,CAAO,CAC9B,CACA,CAAA,OAAA,CAAS,GAAQvC,CAAOG,EAAAA,CAAAA,GAAiBwB,CAAM,CAAA,OAAA,EAAW,CAC5D,CAAA,CAAA,CAAA,CAAC,CACD,CAAA,OAAO,CACL,MAAQC,CAAAA,CAAAA,CACR,GAAGC,CACL,CACF,CA6BO,SAASW,CAAAA,CAAc,CAC5B,kBAAAC,CAAAA,CAAAA,CACA,QAAAC,CAAAA,CACF,CAGI,CAAA,EAA0D,CAAA,CAC5D,IAAM1C,CAAMsB,CAAAA,CAAAA,EACN,CAAA,CAAE,aAAAnB,CAAa,CAAA,CAAIsB,CAAQ,EAAA,CAC3B3B,EAAcC,yBAAe,EAAA,CAE7B,CAAE,WAAA,CAAA4C,CAAa,CAAA,GAAGd,CAAK,CAAA,CAAIe,uBAAY,CAC3C,GAAGF,CACH,CAAA,WAAA,CAAaxB,CAAK,CAAA,UAAA,CAClB,UAAY,CAAA,MAAO2B,GAAmB,CACpC,GAAI,CAAC7C,CAAAA,CACH,MAAM,IAAI,KAAM,CAAA,2BAA2B,EAE7C,GAAI,CAACG,CACH,CAAA,MAAM,IAAI,KAAM,CAAA,qBAAqB,CAEvC,CAAA,IAAI2C,EACJ,GAAI,QAAA,CAASD,CAAK,CAAA,MAAM,CAAI,CAAA,IAAA,CAAO,CACjC,GAAI,CAACJ,CACH,CAAA,MAAM,IAAI,KAAA,CACR,wDACF,CAIFK,CAAAA,CAAAA,CAAAA,CADE,MAAM9C,CAAAA,CAAI,yBAAyByC,CAAkB,CAAA,EACzB,GAChC,CAEA,IAAMM,CAAAA,CAAU,CACd,GAAGF,EACH,UAAYC,CAAAA,CACd,CAEA,CAAA,OAAO9C,EAAI,UAAW+C,CAAAA,CAAO,CAC/B,CAAA,CACA,UAAUnB,CAAMoB,CAAAA,CAAAA,CAAWzB,CAAS,CAAA,CAElCzB,CAAY,CAAA,iBAAA,CAAkB,CAC5B,QAAA,CAAUoB,EAAK,SAAU,EAC3B,CAAC,CAAA,CAEDwB,CAAU,EAAA,SAAA,GAAYd,CAAMoB,CAAAA,CAAAA,CAAWzB,CAAO,EAChD,CAAA,CACA,OAAQlB,CAAAA,CAAAA,CAAO4C,CAAM1B,CAAAA,CAAAA,CAAS,CAE5B,MAAAmB,GAAU,OAAUrC,GAAAA,CAAAA,CAAO4C,CAAM1B,CAAAA,CAAO,EAClClB,CACR,CACF,CAAC,CAAA,CACD,OAAO,CACL,UAAA,CAAYsC,CACZ,CAAA,GAAGd,CACL,CACF,CA0BO,SAASqB,GAAe,CAC7B,SAAA,CAAA/B,CACA,CAAA,QAAA,CAAAuB,CACF,CAGqE,CAAA,CACnE,IAAM1C,CAAAA,CAAMsB,GACN,CAAA,CAAE,YAAAnB,CAAAA,CAAa,CAAIsB,CAAAA,CAAAA,EACnB3B,CAAAA,CAAAA,CAAcC,2BAEd,CAAA,CAAE,WAAA4C,CAAAA,CAAAA,CAAa,GAAGd,CAAK,CAAA,CAAIe,sBAAY,CAAA,CAC3C,GAAGF,CACH,CAAA,WAAA,CAAaxB,CAAK,CAAA,WAAA,CAClB,UAAY,CAAA,MAAO2B,CAAsB,EAAA,CACvC,GAAI,CAAC7C,CAAAA,CACH,MAAM,IAAI,KAAM,CAAA,2BAA2B,CAE7C,CAAA,GAAI,CAACG,CACH,CAAA,MAAM,IAAI,KAAA,CAAM,qBAAqB,CAAA,CAEvC,OAAOH,CAAAA,CAAI,YAAYmB,CAAW0B,CAAAA,CAAI,CACxC,CAAA,CACA,UAAUjB,CAAMoB,CAAAA,CAAAA,CAAWzB,CAAS,CAAA,CAElCzB,EAAY,iBAAkB,CAAA,CAC5B,QAAUoB,CAAAA,CAAAA,CAAK,UAAWC,CAAAA,CAAS,CACrC,CAAC,EAEDuB,CAAU,EAAA,SAAA,GAAYd,CAAMoB,CAAAA,CAAAA,CAAWzB,CAAO,EAChD,CAAA,CACA,OAAQlB,CAAAA,CAAAA,CAAO4C,EAAM1B,CAAS,CAAA,CAE5B,MAAAmB,CAAAA,EAAU,OAAUrC,GAAAA,CAAAA,CAAO4C,CAAM1B,CAAAA,CAAO,EAClClB,CACR,CACF,CAAC,CAAA,CACD,OAAO,CACL,WAAA,CAAasC,CACb,CAAA,GAAGd,CACL,CACF","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 { MoneriumClient } from '@monerium/sdk';\n\nimport { MoneriumContext } from './context';\nimport { AuthorizeParams } from './types';\n\n/**\n * Place this provider at the root of your application.\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 * @returns\n */\nexport const MoneriumProvider = ({\n  children,\n  clientId,\n  redirectUrl,\n  redirectUri,\n  environment = 'sandbox',\n}: {\n  children: ReactNode;\n  clientId: string;\n  redirectUri: string;\n  /** @deprecated use redirectUri */\n  redirectUrl?: string;\n  environment?: 'sandbox' | 'production';\n}) => {\n  const queryClient = useQueryClient();\n\n  const [sdk, setSdk] = useState<MoneriumClient>();\n  const [isAuthorized, setIsAuthorized] = useState<boolean>(false);\n  const [error, setError] = useState<Error | unknown | null>(null);\n  const [loadingAuth, setLoadingAuth] = useState(true);\n\n  // Initialize the SDK\n  useEffect(() => {\n    const sdkInstance = new MoneriumClient({\n      environment: environment,\n      clientId,\n      redirectUri: redirectUri || redirectUrl,\n    });\n    setSdk(sdkInstance);\n  }, []);\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        }\n      }\n    };\n\n    connect();\n\n    return () => {\n      if (sdk) {\n        sdk.disconnect();\n      }\n    };\n  }, [sdk]);\n\n  const authorize = useCallback(\n    async (params?: AuthorizeParams) => {\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 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        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 } from 'react';\nimport { useMutation, useQuery, useQueryClient } from '@tanstack/react-query';\n\nimport MoneriumClient, {\n  AuthContext,\n  Balances,\n  LinkAddress,\n  LinkedAddress,\n  NewOrder,\n  Order,\n  OrderState,\n  Profile,\n  Token,\n} from '@monerium/sdk';\n\nimport { MoneriumContext } from './context';\nimport {\n  MutationOptions,\n  MutationResult,\n  QueryOptions,\n  QueryResult,\n  UseAuthReturn,\n} from './types';\n\n/**\n * @internal\n * Query keys\n * */\nexport const keys = {\n  getAll: ['monerium'],\n  getAuthContext: ['monerium', 'auth-context'],\n  getProfile: (profileId: string) => [\n    'monerium',\n    'profile',\n    ...(profileId ? [profileId] : []),\n  ],\n  getProfiles: ['monerium', 'profiles'],\n  getBalances: (profileId?: string) => [\n    'monerium',\n    'balances',\n    ...(profileId ? [profileId] : []),\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  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 * @example\n * ```ts\n * const { authorize, isAuthorized, isLoading, error } = useAuth();\n *\n * authorize(); // Redirects to the Monerium auth flow.\n *\n * // To opt-in to automated wallet linking, pass the address, signature and chain.\n * authorize({ address, signature, chain }).\n * ```\n *\n * @returns {UseAuthReturn}\n * - `authorize`  - Redirects to the Monerium auth flow.\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  return {\n    isAuthorized: context.isAuthorized,\n    authorize: context.authorize,\n    isLoading: context.isLoading,\n    error: context.error,\n    disconnect: context.disconnect,\n    revokeAccess: context.revokeAccess,\n  };\n}\n\n/**\n * # Get the authentication context.\n * @group Hooks\n *\n * @param {Object} [params] No required parameters.\n * @param {QueryOptions<AuthContext>} [params.query] {@inheritDoc QueryOptions}\n *\n * @example\n * ```ts\n * const {\n *    authContext, // useQuery's `data` property\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useAuthContext();\n * ```\n *\n * @see\n * [API Documentation](https://monerium.dev/api-docs#operation/auth-context)\n *\n * [AuthContext interface](https://github.com/monerium/js-monorepo/blob/main/packages/sdk/docs/generated/interfaces/AuthContext.md)\n */\nexport function useAuthContext({\n  query,\n}: {\n  query?: QueryOptions<AuthContext>;\n} = {}): QueryResult<'authContext', AuthContext> {\n  const { isAuthorized } = useAuth();\n  const sdk = useSdk();\n\n  const { data, ...rest } = 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      return sdk.getAuthContext();\n    },\n    enabled: Boolean(sdk && isAuthorized && (query?.enabled ?? true)),\n  });\n  return {\n    authContext: data,\n    ...rest,\n  };\n}\n\n/**\n * # Get single profile\n * If no `profileId` is provided, the default profile is used.\n * @group Hooks\n * @param {Object} params\n * @param {string} [params.profileId] The id of the profile.\n * @param {QueryOptions<Profile>} [params.query] {@inheritDoc QueryOptions}\n *\n * @example\n * ```ts\n * const {\n *    profile, // useQuery's `data` property\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useProfile();\n * ```\n\n * @see\n * [API Documentation](https://monerium.dev/api-docs#operation/profile)\n *\n * [Profile interface](https://github.com/monerium/js-monorepo/blob/main/packages/sdk/docs/generated/interfaces/Profile.md)\n */\nexport function useProfile({\n  profileId,\n  query,\n}: {\n  profileId?: string;\n  query?: QueryOptions<Profile>;\n} = {}): QueryResult<'profile', Profile> {\n  const { isAuthorized } = useAuth();\n  const sdk = useSdk();\n  const { authContext } = useAuthContext();\n\n  const profileIdToUse = profileId || (authContext?.defaultProfile as string);\n\n  const { data, ...rest } = useQuery({\n    ...query,\n    queryKey: keys.getProfile(profileIdToUse),\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 (!profileIdToUse) {\n        throw new Error('Profile Id is required');\n      }\n\n      return sdk.getProfile(profileIdToUse);\n    },\n    enabled: Boolean(\n      sdk && isAuthorized && profileIdToUse && (query?.enabled ?? true)\n    ),\n  });\n  return {\n    profile: data,\n    ...rest,\n  };\n}\n/**\n * # Get profiles\n * @group Hooks\n * @param {Object} [params] No required parameters.\n * @param {QueryOptions<Profile[]>} [params.query] {@inheritDoc QueryOptions}\n *\n * @example\n * ```ts\n * const {\n *    profiles, // useQuery's `data` property\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useProfiles();\n * ```\n\n * @see\n * [API Documentation](https://monerium.dev/api-docs#operation/profiles)\n *\n * [Profile interface](https://github.com/monerium/js-monorepo/blob/main/packages/sdk/docs/generated/interfaces/Profile.md)\n */\nexport function useProfiles({\n  query,\n}: {\n  query?: QueryOptions<Profile[]>;\n} = {}): QueryResult<'profiles', Profile[]> {\n  const { isAuthorized } = useAuth();\n  const sdk = useSdk();\n\n  const { data, ...rest } = 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  return {\n    profiles: data,\n    ...rest,\n  };\n}\n/**\n * # Get tokens\n * @group Hooks\n * @param {Object} [params] No required parameters.\n * @param {QueryOptions<Token[]>} [params.query] {@inheritDoc QueryOptions}\n *\n * @example\n * ```ts\n * const {\n *    tokens, // useQuery's `data` property\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useTokens();\n * ```\n\n * @see\n * [API Documentation](https://monerium.dev/api-docs#operation/tokens)\n *\n * [Token interface](https://github.com/monerium/js-monorepo/blob/main/packages/sdk/docs/generated/interfaces/Token.md)\n */\nexport function useTokens({\n  query,\n}: { query?: QueryOptions<Token[]> } = {}): QueryResult<'tokens', Token[]> {\n  const sdk = useSdk();\n  const { isAuthorized } = useAuth();\n  const { data, ...rest } = 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  return {\n    tokens: data,\n    ...rest,\n  };\n}\n\n/**\n * # Get balances\n * @group Hooks\n * @param {Object} [params] No required parameters.\n * @param {QueryOptions<Balances[]>} [params.profileId] Fetch balances for a specific profile.\n * @param {QueryOptions<Balances[]>} [params.query] {@inheritDoc QueryOptions}\n\n * @example\n * ```ts\n * const {\n *    balances, // useQuery's `data` property\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useBalances();\n * ```\n * @see\n * [API Documentation](https://monerium.dev/api-docs#operation/profile-balances)\n *\n * [Balances interface](https://github.com/monerium/js-monorepo/blob/main/packages/sdk/docs/generated/interfaces/Balances.md)\n */\nexport function useBalances({\n  profileId,\n  query,\n}: {\n  profileId?: string;\n  query?: QueryOptions<Balances[]>;\n} = {}): QueryResult<'balances', Balances[]> {\n  const sdk = useSdk();\n  const { isAuthorized } = useAuth();\n\n  const { data, ...rest } = useQuery({\n    ...query,\n    queryKey: keys.getBalances(profileId),\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(profileId);\n    },\n    enabled: Boolean(sdk && isAuthorized && (query?.enabled ?? true)),\n  });\n  return {\n    balances: data,\n    ...rest,\n  };\n}\n\n/**\n * # Get single order\n * @group Hooks\n * @param {Object} params\n * @param {Object} params.orderId The id of the order.\n * @param {QueryOptions<Order>} [params.query] {@inheritDoc QueryOptions}\n * @example\n * ```ts\n * const {\n *    order, // useQuery's `data` property\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useOrder();\n * ```\n * @see\n * [API Documentation](https://monerium.dev/api-docs#operation/order)\n *\n * [Order interface](https://github.com/monerium/js-monorepo/blob/main/packages/sdk/docs/generated/interfaces/Order.md)\n */\nexport function useOrder({\n  orderId,\n  query = {},\n}: {\n  orderId: string;\n  query?: QueryOptions<Order>;\n}): QueryResult<'order', Order> {\n  const sdk = useSdk();\n  const { isAuthorized } = useAuth();\n  const { data, ...rest } = 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  return {\n    order: data,\n    ...rest,\n  };\n}\n\n/**\n * # Get orders\n * @group Hooks\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 * @param {QueryOptions<Order[]>} [params.query] {@inheritDoc QueryOptions}\n *\n * @example\n * ```ts\n * const {\n *    orders, // useQuery's `data` property\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useOrders();\n * ```\n * @see\n * [API Documentation](https://monerium.dev/api-docs#operation/orders)\n *\n * [Order interface](https://github.com/monerium/js-monorepo/blob/main/packages/sdk/docs/generated/interfaces/Order.md)\n */\nexport function useOrders({\n  query = {},\n  ...filters\n}: {\n  query?: QueryOptions<Order[]>;\n  address?: string;\n  txHash?: string;\n  profile?: string;\n  memo?: string;\n  state?: OrderState;\n} = {}): QueryResult<'orders', Order[]> {\n  const sdk = useSdk();\n  const { isAuthorized } = useAuth();\n  const { data, ...rest } = 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  return {\n    orders: data,\n    ...rest,\n  };\n}\n\n/**\n * # Place an order.\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 * @param param\n * @param {File} param.supportingDocument Supporting document file.\n * @param {Object} param.mutation {@inheritDoc MutationOptions}\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\n * [API Documentation](https://monerium.dev/api-docs#operation/post-orders)\n *\n * [NewOrder type](https://github.com/monerium/js-monorepo/blob/main/packages/sdk/docs/generated/type-aliases/NewOrder.md)\n */\n\nexport function usePlaceOrder({\n  supportingDocument,\n  mutation,\n}: {\n  supportingDocument?: File;\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      // 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 * When the address has been linked, the relevant profile query will be invalidated and re-fetched.\n *\n * @group Hooks\n * @param param\n * @param {File} param.profileId Which profile to link the address.\n * @param {Object} param.mutation {@inheritDoc MutationOptions}\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\n * [API Documentation](https://monerium.dev/api-docs#operation/profile-addresses)\n *\n * [LinkAddress interface](https://github.com/monerium/js-monorepo/blob/main/packages/sdk/docs/generated/interfaces/LinkAddress.md)\n */\nexport function useLinkAddress({\n  profileId,\n  mutation,\n}: {\n  profileId: string;\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(profileId, body);\n    },\n    onSuccess(data, variables, context) {\n      // Refetch all orders on success.\n      queryClient.invalidateQueries({\n        queryKey: keys.getProfile(profileId),\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"]}
|
package/dist/index.mjs
CHANGED
|
@@ -1,9 +1,10 @@
|
|
|
1
1
|
import { createContext, useState, useEffect, useCallback, useContext } from 'react';
|
|
2
|
+
import { useQueryClient, useQuery, useMutation } from '@tanstack/react-query';
|
|
2
3
|
import { MoneriumClient } from '@monerium/sdk';
|
|
3
4
|
import { jsx } from 'react/jsx-runtime';
|
|
4
5
|
|
|
5
|
-
var
|
|
6
|
+
var y=createContext(null);var T=({children:e,clientId:t,redirectUrl:r,redirectUri:o,environment:n="sandbox"})=>{let u=useQueryClient(),[s,i]=useState(),[a,d]=useState(!1),[A,g]=useState(null),[b,z]=useState(!0);useEffect(()=>{let h=new MoneriumClient({environment:n,clientId:t,redirectUri:o||r});i(h);},[]),useEffect(()=>((async()=>{if(s)try{d(await s.getAccess());}catch(p){console.error("Failed to get access:",p);}finally{z(!1);}})(),()=>{s&&s.disconnect();}),[s]);let v=useCallback(async h=>{try{s&&await s.authorize(h);}catch(p){console.error("Error during authorization:",p),g(p);}},[s]),C=async()=>{try{s&&await s.revokeAccess();}catch(h){console.error("Error during revoking access:",h),g(h);}finally{u.clear(),d(!1);}};return jsx(y.Provider,{value:{sdk:s,authorize:v,isAuthorized:a,isLoading:b,error:A,disconnect:async()=>s?.disconnect(),revokeAccess:async()=>C()},children:e})};var c={getAll:["monerium"],getAuthContext:["monerium","auth-context"],getProfile:e=>["monerium","profile",...e?[e]:[]],getProfiles:["monerium","profiles"],getBalances:e=>["monerium","balances",...e?[e]:[]],getTokens:["monerium","tokens"],getOrder:e=>["monerium","order",e],getOrders:e=>["monerium","orders",...e?[e]:[]],placeOrder:["monerium","place-order"],linkAddress:["monerium","link-address"]};function l(){let e=useContext(y);if(e===null)throw new Error("useSdk must be used within a MoneriumProvider");return e?.sdk}function f(){let e=useContext(y);if(e===null)throw new Error("useAuth must be used within a MoneriumProvider");return {isAuthorized:e.isAuthorized,authorize:e.authorize,isLoading:e.isLoading,error:e.error,disconnect:e.disconnect,revokeAccess:e.revokeAccess}}function M({query:e}={}){let{isAuthorized:t}=f(),r=l(),{data:o,...n}=useQuery({...e,queryKey:c.getAuthContext,queryFn:async()=>{if(!r)throw new Error("No SDK instance available");if(!t)throw new Error("User not authorized");return r.getAuthContext()},enabled:!!(r&&t&&(e?.enabled??!0))});return {authContext:o,...n}}function W({profileId:e,query:t}={}){let{isAuthorized:r}=f(),o=l(),{authContext:n}=M(),u=e||n?.defaultProfile,{data:s,...i}=useQuery({...t,queryKey:c.getProfile(u),queryFn:async()=>{if(!o)throw new Error("No SDK instance available");if(!r)throw new Error("User not authorized");if(!u)throw new Error("Profile Id is required");return o.getProfile(u)},enabled:!!(o&&r&&u&&(t?.enabled??!0))});return {profile:s,...i}}function X({query:e}={}){let{isAuthorized:t}=f(),r=l(),{data:o,...n}=useQuery({...e,queryKey:c.getProfiles,queryFn:async()=>{if(!r)throw new Error("No SDK instance available");if(!t)throw new Error("User not authorized");return r.getProfiles()},enabled:!!(r&&t&&(e?.enabled??!0))});return {profiles:o,...n}}function Y({query:e}={}){let t=l(),{isAuthorized:r}=f(),{data:o,...n}=useQuery({...e,queryKey:c.getTokens,queryFn:async()=>{if(!t)throw new Error("No SDK instance available");if(!r)throw new Error("User not authorized");return t.getTokens()},enabled:!!(t&&r&&(e?.enabled??!0))});return {tokens:o,...n}}function Z({profileId:e,query:t}={}){let r=l(),{isAuthorized:o}=f(),{data:n,...u}=useQuery({...t,queryKey:c.getBalances(e),queryFn:async()=>{if(!r)throw new Error("No SDK instance available");if(!o)throw new Error("User not authorized");return r.getBalances(e)},enabled:!!(r&&o&&(t?.enabled??!0))});return {balances:n,...u}}function _({orderId:e,query:t={}}){let r=l(),{isAuthorized:o}=f(),{data:n,...u}=useQuery({...t,queryKey:c.getOrder(e),queryFn:async()=>{if(!r)throw new Error("No SDK instance available");if(!o)throw new Error("User not authorized");if(!e)throw new Error("Order id is required");return r.getOrder(e)},enabled:!!(r&&o&&e&&(t.enabled??!0))});return {order:n,...u}}function $({query:e={},...t}={}){let r=l(),{isAuthorized:o}=f(),{data:n,...u}=useQuery({...e,queryKey:c.getOrders(t),queryFn:async()=>{if(!r)throw new Error("No SDK instance available");if(!o)throw new Error("User not authorized");return r.getOrders(t)},enabled:!!(r&&o&&(e.enabled??!0))});return {orders:n,...u}}function j({supportingDocument:e,mutation:t}={}){let r=l(),{isAuthorized:o}=f(),n=useQueryClient(),{mutateAsync:u,...s}=useMutation({...t,mutationKey:c.placeOrder,mutationFn:async i=>{if(!r)throw new Error("No SDK instance available");if(!o)throw new Error("User not authorized");let a;if(parseInt(i.amount)>15e3){if(!e)throw new Error("Supporting document is required for orders above 15000");a=(await r.uploadSupportingDocument(e)).id;}let d={...i,documentId:a};return r.placeOrder(d)},onSuccess(i,a,d){n.invalidateQueries({queryKey:c.getOrders()}),t?.onSuccess?.(i,a,d);},onError(i,a,d){throw t?.onError?.(i,a,d),i}});return {placeOrder:u,...s}}function ee({profileId:e,mutation:t}){let r=l(),{isAuthorized:o}=f(),n=useQueryClient(),{mutateAsync:u,...s}=useMutation({...t,mutationKey:c.linkAddress,mutationFn:async i=>{if(!r)throw new Error("No SDK instance available");if(!o)throw new Error("User not authorized");return r.linkAddress(e,i)},onSuccess(i,a,d){n.invalidateQueries({queryKey:c.getProfile(e)}),t?.onSuccess?.(i,a,d);},onError(i,a,d){throw t?.onError?.(i,a,d),i}});return {linkAddress:u,...s}}
|
|
6
7
|
|
|
7
|
-
export {
|
|
8
|
-
//# sourceMappingURL=
|
|
9
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/lib/provider.tsx","../src/lib/context.tsx","../src/lib/hook.tsx"],"names":["useCallback","useEffect","useState","MoneriumClient","createContext","MoneriumContext","jsx","MoneriumProvider","children","clientId","redirectUrl","environment","monerium","setMonerium","isAuthorized","setIsAuthorized","profile","setProfile","balances","setBalances","loading","setLoading","loadingPlaceOrder","setLoadingPlaceOrder","loadingLinkAddress","setLoadingLinkAddress","loadingBalances","setLoadingBalances","error","setError","orders","setOrders","tokens","setTokens","loadingAuth","setLoadingAuth","sdk","authCtx","getBalances","profileData","tokensData","ordersData","err","authorize","placeOrder","orderDetails","supportingDocument","documentId","newOrderDetails","newOrder","prevOrders","linkAddress","addressDetails","useContext","useMonerium","context"],"mappings":"AAAA,OAAwB,eAAAA,EAAa,aAAAC,EAAW,YAAAC,MAAgB,QAEhE,OAGE,kBAAAC,MAKK,gBCVP,OAAS,iBAAAC,MAAqB,QAiCvB,IAAMC,EAAkBD,EAA2C,IAAI,EDsJ1E,cAAAE,MAAA,oBAlKG,IAAMC,GAA8C,CAAC,CAC1D,SAAAC,EACA,SAAAC,EAAW,uCACX,YAAAC,EAAc,wBACd,YAAAC,EAAc,SAChB,IAAM,CACJ,GAAM,CAACC,EAAUC,CAAW,EAAIX,EAAyB,EACnD,CAACY,EAAcC,CAAe,EAAIb,EAAkB,EAAK,EACzD,CAACc,EAASC,CAAU,EAAIf,EAAyB,IAAI,EACrD,CAACgB,EAAUC,CAAW,EAAIjB,EAA4B,IAAI,EAC1D,CAACkB,EAASC,CAAU,EAAInB,EAAS,EAAK,EACtC,CAACoB,EAAmBC,CAAoB,EAAIrB,EAAS,EAAK,EAC1D,CAACsB,EAAoBC,CAAqB,EAAIvB,EAAS,EAAK,EAC5D,CAACwB,EAAiBC,CAAkB,EAAIzB,EAAS,EAAK,EACtD,CAAC0B,EAAOC,CAAQ,EAAI3B,EAAiC,IAAI,EACzD,CAAC4B,EAAQC,CAAS,EAAI7B,EAAkB,CAAC,CAAC,EAC1C,CAAC8B,EAAQC,CAAS,EAAI/B,EAAkB,CAAC,CAAC,EAC1C,CAACgC,EAAaC,CAAc,EAAIjC,EAAS,EAAI,EAGnDD,EAAU,IAAM,CACd,IAAMmC,EAAM,IAAIjC,EAAe,CAC7B,YAAaQ,EACb,SAAAF,EACA,YAAAC,CACF,CAAC,EACDG,EAAYuB,CAAG,CACjB,EAAG,CAAC,CAAC,EAELnC,EAAU,MACQ,SAAY,CAC1B,GAAIW,EACF,GAAI,CACFG,EAAgB,MAAMH,EAAS,UAAU,CAAC,CAC5C,OAASgB,EAAO,CACd,QAAQ,MAAM,wBAAyBA,CAAK,CAC9C,QAAE,CACAO,EAAe,EAAK,CACtB,CAEJ,GAEQ,EAED,IAAM,CACPvB,GACFA,EAAS,WAAW,CAExB,GACC,CAACA,CAAQ,CAAC,EAEbX,EAAU,IAAM,EACI,SAAY,CAC5B,GAAIW,GAAYE,EACd,GAAI,CACFO,EAAW,EAAI,EACf,GAAM,CAACgB,CAAO,EAAI,MAAM,QAAQ,IAAI,CAClCzB,EAAS,eAAe,EACxB0B,EAAY,CACd,CAAC,EAEK,CAACC,EAAaC,CAAU,EAAI,MAAM,QAAQ,IAAI,CAClD5B,EAAS,WAAWyB,EAAQ,cAAc,EAC1CzB,EAAS,UAAU,CACrB,CAAC,EAEK6B,EAAa,MAAM7B,EAAS,UAAU,EAE5CK,EAAWsB,CAAW,EACtBR,EAAUU,CAAU,EACpBR,EAAUO,CAAU,CACtB,OAASE,EAAK,CACZ,QAAQ,MAAM,uBAAwBA,CAAG,EACzCb,EAASa,CAAG,CACd,QAAE,CACArB,EAAW,EAAK,CAClB,CAEJ,GAEU,CACZ,EAAG,CAACT,EAAUE,CAAY,CAAC,EAE3B,IAAM6B,EAAY3C,EAAY,SAAY,CACxC,GAAI,CACEY,GACF,MAAMA,EAAS,UAAU,CAE7B,OAAS8B,EAAK,CACZ,QAAQ,MAAM,8BAA+BA,CAAG,EAChDb,EAASa,CAAG,CACd,CACF,EAAG,CAAC9B,CAAQ,CAAC,EAEP0B,EAActC,EAAY,SAAY,CAC1C,GAAIY,GAAYE,EACd,GAAI,CACFa,EAAmB,EAAI,EACvB,IAAMT,EAAW,MAAMN,EAAS,YAAY,EAC5CO,EAAYD,CAAQ,CACtB,OAASwB,EAAK,CACZ,QAAQ,MAAM,0BAA2BA,CAAG,EAC5Cb,EAASa,CAAG,CACd,QAAE,CACAf,EAAmB,EAAK,CAC1B,CAEJ,EAAG,CAACf,EAAUE,CAAY,CAAC,EAErB8B,EAAa5C,EACjB,MAAO6C,EAAwBC,IAA8B,CAC3D,GAAIlC,GAAYE,EACd,GAAI,CACFS,EAAqB,EAAI,EAEzB,IAAIwB,EACA,SAASF,EAAa,MAAM,EAAI,MAASC,IAG3CC,GADE,MAAMnC,EAAS,yBAAyBkC,CAAkB,GAC9B,IAGhC,IAAME,EAAkB,CACtB,GAAGH,EACH,WAAYE,CACd,EAEME,EAAW,MAAMrC,EAAS,WAAWoC,CAAe,EAC1DjB,EAAWmB,GAAe,CAAC,GAAGA,EAAYD,CAAQ,CAAC,CACrD,OAASP,EAAK,CACZ,QAAQ,MAAM,uBAAwBA,CAAG,EACzCb,EAASa,CAAG,CACd,QAAE,CACAnB,EAAqB,EAAK,CAC5B,CAEJ,EACA,CAACX,EAAUE,CAAY,CACzB,EAEMqC,EAAcnD,EAClB,MAAOoD,GAAgC,CACrC,GAAIxC,GAAYE,GAAgBE,EAC9B,GAAI,CACF,OAAAS,EAAsB,EAAI,EACnB,MAAMb,EAAS,YAAYI,EAAQ,GAAIoC,CAAc,CAG9D,OAASV,EAAK,CACZ,QAAQ,MAAM,yBAA0BA,CAAG,EAC3Cb,EAASa,CAAG,CACd,QAAE,CACAjB,EAAsB,EAAK,CAC7B,CAEJ,EACA,CAACb,EAAUE,EAAcE,CAAO,CAClC,EAIA,OACEV,EAACD,EAAgB,SAAhB,CACC,MAAO,CACL,UAAAsC,EACA,aAAA7B,EACA,QAAAE,EACA,SAAAE,EACA,QAAAE,EACA,kBAAAE,EACA,mBAAAE,EACA,gBAAAE,EACA,YAAAY,EACA,YAAAa,EACA,WAAAP,EACA,OAAAd,EACA,OAAAE,EACA,MAAAJ,EACA,YAAAM,CACF,EAEC,SAAA1B,EACH,CAEJ,EE7MA,OAAS,cAAA6C,MAAkB,QAIpB,SAASC,IAAoC,CAClD,IAAMC,EAAUF,EAAWhD,CAAe,EAE1C,GAAIkD,IAAY,KACd,MAAM,IAAI,MAAM,oDAAoD,EAEtE,OAAOA,CACT","sourcesContent":["import { FC, ReactNode, useCallback, useEffect, useState } from 'react';\n\nimport {\n  Balances,\n  LinkAddress,\n  MoneriumClient,\n  NewOrder,\n  Order,\n  Profile,\n  Token,\n} from '@monerium/sdk';\n\nimport { MoneriumContext } from './context';\n\ninterface MoneriumProviderProps {\n  children: ReactNode;\n  clientId?: string;\n  redirectUrl?: string;\n  environment?: 'sandbox' | 'production';\n}\n\nexport const MoneriumProvider: FC<MoneriumProviderProps> = ({\n  children,\n  clientId = 'f99e629b-6dca-11ee-8aa6-5273f65ed05b',\n  redirectUrl = 'http://localhost:5173',\n  environment = 'sandbox',\n}) => {\n  const [monerium, setMonerium] = useState<MoneriumClient>();\n  const [isAuthorized, setIsAuthorized] = useState<boolean>(false);\n  const [profile, setProfile] = useState<Profile | null>(null);\n  const [balances, setBalances] = useState<Balances[] | null>(null);\n  const [loading, setLoading] = useState(false);\n  const [loadingPlaceOrder, setLoadingPlaceOrder] = useState(false);\n  const [loadingLinkAddress, setLoadingLinkAddress] = useState(false);\n  const [loadingBalances, setLoadingBalances] = useState(false);\n  const [error, setError] = useState<Error | unknown | null>(null);\n  const [orders, setOrders] = useState<Order[]>([]);\n  const [tokens, setTokens] = useState<Token[]>([]);\n  const [loadingAuth, setLoadingAuth] = useState(true);\n\n  // Initialize the SDK\n  useEffect(() => {\n    const sdk = new MoneriumClient({\n      environment: environment,\n      clientId,\n      redirectUrl,\n    });\n    setMonerium(sdk);\n  }, []);\n\n  useEffect(() => {\n    const connect = async () => {\n      if (monerium) {\n        try {\n          setIsAuthorized(await monerium.getAccess());\n        } catch (error) {\n          console.error('Failed to get access:', error);\n        } finally {\n          setLoadingAuth(false);\n        }\n      }\n    };\n\n    connect();\n\n    return () => {\n      if (monerium) {\n        monerium.disconnect();\n      }\n    };\n  }, [monerium]);\n\n  useEffect(() => {\n    const fetchData = async () => {\n      if (monerium && isAuthorized) {\n        try {\n          setLoading(true);\n          const [authCtx] = await Promise.all([\n            monerium.getAuthContext(),\n            getBalances(),\n          ]);\n\n          const [profileData, tokensData] = await Promise.all([\n            monerium.getProfile(authCtx.defaultProfile),\n            monerium.getTokens(),\n          ]);\n\n          const ordersData = await monerium.getOrders();\n\n          setProfile(profileData);\n          setOrders(ordersData);\n          setTokens(tokensData);\n        } catch (err) {\n          console.error('Error fetching data:', err);\n          setError(err);\n        } finally {\n          setLoading(false);\n        }\n      }\n    };\n\n    fetchData();\n  }, [monerium, isAuthorized]);\n\n  const authorize = useCallback(async () => {\n    try {\n      if (monerium) {\n        await monerium.authorize();\n      }\n    } catch (err) {\n      console.error('Error during authorization:', err);\n      setError(err);\n    }\n  }, [monerium]);\n\n  const getBalances = useCallback(async () => {\n    if (monerium && isAuthorized) {\n      try {\n        setLoadingBalances(true);\n        const balances = await monerium.getBalances();\n        setBalances(balances);\n      } catch (err) {\n        console.error('Error getting balances:', err);\n        setError(err);\n      } finally {\n        setLoadingBalances(false);\n      }\n    }\n  }, [monerium, isAuthorized]);\n\n  const placeOrder = useCallback(\n    async (orderDetails: NewOrder, supportingDocument?: File) => {\n      if (monerium && isAuthorized) {\n        try {\n          setLoadingPlaceOrder(true);\n\n          let documentId;\n          if (parseInt(orderDetails.amount) > 15000 && supportingDocument) {\n            const uploadedDocument =\n              await monerium.uploadSupportingDocument(supportingDocument);\n            documentId = uploadedDocument.id;\n          }\n\n          const newOrderDetails = {\n            ...orderDetails,\n            documentId: documentId,\n          };\n\n          const newOrder = await monerium.placeOrder(newOrderDetails);\n          setOrders((prevOrders) => [...prevOrders, newOrder]);\n        } catch (err) {\n          console.error('Error placing order:', err);\n          setError(err);\n        } finally {\n          setLoadingPlaceOrder(false);\n        }\n      }\n    },\n    [monerium, isAuthorized]\n  );\n\n  const linkAddress = useCallback(\n    async (addressDetails: LinkAddress) => {\n      if (monerium && isAuthorized && profile) {\n        try {\n          setLoadingLinkAddress(true);\n          return await monerium.linkAddress(profile.id, addressDetails);\n\n          // Update your state or do something with linkedAddress\n        } catch (err) {\n          console.error('Error linking address:', err);\n          setError(err);\n        } finally {\n          setLoadingLinkAddress(false);\n        }\n      }\n    },\n    [monerium, isAuthorized, profile]\n  );\n\n  //\n\n  return (\n    <MoneriumContext.Provider\n      value={{\n        authorize,\n        isAuthorized,\n        profile,\n        balances,\n        loading,\n        loadingPlaceOrder,\n        loadingLinkAddress,\n        loadingBalances,\n        getBalances,\n        linkAddress,\n        placeOrder,\n        orders,\n        tokens,\n        error,\n        loadingAuth,\n      }}\n    >\n      {children}\n    </MoneriumContext.Provider>\n  );\n};\n","import { createContext } from 'react';\n\nimport {\n  Balances,\n  LinkAddress,\n  NewOrder,\n  Order,\n  Profile,\n  Token,\n} from '@monerium/sdk';\n\nexport interface MoneriumContextValue {\n  authorize: () => Promise<void>;\n  isAuthorized: boolean;\n  profile: Profile | null;\n  balances: Balances[] | null;\n  loading: boolean;\n  loadingPlaceOrder: boolean;\n  loadingLinkAddress: boolean;\n  loadingBalances: boolean;\n  getBalances: () => Promise<void>;\n  linkAddress: (addressDetails: LinkAddress) => Promise<unknown>;\n  placeOrder: (\n    orderDetails: NewOrder,\n    supportingDocument?: File\n  ) => Promise<void>;\n  orders: Order[];\n  tokens: Token[];\n  error: unknown;\n  /** Is still checking if there is an active session */\n  loadingAuth: boolean;\n}\n\nexport const MoneriumContext = createContext<MoneriumContextValue | null>(null);\n","import { useContext } from 'react';\n\nimport { MoneriumContext, MoneriumContextValue } from './context';\n\nexport function useMonerium(): MoneriumContextValue {\n  const context = useContext(MoneriumContext);\n\n  if (context === null) {\n    throw new Error('useMonerium must be used within a MoneriumProvider');\n  }\n  return context;\n}\n"]}
|
|
8
|
+
export { y as MoneriumContext, T as MoneriumProvider, c as keys, f as useAuth, M as useAuthContext, Z as useBalances, ee as useLinkAddress, _ as useOrder, $ as useOrders, j as usePlaceOrder, W as useProfile, X as useProfiles, Y as useTokens };
|
|
9
|
+
//# sourceMappingURL=index.mjs.map
|
|
10
|
+
//# 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","redirectUrl","redirectUri","environment","queryClient","useQueryClient","sdk","setSdk","useState","isAuthorized","setIsAuthorized","error","setError","loadingAuth","setLoadingAuth","useEffect","sdkInstance","MoneriumClient","authorize","useCallback","params","err","revokeAccess","jsx","keys","profileId","orderId","filter","useSdk","context","useContext","useAuth","useAuthContext","query","data","rest","useQuery","useProfile","authContext","profileIdToUse","useProfiles","useTokens","useBalances","useOrder","useOrders","filters","usePlaceOrder","supportingDocument","mutation","mutateAsync","useMutation","body","documentId","newBody","variables","vars","useLinkAddress"],"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 { MoneriumClient } from '@monerium/sdk';\n\nimport { MoneriumContext } from './context';\nimport { AuthorizeParams } from './types';\n\n/**\n * Place this provider at the root of your application.\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 * @returns\n */\nexport const MoneriumProvider = ({\n  children,\n  clientId,\n  redirectUrl,\n  redirectUri,\n  environment = 'sandbox',\n}: {\n  children: ReactNode;\n  clientId: string;\n  redirectUri: string;\n  /** @deprecated use redirectUri */\n  redirectUrl?: string;\n  environment?: 'sandbox' | 'production';\n}) => {\n  const queryClient = useQueryClient();\n\n  const [sdk, setSdk] = useState<MoneriumClient>();\n  const [isAuthorized, setIsAuthorized] = useState<boolean>(false);\n  const [error, setError] = useState<Error | unknown | null>(null);\n  const [loadingAuth, setLoadingAuth] = useState(true);\n\n  // Initialize the SDK\n  useEffect(() => {\n    const sdkInstance = new MoneriumClient({\n      environment: environment,\n      clientId,\n      redirectUri: redirectUri || redirectUrl,\n    });\n    setSdk(sdkInstance);\n  }, []);\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        }\n      }\n    };\n\n    connect();\n\n    return () => {\n      if (sdk) {\n        sdk.disconnect();\n      }\n    };\n  }, [sdk]);\n\n  const authorize = useCallback(\n    async (params?: AuthorizeParams) => {\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 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        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 } from 'react';\nimport { useMutation, useQuery, useQueryClient } from '@tanstack/react-query';\n\nimport MoneriumClient, {\n  AuthContext,\n  Balances,\n  LinkAddress,\n  LinkedAddress,\n  NewOrder,\n  Order,\n  OrderState,\n  Profile,\n  Token,\n} from '@monerium/sdk';\n\nimport { MoneriumContext } from './context';\nimport {\n  MutationOptions,\n  MutationResult,\n  QueryOptions,\n  QueryResult,\n  UseAuthReturn,\n} from './types';\n\n/**\n * @internal\n * Query keys\n * */\nexport const keys = {\n  getAll: ['monerium'],\n  getAuthContext: ['monerium', 'auth-context'],\n  getProfile: (profileId: string) => [\n    'monerium',\n    'profile',\n    ...(profileId ? [profileId] : []),\n  ],\n  getProfiles: ['monerium', 'profiles'],\n  getBalances: (profileId?: string) => [\n    'monerium',\n    'balances',\n    ...(profileId ? [profileId] : []),\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  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 * @example\n * ```ts\n * const { authorize, isAuthorized, isLoading, error } = useAuth();\n *\n * authorize(); // Redirects to the Monerium auth flow.\n *\n * // To opt-in to automated wallet linking, pass the address, signature and chain.\n * authorize({ address, signature, chain }).\n * ```\n *\n * @returns {UseAuthReturn}\n * - `authorize`  - Redirects to the Monerium auth flow.\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  return {\n    isAuthorized: context.isAuthorized,\n    authorize: context.authorize,\n    isLoading: context.isLoading,\n    error: context.error,\n    disconnect: context.disconnect,\n    revokeAccess: context.revokeAccess,\n  };\n}\n\n/**\n * # Get the authentication context.\n * @group Hooks\n *\n * @param {Object} [params] No required parameters.\n * @param {QueryOptions<AuthContext>} [params.query] {@inheritDoc QueryOptions}\n *\n * @example\n * ```ts\n * const {\n *    authContext, // useQuery's `data` property\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useAuthContext();\n * ```\n *\n * @see\n * [API Documentation](https://monerium.dev/api-docs#operation/auth-context)\n *\n * [AuthContext interface](https://github.com/monerium/js-monorepo/blob/main/packages/sdk/docs/generated/interfaces/AuthContext.md)\n */\nexport function useAuthContext({\n  query,\n}: {\n  query?: QueryOptions<AuthContext>;\n} = {}): QueryResult<'authContext', AuthContext> {\n  const { isAuthorized } = useAuth();\n  const sdk = useSdk();\n\n  const { data, ...rest } = 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      return sdk.getAuthContext();\n    },\n    enabled: Boolean(sdk && isAuthorized && (query?.enabled ?? true)),\n  });\n  return {\n    authContext: data,\n    ...rest,\n  };\n}\n\n/**\n * # Get single profile\n * If no `profileId` is provided, the default profile is used.\n * @group Hooks\n * @param {Object} params\n * @param {string} [params.profileId] The id of the profile.\n * @param {QueryOptions<Profile>} [params.query] {@inheritDoc QueryOptions}\n *\n * @example\n * ```ts\n * const {\n *    profile, // useQuery's `data` property\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useProfile();\n * ```\n\n * @see\n * [API Documentation](https://monerium.dev/api-docs#operation/profile)\n *\n * [Profile interface](https://github.com/monerium/js-monorepo/blob/main/packages/sdk/docs/generated/interfaces/Profile.md)\n */\nexport function useProfile({\n  profileId,\n  query,\n}: {\n  profileId?: string;\n  query?: QueryOptions<Profile>;\n} = {}): QueryResult<'profile', Profile> {\n  const { isAuthorized } = useAuth();\n  const sdk = useSdk();\n  const { authContext } = useAuthContext();\n\n  const profileIdToUse = profileId || (authContext?.defaultProfile as string);\n\n  const { data, ...rest } = useQuery({\n    ...query,\n    queryKey: keys.getProfile(profileIdToUse),\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 (!profileIdToUse) {\n        throw new Error('Profile Id is required');\n      }\n\n      return sdk.getProfile(profileIdToUse);\n    },\n    enabled: Boolean(\n      sdk && isAuthorized && profileIdToUse && (query?.enabled ?? true)\n    ),\n  });\n  return {\n    profile: data,\n    ...rest,\n  };\n}\n/**\n * # Get profiles\n * @group Hooks\n * @param {Object} [params] No required parameters.\n * @param {QueryOptions<Profile[]>} [params.query] {@inheritDoc QueryOptions}\n *\n * @example\n * ```ts\n * const {\n *    profiles, // useQuery's `data` property\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useProfiles();\n * ```\n\n * @see\n * [API Documentation](https://monerium.dev/api-docs#operation/profiles)\n *\n * [Profile interface](https://github.com/monerium/js-monorepo/blob/main/packages/sdk/docs/generated/interfaces/Profile.md)\n */\nexport function useProfiles({\n  query,\n}: {\n  query?: QueryOptions<Profile[]>;\n} = {}): QueryResult<'profiles', Profile[]> {\n  const { isAuthorized } = useAuth();\n  const sdk = useSdk();\n\n  const { data, ...rest } = 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  return {\n    profiles: data,\n    ...rest,\n  };\n}\n/**\n * # Get tokens\n * @group Hooks\n * @param {Object} [params] No required parameters.\n * @param {QueryOptions<Token[]>} [params.query] {@inheritDoc QueryOptions}\n *\n * @example\n * ```ts\n * const {\n *    tokens, // useQuery's `data` property\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useTokens();\n * ```\n\n * @see\n * [API Documentation](https://monerium.dev/api-docs#operation/tokens)\n *\n * [Token interface](https://github.com/monerium/js-monorepo/blob/main/packages/sdk/docs/generated/interfaces/Token.md)\n */\nexport function useTokens({\n  query,\n}: { query?: QueryOptions<Token[]> } = {}): QueryResult<'tokens', Token[]> {\n  const sdk = useSdk();\n  const { isAuthorized } = useAuth();\n  const { data, ...rest } = 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  return {\n    tokens: data,\n    ...rest,\n  };\n}\n\n/**\n * # Get balances\n * @group Hooks\n * @param {Object} [params] No required parameters.\n * @param {QueryOptions<Balances[]>} [params.profileId] Fetch balances for a specific profile.\n * @param {QueryOptions<Balances[]>} [params.query] {@inheritDoc QueryOptions}\n\n * @example\n * ```ts\n * const {\n *    balances, // useQuery's `data` property\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useBalances();\n * ```\n * @see\n * [API Documentation](https://monerium.dev/api-docs#operation/profile-balances)\n *\n * [Balances interface](https://github.com/monerium/js-monorepo/blob/main/packages/sdk/docs/generated/interfaces/Balances.md)\n */\nexport function useBalances({\n  profileId,\n  query,\n}: {\n  profileId?: string;\n  query?: QueryOptions<Balances[]>;\n} = {}): QueryResult<'balances', Balances[]> {\n  const sdk = useSdk();\n  const { isAuthorized } = useAuth();\n\n  const { data, ...rest } = useQuery({\n    ...query,\n    queryKey: keys.getBalances(profileId),\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(profileId);\n    },\n    enabled: Boolean(sdk && isAuthorized && (query?.enabled ?? true)),\n  });\n  return {\n    balances: data,\n    ...rest,\n  };\n}\n\n/**\n * # Get single order\n * @group Hooks\n * @param {Object} params\n * @param {Object} params.orderId The id of the order.\n * @param {QueryOptions<Order>} [params.query] {@inheritDoc QueryOptions}\n * @example\n * ```ts\n * const {\n *    order, // useQuery's `data` property\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useOrder();\n * ```\n * @see\n * [API Documentation](https://monerium.dev/api-docs#operation/order)\n *\n * [Order interface](https://github.com/monerium/js-monorepo/blob/main/packages/sdk/docs/generated/interfaces/Order.md)\n */\nexport function useOrder({\n  orderId,\n  query = {},\n}: {\n  orderId: string;\n  query?: QueryOptions<Order>;\n}): QueryResult<'order', Order> {\n  const sdk = useSdk();\n  const { isAuthorized } = useAuth();\n  const { data, ...rest } = 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  return {\n    order: data,\n    ...rest,\n  };\n}\n\n/**\n * # Get orders\n * @group Hooks\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 * @param {QueryOptions<Order[]>} [params.query] {@inheritDoc QueryOptions}\n *\n * @example\n * ```ts\n * const {\n *    orders, // useQuery's `data` property\n *    isLoading,\n *    isError,\n *    error,\n *    refetch,\n *    ...moreUseQueryResults\n * } = useOrders();\n * ```\n * @see\n * [API Documentation](https://monerium.dev/api-docs#operation/orders)\n *\n * [Order interface](https://github.com/monerium/js-monorepo/blob/main/packages/sdk/docs/generated/interfaces/Order.md)\n */\nexport function useOrders({\n  query = {},\n  ...filters\n}: {\n  query?: QueryOptions<Order[]>;\n  address?: string;\n  txHash?: string;\n  profile?: string;\n  memo?: string;\n  state?: OrderState;\n} = {}): QueryResult<'orders', Order[]> {\n  const sdk = useSdk();\n  const { isAuthorized } = useAuth();\n  const { data, ...rest } = 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  return {\n    orders: data,\n    ...rest,\n  };\n}\n\n/**\n * # Place an order.\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 * @param param\n * @param {File} param.supportingDocument Supporting document file.\n * @param {Object} param.mutation {@inheritDoc MutationOptions}\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\n * [API Documentation](https://monerium.dev/api-docs#operation/post-orders)\n *\n * [NewOrder type](https://github.com/monerium/js-monorepo/blob/main/packages/sdk/docs/generated/type-aliases/NewOrder.md)\n */\n\nexport function usePlaceOrder({\n  supportingDocument,\n  mutation,\n}: {\n  supportingDocument?: File;\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      // 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 * When the address has been linked, the relevant profile query will be invalidated and re-fetched.\n *\n * @group Hooks\n * @param param\n * @param {File} param.profileId Which profile to link the address.\n * @param {Object} param.mutation {@inheritDoc MutationOptions}\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\n * [API Documentation](https://monerium.dev/api-docs#operation/profile-addresses)\n *\n * [LinkAddress interface](https://github.com/monerium/js-monorepo/blob/main/packages/sdk/docs/generated/interfaces/LinkAddress.md)\n */\nexport function useLinkAddress({\n  profileId,\n  mutation,\n}: {\n  profileId: string;\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(profileId, body);\n    },\n    onSuccess(data, variables, context) {\n      // Refetch all orders on success.\n      queryClient.invalidateQueries({\n        queryKey: keys.getProfile(profileId),\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"]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@monerium/sdk-react-provider",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.3.0",
|
|
4
4
|
"private": false,
|
|
5
5
|
"description": "React provider for the Monerium SDK.",
|
|
6
6
|
"repository": {
|
|
@@ -27,24 +27,29 @@
|
|
|
27
27
|
"dist/index.d.ts"
|
|
28
28
|
],
|
|
29
29
|
"dependencies": {
|
|
30
|
-
"@monerium/sdk": "
|
|
30
|
+
"@monerium/sdk": "latest"
|
|
31
31
|
},
|
|
32
32
|
"peerDependencies": {
|
|
33
|
+
"@tanstack/react-query": ">=5.0.0",
|
|
33
34
|
"@types/react": "^18.2.61",
|
|
34
|
-
"react": "
|
|
35
|
-
"react-dom": "
|
|
35
|
+
"react": ">=18.2.0",
|
|
36
|
+
"react-dom": ">=18.2.0"
|
|
36
37
|
},
|
|
37
38
|
"devDependencies": {
|
|
38
39
|
"@testing-library/dom": "^10.1.0",
|
|
39
40
|
"@testing-library/jest-dom": "^6.4.6",
|
|
40
|
-
"@testing-library/react": "^16.0.0"
|
|
41
|
+
"@testing-library/react": "^16.0.0",
|
|
42
|
+
"undici": "^6.19.4"
|
|
41
43
|
},
|
|
42
44
|
"scripts": {
|
|
43
|
-
"dev": "tsup --watch",
|
|
44
45
|
"build": "tsup",
|
|
46
|
+
"dev": "tsup --watch --onSuccess 'pnpm type-map & pnpm run docs'",
|
|
47
|
+
"docs": "typedoc",
|
|
48
|
+
"docs:watch": "typedoc --watch",
|
|
45
49
|
"lint": "eslint . --fix",
|
|
46
50
|
"pub:pre": "pnpm publish --no-git-checks --dry-run",
|
|
47
51
|
"test": "jest",
|
|
48
|
-
"test:watch": "jest --watch"
|
|
52
|
+
"test:watch": "jest --watch",
|
|
53
|
+
"type-map": "tsc --emitDeclarationOnly --declaration"
|
|
49
54
|
}
|
|
50
55
|
}
|