@haneullabs/dapp-kit 1.0.4 → 1.0.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/components/AccountDropdownMenu.mjs +8 -8
- package/dist/components/AccountDropdownMenu.mjs.map +2 -2
- package/dist/components/ConnectButton.mjs +12 -12
- package/dist/components/ConnectButton.mjs.map +2 -2
- package/dist/components/HaneulClientProvider.d.ts.map +1 -1
- package/dist/components/HaneulClientProvider.mjs +2 -2
- package/dist/components/HaneulClientProvider.mjs.map +2 -2
- package/dist/components/WalletProvider.mjs +23 -23
- package/dist/components/WalletProvider.mjs.map +2 -2
- package/dist/components/connect-modal/ConnectModal.mjs +4 -4
- package/dist/components/connect-modal/ConnectModal.mjs.map +2 -2
- package/dist/hooks/networkConfig.mjs +6 -6
- package/dist/hooks/networkConfig.mjs.map +2 -2
- package/dist/hooks/useHaneulClient.d.ts +2 -2
- package/dist/hooks/useHaneulClient.d.ts.map +1 -1
- package/dist/hooks/useHaneulClient.mjs +9 -9
- package/dist/hooks/useHaneulClient.mjs.map +2 -2
- package/dist/hooks/useHaneulClientInfiniteQuery.d.ts +2 -2
- package/dist/hooks/useHaneulClientInfiniteQuery.d.ts.map +1 -1
- package/dist/hooks/useHaneulClientInfiniteQuery.mjs +8 -8
- package/dist/hooks/useHaneulClientInfiniteQuery.mjs.map +2 -2
- package/dist/hooks/useHaneulClientMutation.d.ts +2 -2
- package/dist/hooks/useHaneulClientMutation.d.ts.map +1 -1
- package/dist/hooks/useHaneulClientMutation.mjs +8 -8
- package/dist/hooks/useHaneulClientMutation.mjs.map +2 -2
- package/dist/hooks/useHaneulClientQueries.d.ts +6 -6
- package/dist/hooks/useHaneulClientQueries.d.ts.map +1 -1
- package/dist/hooks/useHaneulClientQueries.mjs +8 -8
- package/dist/hooks/useHaneulClientQueries.mjs.map +2 -2
- package/dist/hooks/useHaneulClientQuery.d.ts +5 -5
- package/dist/hooks/useHaneulClientQuery.d.ts.map +1 -1
- package/dist/hooks/useHaneulClientQuery.mjs +14 -14
- package/dist/hooks/useHaneulClientQuery.mjs.map +2 -2
- package/dist/hooks/useResolveHaneulNSNames.mjs +8 -8
- package/dist/hooks/useResolveHaneulNSNames.mjs.map +2 -2
- package/dist/hooks/wallet/useAutoConnectWallet.mjs +4 -4
- package/dist/hooks/wallet/useAutoConnectWallet.mjs.map +2 -2
- package/dist/hooks/wallet/useConnectWallet.mjs +4 -4
- package/dist/hooks/wallet/useConnectWallet.mjs.map +2 -2
- package/dist/hooks/wallet/useSignAndExecuteTransaction.mjs +6 -6
- package/dist/hooks/wallet/useSignAndExecuteTransaction.mjs.map +2 -2
- package/dist/hooks/wallet/useSignPersonalMessage.mjs +6 -6
- package/dist/hooks/wallet/useSignPersonalMessage.mjs.map +2 -2
- package/dist/hooks/wallet/useSignTransaction.mjs +6 -6
- package/dist/hooks/wallet/useSignTransaction.mjs.map +2 -2
- package/dist/hooks/wallet/useUnsafeBurnerWallet.mjs +19 -19
- package/dist/hooks/wallet/useUnsafeBurnerWallet.mjs.map +2 -2
- package/dist/index.mjs +49 -49
- package/dist/index.mjs.map +2 -2
- package/package.json +5 -5
- package/src/components/HaneulClientProvider.tsx +2 -2
- package/src/hooks/networkConfig.ts +2 -2
- package/src/hooks/useHaneulClient.ts +6 -6
- package/src/hooks/useHaneulClientInfiniteQuery.ts +5 -5
- package/src/hooks/useHaneulClientMutation.ts +5 -5
- package/src/hooks/useHaneulClientQueries.ts +9 -9
- package/src/hooks/useHaneulClientQuery.ts +13 -13
- package/src/hooks/useResolveHaneulNSNames.ts +2 -2
- package/src/hooks/wallet/useConnectWallet.ts +4 -4
- package/src/hooks/wallet/useSignAndExecuteTransaction.ts +2 -2
- package/src/hooks/wallet/useSignPersonalMessage.ts +2 -2
- package/src/hooks/wallet/useSignTransaction.ts +2 -2
- package/src/hooks/wallet/useUnsafeBurnerWallet.ts +13 -13
package/package.json
CHANGED
|
@@ -3,7 +3,7 @@
|
|
|
3
3
|
"author": "Haneul Labs <build@haneul-labs.com>",
|
|
4
4
|
"description": "A collection of React hooks and components for interacting with the Haneul blockchain and wallets.",
|
|
5
5
|
"homepage": "https://sdk.haneul-labs.com/dapp-kit",
|
|
6
|
-
"version": "1.0.
|
|
6
|
+
"version": "1.0.6",
|
|
7
7
|
"license": "Apache-2.0",
|
|
8
8
|
"files": [
|
|
9
9
|
"CHANGELOG.md",
|
|
@@ -71,9 +71,9 @@
|
|
|
71
71
|
"vitest": "^4.0.17"
|
|
72
72
|
},
|
|
73
73
|
"dependencies": {
|
|
74
|
-
"@haneullabs/slush-wallet": "
|
|
75
|
-
"@haneullabs/utils": "
|
|
76
|
-
"@haneullabs/wallet-standard": "
|
|
74
|
+
"@haneullabs/slush-wallet": "^1.0.2",
|
|
75
|
+
"@haneullabs/utils": "^0.3.1",
|
|
76
|
+
"@haneullabs/wallet-standard": "^0.20.1",
|
|
77
77
|
"@radix-ui/react-dialog": "^1.1.15",
|
|
78
78
|
"@radix-ui/react-dropdown-menu": "^2.1.16",
|
|
79
79
|
"@radix-ui/react-slot": "^1.2.4",
|
|
@@ -84,7 +84,7 @@
|
|
|
84
84
|
"zustand": "^5.0.10"
|
|
85
85
|
},
|
|
86
86
|
"peerDependencies": {
|
|
87
|
-
"@haneullabs/haneul": "
|
|
87
|
+
"@haneullabs/haneul": "^2.4.0",
|
|
88
88
|
"@tanstack/react-query": "^5.0.0",
|
|
89
89
|
"react": "*"
|
|
90
90
|
},
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
// Copyright (c) Mysten Labs, Inc.
|
|
2
2
|
// SPDX-License-Identifier: Apache-2.0
|
|
3
3
|
|
|
4
|
-
import { getJsonRpcFullnodeUrl,
|
|
4
|
+
import { getJsonRpcFullnodeUrl, isHaneulJsonRpcClient, HaneulJsonRpcClient } from '@haneullabs/haneul/jsonRpc';
|
|
5
5
|
import type { HaneulJsonRpcClientOptions } from '@haneullabs/haneul/jsonRpc';
|
|
6
6
|
import { createContext, useMemo, useState } from 'react';
|
|
7
7
|
|
|
@@ -44,7 +44,7 @@ const DEFAULT_CREATE_CLIENT = function createClient(
|
|
|
44
44
|
_name: string,
|
|
45
45
|
config: NetworkConfig | HaneulJsonRpcClient,
|
|
46
46
|
) {
|
|
47
|
-
if (
|
|
47
|
+
if (isHaneulJsonRpcClient(config)) {
|
|
48
48
|
return config;
|
|
49
49
|
}
|
|
50
50
|
|
|
@@ -3,7 +3,7 @@
|
|
|
3
3
|
|
|
4
4
|
import type { HaneulJsonRpcClientOptions } from '@haneullabs/haneul/jsonRpc';
|
|
5
5
|
|
|
6
|
-
import {
|
|
6
|
+
import { useHaneulClientContext } from './useHaneulClient.js';
|
|
7
7
|
|
|
8
8
|
export type NetworkConfig<T extends object = object> = HaneulJsonRpcClientOptions & {
|
|
9
9
|
variables?: T;
|
|
@@ -15,7 +15,7 @@ export function createNetworkConfig<
|
|
|
15
15
|
Variables extends object = NonNullable<Config['variables']>,
|
|
16
16
|
>(networkConfig: T) {
|
|
17
17
|
function useNetworkConfig(): Config {
|
|
18
|
-
const { config } =
|
|
18
|
+
const { config } = useHaneulClientContext();
|
|
19
19
|
|
|
20
20
|
if (!config) {
|
|
21
21
|
throw new Error('No network config found');
|
|
@@ -6,18 +6,18 @@ import { useContext } from 'react';
|
|
|
6
6
|
|
|
7
7
|
import { HaneulClientContext } from '../components/HaneulClientProvider.js';
|
|
8
8
|
|
|
9
|
-
export function
|
|
10
|
-
const
|
|
9
|
+
export function useHaneulClientContext() {
|
|
10
|
+
const haneulClient = useContext(HaneulClientContext);
|
|
11
11
|
|
|
12
|
-
if (!
|
|
12
|
+
if (!haneulClient) {
|
|
13
13
|
throw new Error(
|
|
14
14
|
'Could not find HaneulClientContext. Ensure that you have set up the HaneulClientProvider',
|
|
15
15
|
);
|
|
16
16
|
}
|
|
17
17
|
|
|
18
|
-
return
|
|
18
|
+
return haneulClient;
|
|
19
19
|
}
|
|
20
20
|
|
|
21
|
-
export function
|
|
22
|
-
return
|
|
21
|
+
export function useHaneulClient(): HaneulJsonRpcClient {
|
|
22
|
+
return useHaneulClientContext().client;
|
|
23
23
|
}
|
|
@@ -10,7 +10,7 @@ import type {
|
|
|
10
10
|
import { useInfiniteQuery } from '@tanstack/react-query';
|
|
11
11
|
|
|
12
12
|
import type { PartialBy } from '../types/utilityTypes.js';
|
|
13
|
-
import {
|
|
13
|
+
import { useHaneulClientContext } from './useHaneulClient.js';
|
|
14
14
|
|
|
15
15
|
interface PaginatedResult {
|
|
16
16
|
data?: unknown;
|
|
@@ -41,7 +41,7 @@ export type HaneulRpcPaginatedMethods = {
|
|
|
41
41
|
: never;
|
|
42
42
|
};
|
|
43
43
|
|
|
44
|
-
export type
|
|
44
|
+
export type UseHaneulClientInfiniteQueryOptions<
|
|
45
45
|
T extends keyof HaneulRpcPaginatedMethods,
|
|
46
46
|
TData,
|
|
47
47
|
> = PartialBy<
|
|
@@ -52,7 +52,7 @@ export type UseSuiClientInfiniteQueryOptions<
|
|
|
52
52
|
'queryKey'
|
|
53
53
|
>;
|
|
54
54
|
|
|
55
|
-
export function
|
|
55
|
+
export function useHaneulClientInfiniteQuery<
|
|
56
56
|
T extends keyof HaneulRpcPaginatedMethods,
|
|
57
57
|
TData = InfiniteData<HaneulRpcPaginatedMethods[T]['result']>,
|
|
58
58
|
>(
|
|
@@ -62,9 +62,9 @@ export function useSuiClientInfiniteQuery<
|
|
|
62
62
|
queryKey = [],
|
|
63
63
|
enabled = !!params,
|
|
64
64
|
...options
|
|
65
|
-
}:
|
|
65
|
+
}: UseHaneulClientInfiniteQueryOptions<T, TData> = {},
|
|
66
66
|
): UseInfiniteQueryResult<TData, Error> {
|
|
67
|
-
const suiContext =
|
|
67
|
+
const suiContext = useHaneulClientContext();
|
|
68
68
|
|
|
69
69
|
return useInfiniteQuery({
|
|
70
70
|
...options,
|
|
@@ -4,19 +4,19 @@
|
|
|
4
4
|
import type { UseMutationOptions, UseMutationResult } from '@tanstack/react-query';
|
|
5
5
|
import { useMutation } from '@tanstack/react-query';
|
|
6
6
|
|
|
7
|
-
import {
|
|
7
|
+
import { useHaneulClientContext } from './useHaneulClient.js';
|
|
8
8
|
import type { HaneulRpcMethods } from './useHaneulClientQuery.js';
|
|
9
9
|
|
|
10
|
-
export type
|
|
10
|
+
export type UseHaneulClientMutationOptions<T extends keyof HaneulRpcMethods> = Omit<
|
|
11
11
|
UseMutationOptions<HaneulRpcMethods[T]['result'], Error, HaneulRpcMethods[T]['params'], unknown[]>,
|
|
12
12
|
'mutationFn'
|
|
13
13
|
>;
|
|
14
14
|
|
|
15
|
-
export function
|
|
15
|
+
export function useHaneulClientMutation<T extends keyof HaneulRpcMethods>(
|
|
16
16
|
method: T,
|
|
17
|
-
options:
|
|
17
|
+
options: UseHaneulClientMutationOptions<T> = {},
|
|
18
18
|
): UseMutationResult<HaneulRpcMethods[T]['result'], Error, HaneulRpcMethods[T]['params'], unknown[]> {
|
|
19
|
-
const suiContext =
|
|
19
|
+
const suiContext = useHaneulClientContext();
|
|
20
20
|
|
|
21
21
|
return useMutation({
|
|
22
22
|
...options,
|
|
@@ -4,8 +4,8 @@
|
|
|
4
4
|
import type { UseQueryResult } from '@tanstack/react-query';
|
|
5
5
|
import { useQueries } from '@tanstack/react-query';
|
|
6
6
|
|
|
7
|
-
import {
|
|
8
|
-
import type { HaneulRpcMethods,
|
|
7
|
+
import { useHaneulClientContext } from './useHaneulClient.js';
|
|
8
|
+
import type { HaneulRpcMethods, UseHaneulClientQueryOptions } from './useHaneulClientQuery.js';
|
|
9
9
|
|
|
10
10
|
type HaneulClientQueryOptions = HaneulRpcMethods[keyof HaneulRpcMethods] extends infer Method
|
|
11
11
|
? Method extends {
|
|
@@ -16,17 +16,17 @@ type HaneulClientQueryOptions = HaneulRpcMethods[keyof HaneulRpcMethods] extends
|
|
|
16
16
|
? {
|
|
17
17
|
method: M;
|
|
18
18
|
params?: P;
|
|
19
|
-
options?:
|
|
19
|
+
options?: UseHaneulClientQueryOptions<M, unknown>;
|
|
20
20
|
}
|
|
21
21
|
: {
|
|
22
22
|
method: M;
|
|
23
23
|
params: P;
|
|
24
|
-
options?:
|
|
24
|
+
options?: UseHaneulClientQueryOptions<M, unknown>;
|
|
25
25
|
}
|
|
26
26
|
: never
|
|
27
27
|
: never;
|
|
28
28
|
|
|
29
|
-
export type
|
|
29
|
+
export type UseHaneulClientQueriesResults<Args extends readonly HaneulClientQueryOptions[]> = {
|
|
30
30
|
-readonly [K in keyof Args]: Args[K] extends {
|
|
31
31
|
method: infer M extends keyof HaneulRpcMethods;
|
|
32
32
|
readonly options?:
|
|
@@ -39,17 +39,17 @@ export type UseSuiClientQueriesResults<Args extends readonly HaneulClientQueryOp
|
|
|
39
39
|
: never;
|
|
40
40
|
};
|
|
41
41
|
|
|
42
|
-
export function
|
|
42
|
+
export function useHaneulClientQueries<
|
|
43
43
|
const Queries extends readonly HaneulClientQueryOptions[],
|
|
44
|
-
Results =
|
|
44
|
+
Results = UseHaneulClientQueriesResults<Queries>,
|
|
45
45
|
>({
|
|
46
46
|
queries,
|
|
47
47
|
combine,
|
|
48
48
|
}: {
|
|
49
49
|
queries: Queries;
|
|
50
|
-
combine?: (results:
|
|
50
|
+
combine?: (results: UseHaneulClientQueriesResults<Queries>) => Results;
|
|
51
51
|
}): Results {
|
|
52
|
-
const suiContext =
|
|
52
|
+
const suiContext = useHaneulClientContext();
|
|
53
53
|
|
|
54
54
|
return useQueries({
|
|
55
55
|
combine: combine as never,
|
|
@@ -11,7 +11,7 @@ import { queryOptions, useQuery, useSuspenseQuery } from '@tanstack/react-query'
|
|
|
11
11
|
import { useMemo } from 'react';
|
|
12
12
|
|
|
13
13
|
import type { PartialBy } from '../types/utilityTypes.js';
|
|
14
|
-
import {
|
|
14
|
+
import { useHaneulClientContext } from './useHaneulClient.js';
|
|
15
15
|
|
|
16
16
|
export type HaneulRpcMethodName = {
|
|
17
17
|
[K in keyof HaneulJsonRpcClient]: HaneulJsonRpcClient[K] extends
|
|
@@ -37,12 +37,12 @@ export type HaneulRpcMethods = {
|
|
|
37
37
|
: never;
|
|
38
38
|
};
|
|
39
39
|
|
|
40
|
-
export type
|
|
40
|
+
export type UseHaneulClientQueryOptions<T extends keyof HaneulRpcMethods, TData> = PartialBy<
|
|
41
41
|
Omit<UseQueryOptions<HaneulRpcMethods[T]['result'], Error, TData, unknown[]>, 'queryFn'>,
|
|
42
42
|
'queryKey'
|
|
43
43
|
>;
|
|
44
44
|
|
|
45
|
-
export type
|
|
45
|
+
export type GetHaneulClientQueryOptions<T extends keyof HaneulRpcMethods> = {
|
|
46
46
|
client: HaneulJsonRpcClient;
|
|
47
47
|
network: string;
|
|
48
48
|
method: T;
|
|
@@ -54,13 +54,13 @@ export type GetSuiClientQueryOptions<T extends keyof HaneulRpcMethods> = {
|
|
|
54
54
|
? { params?: HaneulRpcMethods[T]['params'] }
|
|
55
55
|
: { params: HaneulRpcMethods[T]['params'] });
|
|
56
56
|
|
|
57
|
-
export function
|
|
57
|
+
export function getHaneulClientQuery<T extends keyof HaneulRpcMethods>({
|
|
58
58
|
client,
|
|
59
59
|
network,
|
|
60
60
|
method,
|
|
61
61
|
params,
|
|
62
62
|
options,
|
|
63
|
-
}:
|
|
63
|
+
}: GetHaneulClientQueryOptions<T>) {
|
|
64
64
|
return queryOptions<HaneulRpcMethods[T]['result']>({
|
|
65
65
|
...options,
|
|
66
66
|
queryKey: [network, method, params],
|
|
@@ -70,21 +70,21 @@ export function getSuiClientQuery<T extends keyof HaneulRpcMethods>({
|
|
|
70
70
|
});
|
|
71
71
|
}
|
|
72
72
|
|
|
73
|
-
export function
|
|
73
|
+
export function useHaneulClientQuery<
|
|
74
74
|
T extends keyof HaneulRpcMethods,
|
|
75
75
|
TData = HaneulRpcMethods[T]['result'],
|
|
76
76
|
>(
|
|
77
77
|
...args: undefined extends HaneulRpcMethods[T]['params']
|
|
78
|
-
? [method: T, params?: HaneulRpcMethods[T]['params'], options?:
|
|
79
|
-
: [method: T, params: HaneulRpcMethods[T]['params'], options?:
|
|
78
|
+
? [method: T, params?: HaneulRpcMethods[T]['params'], options?: UseHaneulClientQueryOptions<T, TData>]
|
|
79
|
+
: [method: T, params: HaneulRpcMethods[T]['params'], options?: UseHaneulClientQueryOptions<T, TData>]
|
|
80
80
|
): UseQueryResult<TData, Error> {
|
|
81
81
|
const [method, params, { queryKey = [], ...options } = {}] = args as [
|
|
82
82
|
method: T,
|
|
83
83
|
params?: HaneulRpcMethods[T]['params'],
|
|
84
|
-
options?:
|
|
84
|
+
options?: UseHaneulClientQueryOptions<T, TData>,
|
|
85
85
|
];
|
|
86
86
|
|
|
87
|
-
const suiContext =
|
|
87
|
+
const suiContext = useHaneulClientContext();
|
|
88
88
|
|
|
89
89
|
return useQuery({
|
|
90
90
|
...options,
|
|
@@ -95,7 +95,7 @@ export function useSuiClientQuery<
|
|
|
95
95
|
});
|
|
96
96
|
}
|
|
97
97
|
|
|
98
|
-
export function
|
|
98
|
+
export function useHaneulClientSuspenseQuery<
|
|
99
99
|
T extends keyof HaneulRpcMethods,
|
|
100
100
|
TData = HaneulRpcMethods[T]['result'],
|
|
101
101
|
>(
|
|
@@ -109,10 +109,10 @@ export function useSuiClientSuspenseQuery<
|
|
|
109
109
|
options?: UndefinedInitialDataOptions<TData>,
|
|
110
110
|
];
|
|
111
111
|
|
|
112
|
-
const suiContext =
|
|
112
|
+
const suiContext = useHaneulClientContext();
|
|
113
113
|
|
|
114
114
|
const query = useMemo(() => {
|
|
115
|
-
return
|
|
115
|
+
return getHaneulClientQuery<T>({
|
|
116
116
|
client: suiContext.client,
|
|
117
117
|
network: suiContext.network,
|
|
118
118
|
method,
|
|
@@ -4,7 +4,7 @@
|
|
|
4
4
|
import type { ResolvedNameServiceNames } from '@haneullabs/haneul/jsonRpc';
|
|
5
5
|
import type { UseQueryOptions, UseQueryResult } from '@tanstack/react-query';
|
|
6
6
|
|
|
7
|
-
import {
|
|
7
|
+
import { useHaneulClientQuery } from './useHaneulClientQuery.js';
|
|
8
8
|
|
|
9
9
|
export function useResolveHaneulNSName(
|
|
10
10
|
address?: string | null,
|
|
@@ -13,7 +13,7 @@ export function useResolveHaneulNSName(
|
|
|
13
13
|
'queryFn' | 'queryKey' | 'select'
|
|
14
14
|
>,
|
|
15
15
|
): UseQueryResult<string | null, Error> {
|
|
16
|
-
return
|
|
16
|
+
return useHaneulClientQuery(
|
|
17
17
|
'resolveNameServiceNames',
|
|
18
18
|
{
|
|
19
19
|
address: address!,
|
|
@@ -55,14 +55,14 @@ export function useConnectWallet({
|
|
|
55
55
|
supportedIntents =
|
|
56
56
|
(await wallet.features['haneul:getCapabilities'].getCapabilities()).supportedIntents ?? [];
|
|
57
57
|
}
|
|
58
|
-
const
|
|
58
|
+
const connectedHaneulAccounts = connectResult.accounts.filter((account) =>
|
|
59
59
|
account.chains.some((chain) => chain.split(':')[0] === 'haneul'),
|
|
60
60
|
);
|
|
61
|
-
const selectedAccount = getSelectedAccount(
|
|
61
|
+
const selectedAccount = getSelectedAccount(connectedHaneulAccounts, accountAddress);
|
|
62
62
|
|
|
63
|
-
setWalletConnected(wallet,
|
|
63
|
+
setWalletConnected(wallet, connectedHaneulAccounts, selectedAccount, supportedIntents);
|
|
64
64
|
|
|
65
|
-
return { accounts:
|
|
65
|
+
return { accounts: connectedHaneulAccounts };
|
|
66
66
|
} catch (error) {
|
|
67
67
|
setConnectionStatus('disconnected');
|
|
68
68
|
throw error;
|
|
@@ -18,7 +18,7 @@ import {
|
|
|
18
18
|
WalletNotConnectedError,
|
|
19
19
|
} from '../../errors/walletErrors.js';
|
|
20
20
|
import type { PartialBy } from '../../types/utilityTypes.js';
|
|
21
|
-
import {
|
|
21
|
+
import { useHaneulClientContext } from '../useHaneulClient.js';
|
|
22
22
|
import { useCurrentAccount } from './useCurrentAccount.js';
|
|
23
23
|
import { useCurrentWallet } from './useCurrentWallet.js';
|
|
24
24
|
|
|
@@ -76,7 +76,7 @@ export function useSignAndExecuteTransaction<
|
|
|
76
76
|
> {
|
|
77
77
|
const { currentWallet, supportedIntents } = useCurrentWallet();
|
|
78
78
|
const currentAccount = useCurrentAccount();
|
|
79
|
-
const { client, network } =
|
|
79
|
+
const { client, network } = useHaneulClientContext();
|
|
80
80
|
|
|
81
81
|
const executeTransaction: ({
|
|
82
82
|
bytes,
|
|
@@ -15,7 +15,7 @@ import {
|
|
|
15
15
|
} from '../..//errors/walletErrors.js';
|
|
16
16
|
import { walletMutationKeys } from '../../constants/walletMutationKeys.js';
|
|
17
17
|
import type { PartialBy } from '../../types/utilityTypes.js';
|
|
18
|
-
import {
|
|
18
|
+
import { useHaneulClientContext } from '../useHaneulClient.js';
|
|
19
19
|
import { useCurrentAccount } from './useCurrentAccount.js';
|
|
20
20
|
import { useCurrentWallet } from './useCurrentWallet.js';
|
|
21
21
|
|
|
@@ -52,7 +52,7 @@ export function useSignPersonalMessage({
|
|
|
52
52
|
> {
|
|
53
53
|
const { currentWallet } = useCurrentWallet();
|
|
54
54
|
const currentAccount = useCurrentAccount();
|
|
55
|
-
const { network } =
|
|
55
|
+
const { network } = useHaneulClientContext();
|
|
56
56
|
|
|
57
57
|
return useMutation({
|
|
58
58
|
mutationKey: walletMutationKeys.signPersonalMessage(mutationKey),
|
|
@@ -14,7 +14,7 @@ import {
|
|
|
14
14
|
WalletNotConnectedError,
|
|
15
15
|
} from '../../errors/walletErrors.js';
|
|
16
16
|
import type { PartialBy } from '../../types/utilityTypes.js';
|
|
17
|
-
import {
|
|
17
|
+
import { useHaneulClientContext } from '../useHaneulClient.js';
|
|
18
18
|
import { useCurrentAccount } from './useCurrentAccount.js';
|
|
19
19
|
import { useCurrentWallet } from './useCurrentWallet.js';
|
|
20
20
|
|
|
@@ -56,7 +56,7 @@ export function useSignTransaction({
|
|
|
56
56
|
> {
|
|
57
57
|
const { currentWallet } = useCurrentWallet();
|
|
58
58
|
const currentAccount = useCurrentAccount();
|
|
59
|
-
const { client, network } =
|
|
59
|
+
const { client, network } = useHaneulClientContext();
|
|
60
60
|
|
|
61
61
|
return useMutation({
|
|
62
62
|
mutationKey: walletMutationKeys.signTransaction(mutationKey),
|
|
@@ -21,23 +21,23 @@ import type {
|
|
|
21
21
|
import { getWallets, ReadonlyWalletAccount, HANEUL_CHAINS } from '@haneullabs/wallet-standard';
|
|
22
22
|
import { useEffect } from 'react';
|
|
23
23
|
|
|
24
|
-
import {
|
|
24
|
+
import { useHaneulClient } from '../useHaneulClient.js';
|
|
25
25
|
|
|
26
26
|
const WALLET_NAME = 'Unsafe Burner Wallet';
|
|
27
27
|
|
|
28
28
|
export function useUnsafeBurnerWallet(enabled: boolean) {
|
|
29
|
-
const
|
|
29
|
+
const haneulClient = useHaneulClient();
|
|
30
30
|
|
|
31
31
|
useEffect(() => {
|
|
32
32
|
if (!enabled) {
|
|
33
33
|
return;
|
|
34
34
|
}
|
|
35
|
-
const unregister = registerUnsafeBurnerWallet(
|
|
35
|
+
const unregister = registerUnsafeBurnerWallet(haneulClient);
|
|
36
36
|
return unregister;
|
|
37
|
-
}, [enabled,
|
|
37
|
+
}, [enabled, haneulClient]);
|
|
38
38
|
}
|
|
39
39
|
|
|
40
|
-
function registerUnsafeBurnerWallet(
|
|
40
|
+
function registerUnsafeBurnerWallet(haneulClient: HaneulJsonRpcClient) {
|
|
41
41
|
const walletsApi = getWallets();
|
|
42
42
|
const registeredWallets = walletsApi.get();
|
|
43
43
|
|
|
@@ -54,8 +54,8 @@ function registerUnsafeBurnerWallet(suiClient: HaneulJsonRpcClient) {
|
|
|
54
54
|
|
|
55
55
|
const keypair = new Ed25519Keypair();
|
|
56
56
|
const account = new ReadonlyWalletAccount({
|
|
57
|
-
address: keypair.getPublicKey().
|
|
58
|
-
publicKey: keypair.getPublicKey().
|
|
57
|
+
address: keypair.getPublicKey().toHaneulAddress(),
|
|
58
|
+
publicKey: keypair.getPublicKey().toHaneulBytes(),
|
|
59
59
|
chains: ['haneul:unknown'],
|
|
60
60
|
features: [
|
|
61
61
|
'haneul:signAndExecuteTransactionBlock',
|
|
@@ -135,7 +135,7 @@ function registerUnsafeBurnerWallet(suiClient: HaneulJsonRpcClient) {
|
|
|
135
135
|
|
|
136
136
|
#signTransactionBlock: HaneulSignTransactionBlockMethod = async (transactionInput) => {
|
|
137
137
|
const { bytes, signature } = await transactionInput.transactionBlock.sign({
|
|
138
|
-
client:
|
|
138
|
+
client: haneulClient,
|
|
139
139
|
signer: keypair,
|
|
140
140
|
});
|
|
141
141
|
|
|
@@ -149,7 +149,7 @@ function registerUnsafeBurnerWallet(suiClient: HaneulJsonRpcClient) {
|
|
|
149
149
|
const { bytes, signature } = await Transaction.from(
|
|
150
150
|
await transactionInput.transaction.toJSON(),
|
|
151
151
|
).sign({
|
|
152
|
-
client:
|
|
152
|
+
client: haneulClient,
|
|
153
153
|
signer: keypair,
|
|
154
154
|
});
|
|
155
155
|
|
|
@@ -165,11 +165,11 @@ function registerUnsafeBurnerWallet(suiClient: HaneulJsonRpcClient) {
|
|
|
165
165
|
transactionInput,
|
|
166
166
|
) => {
|
|
167
167
|
const { bytes, signature } = await transactionInput.transactionBlock.sign({
|
|
168
|
-
client:
|
|
168
|
+
client: haneulClient,
|
|
169
169
|
signer: keypair,
|
|
170
170
|
});
|
|
171
171
|
|
|
172
|
-
return
|
|
172
|
+
return haneulClient.executeTransactionBlock({
|
|
173
173
|
signature,
|
|
174
174
|
transactionBlock: bytes,
|
|
175
175
|
options: transactionInput.options,
|
|
@@ -180,13 +180,13 @@ function registerUnsafeBurnerWallet(suiClient: HaneulJsonRpcClient) {
|
|
|
180
180
|
const { bytes, signature } = await Transaction.from(
|
|
181
181
|
await transactionInput.transaction.toJSON(),
|
|
182
182
|
).sign({
|
|
183
|
-
client:
|
|
183
|
+
client: haneulClient,
|
|
184
184
|
signer: keypair,
|
|
185
185
|
});
|
|
186
186
|
|
|
187
187
|
transactionInput.signal?.throwIfAborted();
|
|
188
188
|
|
|
189
|
-
const { rawEffects, digest } = await
|
|
189
|
+
const { rawEffects, digest } = await haneulClient.executeTransactionBlock({
|
|
190
190
|
signature,
|
|
191
191
|
transactionBlock: bytes,
|
|
192
192
|
options: {
|