@manahippo/aptos-wallet-adapter 0.2.0 → 0.3.1

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 (84) hide show
  1. package/README.md +21 -19
  2. package/dist/WalletAdapters/AptosWallet.d.ts +18 -7
  3. package/dist/WalletAdapters/AptosWallet.d.ts.map +1 -1
  4. package/dist/WalletAdapters/AptosWallet.js +47 -32
  5. package/dist/WalletAdapters/AptosWallet.js.map +1 -1
  6. package/dist/WalletAdapters/BaseAdapter.d.ts +10 -6
  7. package/dist/WalletAdapters/BaseAdapter.d.ts.map +1 -1
  8. package/dist/WalletAdapters/BaseAdapter.js.map +1 -1
  9. package/dist/WalletAdapters/FewchaWallet.d.ts +7 -4
  10. package/dist/WalletAdapters/FewchaWallet.d.ts.map +1 -1
  11. package/dist/WalletAdapters/FewchaWallet.js +90 -88
  12. package/dist/WalletAdapters/FewchaWallet.js.map +1 -1
  13. package/dist/WalletAdapters/HippoExtensionWallet.d.ts +8 -4
  14. package/dist/WalletAdapters/HippoExtensionWallet.d.ts.map +1 -1
  15. package/dist/WalletAdapters/HippoExtensionWallet.js +27 -5
  16. package/dist/WalletAdapters/HippoExtensionWallet.js.map +1 -1
  17. package/dist/WalletAdapters/HippoWallet.d.ts +7 -4
  18. package/dist/WalletAdapters/HippoWallet.d.ts.map +1 -1
  19. package/dist/WalletAdapters/HippoWallet.js +28 -2
  20. package/dist/WalletAdapters/HippoWallet.js.map +1 -1
  21. package/dist/WalletAdapters/MartianWallet.d.ts +11 -6
  22. package/dist/WalletAdapters/MartianWallet.d.ts.map +1 -1
  23. package/dist/WalletAdapters/MartianWallet.js +51 -35
  24. package/dist/WalletAdapters/MartianWallet.js.map +1 -1
  25. package/dist/WalletAdapters/NightlyWallet.d.ts +1 -41
  26. package/dist/WalletAdapters/NightlyWallet.d.ts.map +1 -1
  27. package/dist/WalletAdapters/NightlyWallet.js +232 -198
  28. package/dist/WalletAdapters/NightlyWallet.js.map +1 -1
  29. package/dist/WalletAdapters/PontemWallet.d.ts +57 -0
  30. package/dist/WalletAdapters/PontemWallet.d.ts.map +1 -0
  31. package/dist/WalletAdapters/PontemWallet.js +182 -0
  32. package/dist/WalletAdapters/PontemWallet.js.map +1 -0
  33. package/dist/WalletAdapters/SpikaWallet.d.ts +46 -0
  34. package/dist/WalletAdapters/SpikaWallet.d.ts.map +1 -0
  35. package/dist/WalletAdapters/{MultiMaskWallet.js → SpikaWallet.js} +72 -83
  36. package/dist/WalletAdapters/SpikaWallet.js.map +1 -0
  37. package/dist/WalletAdapters/index.d.ts +2 -2
  38. package/dist/WalletAdapters/index.d.ts.map +1 -1
  39. package/dist/WalletAdapters/index.js +3 -2
  40. package/dist/WalletAdapters/index.js.map +1 -1
  41. package/dist/WalletProviders/WalletProvider.d.ts +0 -1
  42. package/dist/WalletProviders/WalletProvider.d.ts.map +1 -1
  43. package/dist/WalletProviders/WalletProvider.js +10 -7
  44. package/dist/WalletProviders/WalletProvider.js.map +1 -1
  45. package/dist/WalletProviders/useWallet.d.ts +5 -3
  46. package/dist/WalletProviders/useWallet.d.ts.map +1 -1
  47. package/dist/WalletProviders/useWallet.js +1 -1
  48. package/dist/WalletProviders/useWallet.js.map +1 -1
  49. package/dist/config/aptosConstants.d.ts +2 -2
  50. package/dist/config/aptosConstants.d.ts.map +1 -1
  51. package/dist/config/aptosConstants.js +1 -1
  52. package/dist/config/aptosConstants.js.map +1 -1
  53. package/dist/hooks/useLocalStorage.d.ts.map +1 -1
  54. package/dist/hooks/useLocalStorage.js +9 -4
  55. package/dist/hooks/useLocalStorage.js.map +1 -1
  56. package/dist/hooks/useSSR.d.ts +4 -0
  57. package/dist/hooks/useSSR.d.ts.map +1 -0
  58. package/dist/hooks/useSSR.js +17 -0
  59. package/dist/hooks/useSSR.js.map +1 -0
  60. package/dist/utilities/util.d.ts +8 -0
  61. package/dist/utilities/util.d.ts.map +1 -0
  62. package/dist/utilities/util.js +14 -0
  63. package/dist/utilities/util.js.map +1 -0
  64. package/package.json +10 -10
  65. package/src/WalletAdapters/AptosWallet.ts +63 -37
  66. package/src/WalletAdapters/BaseAdapter.ts +14 -16
  67. package/src/WalletAdapters/FewchaWallet.ts +97 -81
  68. package/src/WalletAdapters/HippoExtensionWallet.ts +32 -9
  69. package/src/WalletAdapters/HippoWallet.ts +35 -7
  70. package/src/WalletAdapters/MartianWallet.ts +57 -42
  71. package/src/WalletAdapters/NightlyWallet.ts +230 -229
  72. package/src/WalletAdapters/PontemWallet.ts +250 -0
  73. package/src/WalletAdapters/SpikaWallet.ts +229 -0
  74. package/src/WalletAdapters/index.ts +3 -2
  75. package/src/WalletProviders/WalletProvider.tsx +12 -10
  76. package/src/WalletProviders/useWallet.ts +7 -14
  77. package/src/config/aptosConstants.ts +1 -1
  78. package/src/hooks/useLocalStorage.ts +9 -4
  79. package/src/hooks/useSSR.ts +15 -0
  80. package/src/utilities/util.ts +11 -0
  81. package/dist/WalletAdapters/MultiMaskWallet.d.ts +0 -39
  82. package/dist/WalletAdapters/MultiMaskWallet.d.ts.map +0 -1
  83. package/dist/WalletAdapters/MultiMaskWallet.js.map +0 -1
  84. package/src/WalletAdapters/MultiMaskWallet.ts +0 -245
