@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 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
- # Usage
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 the application with the provider and pass the configuration as props.
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
- <MoneriumProvider
26
- clientId="f99e629b-6dca-11ee-8aa6-5273f65ed05b"
27
- redirectUrl="https://pntvgs.csb.app/"
28
- environment="sandbox"
29
- >
30
- <App />
31
- </MoneriumProvider>
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
- Use the hook to access the Monerium SDK.
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 { useMonerium } from '@monerium/sdk-react-provider';
92
+ import { useAuth, useProfile } from '@monerium/sdk-react-provider';
40
93
 
41
94
  export default function App() {
42
- const { authorize, isAuthorized, profile, balances, tokens, orders } =
43
- useMonerium();
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
- <h1>Hello {profile ? profile?.email : 'CodeSandbox'}</h1>
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 { FC, ReactNode } from 'react';
3
- import { Profile, Balances, LinkAddress, NewOrder, Order, Token } from '@monerium/sdk';
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
- interface MoneriumProviderProps {
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?: string;
20
+ clientId: string;
21
+ redirectUri: string;
22
+ /** @deprecated use redirectUri */
8
23
  redirectUrl?: string;
9
- environment?: 'sandbox' | 'production';
10
- }
11
- declare const MoneriumProvider: FC<MoneriumProviderProps>;
24
+ environment?: "sandbox" | "production";
25
+ }) => react_jsx_runtime.JSX.Element;
12
26
 
13
- interface MoneriumContextValue {
14
- authorize: () => Promise<void>;
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
- profile: Profile | null;
17
- balances: Balances[] | null;
18
- loading: boolean;
19
- loadingPlaceOrder: boolean;
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
- /** Is still checking if there is an active session */
29
- loadingAuth: boolean;
30
- }
31
- declare const MoneriumContext: react.Context<MoneriumContextValue | null>;
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 function useMonerium(): MoneriumContextValue;
250
+ declare const MoneriumContext: react.Context<(UseAuthReturn & SdkInstance) | null>;
34
251
 
