@relayprotocol/relay-kit-hooks 1.12.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (68) hide show
  1. package/LICENSE +21 -0
  2. package/_cjs/package.json +1 -0
  3. package/_cjs/src/fetcher.js +20 -0
  4. package/_cjs/src/fetcher.js.map +1 -0
  5. package/_cjs/src/hooks/useExecutionStatus.js +62 -0
  6. package/_cjs/src/hooks/useExecutionStatus.js.map +1 -0
  7. package/_cjs/src/hooks/useQuote.js +94 -0
  8. package/_cjs/src/hooks/useQuote.js.map +1 -0
  9. package/_cjs/src/hooks/useRelayChains.js +33 -0
  10. package/_cjs/src/hooks/useRelayChains.js.map +1 -0
  11. package/_cjs/src/hooks/useRelayConfig.js +29 -0
  12. package/_cjs/src/hooks/useRelayConfig.js.map +1 -0
  13. package/_cjs/src/hooks/useRequests.js +39 -0
  14. package/_cjs/src/hooks/useRequests.js.map +1 -0
  15. package/_cjs/src/hooks/useTokenList.js +29 -0
  16. package/_cjs/src/hooks/useTokenList.js.map +1 -0
  17. package/_cjs/src/hooks/useTokenPrice.js +29 -0
  18. package/_cjs/src/hooks/useTokenPrice.js.map +1 -0
  19. package/_cjs/src/hooks/useTrendingCurrencies.js +24 -0
  20. package/_cjs/src/hooks/useTrendingCurrencies.js.map +1 -0
  21. package/_cjs/src/index.js +31 -0
  22. package/_cjs/src/index.js.map +1 -0
  23. package/_cjs/tsconfig.build.tsbuildinfo +1 -0
  24. package/_esm/package.json +1 -0
  25. package/_esm/src/fetcher.js +15 -0
  26. package/_esm/src/fetcher.js.map +1 -0
  27. package/_esm/src/hooks/useExecutionStatus.js +56 -0
  28. package/_esm/src/hooks/useExecutionStatus.js.map +1 -0
  29. package/_esm/src/hooks/useQuote.js +89 -0
  30. package/_esm/src/hooks/useQuote.js.map +1 -0
  31. package/_esm/src/hooks/useRelayChains.js +27 -0
  32. package/_esm/src/hooks/useRelayChains.js.map +1 -0
  33. package/_esm/src/hooks/useRelayConfig.js +23 -0
  34. package/_esm/src/hooks/useRelayConfig.js.map +1 -0
  35. package/_esm/src/hooks/useRequests.js +33 -0
  36. package/_esm/src/hooks/useRequests.js.map +1 -0
  37. package/_esm/src/hooks/useTokenList.js +24 -0
  38. package/_esm/src/hooks/useTokenList.js.map +1 -0
  39. package/_esm/src/hooks/useTokenPrice.js +23 -0
  40. package/_esm/src/hooks/useTokenPrice.js.map +1 -0
  41. package/_esm/src/hooks/useTrendingCurrencies.js +19 -0
  42. package/_esm/src/hooks/useTrendingCurrencies.js.map +1 -0
  43. package/_esm/src/index.js +10 -0
  44. package/_esm/src/index.js.map +1 -0
  45. package/_esm/tsconfig.build.tsbuildinfo +1 -0
  46. package/_types/src/fetcher.d.ts +5 -0
  47. package/_types/src/fetcher.d.ts.map +1 -0
  48. package/_types/src/hooks/useExecutionStatus.d.ts +32 -0
  49. package/_types/src/hooks/useExecutionStatus.d.ts.map +1 -0
  50. package/_types/src/hooks/useQuote.d.ts +426 -0
  51. package/_types/src/hooks/useQuote.d.ts.map +1 -0
  52. package/_types/src/hooks/useRelayChains.d.ts +141 -0
  53. package/_types/src/hooks/useRelayChains.d.ts.map +1 -0
  54. package/_types/src/hooks/useRelayConfig.d.ts +25 -0
  55. package/_types/src/hooks/useRelayConfig.d.ts.map +1 -0
  56. package/_types/src/hooks/useRequests.d.ts +5358 -0
  57. package/_types/src/hooks/useRequests.d.ts.map +1 -0
  58. package/_types/src/hooks/useTokenList.d.ts +40 -0
  59. package/_types/src/hooks/useTokenList.d.ts.map +1 -0
  60. package/_types/src/hooks/useTokenPrice.d.ts +14 -0
  61. package/_types/src/hooks/useTokenPrice.d.ts.map +1 -0
  62. package/_types/src/hooks/useTrendingCurrencies.d.ts +24 -0
  63. package/_types/src/hooks/useTrendingCurrencies.d.ts.map +1 -0
  64. package/_types/src/index.d.ts +11 -0
  65. package/_types/src/index.d.ts.map +1 -0
  66. package/_types/tsconfig.build.tsbuildinfo +1 -0
  67. package/package.json +66 -0
  68. package/readme.md +36 -0