@@ -1,16 +1,13 @@
1
1
  import {
2
- PendingTransaction,
3
- SubmitTransactionRequest,
4
- TransactionPayload
5
- } from 'aptos/dist/api/data-contracts';
6
- import { aptosClient, WEBWALLET_URL } from '../config/aptosConstants';
7
- import {
2
+ WalletConnectionError,
8
3
  WalletDisconnectionError,
9
4
  WalletNotConnectedError,
10
5
  WalletNotReadyError,
6
+ WalletSignAndSubmitMessageError,
7
+ WalletSignMessageError,
11
8
  WalletSignTransactionError
12
9
  } from '../WalletProviders/errors';
13
- import Web3, { Web3Provider, Web3ProviderType } from '@fewcha/web3';
10
+ import Web3, { Web3ProviderType } from '@fewcha/web3';
14
11
  import {
15
12
  AccountKeys,
16
13
  BaseWalletAdapter,
@@ -18,8 +15,14 @@ import {
18
15
  WalletName,
19
16
  WalletReadyState
20
17
  } from './BaseAdapter';
18
+ import {
19
+ TransactionPayload,
20
+ SubmitTransactionRequest,
21
+ HexEncodedBytes,
22
+ EntryFunctionPayload
23
+ } from 'aptos/dist/generated';
21
24
 
22
- export const FewchaWalletName = 'Fewcha Wallet' as WalletName<'Fewcha Wallet'>;
25
+ export const FewchaWalletName = 'Fewcha' as WalletName<'Fewcha'>;
23
26
 
24
27
  interface FewchaWindow extends Window {
25
28
  fewcha: Web3ProviderType;
@@ -27,8 +30,6 @@ interface FewchaWindow extends Window {
27
30
 
28
31
  declare const window: FewchaWindow;
29
32
 
30
- const defaultWeb3 = new Web3(new Web3Provider(window.fewcha));
31
-
32
33
  export interface FewchaAdapterConfig {
33
34
  provider?: string;
34
35
  // network?: WalletAdapterNetwork;
@@ -60,14 +61,13 @@ export class FewchaWalletAdapter extends BaseWalletAdapter {
60
61
  }: FewchaAdapterConfig = {}) {
61
62
  super();
62
63
 
63
- this._provider = defaultWeb3.action;
64
64
  // this._network = network;
65
65
  this._timeout = timeout;
66
66
  this._connecting = false;
67
67
  this._wallet = null;
68
68
  // this._readyState = WalletReadyState.Installed;
69
69
 
70
- if (this._readyState !== WalletReadyState.Unsupported) {
70
+ if (typeof window !== 'undefined' && this._readyState !== WalletReadyState.Unsupported) {
71
71
  scopePollingDetectionStrategy(() => {
72
72
  if (window.fewcha) {
73
73
  this._readyState = WalletReadyState.Installed;
@@ -77,28 +77,6 @@ export class FewchaWalletAdapter extends BaseWalletAdapter {
77
77
  return false;
78
78
  });
79
79
  }
80
-
81
- window.addEventListener('aptos#connected', async () => {
82
- const publicAccount = await this._provider?.account();
83
- const isConnected = await this._provider?.isConnected();
84
- if (publicAccount?.data.publicKey && isConnected) {
85
- this._wallet = {
86
- connected: isConnected,
87
- ...publicAccount.data
88
- };
89
- this.emit('connect', this._wallet.publicKey);
90
- }
91
- });
92
-
93
- window.addEventListener('aptos#transaction', (e: any) => {
94
- if (e?.detail?.tx) {
95
- this.emit('success', e?.detail?.tx);
96
- }
97
- });
98
-
99
- window.addEventListener('aptos#disconnected', () => {
100
- this.emit('disconnect');
101
- });
102
80
  }
103
81
 
104
82
  get publicAccount(): AccountKeys {
@@ -133,12 +111,32 @@ export class FewchaWalletAdapter extends BaseWalletAdapter {
133
111
  throw new WalletNotReadyError();
134
112
 
135
113
  this._connecting = true;
136
- const provider = this._provider;
137
- const isConnected = await this._provider?.isConnected();
138
- if (isConnected) {
139
- await provider?.disconnect();
114
+ const provider = new Web3().action;
115
+ const isConnected = await provider.isConnected();
116
+ if (isConnected?.data === true) {
117
+ await provider.disconnect();
118
+ }
119
+ const response = await provider.connect();
120
+ if (response.status === 401) {
121
+ throw new WalletConnectionError('User has rejected the connection');
122
+ } else if (response.status !== 200) {
123
+ throw new WalletConnectionError('Wallet connect issue');
124
+ }
125
+ let accountDetail = { ...response.data };
126
+
127
+ if (!accountDetail.publicKey) {
128
+ const accountResp = await provider.account();
129
+ if (!accountResp.data.publicKey) {
130
+ throw new WalletConnectionError('Wallet connect issue', response.data);
131
+ }
132
+ accountDetail = { ...accountResp.data };
140
133
  }
141
- await provider?.connect();
134
+ this._wallet = {
135
+ connected: true,
136
+ ...accountDetail
137
+ };
138
+ this._provider = provider;
139
+ this.emit('connect', this._wallet.publicKey);
142
140
  } catch (error: any) {
143
141
  this.emit('error', error);
144
142
  throw error;
@@ -148,68 +146,86 @@ export class FewchaWalletAdapter extends BaseWalletAdapter {
148
146
  }
149
147
 
150
148
  async disconnect(): Promise<void> {
151
- const wallet = this._wallet;
152
- if (wallet) {
153
- this._wallet = null;
154
-
149
+ const provider = this._provider;
150
+ if (provider) {
155
151
  try {
156
- const provider = this._provider;
157
- await provider?.disconnect();
152
+ const isDisconnected = await provider.disconnect();
153
+ if (isDisconnected.data === true) {
154
+ this._provider = undefined;
155
+ this._wallet = null;
156
+ } else {
157
+ throw new Error('Disconnect failed');
158
+ }
158
159
  } catch (error: any) {
159
160
  this.emit('error', new WalletDisconnectionError(error?.message, error));
161
+ throw error;
160
162
  }
161
163
  }
164
+ this.emit('disconnect');
162
165
  }
163
166
 
164
167
  async signTransaction(transaction: TransactionPayload): Promise<SubmitTransactionRequest> {
165
168
  try {
166
- const request = new URLSearchParams({
167
- request: JSON.stringify({
168
- method: 'signTransaction',
169
- payload: transaction
170
- }),
171
- origin: window.location.origin
172
- }).toString();
173
- const popup = window.open(
174
- `${WEBWALLET_URL}?${request}`,
175
- 'Transaction Confirmation',
176
- 'scrollbars=no,resizable=no,status=no,location=no,toolbar=no,menubar=no,width=440,height=700'
177
- );
178
- if (!popup) throw new WalletNotConnectedError();
179
- const promise = await new Promise((resolve, reject) => {
180
- this.once('success', resolve);
181
- this.once('error', reject);
182
- });
183
- return promise as SubmitTransactionRequest;
169
+ const wallet = this._wallet;
170
+ if (!wallet) throw new WalletNotConnectedError();
171
+
172
+ const provider = this._provider || window.fewcha;
173
+ const tx = await provider.generateTransaction(transaction as EntryFunctionPayload);
174
+ if (!tx) throw new Error('Cannot generate transaction');
175
+ const response = await provider?.signTransaction(tx.data);
176
+
177
+ if (!response) {
178
+ throw new Error('No response');
179
+ }
180
+ const result = { hash: response } as any;
181
+ return result as SubmitTransactionRequest;
184
182
  } catch (error: any) {
185
- this.emit('error', error);
183
+ const errMsg = error instanceof Error ? error.message : error.response.data.message;
184
+ this.emit('error', new WalletSignTransactionError(errMsg));
186
185
  throw error;
187
186
  }
188
187
  }
189
188
 
190
- async signAndSubmitTransaction(transaction: TransactionPayload): Promise<PendingTransaction> {
189
+ async signAndSubmitTransaction(
190
+ transaction: TransactionPayload
191
+ ): Promise<{ hash: HexEncodedBytes }> {
191
192
  try {
192
193
  const wallet = this._wallet;
193
194
  if (!wallet) throw new WalletNotConnectedError();
194
195
 
195
- try {
196
- const provider = this._provider;
197
- const tx = await aptosClient.generateTransaction(wallet.address, transaction);
198
- await provider?.signAndSubmitTransaction(tx);
199
-
200
- const promise = await new Promise((resolve, reject) => {
201
- this.once('success', resolve);
202
- this.once('error', reject);
203
- });
204
- return {
205
- hash: promise
206
- } as PendingTransaction;
207
- } catch (error: any) {
208
- const errMsg = error instanceof Error ? error.message : error.response.data.message;
209
- throw new WalletSignTransactionError(errMsg);
196
+ const provider = this._provider || window.fewcha;
197
+ const tx = await provider.generateTransaction(transaction as EntryFunctionPayload);
198
+ if (!tx) throw new Error('Cannot generate transaction');
199
+ const response = await provider?.signAndSubmitTransaction(tx.data);
200
+ if (response.status === 401) {
201
+ throw new Error('User has rejected the transaction');
202
+ } else if (response.status !== 200) {
203
+ throw new Error('Transaction issue');
210
204
  }
205
+ return {
206
+ hash: response.data
207
+ };
211
208
  } catch (error: any) {
212
- this.emit('error', error);
209
+ const errMsg = error instanceof Error ? error.message : error.response.data.message;
210
+ this.emit('error', new WalletSignAndSubmitMessageError(errMsg));
211
+ throw error;
212
+ }
213
+ }
214
+
215
+ async signMessage(message: string): Promise<string> {
216
+ try {
217
+ const wallet = this._wallet;
218
+ const provider = this._provider || window.fewcha;
219
+ if (!wallet || !provider) throw new WalletNotConnectedError();
220
+ const response = await provider?.signMessage(message);
221
+ if (response) {
222
+ return response.data;
223
+ } else {
224
+ throw new Error('Sign Message failed');
225
+ }
226
+ } catch (error: any) {
227
+ const errMsg = error.message;
228
+ this.emit('error', new WalletSignMessageError(errMsg));
213
229
  throw error;
214
230
  }
215
231
  }
@@ -1,13 +1,15 @@
1
1
  import { MaybeHexString } from 'aptos';
2
2
  import {
3
- PendingTransaction,
3
+ TransactionPayload,
4
4
  SubmitTransactionRequest,
5
- TransactionPayload
6
- } from 'aptos/dist/api/data-contracts';
5
+ HexEncodedBytes
6
+ } from 'aptos/dist/generated';
7
7
  import {
8
8
  WalletDisconnectionError,
9
9
  WalletNotConnectedError,
10
10
  WalletNotReadyError,
11
+ WalletSignAndSubmitMessageError,
12
+ WalletSignMessageError,
11
13
  WalletSignTransactionError
12
14
  } from '../WalletProviders/errors';
13
15
  import {
@@ -28,6 +30,7 @@ interface IHippoWallet {
28
30
  isConnected: () => Promise<boolean>;
29
31
  signAndSubmitTransaction(transaction: any): Promise<any>;
30
32
  signTransaction(transaction: any): Promise<void>;
33
+ signMessage(message: string): Promise<string>;
31
34
  disconnect(): Promise<void>;
32
35
  }
33
36
 
@@ -37,7 +40,7 @@ interface HippoWindow extends Window {
37
40
 
38
41
  declare const window: HippoWindow;
39
42
 
40
- export const HippoExtensionWalletName = 'Hippo Wallet' as WalletName<'Hippo Wallet'>;
43
+ export const HippoExtensionWalletName = 'Hippo' as WalletName<'Hippo'>;
41
44
 
42
45
  export interface HippoExtensionWalletAdapterConfig {
43
46
  provider?: IHippoWallet;
@@ -73,13 +76,13 @@ export class HippoExtensionWalletAdapter extends BaseWalletAdapter {
73
76
  }: HippoExtensionWalletAdapterConfig = {}) {
74
77
  super();
75
78
 
76
- this._provider = window.hippoWallet;
79
+ this._provider = typeof window !== 'undefined' ? window.hippoWallet : undefined;
77
80
  // this._network = network;
78
81
  this._timeout = timeout;
79
82
  this._connecting = false;
80
83
  this._wallet = null;
81
84
 
82
- if (this._readyState !== WalletReadyState.Unsupported) {
85
+ if (typeof window !== 'undefined' && this._readyState !== WalletReadyState.Unsupported) {
83
86
  scopePollingDetectionStrategy(() => {
84
87
  if (window.hippoWallet) {
85
88
  this._readyState = WalletReadyState.Installed;
@@ -178,7 +181,9 @@ export class HippoExtensionWalletAdapter extends BaseWalletAdapter {
178
181
  }
179
182
  }
180
183
 
181
- async signAndSubmitTransaction(transaction: TransactionPayload): Promise<PendingTransaction> {
184
+ async signAndSubmitTransaction(
185
+ transaction: TransactionPayload
186
+ ): Promise<{ hash: HexEncodedBytes }> {
182
187
  try {
183
188
  const wallet = this._wallet;
184
189
  if (!wallet) throw new WalletNotConnectedError();
@@ -187,17 +192,35 @@ export class HippoExtensionWalletAdapter extends BaseWalletAdapter {
187
192
  const provider = this._provider || window.hippoWallet;
188
193
  const response = await provider?.signAndSubmitTransaction(transaction);
189
194
  if (response) {
190
- return response.detail;
195
+ return response.detail.hash;
191
196
  } else {
192
197
  throw new Error('Transaction failed');
193
198
  }
194
199
  } catch (error: any) {
195
200
  // console.log('transact err', error, error.message);
196
- throw new WalletSignTransactionError(error.message || error);
201
+ throw new WalletSignAndSubmitMessageError(error.message || error);
197
202
  }
198
203
  } catch (error: any) {
199
204
  this.emit('error', error);
200
205
  throw error;
201
206
  }
202
207
  }
208
+
209
+ async signMessage(message: string): Promise<string> {
210
+ try {
211
+ const wallet = this._wallet;
212
+ const provider = this._provider || window.hippoWallet;
213
+ if (!wallet || !provider) throw new WalletNotConnectedError();
214
+ const response = await provider?.signMessage(message);
215
+ if (response) {
216
+ return response;
217
+ } else {
218
+ throw new Error('Sign Message failed');
219
+ }
220
+ } catch (error: any) {
221
+ const errMsg = error.message;
222
+ this.emit('error', new WalletSignMessageError(errMsg));
223
+ throw error;
224
+ }
225
+ }
203
226
  }
@@ -1,9 +1,9 @@
1
1
  import { MaybeHexString } from 'aptos';
2
2
  import {
3
- PendingTransaction,
3
+ TransactionPayload,
4
4
  SubmitTransactionRequest,
5
- TransactionPayload
6
- } from 'aptos/dist/api/data-contracts';
5
+ HexEncodedBytes
6
+ } from 'aptos/dist/generated';
7
7
  import { WEBWALLET_URL } from '../config/aptosConstants';
8
8
  import {
9
9
  WalletNotConnectedError,
@@ -12,7 +12,7 @@ import {
12
12
  } from '../WalletProviders/errors';
13
13
  import { AccountKeys, BaseWalletAdapter, WalletName, WalletReadyState } from './BaseAdapter';
14
14
 
15
- export const HippoWalletName = 'Hippo Web Wallet' as WalletName<'Hippo Web Wallet'>;
15
+ export const HippoWalletName = 'Hippo Web' as WalletName<'Hippo Web'>;
16
16
 
17
17
  export interface HippoWalletAdapterConfig {
18
18
  provider?: string;
@@ -102,7 +102,7 @@ export class HippoWalletAdapter extends BaseWalletAdapter {
102
102
  };
103
103
  this.emit('connect', this._wallet);
104
104
  } else if (e.data.method === 'success') {
105
- this.emit('success', e.data.detail);
105
+ this.emit('success', e.data.detail?.hash);
106
106
  } else if (e.data.method === 'fail') {
107
107
  this.emit('error', new WalletSignAndSubmitMessageError(e.data.error));
108
108
  } else if (e.data.method === 'disconnected') {
@@ -168,7 +168,9 @@ export class HippoWalletAdapter extends BaseWalletAdapter {
168
168
  }
169
169
  }
170
170
 
171
- async signAndSubmitTransaction(transaction: TransactionPayload): Promise<PendingTransaction> {
171
+ async signAndSubmitTransaction(
172
+ transaction: TransactionPayload
173
+ ): Promise<{ hash: HexEncodedBytes }> {
172
174
  try {
173
175
  const request = new URLSearchParams({
174
176
  request: JSON.stringify({
@@ -187,7 +189,33 @@ export class HippoWalletAdapter extends BaseWalletAdapter {
187
189
  this.once('success', resolve);
188
190
  this.once('error', reject);
189
191
  });
190
- return promise as PendingTransaction;
192
+ return promise as { hash: HexEncodedBytes };
193
+ } catch (error: any) {
194
+ this.emit('error', error);
195
+ throw error;
196
+ }
197
+ }
198
+
199
+ async signMessage(message: string): Promise<string> {
200
+ try {
201
+ const request = new URLSearchParams({
202
+ request: JSON.stringify({
203
+ method: 'signMessage',
204
+ payload: message
205
+ }),
206
+ origin: window.location.origin
207
+ }).toString();
208
+ const popup = window.open(
209
+ `${WEBWALLET_URL}?${request}`,
210
+ 'Transaction Confirmation',
211
+ 'scrollbars=no,resizable=no,status=no,location=no,toolbar=no,menubar=no,width=440,height=700'
212
+ );
213
+ if (!popup) throw new WalletNotConnectedError();
214
+ const promise = await new Promise((resolve, reject) => {
215
+ this.once('success', resolve);
216
+ this.once('error', reject);
217
+ });
218
+ return promise as string;
191
219
  } catch (error: any) {
192
220
  this.emit('error', error);
193
221
  throw error;
@@ -1,14 +1,15 @@
1
1
  import { MaybeHexString } from 'aptos';
2
2
  import {
3
- PendingTransaction,
3
+ TransactionPayload,
4
4
  SubmitTransactionRequest,
5
- TransactionPayload
6
- } from 'aptos/dist/api/data-contracts';
7
- import { aptosClient } from '../config/aptosConstants';
5
+ HexEncodedBytes
6
+ } from 'aptos/dist/generated';
8
7
  import {
9
8
  WalletDisconnectionError,
10
9
  WalletNotConnectedError,
11
10
  WalletNotReadyError,
11
+ WalletSignAndSubmitMessageError,
12
+ WalletSignMessageError,
12
13
  WalletSignTransactionError
13
14
  } from '../WalletProviders/errors';
14
15
  import {
@@ -33,12 +34,13 @@ interface MartianAccount {
33
34
  isConnected: boolean;
34
35
  }
35
36
  interface IMartianWallet {
36
- connect: (params?: any) => Promise<ConnectMartianAccount>;
37
+ connect: () => Promise<ConnectMartianAccount>;
37
38
  account(): Promise<MartianAccount>;
38
39
  isConnected(): Promise<boolean>;
39
40
  generateTransaction(sender: MaybeHexString, payload: any): Promise<any>;
40
- signAndSubmitTransaction(transaction: any): Promise<string>;
41
- // signTransaction(transaction: any): Promise<void>;
41
+ signAndSubmitTransaction(transaction: TransactionPayload): Promise<HexEncodedBytes>;
42
+ signTransaction(transaction: TransactionPayload): Promise<HexEncodedBytes>;
43
+ signMessage(message: string): Promise<string>;
42
44
  disconnect(): Promise<void>;
43
45
  }
44
46
 
@@ -48,7 +50,7 @@ interface MartianWindow extends Window {
48
50
 
49
51
  declare const window: MartianWindow;
50
52
 
51
- export const MartianWalletName = 'MartianWallet' as WalletName<'MartianWallet'>;
53
+ export const MartianWalletName = 'Martian' as WalletName<'Martian'>;
52
54
 
53
55
  export interface MartianWalletAdapterConfig {
54
56
  provider?: IMartianWallet;
@@ -62,7 +64,7 @@ export class MartianWalletAdapter extends BaseWalletAdapter {
62
64
  url = 'https://chrome.google.com/webstore/detail/martian-wallet/efbglgofoippbgcjepnhiblaibcnclgk';
63
65
 
64
66
  icon =
65
- 'https://www.gitbook.com/cdn-cgi/image/width=40,height=40,fit=contain,dpr=2,format=auto/https%3A%2F%2F1159842905-files.gitbook.io%2F~%2Ffiles%2Fv0%2Fb%2Fgitbook-x-prod.appspot.com%2Fo%2Fspaces%252FXillBNDwQOz0oPJ4OtRH%252Ficon%252FaBwgf6d32iEu3YE56Jvk%252Flogo128_squ.png%3Falt%3Dmedia%26token%3D0f5bef1f-a4bd-495e-a447-289c235bb76a';
67
+ '';
66
68
 
67
69
  protected _provider: IMartianWallet | undefined;
68
70
 
@@ -85,15 +87,15 @@ export class MartianWalletAdapter extends BaseWalletAdapter {
85
87
  }: MartianWalletAdapterConfig = {}) {
86
88
  super();
87
89
 
88
- this._provider = window.martian;
90
+ this._provider = typeof window !== 'undefined' ? window.martian : undefined;
89
91
  // this._network = network;
90
92
  this._timeout = timeout;
91
93
  this._connecting = false;
92
94
  this._wallet = null;
93
95
 
94
- if (this._readyState !== WalletReadyState.Unsupported) {
96
+ if (typeof window !== 'undefined' && this._readyState !== WalletReadyState.Unsupported) {
95
97
  scopePollingDetectionStrategy(() => {
96
- if (window.martian) {
98
+ if (this._provider) {
97
99
  this._readyState = WalletReadyState.Installed;
98
100
  this.emit('readyStateChange', this._readyState);
99
101
  return true;
@@ -125,9 +127,7 @@ export class MartianWalletAdapter extends BaseWalletAdapter {
125
127
 
126
128
  async connect(): Promise<void> {
127
129
  try {
128
- // console.log(1, window.martian);
129
130
  if (this.connected || this.connecting) return;
130
- // console.log(2);
131
131
  if (
132
132
  !(
133
133
  this._readyState === WalletReadyState.Loadable ||
@@ -135,14 +135,14 @@ export class MartianWalletAdapter extends BaseWalletAdapter {
135
135
  )
136
136
  )
137
137
  throw new WalletNotReadyError();
138
- // console.log(3);
139
138
  this._connecting = true;
140
139
 
141
- const provider = window.martian;
142
- await provider?.disconnect();
143
- // console.log(4);
140
+ const provider = this._provider || window.martian;
141
+ const isConnected = await provider?.isConnected();
142
+ if (isConnected) {
143
+ await provider?.disconnect();
144
+ }
144
145
  const response = await provider?.connect();
145
- // console.log(5, response);
146
146
 
147
147
  if (!response) {
148
148
  throw new WalletNotConnectedError('No connect response');
@@ -154,16 +154,12 @@ export class MartianWalletAdapter extends BaseWalletAdapter {
154
154
  ...walletAccount,
155
155
  isConnected: true
156
156
  };
157
- // console.log(6, this._wallet);
158
157
  }
159
- // console.log(9, this._wallet?.address);
160
158
  this.emit('connect', this._wallet?.address || '');
161
159
  } catch (error: any) {
162
- // console.log(10, error);
163
- this.emit('error', error);
160
+ this.emit('error', new Error(error));
164
161
  throw error;
165
162
  } finally {
166
- // console.log(11);
167
163
  this._connecting = false;
168
164
  }
169
165
  }
@@ -187,39 +183,58 @@ export class MartianWalletAdapter extends BaseWalletAdapter {
187
183
  async signTransaction(transactionPyld: TransactionPayload): Promise<SubmitTransactionRequest> {
188
184
  try {
189
185
  const wallet = this._wallet;
190
- const provider = this._provider;
191
- if (!wallet) throw new WalletNotConnectedError();
192
- const tx = await aptosClient.generateTransaction(wallet.address || '', transactionPyld);
193
- const response = await provider?.signAndSubmitTransaction(tx);
186
+ const provider = this._provider || window.martian;
187
+ if (!wallet || !provider) throw new WalletNotConnectedError();
188
+ const tx = await provider.generateTransaction(wallet.address || '', transactionPyld);
189
+ if (!tx) throw new Error('Cannot generate transaction');
190
+ const response = await provider?.signTransaction(tx);
194
191
 
195
192
  if (!response) {
196
- throw new WalletSignTransactionError('No response');
193
+ throw new Error('No response');
197
194
  }
198
- return {
199
- hash: response
200
- } as PendingTransaction;
195
+ const result = { hash: response } as any;
196
+ return result as SubmitTransactionRequest;
201
197
  } catch (error: any) {
202
- this.emit('error', error);
198
+ this.emit('error', new WalletSignTransactionError(error));
203
199
  throw error;
204
200
  }
205
201
  }
206
202
 
207
- async signAndSubmitTransaction(transactionPyld: TransactionPayload): Promise<PendingTransaction> {
203
+ async signAndSubmitTransaction(
204
+ transactionPyld: TransactionPayload
205
+ ): Promise<{ hash: HexEncodedBytes }> {
208
206
  try {
209
207
  const wallet = this._wallet;
210
- const provider = this._provider;
211
- if (!wallet) throw new WalletNotConnectedError();
212
- const tx = await provider?.generateTransaction(wallet.address || '', transactionPyld);
208
+ const provider = this._provider || window.martian;
209
+ if (!wallet || !provider) throw new WalletNotConnectedError();
210
+ const tx = await provider.generateTransaction(wallet.address || '', transactionPyld);
211
+ if (!tx) throw new Error('Cannot generate transaction');
213
212
  const response = await provider?.signAndSubmitTransaction(tx);
214
213
 
215
214
  if (!response) {
216
- throw new WalletSignTransactionError('No response');
215
+ throw new Error('No response');
216
+ }
217
+ return { hash: response };
218
+ } catch (error: any) {
219
+ this.emit('error', new WalletSignAndSubmitMessageError(error));
220
+ throw error;
221
+ }
222
+ }
223
+
224
+ async signMessage(message: string): Promise<string> {
225
+ try {
226
+ const wallet = this._wallet;
227
+ const provider = this._provider || window.martian;
228
+ if (!wallet || !provider) throw new WalletNotConnectedError();
229
+ const response = await provider?.signMessage(message);
230
+ if (response) {
231
+ return response;
232
+ } else {
233
+ throw new Error('Sign Message failed');
217
234
  }
218
- return {
219
- hash: response
220
- } as PendingTransaction;
221
235
  } catch (error: any) {
222
- this.emit('error', error);
236
+ const errMsg = error.message;
237
+ this.emit('error', new WalletSignMessageError(errMsg));
223
238
  throw error;
224
239
  }
225
240
  }