35
- export { MoneriumContext, type MoneriumContextValue, MoneriumProvider, useMonerium };
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 c=react.createContext(null);var ae=({children:i,clientId:A="f99e629b-6dca-11ee-8aa6-5273f65ed05b",redirectUrl:O="http://localhost:5173",environment:b="sandbox"})=>{let[e,y]=react.useState(),[t,C]=react.useState(!1),[l,M]=react.useState(null),[v,L]=react.useState(null),[B,g]=react.useState(!1),[D,p]=react.useState(!1),[E,h]=react.useState(!1),[z,k]=react.useState(!1),[N,s]=react.useState(null),[T,P]=react.useState([]),[F,I]=react.useState([]),[V,R]=react.useState(!0);react.useEffect(()=>{let r=new sdk.MoneriumClient({environment:b,clientId:A,redirectUrl:O});y(r);},[]),react.useEffect(()=>((async()=>{if(e)try{C(await e.getAccess());}catch(o){console.error("Failed to get access:",o);}finally{R(!1);}})(),()=>{e&&e.disconnect();}),[e]),react.useEffect(()=>{(async()=>{if(e&&t)try{g(!0);let[o]=await Promise.all([e.getAuthContext(),w()]),[a,u]=await Promise.all([e.getProfile(o.defaultProfile),e.getTokens()]),f=await e.getOrders();M(a),P(f),I(u);}catch(o){console.error("Error fetching data:",o),s(o);}finally{g(!1);}})();},[e,t]);let S=react.useCallback(async()=>{try{e&&await e.authorize();}catch(r){console.error("Error during authorization:",r),s(r);}},[e]),w=react.useCallback(async()=>{if(e&&t)try{k(!0);let r=await e.getBalances();L(r);}catch(r){console.error("Error getting balances:",r),s(r);}finally{k(!1);}},[e,t]),U=react.useCallback(async(r,o)=>{if(e&&t)try{p(!0);let a;parseInt(r.amount)>15e3&&o&&(a=(await e.uploadSupportingDocument(o)).id);let u={...r,documentId:a},f=await e.placeOrder(u);P(x=>[...x,f]);}catch(a){console.error("Error placing order:",a),s(a);}finally{p(!1);}},[e,t]),q=react.useCallback(async r=>{if(e&&t&&l)try{return h(!0),await e.linkAddress(l.id,r)}catch(o){console.error("Error linking address:",o),s(o);}finally{h(!1);}},[e,t,l]);return jsxRuntime.jsx(c.Provider,{value:{authorize:S,isAuthorized:t,profile:l,balances:v,loading:B,loadingPlaceOrder:D,loadingLinkAddress:E,loadingBalances:z,getBalances:w,linkAddress:q,placeOrder:U,orders:T,tokens:F,error:N,loadingAuth:V},children:i})};function ue(){let i=react.useContext(c);if(i===null)throw new Error("useMonerium must be used within a MoneriumProvider");return i}
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 = c;
10
- exports.MoneriumProvider = ae;
11
- exports.useMonerium = ue;
12
- //# sourceMappingURL=out.js.map
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":"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","file":"index.js","sourcesContent":["import { createContext } from 'react';\n\nimport { SdkInstance, UseAuthReturn } from './types';\n\nexport const MoneriumContext = createContext<\n  (UseAuthReturn & SdkInstance) | null\n>(null);\n","import { ReactNode, useCallback, useEffect, useState } from 'react';\nimport { useQueryClient } from '@tanstack/react-query';\n\nimport { 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 c=createContext(null);var ae=({children:i,clientId:A="f99e629b-6dca-11ee-8aa6-5273f65ed05b",redirectUrl:O="http://localhost:5173",environment:b="sandbox"})=>{let[e,y]=useState(),[t,C]=useState(!1),[l,M]=useState(null),[v,L]=useState(null),[B,g]=useState(!1),[D,p]=useState(!1),[E,h]=useState(!1),[z,k]=useState(!1),[N,s]=useState(null),[T,P]=useState([]),[F,I]=useState([]),[V,R]=useState(!0);useEffect(()=>{let r=new MoneriumClient({environment:b,clientId:A,redirectUrl:O});y(r);},[]),useEffect(()=>((async()=>{if(e)try{C(await e.getAccess());}catch(o){console.error("Failed to get access:",o);}finally{R(!1);}})(),()=>{e&&e.disconnect();}),[e]),useEffect(()=>{(async()=>{if(e&&t)try{g(!0);let[o]=await Promise.all([e.getAuthContext(),w()]),[a,u]=await Promise.all([e.getProfile(o.defaultProfile),e.getTokens()]),f=await e.getOrders();M(a),P(f),I(u);}catch(o){console.error("Error fetching data:",o),s(o);}finally{g(!1);}})();},[e,t]);let S=useCallback(async()=>{try{e&&await e.authorize();}catch(r){console.error("Error during authorization:",r),s(r);}},[e]),w=useCallback(async()=>{if(e&&t)try{k(!0);let r=await e.getBalances();L(r);}catch(r){console.error("Error getting balances:",r),s(r);}finally{k(!1);}},[e,t]),U=useCallback(async(r,o)=>{if(e&&t)try{p(!0);let a;parseInt(r.amount)>15e3&&o&&(a=(await e.uploadSupportingDocument(o)).id);let u={...r,documentId:a},f=await e.placeOrder(u);P(x=>[...x,f]);}catch(a){console.error("Error placing order:",a),s(a);}finally{p(!1);}},[e,t]),q=useCallback(async r=>{if(e&&t&&l)try{return h(!0),await e.linkAddress(l.id,r)}catch(o){console.error("Error linking address:",o),s(o);}finally{h(!1);}},[e,t,l]);return jsx(c.Provider,{value:{authorize:S,isAuthorized:t,profile:l,balances:v,loading:B,loadingPlaceOrder:D,loadingLinkAddress:E,loadingBalances:z,getBalances:w,linkAddress:q,placeOrder:U,orders:T,tokens:F,error:N,loadingAuth:V},children:i})};function ue(){let i=useContext(c);if(i===null)throw new Error("useMonerium must be used within a MoneriumProvider");return i}
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 { c as MoneriumContext, ae as MoneriumProvider, ue as useMonerium };
8
- //# sourceMappingURL=out.js.map
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":"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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"]}
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.1.2",
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": "2.13.0"
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": "^18.2.0",
35
- "react-dom": "^18.2.0"
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
  }