@mezo-org/passport 0.4.0-dev.2 → 0.4.0-dev.20

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 (263) hide show
  1. package/dist/src/api/auth.d.ts +57 -52
  2. package/dist/src/api/auth.d.ts.map +1 -1
  3. package/dist/src/api/auth.js +22 -53
  4. package/dist/src/api/auth.js.map +1 -1
  5. package/dist/src/api/client.d.ts +24 -0
  6. package/dist/src/api/client.d.ts.map +1 -0
  7. package/dist/src/api/client.js +54 -0
  8. package/dist/src/api/client.js.map +1 -0
  9. package/dist/src/api/fetch-error.d.ts +5 -0
  10. package/dist/src/api/fetch-error.d.ts.map +1 -0
  11. package/dist/src/api/fetch-error.js +8 -0
  12. package/dist/src/api/fetch-error.js.map +1 -0
  13. package/dist/src/api/index.d.ts +3 -0
  14. package/dist/src/api/index.d.ts.map +1 -0
  15. package/dist/src/api/index.js +3 -0
  16. package/dist/src/api/index.js.map +1 -0
  17. package/dist/src/api/portal.d.ts +32 -0
  18. package/dist/src/api/portal.d.ts.map +1 -0
  19. package/dist/src/api/portal.js +23 -0
  20. package/dist/src/api/portal.js.map +1 -0
  21. package/dist/src/assets/DefaultAvatar.d.ts +5 -0
  22. package/dist/src/assets/DefaultAvatar.d.ts.map +1 -0
  23. package/dist/src/assets/DefaultAvatar.js +21 -0
  24. package/dist/src/assets/DefaultAvatar.js.map +1 -0
  25. package/dist/src/components/Dropdown/ConnectedTrigger.d.ts +8 -0
  26. package/dist/src/components/Dropdown/ConnectedTrigger.d.ts.map +1 -0
  27. package/dist/src/components/Dropdown/ConnectedTrigger.js +39 -0
  28. package/dist/src/components/Dropdown/ConnectedTrigger.js.map +1 -0
  29. package/dist/src/components/Dropdown/Content.d.ts +9 -0
  30. package/dist/src/components/Dropdown/Content.d.ts.map +1 -0
  31. package/dist/src/components/Dropdown/Content.js +25 -0
  32. package/dist/src/components/Dropdown/Content.js.map +1 -0
  33. package/dist/src/components/Dropdown/DisconnectedTrigger.d.ts +7 -0
  34. package/dist/src/components/Dropdown/DisconnectedTrigger.d.ts.map +1 -0
  35. package/dist/src/components/Dropdown/DisconnectedTrigger.js +13 -0
  36. package/dist/src/components/Dropdown/DisconnectedTrigger.js.map +1 -0
  37. package/dist/src/components/Dropdown/Dropdown.d.ts +27 -0
  38. package/dist/src/components/Dropdown/Dropdown.d.ts.map +1 -0
  39. package/dist/src/components/Dropdown/Dropdown.js +64 -0
  40. package/dist/src/components/Dropdown/Dropdown.js.map +1 -0
  41. package/dist/src/components/Dropdown/NestedViewLayout.d.ts +7 -0
  42. package/dist/src/components/Dropdown/NestedViewLayout.d.ts.map +1 -0
  43. package/dist/src/components/Dropdown/NestedViewLayout.js +34 -0
  44. package/dist/src/components/Dropdown/NestedViewLayout.js.map +1 -0
  45. package/dist/src/components/Dropdown/Receive/Receive.d.ts +7 -0
  46. package/dist/src/components/Dropdown/Receive/Receive.d.ts.map +1 -0
  47. package/dist/src/components/Dropdown/Receive/Receive.js +53 -0
  48. package/dist/src/components/Dropdown/Receive/Receive.js.map +1 -0
  49. package/dist/src/components/Dropdown/Root/AccountAddressActions.d.ts +7 -0
  50. package/dist/src/components/Dropdown/Root/AccountAddressActions.d.ts.map +1 -0
  51. package/dist/src/components/Dropdown/Root/AccountAddressActions.js +48 -0
  52. package/dist/src/components/Dropdown/Root/AccountAddressActions.js.map +1 -0
  53. package/dist/src/components/Dropdown/Root/AccountAssets.d.ts +13 -0
  54. package/dist/src/components/Dropdown/Root/AccountAssets.d.ts.map +1 -0
  55. package/dist/src/components/Dropdown/Root/AccountAssets.js +43 -0
  56. package/dist/src/components/Dropdown/Root/AccountAssets.js.map +1 -0
  57. package/dist/src/components/Dropdown/Root/AccountBalance.d.ts +7 -0
  58. package/dist/src/components/Dropdown/Root/AccountBalance.d.ts.map +1 -0
  59. package/dist/src/components/Dropdown/Root/AccountBalance.js +16 -0
  60. package/dist/src/components/Dropdown/Root/AccountBalance.js.map +1 -0
  61. package/dist/src/components/Dropdown/Root/Root.d.ts +8 -0
  62. package/dist/src/components/Dropdown/Root/Root.d.ts.map +1 -0
  63. package/dist/src/components/Dropdown/Root/Root.js +64 -0
  64. package/dist/src/components/Dropdown/Root/Root.js.map +1 -0
  65. package/dist/src/components/Dropdown/Root/WalletAddress.d.ts +8 -0
  66. package/dist/src/components/Dropdown/Root/WalletAddress.d.ts.map +1 -0
  67. package/dist/src/components/Dropdown/Root/WalletAddress.js +65 -0
  68. package/dist/src/components/Dropdown/Root/WalletAddress.js.map +1 -0
  69. package/dist/src/components/Dropdown/Root/WelcomeBlock.d.ts +8 -0
  70. package/dist/src/components/Dropdown/Root/WelcomeBlock.d.ts.map +1 -0
  71. package/dist/src/components/Dropdown/Root/WelcomeBlock.js +43 -0
  72. package/dist/src/components/Dropdown/Root/WelcomeBlock.js.map +1 -0
  73. package/dist/src/components/Dropdown/index.d.ts +3 -0
  74. package/dist/src/components/Dropdown/index.d.ts.map +1 -0
  75. package/dist/src/components/Dropdown/index.js +2 -0
  76. package/dist/src/components/Dropdown/index.js.map +1 -0
  77. package/dist/src/components/index.d.ts +2 -0
  78. package/dist/src/components/index.d.ts.map +1 -0
  79. package/dist/src/components/index.js +2 -0
  80. package/dist/src/components/index.js.map +1 -0
  81. package/dist/src/hooks/constants.d.ts +3 -3
  82. package/dist/src/hooks/constants.js +4 -4
  83. package/dist/src/hooks/constants.js.map +1 -1
  84. package/dist/src/hooks/index.d.ts +2 -4
  85. package/dist/src/hooks/index.d.ts.map +1 -1
  86. package/dist/src/hooks/index.js +2 -4
  87. package/dist/src/hooks/index.js.map +1 -1
  88. package/dist/src/hooks/useAssetsUSDConversion.d.ts +8 -0
  89. package/dist/src/hooks/useAssetsUSDConversion.d.ts.map +1 -0
  90. package/dist/src/hooks/useAssetsUSDConversion.js +21 -0
  91. package/dist/src/hooks/useAssetsUSDConversion.js.map +1 -0
  92. package/dist/src/hooks/useAuthApiClient.d.ts +1 -1
  93. package/dist/src/hooks/useAuthApiClient.d.ts.map +1 -1
  94. package/dist/src/hooks/useAuthenticateWithWallet.d.ts +73 -0
  95. package/dist/src/hooks/useAuthenticateWithWallet.d.ts.map +1 -0
  96. package/dist/src/hooks/useAuthenticateWithWallet.js +69 -0
  97. package/dist/src/hooks/useAuthenticateWithWallet.js.map +1 -0
  98. package/dist/src/hooks/useCreateAccount.d.ts +41 -137
  99. package/dist/src/hooks/useCreateAccount.d.ts.map +1 -1
  100. package/dist/src/hooks/useCreateAccount.js +8 -10
  101. package/dist/src/hooks/useCreateAccount.js.map +1 -1
  102. package/dist/src/hooks/useCreateSession.d.ts +12 -182
  103. package/dist/src/hooks/useCreateSession.d.ts.map +1 -1
  104. package/dist/src/hooks/useCreateSession.js +12 -18
  105. package/dist/src/hooks/useCreateSession.js.map +1 -1
  106. package/dist/src/hooks/useDropdownData.d.ts +45 -0
  107. package/dist/src/hooks/useDropdownData.d.ts.map +1 -0
  108. package/dist/src/hooks/useDropdownData.js +80 -0
  109. package/dist/src/hooks/useDropdownData.js.map +1 -0
  110. package/dist/src/hooks/useEnsureNoSessionAndFetchNonce.d.ts +5 -0
  111. package/dist/src/hooks/useEnsureNoSessionAndFetchNonce.d.ts.map +1 -0
  112. package/dist/src/hooks/useEnsureNoSessionAndFetchNonce.js +34 -0
  113. package/dist/src/hooks/useEnsureNoSessionAndFetchNonce.js.map +1 -0
  114. package/dist/src/hooks/useGetAccountByAddress.d.ts +3 -5
  115. package/dist/src/hooks/useGetAccountByAddress.d.ts.map +1 -1
  116. package/dist/src/hooks/useGetAccountByAddress.js +3 -4
  117. package/dist/src/hooks/useGetAccountByAddress.js.map +1 -1
  118. package/dist/src/hooks/useGetAccountByMezoId.d.ts +3 -5
  119. package/dist/src/hooks/useGetAccountByMezoId.d.ts.map +1 -1
  120. package/dist/src/hooks/useGetAccountByMezoId.js +3 -4
  121. package/dist/src/hooks/useGetAccountByMezoId.js.map +1 -1
  122. package/dist/src/hooks/useGetCurrentAccount.d.ts +14 -8
  123. package/dist/src/hooks/useGetCurrentAccount.d.ts.map +1 -1
  124. package/dist/src/hooks/useGetCurrentAccount.js +28 -6
  125. package/dist/src/hooks/useGetCurrentAccount.js.map +1 -1
  126. package/dist/src/hooks/useGetSession.d.ts +3 -20
  127. package/dist/src/hooks/useGetSession.d.ts.map +1 -1
  128. package/dist/src/hooks/useGetSession.js +2 -2
  129. package/dist/src/hooks/useGetSession.js.map +1 -1
  130. package/dist/src/hooks/useLinkAccount.d.ts +15 -121
  131. package/dist/src/hooks/useLinkAccount.d.ts.map +1 -1
  132. package/dist/src/hooks/useLinkAccount.js +8 -21
  133. package/dist/src/hooks/useLinkAccount.js.map +1 -1
  134. package/dist/src/hooks/usePortalApiClient.d.ts +2 -0
  135. package/dist/src/hooks/usePortalApiClient.d.ts.map +1 -0
  136. package/dist/src/hooks/usePortalApiClient.js +6 -0
  137. package/dist/src/hooks/usePortalApiClient.js.map +1 -0
  138. package/dist/src/hooks/useRefreshPassport.d.ts +17 -0
  139. package/dist/src/hooks/useRefreshPassport.d.ts.map +1 -0
  140. package/dist/src/hooks/useRefreshPassport.js +29 -0
  141. package/dist/src/hooks/useRefreshPassport.js.map +1 -0
  142. package/dist/src/hooks/useSignInWithDiscord.d.ts +12 -181
  143. package/dist/src/hooks/useSignInWithDiscord.d.ts.map +1 -1
  144. package/dist/src/hooks/useSignInWithDiscord.js +11 -22
  145. package/dist/src/hooks/useSignInWithDiscord.js.map +1 -1
  146. package/dist/src/hooks/useSignInWithWallet.d.ts +12 -181
  147. package/dist/src/hooks/useSignInWithWallet.d.ts.map +1 -1
  148. package/dist/src/hooks/useSignInWithWallet.js +6 -44
  149. package/dist/src/hooks/useSignInWithWallet.js.map +1 -1
  150. package/dist/src/hooks/useSignOut.d.ts +12 -28
  151. package/dist/src/hooks/useSignOut.d.ts.map +1 -1
  152. package/dist/src/hooks/useSignOut.js +11 -6
  153. package/dist/src/hooks/useSignOut.js.map +1 -1
  154. package/dist/src/hooks/useSignUpWithWallet.d.ts +73 -0
  155. package/dist/src/hooks/useSignUpWithWallet.d.ts.map +1 -0
  156. package/dist/src/hooks/useSignUpWithWallet.js +11 -0
  157. package/dist/src/hooks/useSignUpWithWallet.js.map +1 -0
  158. package/dist/src/hooks/useUpdateMezoId.d.ts +30 -82
  159. package/dist/src/hooks/useUpdateMezoId.d.ts.map +1 -1
  160. package/dist/src/hooks/useUpdateMezoId.js +8 -12
  161. package/dist/src/hooks/useUpdateMezoId.js.map +1 -1
  162. package/dist/src/hooks/useWalletAccount.d.ts +12 -0
  163. package/dist/src/hooks/useWalletAccount.d.ts.map +1 -0
  164. package/dist/src/hooks/useWalletAccount.js +28 -0
  165. package/dist/src/hooks/useWalletAccount.js.map +1 -0
  166. package/dist/src/index.d.ts +1 -0
  167. package/dist/src/index.d.ts.map +1 -1
  168. package/dist/src/index.js +1 -0
  169. package/dist/src/index.js.map +1 -1
  170. package/dist/src/provider.d.ts +10 -13
  171. package/dist/src/provider.d.ts.map +1 -1
  172. package/dist/src/provider.js +11 -20
  173. package/dist/src/provider.js.map +1 -1
  174. package/dist/src/stores/dropdownStore.d.ts +12 -0
  175. package/dist/src/stores/dropdownStore.d.ts.map +1 -0
  176. package/dist/src/stores/dropdownStore.js +13 -0
  177. package/dist/src/stores/dropdownStore.js.map +1 -0
  178. package/dist/src/utils/address.d.ts +15 -0
  179. package/dist/src/utils/address.d.ts.map +1 -0
  180. package/dist/src/utils/address.js +37 -0
  181. package/dist/src/utils/address.js.map +1 -0
  182. package/dist/src/utils/address.test.d.ts +2 -0
  183. package/dist/src/utils/address.test.d.ts.map +1 -0
  184. package/dist/src/utils/address.test.js +40 -0
  185. package/dist/src/utils/address.test.js.map +1 -0
  186. package/dist/src/utils/cryptoAssets.d.ts +28 -0
  187. package/dist/src/utils/cryptoAssets.d.ts.map +1 -0
  188. package/dist/src/utils/cryptoAssets.js +73 -0
  189. package/dist/src/utils/cryptoAssets.js.map +1 -0
  190. package/dist/src/utils/cryptoAssets.test.d.ts +2 -0
  191. package/dist/src/utils/cryptoAssets.test.d.ts.map +1 -0
  192. package/dist/src/utils/cryptoAssets.test.js +50 -0
  193. package/dist/src/utils/cryptoAssets.test.js.map +1 -0
  194. package/dist/src/utils/currency.d.ts +14 -0
  195. package/dist/src/utils/currency.d.ts.map +1 -0
  196. package/dist/src/utils/currency.js +27 -0
  197. package/dist/src/utils/currency.js.map +1 -0
  198. package/dist/src/utils/currency.test.d.ts +2 -0
  199. package/dist/src/utils/currency.test.d.ts.map +1 -0
  200. package/dist/src/utils/currency.test.js +34 -0
  201. package/dist/src/utils/currency.test.js.map +1 -0
  202. package/dist/src/utils/numbers.d.ts +45 -0
  203. package/dist/src/utils/numbers.d.ts.map +1 -0
  204. package/dist/src/utils/numbers.js +86 -0
  205. package/dist/src/utils/numbers.js.map +1 -0
  206. package/dist/src/utils/numbers.test.d.ts +2 -0
  207. package/dist/src/utils/numbers.test.d.ts.map +1 -0
  208. package/dist/src/utils/numbers.test.js +170 -0
  209. package/dist/src/utils/numbers.test.js.map +1 -0
  210. package/package.json +10 -4
  211. package/src/api/auth.ts +104 -129
  212. package/src/api/client.ts +78 -0
  213. package/src/api/fetch-error.ts +8 -0
  214. package/src/api/index.ts +2 -0
  215. package/src/api/portal.ts +56 -0
  216. package/src/assets/DefaultAvatar.tsx +74 -0
  217. package/src/components/Dropdown/ConnectedTrigger.tsx +76 -0
  218. package/src/components/Dropdown/Content.tsx +62 -0
  219. package/src/components/Dropdown/DisconnectedTrigger.tsx +36 -0
  220. package/src/components/Dropdown/Dropdown.tsx +124 -0
  221. package/src/components/Dropdown/NestedViewLayout.tsx +75 -0
  222. package/src/components/Dropdown/README.md +55 -0
  223. package/src/components/Dropdown/Receive/Receive.tsx +119 -0
  224. package/src/components/Dropdown/Root/AccountAddressActions.tsx +101 -0
  225. package/src/components/Dropdown/Root/AccountAssets.tsx +108 -0
  226. package/src/components/Dropdown/Root/AccountBalance.tsx +35 -0
  227. package/src/components/Dropdown/Root/Root.tsx +141 -0
  228. package/src/components/Dropdown/Root/WalletAddress.tsx +128 -0
  229. package/src/components/Dropdown/Root/WelcomeBlock.tsx +91 -0
  230. package/src/components/Dropdown/index.ts +2 -0
  231. package/src/components/index.ts +1 -0
  232. package/src/hooks/constants.ts +4 -4
  233. package/src/hooks/index.ts +2 -4
  234. package/src/hooks/useAssetsUSDConversion.ts +31 -0
  235. package/src/hooks/useAuthenticateWithWallet.ts +98 -0
  236. package/src/hooks/useCreateAccount.ts +20 -11
  237. package/src/hooks/useCreateSession.ts +24 -18
  238. package/src/hooks/useDropdownData.ts +160 -0
  239. package/src/hooks/useEnsureNoSessionAndFetchNonce.ts +46 -0
  240. package/src/hooks/useGetAccountByAddress.ts +11 -5
  241. package/src/hooks/useGetAccountByMezoId.ts +11 -5
  242. package/src/hooks/useGetCurrentAccount.ts +53 -7
  243. package/src/hooks/useGetSession.ts +10 -3
  244. package/src/hooks/useLinkAccount.ts +19 -31
  245. package/src/hooks/usePortalApiClient.ts +6 -0
  246. package/src/hooks/useRefreshPassport.ts +40 -0
  247. package/src/hooks/useSignInWithDiscord.ts +19 -28
  248. package/src/hooks/useSignInWithWallet.ts +14 -55
  249. package/src/hooks/useSignOut.ts +22 -6
  250. package/src/hooks/useSignUpWithWallet.ts +21 -0
  251. package/src/hooks/useUpdateMezoId.ts +20 -12
  252. package/src/hooks/useWalletAccount.ts +53 -0
  253. package/src/index.ts +1 -0
  254. package/src/provider.ts +30 -37
  255. package/src/stores/dropdownStore.ts +20 -0
  256. package/src/utils/address.test.ts +48 -0
  257. package/src/utils/address.ts +45 -0
  258. package/src/utils/cryptoAssets.test.ts +61 -0
  259. package/src/utils/cryptoAssets.ts +93 -0
  260. package/src/utils/currency.test.ts +38 -0
  261. package/src/utils/currency.ts +32 -0
  262. package/src/utils/numbers.test.ts +220 -0
  263. package/src/utils/numbers.ts +120 -0