@@ -0,0 +1 @@
1
+ {"type": "module","sideEffects":false}
@@ -0,0 +1,15 @@
1
+ import axios, {} from 'axios';
2
+ const fetcher = async (url, headers) => {
3
+ const response = await fetch(url, { headers });
4
+ if (!response.ok) {
5
+ const errorData = await response.json();
6
+ throw new Error(errorData.message || 'Network error');
7
+ }
8
+ return response.json();
9
+ };
10
+ export default fetcher;
11
+ export const axiosPostFetcher = async (url, params, config) => {
12
+ const { data } = await axios.post(url, params, config);
13
+ return data;
14
+ };
15
+ //# sourceMappingURL=fetcher.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"fetcher.js","sourceRoot":"","sources":["../../src/fetcher.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAA2B,MAAM,OAAO,CAAA;AAEtD,MAAM,OAAO,GAAG,KAAK,EAAE,GAAW,EAAE,OAAqB,EAAE,EAAE;IAC3D,MAAM,QAAQ,GAAG,MAAM,KAAK,CAAC,GAAG,EAAE,EAAE,OAAO,EAAE,CAAC,CAAA;IAE9C,IAAI,CAAC,QAAQ,CAAC,EAAE,EAAE,CAAC;QACjB,MAAM,SAAS,GAAG,MAAM,QAAQ,CAAC,IAAI,EAAE,CAAA;QACvC,MAAM,IAAI,KAAK,CAAC,SAAS,CAAC,OAAO,IAAI,eAAe,CAAC,CAAA;IACvD,CAAC;IAED,OAAO,QAAQ,CAAC,IAAI,EAAE,CAAA;AACxB,CAAC,CAAA;AAED,eAAe,OAAO,CAAA;AAEtB,MAAM,CAAC,MAAM,gBAAgB,GAAG,KAAK,EACnC,GAAW,EACX,MAAW,EACX,MAA2B,EAC3B,EAAE;IACF,MAAM,EAAE,IAAI,EAAE,GAAG,MAAM,KAAK,CAAC,IAAI,CAAC,GAAG,EAAE,MAAM,EAAE,MAAM,CAAC,CAAA;IACtD,OAAO,IAAI,CAAA;AACb,CAAC,CAAA"}
@@ -0,0 +1,56 @@
1
+ import { MAINNET_RELAY_API, RelayClient, setParams } from '@relayprotocol/relay-sdk';
2
+ import fetcher from '../fetcher.js';
3
+ import { useQuery } from '@tanstack/react-query';
4
+ import { useMemo } from 'react';
5
+ export const queryExecutionStatus = function (baseApiUrl = MAINNET_RELAY_API, options, headers) {
6
+ return new Promise((resolve, reject) => {
7
+ const url = new URL(`${baseApiUrl}/intents/status/v2`);
8
+ let query = { ...options };
9
+ setParams(url, query);
10
+ fetcher(url.href, headers)
11
+ .then((response) => {
12
+ const request = {
13
+ url: url.href,
14
+ method: 'get'
15
+ };
16
+ resolve({
17
+ ...response,
18
+ request
19
+ });
20
+ })
21
+ .catch((e) => {
22
+ reject(e);
23
+ });
24
+ });
25
+ };
26
+ export default function (client, options, onRequest, onResponse, queryOptions) {
27
+ const queryKey = ['useExecutionStatus', options];
28
+ const response = useQuery({
29
+ queryKey: queryKey,
30
+ queryFn: () => {
31
+ onRequest?.();
32
+ const promise = queryExecutionStatus(client?.baseApiUrl, options);
33
+ promise.then((response) => {
34
+ onResponse?.(response);
35
+ });
36
+ return promise;
37
+ },
38
+ enabled: client !== undefined && options !== undefined,
39
+ retry: false,
40
+ ...queryOptions
41
+ });
42
+ return useMemo(() => ({
43
+ ...response,
44
+ data: response.error ? undefined : response.data,
45
+ queryKey
46
+ }), [
47
+ response.data,
48
+ response.error,
49
+ response.isLoading,
50
+ response.isFetching,
51
+ response.isRefetching,
52
+ response.dataUpdatedAt,
53
+ queryKey
54
+ ]);
55
+ }
56
+ //# sourceMappingURL=useExecutionStatus.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useExecutionStatus.js","sourceRoot":"","sources":["../../../src/hooks/useExecutionStatus.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,iBAAiB,EACjB,WAAW,EACX,SAAS,EAIV,MAAM,0BAA0B,CAAA;AACjC,OAAO,OAAO,MAAM,eAAe,CAAA;AACnC,OAAO,EACL,QAAQ,EAGT,MAAM,uBAAuB,CAAA;AAC9B,OAAO,EAAE,OAAO,EAAE,MAAM,OAAO,CAAA;AAmB/B,MAAM,CAAC,MAAM,oBAAoB,GAAG,UAClC,aAAqB,iBAAiB,EACtC,OAA+B,EAC/B,OAAqB;IAErB,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;QACrC,MAAM,GAAG,GAAG,IAAI,GAAG,CAAC,GAAG,UAAU,oBAAoB,CAAC,CAAA;QACtD,IAAI,KAAK,GAA0B,EAAE,GAAG,OAAO,EAAE,CAAA;QACjD,SAAS,CAAC,GAAG,EAAE,KAAK,CAAC,CAAA;QAErB,OAAO,CAAC,GAAG,CAAC,IAAI,EAAE,OAAO,CAAC;aACvB,IAAI,CAAC,CAAC,QAAQ,EAAE,EAAE;YACjB,MAAM,OAAO,GAAuB;gBAClC,GAAG,EAAE,GAAG,CAAC,IAAI;gBACb,MAAM,EAAE,KAAK;aACd,CAAA;YACD,OAAO,CAAC;gBACN,GAAG,QAAQ;gBACX,OAAO;aACR,CAAC,CAAA;QACJ,CAAC,CAAC;aACD,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE;YACX,MAAM,CAAC,CAAC,CAAC,CAAA;QACX,CAAC,CAAC,CAAA;IACN,CAAC,CAAC,CAAA;AACJ,CAAC,CAAA;AAID,MAAM,CAAC,OAAO,WACZ,MAAoB,EACpB,OAA+B,EAC/B,SAAsB,EACtB,UAAoC,EACpC,YAAoC;IAEpC,MAAM,QAAQ,GAAG,CAAC,oBAAoB,EAAE,OAAO,CAAC,CAAA;IAChD,MAAM,QAAQ,GAAI,QAAsB,CAAC;QACvC,QAAQ,EAAE,QAAQ;QAClB,OAAO,EAAE,GAAG,EAAE;YACZ,SAAS,EAAE,EAAE,CAAA;YACb,MAAM,OAAO,GAAG,oBAAoB,CAAC,MAAM,EAAE,UAAU,EAAE,OAAO,CAAC,CAAA;YACjE,OAAO,CAAC,IAAI,CAAC,CAAC,QAAa,EAAE,EAAE;gBAC7B,UAAU,EAAE,CAAC,QAAQ,CAAC,CAAA;YACxB,CAAC,CAAC,CAAA;YACF,OAAO,OAAO,CAAA;QAChB,CAAC;QACD,OAAO,EAAE,MAAM,KAAK,SAAS,IAAI,OAAO,KAAK,SAAS;QACtD,KAAK,EAAE,KAAK;QACZ,GAAG,YAAY;KAChB,CAAC,CAAA;IAEF,OAAO,OAAO,CACZ,GAAG,EAAE,CACH,CAAC;QACC,GAAG,QAAQ;QACX,IAAI,EAAE,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,QAAQ,CAAC,IAAI;QAChD,QAAQ;KACT,CAGA,EACH;QACE,QAAQ,CAAC,IAAI;QACb,QAAQ,CAAC,KAAK;QACd,QAAQ,CAAC,SAAS;QAClB,QAAQ,CAAC,UAAU;QACnB,QAAQ,CAAC,YAAY;QACrB,QAAQ,CAAC,aAAa;QACtB,QAAQ;KACT,CACF,CAAA;AACH,CAAC"}
@@ -0,0 +1,89 @@
1
+ import { MAINNET_RELAY_API, RelayClient } from '@relayprotocol/relay-sdk';
2
+ import { axiosPostFetcher } from '../fetcher.js';
3
+ import { useQuery } from '@tanstack/react-query';
4
+ import { useCallback, useMemo } from 'react';
5
+ export const queryQuote = function (baseApiUrl = MAINNET_RELAY_API, options, config) {
6
+ return new Promise((resolve, reject) => {
7
+ const url = new URL(`${baseApiUrl}/quote`);
8
+ axiosPostFetcher(url.href, options, config)
9
+ .then((response) => {
10
+ const request = {
11
+ url: url.href,
12
+ method: 'post',
13
+ data: options
14
+ };
15
+ resolve({
16
+ ...response,
17
+ request
18
+ });
19
+ })
20
+ .catch((e) => {
21
+ reject(e);
22
+ });
23
+ });
24
+ };
25
+ export default function (client, wallet, options, onRequest, onResponse, queryOptions, onError, config) {
26
+ const queryKey = ['useQuote', options];
27
+ const response = useQuery({
28
+ queryKey: queryKey,
29
+ queryFn: () => {
30
+ onRequest?.(options, config);
31
+ if (options && client?.source && !options.referrer) {
32
+ options.referrer = client.source;
33
+ }
34
+ const promise = queryQuote(client?.baseApiUrl, options, {
35
+ ...config,
36
+ headers: {
37
+ 'relay-sdk-version': client?.version ?? 'unknown',
38
+ 'relay-kit-ui-version': client?.uiVersion ?? 'unknown'
39
+ }
40
+ });
41
+ promise
42
+ .then((response) => {
43
+ onResponse?.(response, options);
44
+ })
45
+ .catch((e) => {
46
+ if (onError) {
47
+ onError?.(e);
48
+ }
49
+ else {
50
+ throw e;
51
+ }
52
+ });
53
+ return promise;
54
+ },
55
+ enabled: client !== undefined && options !== undefined,
56
+ retry: false,
57
+ ...queryOptions
58
+ });
59
+ const executeQuote = useCallback((onProgress) => {
60
+ if (!wallet) {
61
+ throw 'Missing a valid wallet';
62
+ }
63
+ if (!response.data) {
64
+ throw 'Missing a quote';
65
+ }
66
+ const promise = client?.actions?.execute({
67
+ wallet,
68
+ quote: response.data,
69
+ onProgress
70
+ });
71
+ return promise;
72
+ }, [response.data, wallet, client]);
73
+ return useMemo(() => ({
74
+ ...response,
75
+ data: response.error ? undefined : response.data,
76
+ queryKey,
77
+ executeQuote
78
+ }), [
79
+ response.data,
80
+ response.error,
81
+ response.isLoading,
82
+ response.isFetching,
83
+ response.isRefetching,
84
+ response.dataUpdatedAt,
85
+ executeQuote,
86
+ queryKey
87
+ ]);
88
+ }
89
+ //# sourceMappingURL=useQuote.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useQuote.js","sourceRoot":"","sources":["../../../src/hooks/useQuote.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,27 @@
1
+ import { configureViemChain, convertViemChainToRelayChain, MAINNET_RELAY_API, setParams } from '@relayprotocol/relay-sdk';
2
+ import fetcher from '../fetcher.js';
3
+ import { useQuery } from '@tanstack/react-query';
4
+ import { useMemo } from 'react';
5
+ import { mainnet } from 'viem/chains';
6
+ export const queryRelayChains = function (baseApiUrl = MAINNET_RELAY_API, options, headers) {
7
+ const url = new URL(`${baseApiUrl}/chains`);
8
+ setParams(url, options ?? {});
9
+ return fetcher(url.href, headers);
10
+ };
11
+ export default function (baseApiUrl, options, queryOptions) {
12
+ const response = useQuery({
13
+ queryKey: ['useRelayChains', baseApiUrl, options],
14
+ queryFn: () => queryRelayChains(baseApiUrl, options),
15
+ retry: false,
16
+ ...queryOptions
17
+ });
18
+ return useMemo(() => {
19
+ const chains = response?.data?.chains?.map((chain) => configureViemChain(chain));
20
+ return {
21
+ ...response,
22
+ viemChains: chains?.map((chain) => chain.viemChain),
23
+ chains: chains ? chains : [convertViemChainToRelayChain(mainnet)]
24
+ };
25
+ }, [response.data, response.data?.chains, response.error, response.isLoading]);
26
+ }
27
+ //# sourceMappingURL=useRelayChains.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useRelayChains.js","sourceRoot":"","sources":["../../../src/hooks/useRelayChains.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,kBAAkB,EAClB,4BAA4B,EAC5B,iBAAiB,EACjB,SAAS,EAEV,MAAM,0BAA0B,CAAA;AACjC,OAAO,OAAO,MAAM,eAAe,CAAA;AACnC,OAAO,EACL,QAAQ,EAGT,MAAM,uBAAuB,CAAA;AAC9B,OAAO,EAAE,OAAO,EAAE,MAAM,OAAO,CAAA;AAC/B,OAAO,EAAE,OAAO,EAAE,MAAM,aAAa,CAAA;AAiBrC,MAAM,CAAC,MAAM,gBAAgB,GAAG,UAC9B,aAAqB,iBAAiB,EACtC,OAAqB,EACrB,OAAqB;IAErB,MAAM,GAAG,GAAG,IAAI,GAAG,CAAC,GAAG,UAAU,SAAS,CAAC,CAAA;IAC3C,SAAS,CAAC,GAAG,EAAE,OAAO,IAAI,EAAE,CAAC,CAAA;IAC7B,OAAO,OAAO,CAAC,GAAG,CAAC,IAAI,EAAE,OAAO,CAAC,CAAA;AACnC,CAAC,CAAA;AAED,MAAM,CAAC,OAAO,WACZ,UAAmB,EACnB,OAAqB,EACrB,YAAoC;IAEpC,MAAM,QAAQ,GAAI,QAAsB,CAAC;QACvC,QAAQ,EAAE,CAAC,gBAAgB,EAAE,UAAU,EAAE,OAAO,CAAC;QACjD,OAAO,EAAE,GAAG,EAAE,CAAC,gBAAgB,CAAC,UAAU,EAAE,OAAO,CAAC;QACpD,KAAK,EAAE,KAAK;QACZ,GAAG,YAAY;KAChB,CAAC,CAAA;IAIF,OAAO,OAAO,CAAC,GAAG,EAAE;QAClB,MAAM,MAAM,GACV,QAAQ,EAAE,IAAI,EAAE,MAAM,EAAE,GAAG,CAAC,CAAC,KAAU,EAAE,EAAE,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC,CAAA;QACxE,OAAO;YACL,GAAG,QAAQ;YACX,UAAU,EAAE,MAAM,EAAE,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,SAAS,CAAC;YACnD,MAAM,EAAE,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,4BAA4B,CAAC,OAAO,CAAC,CAAC;SAIlE,CAAA;IACH,CAAC,EAAE,CAAC,QAAQ,CAAC,IAAI,EAAE,QAAQ,CAAC,IAAI,EAAE,MAAM,EAAE,QAAQ,CAAC,KAAK,EAAE,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAA;AAChF,CAAC"}
@@ -0,0 +1,23 @@
1
+ import { MAINNET_RELAY_API, setParams } from '@relayprotocol/relay-sdk';
2
+ import fetcher from '../fetcher.js';
3
+ import { useQuery } from '@tanstack/react-query';
4
+ import { useMemo } from 'react';
5
+ export const queryRelayConfig = function (baseApiUrl = MAINNET_RELAY_API, options, headers) {
6
+ const url = new URL(`${baseApiUrl}/config/v2`);
7
+ setParams(url, options ?? {});
8
+ return fetcher(url.href, headers);
9
+ };
10
+ export default function (baseApiUrl, options, queryOptions) {
11
+ const response = useQuery({
12
+ queryKey: ['useRelayConfig', options],
13
+ queryFn: () => queryRelayConfig(baseApiUrl, options),
14
+ retry: false,
15
+ ...queryOptions
16
+ });
17
+ return useMemo(() => {
18
+ return {
19
+ ...response
20
+ };
21
+ }, [response.data, response.error, response.isLoading]);
22
+ }
23
+ //# sourceMappingURL=useRelayConfig.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useRelayConfig.js","sourceRoot":"","sources":["../../../src/hooks/useRelayConfig.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,iBAAiB,EACjB,SAAS,EAEV,MAAM,0BAA0B,CAAA;AACjC,OAAO,OAAO,MAAM,eAAe,CAAA;AACnC,OAAO,EACL,QAAQ,EAGT,MAAM,uBAAuB,CAAA;AAC9B,OAAO,EAAE,OAAO,EAAE,MAAM,OAAO,CAAA;AAiB/B,MAAM,CAAC,MAAM,gBAAgB,GAAG,UAC9B,aAAqB,iBAAiB,EACtC,OAAqB,EACrB,OAAqB;IAErB,MAAM,GAAG,GAAG,IAAI,GAAG,CAAC,GAAG,UAAU,YAAY,CAAC,CAAA;IAC9C,SAAS,CAAC,GAAG,EAAE,OAAO,IAAI,EAAE,CAAC,CAAA;IAC7B,OAAO,OAAO,CAAC,GAAG,CAAC,IAAI,EAAE,OAAO,CAAC,CAAA;AACnC,CAAC,CAAA;AAED,MAAM,CAAC,OAAO,WACZ,UAAmB,EACnB,OAAqB,EACrB,YAAoC;IAEpC,MAAM,QAAQ,GAAI,QAAsB,CAAC;QACvC,QAAQ,EAAE,CAAC,gBAAgB,EAAE,OAAO,CAAC;QACrC,OAAO,EAAE,GAAG,EAAE,CAAC,gBAAgB,CAAC,UAAU,EAAE,OAAO,CAAC;QACpD,KAAK,EAAE,KAAK;QACZ,GAAG,YAAY;KAChB,CAAC,CAAA;IAEF,OAAO,OAAO,CAAC,GAAG,EAAE;QAClB,OAAO;YACL,GAAG,QAAQ;SACa,CAAA;IAC5B,CAAC,EAAE,CAAC,QAAQ,CAAC,IAAI,EAAE,QAAQ,CAAC,KAAK,EAAE,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAA;AACzD,CAAC"}
@@ -0,0 +1,33 @@
1
+ import { MAINNET_RELAY_API, setParams } from '@relayprotocol/relay-sdk';
2
+ import { useMemo } from 'react';
3
+ import { useInfiniteQuery } from '@tanstack/react-query';
4
+ import fetcher from '../fetcher.js';
5
+ export const queryRequests = function (baseApiUrl = MAINNET_RELAY_API, options, pageParam, headers) {
6
+ const baseUrl = typeof window !== 'undefined' ? window.location.origin : undefined;
7
+ const url = new URL(`${baseApiUrl}/requests/v2`, baseUrl);
8
+ let query = { ...options };
9
+ if (pageParam) {
10
+ query.continuation = pageParam;
11
+ }
12
+ setParams(url, query);
13
+ return fetcher(url.href, headers);
14
+ };
15
+ export default function (options, baseApiUrl, queryOptions) {
16
+ const response = useInfiniteQuery({
17
+ queryKey: ['useUserTransactions', options],
18
+ enabled: options !== undefined,
19
+ queryFn: (data) => queryRequests(baseApiUrl, options, data.pageParam),
20
+ getNextPageParam: (data) => {
21
+ return data.continuation;
22
+ },
23
+ initialPageParam: null,
24
+ retry: false,
25
+ ...queryOptions
26
+ });
27
+ const transactions = useMemo(() => response.data?.pages?.flatMap((page) => page?.requests || []) ?? [], [response.data]);
28
+ return {
29
+ ...response,
30
+ data: transactions
31
+ };
32
+ }
33
+ //# sourceMappingURL=useRequests.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useRequests.js","sourceRoot":"","sources":["../../../src/hooks/useRequests.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,iBAAiB,EAEjB,SAAS,EACV,MAAM,0BAA0B,CAAA;AACjC,OAAO,EAAE,OAAO,EAAE,MAAM,OAAO,CAAA;AAC/B,OAAO,EACL,gBAAgB,EAIjB,MAAM,uBAAuB,CAAA;AAC9B,OAAO,OAAO,MAAM,eAAe,CAAA;AAmBnC,MAAM,CAAC,MAAM,aAAa,GAAG,UAC3B,aAAqB,iBAAiB,EACtC,OAAsC,EACtC,SAAyB,EACzB,OAAqB;IAErB,MAAM,OAAO,GACX,OAAO,MAAM,KAAK,WAAW,CAAC,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS,CAAA;IACpE,MAAM,GAAG,GAAG,IAAI,GAAG,CAAC,GAAG,UAAU,cAAc,EAAE,OAAO,CAAC,CAAA;IAEzD,IAAI,KAAK,GAAyB,EAAE,GAAG,OAAO,EAAE,CAAA;IAEhD,IAAI,SAAS,EAAE,CAAC;QACd,KAAK,CAAC,YAAY,GAAG,SAAS,CAAA;IAChC,CAAC;IAED,SAAS,CAAC,GAAG,EAAE,KAAK,CAAC,CAAA;IACrB,OAAO,OAAO,CAAC,GAAG,CAAC,IAAI,EAAE,OAAO,CAAC,CAAA;AACnC,CAAC,CAAA;AAED,MAAM,CAAC,OAAO,WACZ,OAAsC,EACtC,UAAmB,EACnB,YAAoC;IAEpC,MAAM,QAAQ,GAAI,gBAAsC,CAAC;QACvD,QAAQ,EAAE,CAAC,qBAAqB,EAAE,OAAO,CAAC;QAC1C,OAAO,EAAE,OAAO,KAAK,SAAS;QAC9B,OAAO,EAAE,CAAC,IAAI,EAAE,EAAE,CAAC,aAAa,CAAC,UAAU,EAAE,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC;QACrE,gBAAgB,EAAE,CAAC,IAAI,EAAE,EAAE;YACzB,OAAO,IAAI,CAAC,YAAY,CAAA;QAC1B,CAAC;QACD,gBAAgB,EAAE,IAAI;QACtB,KAAK,EAAE,KAAK;QACZ,GAAG,YAAY;KAChB,CAAC,CAAA;IAEF,MAAM,YAAY,GAAG,OAAO,CAC1B,GAAG,EAAE,CAAC,QAAQ,CAAC,IAAI,EAAE,KAAK,EAAE,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,EAAE,QAAQ,IAAI,EAAE,CAAC,IAAI,EAAE,EACzE,CAAC,QAAQ,CAAC,IAAI,CAAC,CAChB,CAAA;IAED,OAAO;QACL,GAAG,QAAQ;QACX,IAAI,EAAE,YAAY;KACnB,CAAA;AACH,CAAC"}
@@ -0,0 +1,24 @@
1
+ import { axiosPostFetcher } from '../fetcher.js';
2
+ import { useMemo } from 'react';
3
+ import { MAINNET_RELAY_API } from '@relayprotocol/relay-sdk';
4
+ import { useQuery } from '@tanstack/react-query';
5
+ export const queryTokenList = function (baseApiUrl = MAINNET_RELAY_API, options, headers) {
6
+ const url = new URL(`${baseApiUrl}/currencies/v2`);
7
+ return axiosPostFetcher(url.href, options, headers);
8
+ };
9
+ export default function (baseApiUrl, options, queryOptions) {
10
+ const response = useQuery({
11
+ queryKey: ['useTokenList', options],
12
+ queryFn: () => queryTokenList(baseApiUrl, options),
13
+ enabled: options ? true : false,
14
+ retry: false,
15
+ ...queryOptions
16
+ });
17
+ return useMemo(() => {
18
+ return {
19
+ ...response,
20
+ data: response.error ? undefined : response.data
21
+ };
22
+ }, [response.data, response.error, response.isLoading]);
23
+ }
24
+ //# sourceMappingURL=useTokenList.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useTokenList.js","sourceRoot":"","sources":["../../../src/hooks/useTokenList.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAA;AAChD,OAAO,EAAE,OAAO,EAAE,MAAM,OAAO,CAAA;AAC/B,OAAO,EAAE,iBAAiB,EAAc,MAAM,0BAA0B,CAAA;AACxE,OAAO,EACL,QAAQ,EAGT,MAAM,uBAAuB,CAAA;AAiB9B,MAAM,CAAC,MAAM,cAAc,GAAG,UAC5B,aAAqB,iBAAiB,EACtC,OAA2B,EAC3B,OAAgC;IAEhC,MAAM,GAAG,GAAG,IAAI,GAAG,CAAC,GAAG,UAAU,gBAAgB,CAAC,CAAA;IAClD,OAAO,gBAAgB,CAAC,GAAG,CAAC,IAAI,EAAE,OAAO,EAAE,OAAO,CAAC,CAAA;AACrD,CAAC,CAAA;AAED,MAAM,CAAC,OAAO,WACZ,UAAmB,EACnB,OAA2B,EAC3B,YAAoC;IAEpC,MAAM,QAAQ,GAAI,QAAsB,CAAC;QACvC,QAAQ,EAAE,CAAC,cAAc,EAAE,OAAO,CAAC;QACnC,OAAO,EAAE,GAAG,EAAE,CAAC,cAAc,CAAC,UAAU,EAAE,OAAO,CAAC;QAClD,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK;QAC/B,KAAK,EAAE,KAAK;QACZ,GAAG,YAAY;KAChB,CAAC,CAAA;IAEF,OAAO,OAAO,CAAC,GAAG,EAAE;QAClB,OAAO;YACL,GAAG,QAAQ;YACX,IAAI,EAAE,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,QAAQ,CAAC,IAAI;SAGjD,CAAA;IACH,CAAC,EAAE,CAAC,QAAQ,CAAC,IAAI,EAAE,QAAQ,CAAC,KAAK,EAAE,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAA;AACzD,CAAC"}
@@ -0,0 +1,23 @@
1
+ import { MAINNET_RELAY_API, setParams } from '@relayprotocol/relay-sdk';
2
+ import fetcher from '../fetcher.js';
3
+ import { useQuery } from '@tanstack/react-query';
4
+ import { useMemo } from 'react';
5
+ export const queryTokenPrice = function (baseApiUrl = MAINNET_RELAY_API, options, headers) {
6
+ const url = new URL(`${baseApiUrl}/currencies/token/price`);
7
+ setParams(url, options ?? {});
8
+ return fetcher(url.href, headers);
9
+ };
10
+ export default function (baseApiUrl, options, queryOptions) {
11
+ const response = useQuery({
12
+ queryKey: ['useTokenPrice', options],
13
+ queryFn: () => queryTokenPrice(baseApiUrl, options),
14
+ retry: false,
15
+ ...queryOptions
16
+ });
17
+ return useMemo(() => {
18
+ return {
19
+ ...response
20
+ };
21
+ }, [response.data, response.error, response.isLoading]);
22
+ }
23
+ //# sourceMappingURL=useTokenPrice.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useTokenPrice.js","sourceRoot":"","sources":["../../../src/hooks/useTokenPrice.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,iBAAiB,EACjB,SAAS,EAEV,MAAM,0BAA0B,CAAA;AACjC,OAAO,OAAO,MAAM,eAAe,CAAA;AACnC,OAAO,EACL,QAAQ,EAGT,MAAM,uBAAuB,CAAA;AAC9B,OAAO,EAAE,OAAO,EAAE,MAAM,OAAO,CAAA;AAkB/B,MAAM,CAAC,MAAM,eAAe,GAAG,UAC7B,aAAqB,iBAAiB,EACtC,OAAyB,EACzB,OAAqB;IAErB,MAAM,GAAG,GAAG,IAAI,GAAG,CAAC,GAAG,UAAU,yBAAyB,CAAC,CAAA;IAC3D,SAAS,CAAC,GAAG,EAAE,OAAO,IAAI,EAAE,CAAC,CAAA;IAC7B,OAAO,OAAO,CAAC,GAAG,CAAC,IAAI,EAAE,OAAO,CAAC,CAAA;AACnC,CAAC,CAAA;AAED,MAAM,CAAC,OAAO,WACZ,UAAmB,EACnB,OAAyB,EACzB,YAAoC;IAEpC,MAAM,QAAQ,GAAI,QAAsB,CAAC;QACvC,QAAQ,EAAE,CAAC,eAAe,EAAE,OAAO,CAAC;QACpC,OAAO,EAAE,GAAG,EAAE,CAAC,eAAe,CAAC,UAAU,EAAE,OAAO,CAAC;QACnD,KAAK,EAAE,KAAK;QACZ,GAAG,YAAY;KAChB,CAAC,CAAA;IAEF,OAAO,OAAO,CAAC,GAAG,EAAE;QAClB,OAAO;YACL,GAAG,QAAQ;SACa,CAAA;IAC5B,CAAC,EAAE,CAAC,QAAQ,CAAC,IAAI,EAAE,QAAQ,CAAC,KAAK,EAAE,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAA;AACzD,CAAC"}
@@ -0,0 +1,19 @@
1
+ import { useQuery } from '@tanstack/react-query';
2
+ import { setParams, MAINNET_RELAY_API } from '@relayprotocol/relay-sdk';
3
+ import fetcher from '../fetcher.js';
4
+ export const queryTrendingCurrencies = function (baseApiUrl = MAINNET_RELAY_API, options, headers) {
5
+ const url = new URL(`${baseApiUrl}/currencies/trending`);
6
+ setParams(url, options ?? {});
7
+ return fetcher(url.href, headers);
8
+ };
9
+ export default (baseApiUrl, queryParams, queryOptions) => {
10
+ const queryKey = ['useTrendingCurrencies', queryParams];
11
+ const response = useQuery({
12
+ queryKey: queryKey,
13
+ queryFn: () => queryTrendingCurrencies(baseApiUrl, queryParams),
14
+ ...queryOptions,
15
+ enabled: queryOptions?.enabled
16
+ });
17
+ return response;
18
+ };
19
+ //# sourceMappingURL=useTrendingCurrencies.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useTrendingCurrencies.js","sourceRoot":"","sources":["../../../src/hooks/useTrendingCurrencies.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,QAAQ,EAGT,MAAM,uBAAuB,CAAA;AAC9B,OAAO,EACL,SAAS,EAET,iBAAiB,EAClB,MAAM,0BAA0B,CAAA;AACjC,OAAO,OAAO,MAAM,eAAe,CAAA;AAkBnC,MAAM,CAAC,MAAM,uBAAuB,GAAG,UACrC,aAAqB,iBAAiB,EACtC,OAAiC,EACjC,OAAgC;IAEhC,MAAM,GAAG,GAAG,IAAI,GAAG,CAAC,GAAG,UAAU,sBAAsB,CAAC,CAAA;IACxD,SAAS,CAAC,GAAG,EAAE,OAAO,IAAI,EAAE,CAAC,CAAA;IAC7B,OAAO,OAAO,CAAC,GAAG,CAAC,IAAI,EAAE,OAAO,CAAC,CAAA;AACnC,CAAC,CAAA;AAED,eAAe,CACb,UAAmB,EACnB,WAAqC,EACrC,YAAoC,EACpC,EAAE;IACF,MAAM,QAAQ,GAAG,CAAC,uBAAuB,EAAE,WAAW,CAAC,CAAA;IAEvD,MAAM,QAAQ,GAAI,QAAsB,CAAC;QACvC,QAAQ,EAAE,QAAQ;QAClB,OAAO,EAAE,GAAG,EAAE,CAAC,uBAAuB,CAAC,UAAU,EAAE,WAAW,CAAC;QAC/D,GAAG,YAAY;QACf,OAAO,EAAE,YAAY,EAAE,OAAO;KAC/B,CAAC,CAAA;IAEF,OAAO,QAAQ,CAAA;AACjB,CAAC,CAAA"}
@@ -0,0 +1,10 @@
1
+ //hooks
2
+ export { default as useRequests, queryRequests } from './hooks/useRequests.js';
3
+ export { default as useQuote, queryQuote } from './hooks/useQuote.js';
4
+ export { default as useTokenList, queryTokenList } from './hooks/useTokenList.js';
5
+ export { default as useRelayChains, queryRelayChains } from './hooks/useRelayChains.js';
6
+ export { default as useRelayConfig, queryRelayConfig } from './hooks/useRelayConfig.js';
7
+ export { default as useExecutionStatus, queryExecutionStatus } from './hooks/useExecutionStatus.js';
8
+ export { default as useTokenPrice, queryTokenPrice } from './hooks/useTokenPrice.js';
9
+ export { default as useTrendingCurrencies, queryTrendingCurrencies } from './hooks/useTrendingCurrencies.js';
10
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO;AACP,OAAO,EAAE,OAAO,IAAI,WAAW,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAA;AAC9E,OAAO,EAAE,OAAO,IAAI,QAAQ,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAA;AACrE,OAAO,EACL,OAAO,IAAI,YAAY,EACvB,cAAc,EACf,MAAM,yBAAyB,CAAA;AAChC,OAAO,EACL,OAAO,IAAI,cAAc,EACzB,gBAAgB,EACjB,MAAM,2BAA2B,CAAA;AAClC,OAAO,EACL,OAAO,IAAI,cAAc,EACzB,gBAAgB,EACjB,MAAM,2BAA2B,CAAA;AAClC,OAAO,EACL,OAAO,IAAI,kBAAkB,EAC7B,oBAAoB,EACrB,MAAM,+BAA+B,CAAA;AACtC,OAAO,EACL,OAAO,IAAI,aAAa,EACxB,eAAe,EAChB,MAAM,0BAA0B,CAAA;AACjC,OAAO,EACL,OAAO,IAAI,qBAAqB,EAChC,uBAAuB,EACxB,MAAM,kCAAkC,CAAA"}