@@ -1,4 +1,6 @@
1
- export declare function useUpdateMezoId(useMutationOptions?: {}): {
1
+ import { MutationOptions, DefaultError } from "@tanstack/react-query";
2
+ import type { UpdateMezoIdResponse } from "../api";
3
+ export declare function useUpdateMezoId(mutationOptions?: Omit<MutationOptions<UpdateMezoIdResponse, DefaultError, string>, "mutationFn" | "mutationKey">): {
2
4
  data: undefined;
3
5
  variables: undefined;
4
6
  error: null;
@@ -14,26 +16,14 @@ export declare function useUpdateMezoId(useMutationOptions?: {}): {
14
16
  isPaused: boolean;
15
17
  submittedAt: number;
16
18
  updateMezoId: import("@tanstack/react-query").UseMutateFunction<{
17
- app_metadata: {
18
- provider: "wallet" | "discord" | "email";
19
- providers: ("wallet" | "discord" | "email")[];
20
- };
21
- user_metadata: {
22
- mezoId?: string | undefined;
23
- btcAddress: string;
24
- evmAddress: string;
25
- };
19
+ mezoId: string;
20
+ hasModifiedMezoId: boolean;
21
+ linkedAccounts: import("../api").LinkedAccount[];
26
22
  }, Error, string, unknown>;
27
23
  updateMezoIdAsync: import("@tanstack/react-query").UseMutateAsyncFunction<{
28
- app_metadata: {
29
- provider: "wallet" | "discord" | "email";
30
- providers: ("wallet" | "discord" | "email")[];
31
- };
32
- user_metadata: {
33
- mezoId?: string | undefined;
34
- btcAddress: string;
35
- evmAddress: string;
36
- };
24
+ mezoId: string;
25
+ hasModifiedMezoId: boolean;
26
+ linkedAccounts: import("../api").LinkedAccount[];
37
27
  }, Error, string, unknown>;
38
28
  } | {
39
29
  data: undefined;
@@ -51,26 +41,14 @@ export declare function useUpdateMezoId(useMutationOptions?: {}): {
51
41
  isPaused: boolean;
52
42
  submittedAt: number;
53
43
  updateMezoId: import("@tanstack/react-query").UseMutateFunction<{
54
- app_metadata: {
55
- provider: "wallet" | "discord" | "email";
56
- providers: ("wallet" | "discord" | "email")[];
57
- };
58
- user_metadata: {
59
- mezoId?: string | undefined;
60
- btcAddress: string;
61
- evmAddress: string;
62
- };
44
+ mezoId: string;
45
+ hasModifiedMezoId: boolean;
46
+ linkedAccounts: import("../api").LinkedAccount[];
63
47
  }, Error, string, unknown>;
64
48
  updateMezoIdAsync: import("@tanstack/react-query").UseMutateAsyncFunction<{
65
- app_metadata: {
66
- provider: "wallet" | "discord" | "email";
67
- providers: ("wallet" | "discord" | "email")[];
68
- };
69
- user_metadata: {
70
- mezoId?: string | undefined;
71
- btcAddress: string;
72
- evmAddress: string;
73
- };
49
+ mezoId: string;
50
+ hasModifiedMezoId: boolean;
51
+ linkedAccounts: import("../api").LinkedAccount[];
74
52
  }, Error, string, unknown>;
75
53
  } | {
76
54
  data: undefined;
@@ -88,38 +66,20 @@ export declare function useUpdateMezoId(useMutationOptions?: {}): {
88
66
  isPaused: boolean;
89
67
  submittedAt: number;
90
68
  updateMezoId: import("@tanstack/react-query").UseMutateFunction<{
91
- app_metadata: {
92
- provider: "wallet" | "discord" | "email";
93
- providers: ("wallet" | "discord" | "email")[];
94
- };
95
- user_metadata: {
96
- mezoId?: string | undefined;
97
- btcAddress: string;
98
- evmAddress: string;
99
- };
69
+ mezoId: string;
70
+ hasModifiedMezoId: boolean;
71
+ linkedAccounts: import("../api").LinkedAccount[];
100
72
  }, Error, string, unknown>;
101
73
  updateMezoIdAsync: import("@tanstack/react-query").UseMutateAsyncFunction<{
102
- app_metadata: {
103
- provider: "wallet" | "discord" | "email";
104
- providers: ("wallet" | "discord" | "email")[];
105
- };
106
- user_metadata: {
107
- mezoId?: string | undefined;
108
- btcAddress: string;
109
- evmAddress: string;
110
- };
74
+ mezoId: string;
75
+ hasModifiedMezoId: boolean;
76
+ linkedAccounts: import("../api").LinkedAccount[];
111
77
  }, Error, string, unknown>;
112
78
  } | {
113
79
  data: {
114
- app_metadata: {
115
- provider: "wallet" | "discord" | "email";
116
- providers: ("wallet" | "discord" | "email")[];
117
- };
118
- user_metadata: {
119
- mezoId?: string | undefined;
120
- btcAddress: string;
121
- evmAddress: string;
122
- };
80
+ mezoId: string;
81
+ hasModifiedMezoId: boolean;
82
+ linkedAccounts: import("../api").LinkedAccount[];
123
83
  };
124
84
  error: null;
125
85
  variables: string;
@@ -135,26 +95,14 @@ export declare function useUpdateMezoId(useMutationOptions?: {}): {
135
95
  isPaused: boolean;
136
96
  submittedAt: number;
137
97
  updateMezoId: import("@tanstack/react-query").UseMutateFunction<{
138
- app_metadata: {
139
- provider: "wallet" | "discord" | "email";
140
- providers: ("wallet" | "discord" | "email")[];
141
- };
142
- user_metadata: {
143
- mezoId?: string | undefined;
144
- btcAddress: string;
145
- evmAddress: string;
146
- };
98
+ mezoId: string;
99
+ hasModifiedMezoId: boolean;
100
+ linkedAccounts: import("../api").LinkedAccount[];
147
101
  }, Error, string, unknown>;
148
102
  updateMezoIdAsync: import("@tanstack/react-query").UseMutateAsyncFunction<{
149
- app_metadata: {
150
- provider: "wallet" | "discord" | "email";
151
- providers: ("wallet" | "discord" | "email")[];
152
- };
153
- user_metadata: {
154
- mezoId?: string | undefined;
155
- btcAddress: string;
156
- evmAddress: string;
157
- };
103
+ mezoId: string;
104
+ hasModifiedMezoId: boolean;
105
+ linkedAccounts: import("../api").LinkedAccount[];
158
106
  }, Error, string, unknown>;
159
107
  };
160
108
  //# sourceMappingURL=useUpdateMezoId.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"useUpdateMezoId.d.ts","sourceRoot":"","sources":["../../../src/hooks/useUpdateMezoId.ts"],"names":[],"mappings":"AAIA,wBAAgB,eAAe,CAAC,kBAAkB,KAAK;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAoBtD"}
1
+ {"version":3,"file":"useUpdateMezoId.d.ts","sourceRoot":"","sources":["../../../src/hooks/useUpdateMezoId.ts"],"names":[],"mappings":"AAAA,OAAO,EAGL,eAAe,EACf,YAAY,EACb,MAAM,uBAAuB,CAAA;AAG9B,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,QAAQ,CAAA;AAElD,wBAAgB,eAAe,CAC7B,eAAe,GAAE,IAAI,CACnB,eAAe,CAAC,oBAAoB,EAAE,YAAY,EAAE,MAAM,CAAC,EAC3D,YAAY,GAAG,aAAa,CACxB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAkBP"}
@@ -1,22 +1,18 @@
1
- import { useQueryClient, useMutation } from "@tanstack/react-query";
1
+ import { useQueryClient, useMutation, } from "@tanstack/react-query";
2
2
  import { useAuthApiClient } from "./useAuthApiClient";
3
3
  import { QUERY_KEYS } from "./constants";
4
- export function useUpdateMezoId(useMutationOptions = {}) {
4
+ export function useUpdateMezoId(mutationOptions = {}) {
5
5
  const queryClient = useQueryClient();
6
6
  const authApiClient = useAuthApiClient();
7
+ const { onSuccess: customOnSuccess, ...restMutationOptions } = mutationOptions;
7
8
  const { mutate, mutateAsync, ...rest } = useMutation({
8
9
  mutationFn: (newMezoId) => authApiClient.updateMezoId(newMezoId),
9
- onSuccess: () => {
10
- queryClient.resetQueries({
11
- queryKey: [QUERY_KEYS.ACCOUNT_BY_ADDRESS],
12
- exact: false,
13
- });
14
- queryClient.resetQueries({
15
- queryKey: [QUERY_KEYS.ACCOUNT_BY_MEZO_ID],
16
- exact: false,
17
- });
10
+ onSuccess: (data, variables, context) => {
11
+ queryClient.resetQueries({ queryKey: [QUERY_KEYS.ACCOUNT] });
12
+ if (customOnSuccess)
13
+ customOnSuccess(data, variables, context);
18
14
  },
19
- ...useMutationOptions,
15
+ ...restMutationOptions,
20
16
  });
21
17
  return { updateMezoId: mutate, updateMezoIdAsync: mutateAsync, ...rest };
22
18
  }
@@ -1 +1 @@
1
- {"version":3,"file":"useUpdateMezoId.js","sourceRoot":"","sources":["../../../src/hooks/useUpdateMezoId.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAA;AACnE,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAA;AACrD,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAA;AAExC,MAAM,UAAU,eAAe,CAAC,kBAAkB,GAAG,EAAE;IACrD,MAAM,WAAW,GAAG,cAAc,EAAE,CAAA;IACpC,MAAM,aAAa,GAAG,gBAAgB,EAAE,CAAA;IAExC,MAAM,EAAE,MAAM,EAAE,WAAW,EAAE,GAAG,IAAI,EAAE,GAAG,WAAW,CAAC;QACnD,UAAU,EAAE,CAAC,SAAiB,EAAE,EAAE,CAAC,aAAa,CAAC,YAAY,CAAC,SAAS,CAAC;QACxE,SAAS,EAAE,GAAG,EAAE;YACd,WAAW,CAAC,YAAY,CAAC;gBACvB,QAAQ,EAAE,CAAC,UAAU,CAAC,kBAAkB,CAAC;gBACzC,KAAK,EAAE,KAAK;aACb,CAAC,CAAA;YACF,WAAW,CAAC,YAAY,CAAC;gBACvB,QAAQ,EAAE,CAAC,UAAU,CAAC,kBAAkB,CAAC;gBACzC,KAAK,EAAE,KAAK;aACb,CAAC,CAAA;QACJ,CAAC;QACD,GAAG,kBAAkB;KACtB,CAAC,CAAA;IAEF,OAAO,EAAE,YAAY,EAAE,MAAM,EAAE,iBAAiB,EAAE,WAAW,EAAE,GAAG,IAAI,EAAE,CAAA;AAC1E,CAAC"}
1
+ {"version":3,"file":"useUpdateMezoId.js","sourceRoot":"","sources":["../../../src/hooks/useUpdateMezoId.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,cAAc,EACd,WAAW,GAGZ,MAAM,uBAAuB,CAAA;AAC9B,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAA;AACrD,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAA;AAGxC,MAAM,UAAU,eAAe,CAC7B,kBAGI,EAAE;IAEN,MAAM,WAAW,GAAG,cAAc,EAAE,CAAA;IACpC,MAAM,aAAa,GAAG,gBAAgB,EAAE,CAAA;IAExC,MAAM,EAAE,SAAS,EAAE,eAAe,EAAE,GAAG,mBAAmB,EAAE,GAAG,eAAe,CAAA;IAE9E,MAAM,EAAE,MAAM,EAAE,WAAW,EAAE,GAAG,IAAI,EAAE,GAAG,WAAW,CAAC;QACnD,UAAU,EAAE,CAAC,SAAiB,EAAE,EAAE,CAAC,aAAa,CAAC,YAAY,CAAC,SAAS,CAAC;QACxE,SAAS,EAAE,CAAC,IAAI,EAAE,SAAS,EAAE,OAAO,EAAE,EAAE;YACtC,WAAW,CAAC,YAAY,CAAC,EAAE,QAAQ,EAAE,CAAC,UAAU,CAAC,OAAO,CAAC,EAAE,CAAC,CAAA;YAE5D,IAAI,eAAe;gBAAE,eAAe,CAAC,IAAI,EAAE,SAAS,EAAE,OAAO,CAAC,CAAA;QAChE,CAAC;QACD,GAAG,mBAAmB;KACvB,CAAC,CAAA;IAEF,OAAO,EAAE,YAAY,EAAE,MAAM,EAAE,iBAAiB,EAAE,WAAW,EAAE,GAAG,IAAI,EAAE,CAAA;AAC1E,CAAC"}
@@ -0,0 +1,12 @@
1
+ import { Address } from "viem";
2
+ import { Connector } from "wagmi";
3
+ type UseWalletAccountReturn = {
4
+ address?: string | Address;
5
+ isConnected: boolean;
6
+ networkFamily: "bitcoin" | "evm";
7
+ connector?: Connector;
8
+ chainId?: number;
9
+ };
10
+ export default function useWalletAccount(): UseWalletAccountReturn;
11
+ export {};
12
+ //# sourceMappingURL=useWalletAccount.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useWalletAccount.d.ts","sourceRoot":"","sources":["../../../src/hooks/useWalletAccount.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAA;AAC9B,OAAO,EAAE,SAAS,EAAc,MAAM,OAAO,CAAA;AAE7C,KAAK,sBAAsB,GAAG;IAC5B,OAAO,CAAC,EAAE,MAAM,GAAG,OAAO,CAAA;IAC1B,WAAW,EAAE,OAAO,CAAA;IACpB,aAAa,EAAE,SAAS,GAAG,KAAK,CAAA;IAChC,SAAS,CAAC,EAAE,SAAS,CAAA;IACrB,OAAO,CAAC,EAAE,MAAM,CAAA;CACjB,CAAA;AAMD,MAAM,CAAC,OAAO,UAAU,gBAAgB,IAAI,sBAAsB,CAkCjE"}
@@ -0,0 +1,28 @@
1
+ import { useQuery } from "@tanstack/react-query";
2
+ import { useMemo } from "react";
3
+ import { useAccount } from "wagmi";
4
+ export default function useWalletAccount() {
5
+ const { address: evmAddress, connector, chainId } = useAccount();
6
+ const networkFamily = useMemo(() => (connector?.type !== "orangekit" ? "evm" : "bitcoin"), [connector]);
7
+ const { data: btcData } = useQuery({
8
+ queryKey: [connector?.id],
9
+ queryFn: async () => {
10
+ const bitcoinProvider = connector.getBitcoinProvider();
11
+ const address = await bitcoinProvider.getAddress();
12
+ const balance = await bitcoinProvider.getBalance();
13
+ return {
14
+ address,
15
+ balance,
16
+ };
17
+ },
18
+ });
19
+ const { address: btcAddress } = btcData || {};
20
+ return {
21
+ address: networkFamily === "bitcoin" ? btcAddress : evmAddress,
22
+ isConnected: networkFamily === "bitcoin" ? !!btcAddress : !!evmAddress,
23
+ networkFamily,
24
+ connector,
25
+ chainId,
26
+ };
27
+ }
28
+ //# sourceMappingURL=useWalletAccount.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useWalletAccount.js","sourceRoot":"","sources":["../../../src/hooks/useWalletAccount.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,QAAQ,EAAE,MAAM,uBAAuB,CAAA;AAChD,OAAO,EAAE,OAAO,EAAE,MAAM,OAAO,CAAA;AAE/B,OAAO,EAAa,UAAU,EAAE,MAAM,OAAO,CAAA;AAc7C,MAAM,CAAC,OAAO,UAAU,gBAAgB;IACtC,MAAM,EAAE,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,OAAO,EAAE,GAAG,UAAU,EAAE,CAAA;IAEhE,MAAM,aAAa,GAAG,OAAO,CAC3B,GAAG,EAAE,CAAC,CAAC,SAAS,EAAE,IAAI,KAAK,WAAW,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,SAAS,CAAC,EAC3D,CAAC,SAAS,CAAC,CACZ,CAAA;IAED,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,GAAG,QAAQ,CAAC;QACjC,QAAQ,EAAE,CAAC,SAAS,EAAE,EAAE,CAAC;QACzB,OAAO,EAAE,KAAK,IAAI,EAAE;YAClB,MAAM,eAAe,GACnB,SACD,CAAC,kBAAkB,EAAE,CAAA;YAEtB,MAAM,OAAO,GAAG,MAAM,eAAe,CAAC,UAAU,EAAE,CAAA;YAClD,MAAM,OAAO,GAAG,MAAM,eAAe,CAAC,UAAU,EAAE,CAAA;YAElD,OAAO;gBACL,OAAO;gBACP,OAAO;aACR,CAAA;QACH,CAAC;KACF,CAAC,CAAA;IAEF,MAAM,EAAE,OAAO,EAAE,UAAU,EAAE,GAAG,OAAO,IAAI,EAAE,CAAA;IAE7C,OAAO;QACL,OAAO,EAAE,aAAa,KAAK,SAAS,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,UAAU;QAC9D,WAAW,EAAE,aAAa,KAAK,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,UAAU;QACtE,aAAa;QACb,SAAS;QACT,OAAO;KACC,CAAA;AACZ,CAAC"}
@@ -1,3 +1,4 @@
1
+ export * from "./components";
1
2
  export * from "./config";
2
3
  export * from "./constants";
3
4
  export * from "./hooks";
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,UAAU,CAAA;AACxB,cAAc,aAAa,CAAA;AAC3B,cAAc,SAAS,CAAA;AACvB,cAAc,YAAY,CAAA;AAC1B,cAAc,UAAU,CAAA"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,cAAc,CAAA;AAC5B,cAAc,UAAU,CAAA;AACxB,cAAc,aAAa,CAAA;AAC3B,cAAc,SAAS,CAAA;AACvB,cAAc,YAAY,CAAA;AAC1B,cAAc,UAAU,CAAA"}
package/dist/src/index.js CHANGED
@@ -1,3 +1,4 @@
1
+ export * from "./components";
1
2
  export * from "./config";
2
3
  export * from "./constants";
3
4
  export * from "./hooks";
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,UAAU,CAAA;AACxB,cAAc,aAAa,CAAA;AAC3B,cAAc,SAAS,CAAA;AACvB,cAAc,YAAY,CAAA;AAC1B,cAAc,UAAU,CAAA"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,cAAc,CAAA;AAC5B,cAAc,UAAU,CAAA;AACxB,cAAc,aAAa,CAAA;AAC3B,cAAc,SAAS,CAAA;AACvB,cAAc,YAAY,CAAA;AAC1B,cAAc,UAAU,CAAA"}
@@ -1,20 +1,17 @@
1
- /// <reference types="react" />
2
- import { API_ENDPOINTS_BY_ENV, AuthApiClient } from "./api/auth";
1
+ import { AuthApiClient, PortalApiClient } from "./api";
3
2
  export interface PassportContextValue {
4
3
  authApiClient: AuthApiClient;
4
+ portalApiClient: PortalApiClient;
5
+ environment?: Environment;
5
6
  }
6
7
  export declare const PassportContext: import("react").Context<PassportContextValue | undefined>;
7
- interface PassportProviderProps {
8
- options: {
9
- environment?: keyof typeof API_ENDPOINTS_BY_ENV;
10
- apiUrl?: string;
11
- } & ({
12
- environment: keyof typeof API_ENDPOINTS_BY_ENV;
13
- } | {
14
- apiUrl: string;
15
- });
8
+ type Environment = "mainnet" | "testnet";
9
+ type PassportProviderProps = {
16
10
  children: React.ReactNode;
17
- }
18
- export declare function PassportProvider({ options, children }: PassportProviderProps): import("react").FunctionComponentElement<import("react").ProviderProps<PassportContextValue | undefined>>;
11
+ environment?: Environment;
12
+ authApiUrl?: string;
13
+ portalApiUrl?: string;
14
+ };
15
+ export declare function PassportProvider({ environment, authApiUrl, portalApiUrl, children, }: PassportProviderProps): import("react").FunctionComponentElement<import("react").ProviderProps<PassportContextValue | undefined>>;
19
16
  export {};
20
17
  //# sourceMappingURL=provider.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"provider.d.ts","sourceRoot":"","sources":["../../src/provider.ts"],"names":[],"mappings":";AACA,OAAO,EAAE,oBAAoB,EAAE,aAAa,EAAE,MAAM,YAAY,CAAA;AAEhE,MAAM,WAAW,oBAAoB;IACnC,aAAa,EAAE,aAAa,CAAA;CAC7B;AAED,eAAO,MAAM,eAAe,2DAE3B,CAAA;AAED,UAAU,qBAAqB;IAE7B,OAAO,EAAE;QACP,WAAW,CAAC,EAAE,MAAM,OAAO,oBAAoB,CAAA;QAC/C,MAAM,CAAC,EAAE,MAAM,CAAA;KAChB,GAAG,CACA;QACE,WAAW,EAAE,MAAM,OAAO,oBAAoB,CAAA;KAC/C,GACD;QACE,MAAM,EAAE,MAAM,CAAA;KACf,CACJ,CAAA;IACD,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAA;CAC1B;AAED,wBAAgB,gBAAgB,CAAC,EAAE,OAAO,EAAE,QAAQ,EAAE,EAAE,qBAAqB,6GA6B5E"}
1
+ {"version":3,"file":"provider.d.ts","sourceRoot":"","sources":["../../src/provider.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,eAAe,EAAE,MAAM,OAAO,CAAA;AAEtD,MAAM,WAAW,oBAAoB;IACnC,aAAa,EAAE,aAAa,CAAA;IAC5B,eAAe,EAAE,eAAe,CAAA;IAChC,WAAW,CAAC,EAAE,WAAW,CAAA;CAC1B;AAED,eAAO,MAAM,eAAe,2DAE3B,CAAA;AAED,KAAK,WAAW,GAAG,SAAS,GAAG,SAAS,CAAA;AAExC,KAAK,qBAAqB,GAAG;IAC3B,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAA;IAEzB,WAAW,CAAC,EAAE,WAAW,CAAA;IAEzB,UAAU,CAAC,EAAE,MAAM,CAAA;IAEnB,YAAY,CAAC,EAAE,MAAM,CAAA;CACtB,CAAA;AAED,wBAAgB,gBAAgB,CAAC,EAC/B,WAAW,EACX,UAAU,EACV,YAAY,EACZ,QAAQ,GACT,EAAE,qBAAqB,6GAmBvB"}
@@ -1,25 +1,16 @@
1
- import { createContext, createElement, useMemo } from "react";
2
- import { API_ENDPOINTS_BY_ENV, AuthApiClient } from "./api/auth";
1
+ import { createContext, createElement } from "react";
2
+ import { AuthApiClient, PortalApiClient } from "./api";
3
3
  export const PassportContext = createContext(undefined);
4
- export function PassportProvider({ options, children }) {
5
- const { environment, apiUrl } = options;
6
- const finalApiUrl = useMemo(() => {
7
- if (!environment && !apiUrl) {
8
- throw new Error("Neither apiUrl or environment are specified in Passport Provider");
9
- }
10
- if (apiUrl)
11
- return apiUrl;
12
- if (!(environment in API_ENDPOINTS_BY_ENV)) {
13
- throw new Error("Wrong environment passed to PassportProvider.");
14
- }
15
- return API_ENDPOINTS_BY_ENV[environment];
16
- }, [environment, apiUrl]);
4
+ export function PassportProvider({ environment, authApiUrl, portalApiUrl, children, }) {
5
+ if (environment && !["mainnet", "testnet"].includes(environment)) {
6
+ throw new Error("Wrong environment passed to PassportProvider.");
7
+ }
17
8
  return createElement(PassportContext.Provider, {
18
- value: finalApiUrl
19
- ? {
20
- authApiClient: new AuthApiClient(finalApiUrl),
21
- }
22
- : undefined,
9
+ value: {
10
+ authApiClient: new AuthApiClient(environment ?? "mainnet", authApiUrl),
11
+ portalApiClient: new PortalApiClient(environment ?? "mainnet", portalApiUrl),
12
+ environment,
13
+ },
23
14
  }, children);
24
15
  }
25
16
  //# sourceMappingURL=provider.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"provider.js","sourceRoot":"","sources":["../../src/provider.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,aAAa,EAAE,OAAO,EAAE,MAAM,OAAO,CAAA;AAC7D,OAAO,EAAE,oBAAoB,EAAE,aAAa,EAAE,MAAM,YAAY,CAAA;AAMhE,MAAM,CAAC,MAAM,eAAe,GAAG,aAAa,CAC1C,SAAS,CACV,CAAA;AAkBD,MAAM,UAAU,gBAAgB,CAAC,EAAE,OAAO,EAAE,QAAQ,EAAyB;IAC3E,MAAM,EAAE,WAAW,EAAE,MAAM,EAAE,GAAG,OAAO,CAAA;IAEvC,MAAM,WAAW,GAAG,OAAO,CAAC,GAAG,EAAE;QAC/B,IAAI,CAAC,WAAW,IAAI,CAAC,MAAM,EAAE,CAAC;YAC5B,MAAM,IAAI,KAAK,CACb,kEAAkE,CACnE,CAAA;QACH,CAAC;QACD,IAAI,MAAM;YAAE,OAAO,MAAM,CAAA;QAEzB,IAAI,CAAC,CAAC,WAAY,IAAI,oBAAoB,CAAC,EAAE,CAAC;YAC5C,MAAM,IAAI,KAAK,CAAC,+CAA+C,CAAC,CAAA;QAClE,CAAC;QAED,OAAO,oBAAoB,CAAC,WAAY,CAAC,CAAA;IAC3C,CAAC,EAAE,CAAC,WAAW,EAAE,MAAM,CAAC,CAAC,CAAA;IAEzB,OAAO,aAAa,CAClB,eAAe,CAAC,QAAQ,EACxB;QACE,KAAK,EAAE,WAAW;YAChB,CAAC,CAAC;gBACE,aAAa,EAAE,IAAI,aAAa,CAAC,WAAW,CAAC;aAC9C;YACH,CAAC,CAAC,SAAS;KACd,EACD,QAAQ,CACT,CAAA;AACH,CAAC"}
1
+ {"version":3,"file":"provider.js","sourceRoot":"","sources":["../../src/provider.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,OAAO,CAAA;AACpD,OAAO,EAAE,aAAa,EAAE,eAAe,EAAE,MAAM,OAAO,CAAA;AAQtD,MAAM,CAAC,MAAM,eAAe,GAAG,aAAa,CAC1C,SAAS,CACV,CAAA;AAcD,MAAM,UAAU,gBAAgB,CAAC,EAC/B,WAAW,EACX,UAAU,EACV,YAAY,EACZ,QAAQ,GACc;IACtB,IAAI,WAAW,IAAI,CAAC,CAAC,SAAS,EAAE,SAAS,CAAC,CAAC,QAAQ,CAAC,WAAW,CAAC,EAAE,CAAC;QACjE,MAAM,IAAI,KAAK,CAAC,+CAA+C,CAAC,CAAA;IAClE,CAAC;IAED,OAAO,aAAa,CAClB,eAAe,CAAC,QAAQ,EACxB;QACE,KAAK,EAAE;YACL,aAAa,EAAE,IAAI,aAAa,CAAC,WAAW,IAAI,SAAS,EAAE,UAAU,CAAC;YACtE,eAAe,EAAE,IAAI,eAAe,CAClC,WAAW,IAAI,SAAS,EACxB,YAAY,CACb;YACD,WAAW;SACZ;KACF,EACD,QAAQ,CACT,CAAA;AACH,CAAC"}
@@ -0,0 +1,12 @@
1
+ export declare enum DropdownView {
2
+ ROOT = "ROOT",
3
+ RECEIVE = "RECEIVE"
4
+ }
5
+ interface DropdownStore {
6
+ view: DropdownView;
7
+ setView: (view: DropdownView) => void;
8
+ isNestedView: () => boolean;
9
+ }
10
+ declare const useDropdownStore: import("zustand").UseBoundStore<import("zustand").StoreApi<DropdownStore>>;
11
+ export default useDropdownStore;
12
+ //# sourceMappingURL=dropdownStore.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dropdownStore.d.ts","sourceRoot":"","sources":["../../../src/stores/dropdownStore.ts"],"names":[],"mappings":"AAEA,oBAAY,YAAY;IACtB,IAAI,SAAS;IACb,OAAO,YAAY;CACpB;AAED,UAAU,aAAa;IACrB,IAAI,EAAE,YAAY,CAAA;IAClB,OAAO,EAAE,CAAC,IAAI,EAAE,YAAY,KAAK,IAAI,CAAA;IACrC,YAAY,EAAE,MAAM,OAAO,CAAA;CAC5B;AAED,QAAA,MAAM,gBAAgB,4EAInB,CAAA;AAEH,eAAe,gBAAgB,CAAA"}
@@ -0,0 +1,13 @@
1
+ import { create } from "zustand";
2
+ export var DropdownView;
3
+ (function (DropdownView) {
4
+ DropdownView["ROOT"] = "ROOT";
5
+ DropdownView["RECEIVE"] = "RECEIVE";
6
+ })(DropdownView || (DropdownView = {}));
7
+ const useDropdownStore = create((set, get) => ({
8
+ view: DropdownView.ROOT,
9
+ setView: (view) => set({ view }),
10
+ isNestedView: () => get().view !== DropdownView.ROOT,
11
+ }));
12
+ export default useDropdownStore;
13
+ //# sourceMappingURL=dropdownStore.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dropdownStore.js","sourceRoot":"","sources":["../../../src/stores/dropdownStore.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,SAAS,CAAA;AAEhC,MAAM,CAAN,IAAY,YAGX;AAHD,WAAY,YAAY;IACtB,6BAAa,CAAA;IACb,mCAAmB,CAAA;AACrB,CAAC,EAHW,YAAY,KAAZ,YAAY,QAGvB;AAQD,MAAM,gBAAgB,GAAG,MAAM,CAAgB,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE,CAAC,CAAC;IAC5D,IAAI,EAAE,YAAY,CAAC,IAAI;IACvB,OAAO,EAAE,CAAC,IAAkB,EAAE,EAAE,CAAC,GAAG,CAAC,EAAE,IAAI,EAAE,CAAC;IAC9C,YAAY,EAAE,GAAG,EAAE,CAAC,GAAG,EAAE,CAAC,IAAI,KAAK,YAAY,CAAC,IAAI;CACrD,CAAC,CAAC,CAAA;AAEH,eAAe,gBAAgB,CAAA"}
@@ -0,0 +1,15 @@
1
+ /**
2
+ * Trims the address to the first 5 and last 5 characters.
3
+ * @param address The address to trim.
4
+ * @returns The trimmed address.
5
+ */
6
+ export declare function trimAddress(address: string): string;
7
+ /**
8
+ * Get the URL of the block explorer page for an address.
9
+ * @param address - The address to link to.
10
+ * @param chainType - The chain type of the address.
11
+ * @param isTestnet - Whether the address is on testnet.
12
+ * @returns The URL of the block explorer page for the address.
13
+ */
14
+ export declare function getAddressExplorerUrl(address: string, chainType: "bitcoin" | "evm" | "mezo", isTestnet: boolean): string;
15
+ //# sourceMappingURL=address.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"address.d.ts","sourceRoot":"","sources":["../../../src/utils/address.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AACH,wBAAgB,WAAW,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM,CAMnD;AAcD;;;;;;GAMG;AACH,wBAAgB,qBAAqB,CACnC,OAAO,EAAE,MAAM,EACf,SAAS,EAAE,SAAS,GAAG,KAAK,GAAG,MAAM,EACrC,SAAS,EAAE,OAAO,UASnB"}
@@ -0,0 +1,37 @@
1
+ /**
2
+ * Trims the address to the first 5 and last 5 characters.
3
+ * @param address The address to trim.
4
+ * @returns The trimmed address.
5
+ */
6
+ export function trimAddress(address) {
7
+ if (address.length < 11)
8
+ return address;
9
+ const trimmedAddress = `${address.slice(0, 5)}...${address.slice(-5)}`;
10
+ return trimmedAddress;
11
+ }
12
+ const MAINNET_EXPLORER_URLS = {
13
+ bitcoin: "https://mempool.space",
14
+ evm: "https://etherscan.io",
15
+ mezo: "https://explorer.mezo.org",
16
+ };
17
+ const TESTNET_EXPLORER_URLS = {
18
+ bitcoin: "https://mempool.space/testnet",
19
+ evm: "https://sepolia.etherscan.io",
20
+ mezo: "https://explorer.test.mezo.org",
21
+ };
22
+ /**
23
+ * Get the URL of the block explorer page for an address.
24
+ * @param address - The address to link to.
25
+ * @param chainType - The chain type of the address.
26
+ * @param isTestnet - Whether the address is on testnet.
27
+ * @returns The URL of the block explorer page for the address.
28
+ */
29
+ export function getAddressExplorerUrl(address, chainType, isTestnet) {
30
+ const EXPLORER_URLS = isTestnet
31
+ ? TESTNET_EXPLORER_URLS
32
+ : MAINNET_EXPLORER_URLS;
33
+ const baseUrl = EXPLORER_URLS[chainType];
34
+ const endpoint = `address/${address}`;
35
+ return `${baseUrl}/${endpoint}`;
36
+ }
37
+ //# sourceMappingURL=address.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"address.js","sourceRoot":"","sources":["../../../src/utils/address.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AACH,MAAM,UAAU,WAAW,CAAC,OAAe;IACzC,IAAI,OAAO,CAAC,MAAM,GAAG,EAAE;QAAE,OAAO,OAAO,CAAA;IAEvC,MAAM,cAAc,GAAG,GAAG,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,MAAM,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAAA;IAEtE,OAAO,cAAc,CAAA;AACvB,CAAC;AAED,MAAM,qBAAqB,GAA+C;IACxE,OAAO,EAAE,uBAAuB;IAChC,GAAG,EAAE,sBAAsB;IAC3B,IAAI,EAAE,2BAA2B;CAClC,CAAA;AAED,MAAM,qBAAqB,GAA+C;IACxE,OAAO,EAAE,+BAA+B;IACxC,GAAG,EAAE,8BAA8B;IACnC,IAAI,EAAE,gCAAgC;CACvC,CAAA;AAED;;;;;;GAMG;AACH,MAAM,UAAU,qBAAqB,CACnC,OAAe,EACf,SAAqC,EACrC,SAAkB;IAElB,MAAM,aAAa,GAAG,SAAS;QAC7B,CAAC,CAAC,qBAAqB;QACvB,CAAC,CAAC,qBAAqB,CAAA;IACzB,MAAM,OAAO,GAAG,aAAa,CAAC,SAAS,CAAC,CAAA;IACxC,MAAM,QAAQ,GAAG,WAAW,OAAO,EAAE,CAAA;IAErC,OAAO,GAAG,OAAO,IAAI,QAAQ,EAAE,CAAA;AACjC,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=address.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"address.test.d.ts","sourceRoot":"","sources":["../../../src/utils/address.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,40 @@
1
+ import { getAddressExplorerUrl, trimAddress } from "./address";
2
+ describe("trimAddress", () => {
3
+ it("returns full address if length is less than 11", () => {
4
+ expect(trimAddress("0x12345")).toBe("0x12345");
5
+ });
6
+ it("returns trimmed address if length is 11 or more", () => {
7
+ const input = "0x123456789abcdef";
8
+ const expected = "0x123...bcdef";
9
+ expect(trimAddress(input)).toBe(expected);
10
+ });
11
+ });
12
+ describe("getAddressExplorerUrl", () => {
13
+ const btcAddress = "bc1qxyz123";
14
+ const evmAddress = "0x1234567890abcdef";
15
+ it("returns correct mainnet Bitcoin explorer URL", () => {
16
+ const url = getAddressExplorerUrl(btcAddress, "bitcoin", false);
17
+ expect(url).toBe(`https://mempool.space/address/${btcAddress}`);
18
+ });
19
+ it("returns correct testnet Bitcoin explorer URL", () => {
20
+ const url = getAddressExplorerUrl(btcAddress, "bitcoin", true);
21
+ expect(url).toBe(`https://mempool.space/testnet/address/${btcAddress}`);
22
+ });
23
+ it("returns correct mainnet EVM explorer URL", () => {
24
+ const url = getAddressExplorerUrl(evmAddress, "evm", false);
25
+ expect(url).toBe(`https://etherscan.io/address/${evmAddress}`);
26
+ });
27
+ it("returns correct testnet EVM explorer URL", () => {
28
+ const url = getAddressExplorerUrl(evmAddress, "evm", true);
29
+ expect(url).toBe(`https://sepolia.etherscan.io/address/${evmAddress}`);
30
+ });
31
+ it("returns correct mainnet Mezo explorer URL", () => {
32
+ const url = getAddressExplorerUrl(evmAddress, "mezo", false);
33
+ expect(url).toBe(`https://explorer.mezo.org/address/${evmAddress}`);
34
+ });
35
+ it("returns correct testnet Mezo explorer URL", () => {
36
+ const url = getAddressExplorerUrl(evmAddress, "mezo", true);
37
+ expect(url).toBe(`https://explorer.test.mezo.org/address/${evmAddress}`);
38
+ });
39
+ });
40
+ //# sourceMappingURL=address.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"address.test.js","sourceRoot":"","sources":["../../../src/utils/address.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAE,WAAW,EAAE,MAAM,WAAW,CAAA;AAE9D,QAAQ,CAAC,aAAa,EAAE,GAAG,EAAE;IAC3B,EAAE,CAAC,gDAAgD,EAAE,GAAG,EAAE;QACxD,MAAM,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAA;IAChD,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,iDAAiD,EAAE,GAAG,EAAE;QACzD,MAAM,KAAK,GAAG,mBAAmB,CAAA;QACjC,MAAM,QAAQ,GAAG,eAAe,CAAA;QAChC,MAAM,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAA;IAC3C,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA;AAEF,QAAQ,CAAC,uBAAuB,EAAE,GAAG,EAAE;IACrC,MAAM,UAAU,GAAG,YAAY,CAAA;IAC/B,MAAM,UAAU,GAAG,oBAAoB,CAAA;IAEvC,EAAE,CAAC,8CAA8C,EAAE,GAAG,EAAE;QACtD,MAAM,GAAG,GAAG,qBAAqB,CAAC,UAAU,EAAE,SAAS,EAAE,KAAK,CAAC,CAAA;QAC/D,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,iCAAiC,UAAU,EAAE,CAAC,CAAA;IACjE,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,8CAA8C,EAAE,GAAG,EAAE;QACtD,MAAM,GAAG,GAAG,qBAAqB,CAAC,UAAU,EAAE,SAAS,EAAE,IAAI,CAAC,CAAA;QAC9D,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,yCAAyC,UAAU,EAAE,CAAC,CAAA;IACzE,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,0CAA0C,EAAE,GAAG,EAAE;QAClD,MAAM,GAAG,GAAG,qBAAqB,CAAC,UAAU,EAAE,KAAK,EAAE,KAAK,CAAC,CAAA;QAC3D,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,gCAAgC,UAAU,EAAE,CAAC,CAAA;IAChE,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,0CAA0C,EAAE,GAAG,EAAE;QAClD,MAAM,GAAG,GAAG,qBAAqB,CAAC,UAAU,EAAE,KAAK,EAAE,IAAI,CAAC,CAAA;QAC1D,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,wCAAwC,UAAU,EAAE,CAAC,CAAA;IACxE,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,2CAA2C,EAAE,GAAG,EAAE;QACnD,MAAM,GAAG,GAAG,qBAAqB,CAAC,UAAU,EAAE,MAAM,EAAE,KAAK,CAAC,CAAA;QAC5D,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,qCAAqC,UAAU,EAAE,CAAC,CAAA;IACrE,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,2CAA2C,EAAE,GAAG,EAAE;QACnD,MAAM,GAAG,GAAG,qBAAqB,CAAC,UAAU,EAAE,MAAM,EAAE,IAAI,CAAC,CAAA;QAC3D,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,0CAA0C,UAAU,EAAE,CAAC,CAAA;IAC1E,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA"}
@@ -0,0 +1,28 @@
1
+ import { IconProps } from "@mezo-org/mezo-clay";
2
+ import { FC } from "react";
3
+ export type CryptoAssetKey = "btc" | "eth" | "tbtc" | "wbtc" | "mbtc" | "musd";
4
+ export type CryptoAsset = {
5
+ name: string;
6
+ symbol: string;
7
+ icon: FC<IconProps>;
8
+ decimals: number;
9
+ };
10
+ /**
11
+ * Gets details of given crypto asset
12
+ * @param key The key of crypto asset
13
+ * @returns The crypto asset details
14
+ */
15
+ export declare function getCryptoAsset(key: CryptoAssetKey): CryptoAsset;
16
+ /**
17
+ * Checks if given crypto asset is Bitcoin-like
18
+ * @param key The key of crypto asset
19
+ * @returns True if crypto asset is Bitcoin-like
20
+ */
21
+ export declare function isBitcoinLikeCryptoAsset(key: CryptoAssetKey): boolean;
22
+ /**
23
+ * Checks if given crypto asset is USD-like
24
+ * @param key The key of crypto asset
25
+ * @returns True if crypto asset is USD-like
26
+ */
27
+ export declare function isUsdLikeCryptoAsset(key: CryptoAssetKey): boolean;
28
+ //# sourceMappingURL=cryptoAssets.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cryptoAssets.d.ts","sourceRoot":"","sources":["../../../src/utils/cryptoAssets.ts"],"names":[],"mappings":"AAAA,OAAO,EAGL,SAAS,EAGV,MAAM,qBAAqB,CAAA;AAC5B,OAAO,EAAiB,EAAE,EAAE,MAAM,OAAO,CAAA;AAEzC,MAAM,MAAM,cAAc,GAAG,KAAK,GAAG,KAAK,GAAG,MAAM,GAAG,MAAM,GAAG,MAAM,GAAG,MAAM,CAAA;AAE9E,MAAM,MAAM,WAAW,GAAG;IACxB,IAAI,EAAE,MAAM,CAAA;IACZ,MAAM,EAAE,MAAM,CAAA;IACd,IAAI,EAAE,EAAE,CAAC,SAAS,CAAC,CAAA;IACnB,QAAQ,EAAE,MAAM,CAAA;CACjB,CAAA;AAmDD;;;;GAIG;AACH,wBAAgB,cAAc,CAAC,GAAG,EAAE,cAAc,eAEjD;AAED;;;;GAIG;AACH,wBAAgB,wBAAwB,CAAC,GAAG,EAAE,cAAc,WAE3D;AAED;;;;GAIG;AACH,wBAAgB,oBAAoB,CAAC,GAAG,EAAE,cAAc,WAEvD"}
@@ -0,0 +1,73 @@
1
+ import { BitcoinCircle, EthCircle, MUsdCircle, TBtcCircle, } from "@mezo-org/mezo-clay";
2
+ import { createElement } from "react";
3
+ const CRYPTO_ASSETS = {
4
+ btc: {
5
+ name: "Bitcoin",
6
+ symbol: "BTC",
7
+ icon: BitcoinCircle,
8
+ decimals: 8,
9
+ },
10
+ eth: {
11
+ name: "Ethereum",
12
+ symbol: "ETH",
13
+ icon: EthCircle,
14
+ decimals: 18,
15
+ },
16
+ tbtc: {
17
+ name: "Threshold Bitcoin",
18
+ symbol: "tBTC",
19
+ icon: TBtcCircle,
20
+ decimals: 18,
21
+ },
22
+ wbtc: {
23
+ name: "Wrapped Bitcoin",
24
+ symbol: "wBTC",
25
+ icon: (props) => createElement(BitcoinCircle, {
26
+ ...props,
27
+ symbolColor: "#FF8A00",
28
+ color: "#000000",
29
+ }),
30
+ decimals: 8,
31
+ },
32
+ mbtc: {
33
+ name: "Matsnet Bitcoin",
34
+ symbol: "BTC",
35
+ icon: (props) => createElement(BitcoinCircle, {
36
+ ...props,
37
+ symbolColor: "#000000",
38
+ color: "#FFC907",
39
+ }),
40
+ decimals: 18,
41
+ },
42
+ musd: {
43
+ name: "Mezo USD",
44
+ symbol: "MUSD",
45
+ icon: MUsdCircle,
46
+ decimals: 18,
47
+ },
48
+ };
49
+ /**
50
+ * Gets details of given crypto asset
51
+ * @param key The key of crypto asset
52
+ * @returns The crypto asset details
53
+ */
54
+ export function getCryptoAsset(key) {
55
+ return CRYPTO_ASSETS[key];
56
+ }
57
+ /**
58
+ * Checks if given crypto asset is Bitcoin-like
59
+ * @param key The key of crypto asset
60
+ * @returns True if crypto asset is Bitcoin-like
61
+ */
62
+ export function isBitcoinLikeCryptoAsset(key) {
63
+ return ["btc", "tbtc", "wbtc", "mbtc"].includes(key);
64
+ }
65
+ /**
66
+ * Checks if given crypto asset is USD-like
67
+ * @param key The key of crypto asset
68
+ * @returns True if crypto asset is USD-like
69
+ */
70
+ export function isUsdLikeCryptoAsset(key) {
71
+ return ["musd"].includes(key);
72
+ }
73
+ //# sourceMappingURL=cryptoAssets.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cryptoAssets.js","sourceRoot":"","sources":["../../../src/utils/cryptoAssets.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,aAAa,EACb,SAAS,EAET,UAAU,EACV,UAAU,GACX,MAAM,qBAAqB,CAAA;AAC5B,OAAO,EAAE,aAAa,EAAM,MAAM,OAAO,CAAA;AAWzC,MAAM,aAAa,GAAwC;IACzD,GAAG,EAAE;QACH,IAAI,EAAE,SAAS;QACf,MAAM,EAAE,KAAK;QACb,IAAI,EAAE,aAAa;QACnB,QAAQ,EAAE,CAAC;KACZ;IACD,GAAG,EAAE;QACH,IAAI,EAAE,UAAU;QAChB,MAAM,EAAE,KAAK;QACb,IAAI,EAAE,SAAS;QACf,QAAQ,EAAE,EAAE;KACb;IACD,IAAI,EAAE;QACJ,IAAI,EAAE,mBAAmB;QACzB,MAAM,EAAE,MAAM;QACd,IAAI,EAAE,UAAU;QAChB,QAAQ,EAAE,EAAE;KACb;IACD,IAAI,EAAE;QACJ,IAAI,EAAE,iBAAiB;QACvB,MAAM,EAAE,MAAM;QACd,IAAI,EAAE,CAAC,KAAK,EAAE,EAAE,CACd,aAAa,CAAC,aAAa,EAAE;YAC3B,GAAG,KAAK;YACR,WAAW,EAAE,SAAS;YACtB,KAAK,EAAE,SAAS;SACjB,CAAC;QACJ,QAAQ,EAAE,CAAC;KACZ;IACD,IAAI,EAAE;QACJ,IAAI,EAAE,iBAAiB;QACvB,MAAM,EAAE,KAAK;QACb,IAAI,EAAE,CAAC,KAAK,EAAE,EAAE,CACd,aAAa,CAAC,aAAa,EAAE;YAC3B,GAAG,KAAK;YACR,WAAW,EAAE,SAAS;YACtB,KAAK,EAAE,SAAS;SACjB,CAAC;QACJ,QAAQ,EAAE,EAAE;KACb;IACD,IAAI,EAAE;QACJ,IAAI,EAAE,UAAU;QAChB,MAAM,EAAE,MAAM;QACd,IAAI,EAAE,UAAU;QAChB,QAAQ,EAAE,EAAE;KACb;CACF,CAAA;AAED;;;;GAIG;AACH,MAAM,UAAU,cAAc,CAAC,GAAmB;IAChD,OAAO,aAAa,CAAC,GAAG,CAAC,CAAA;AAC3B,CAAC;AAED;;;;GAIG;AACH,MAAM,UAAU,wBAAwB,CAAC,GAAmB;IAC1D,OAAO,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAA;AACtD,CAAC;AAED;;;;GAIG;AACH,MAAM,UAAU,oBAAoB,CAAC,GAAmB;IACtD,OAAO,CAAC,MAAM,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAA;AAC/B,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=cryptoAssets.test.d.ts.map