@frak-labs/core-sdk 0.1.0-beta.afa252b0 → 0.1.0-beta.c7e026e5
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/cdn/bundle.iife.js +14 -0
- package/dist/actions-CEEObPYc.js +1 -0
- package/dist/actions-DbQhWYx8.cjs +1 -0
- package/dist/actions.cjs +1 -1
- package/dist/actions.d.cts +3 -1481
- package/dist/actions.d.ts +3 -1481
- package/dist/actions.js +1 -1
- package/dist/bundle.cjs +1 -13
- package/dist/bundle.d.cts +6 -2087
- package/dist/bundle.d.ts +6 -2087
- package/dist/bundle.js +1 -13
- package/dist/index-7OZ39x1U.d.ts +195 -0
- package/dist/index-C6FxkWPC.d.cts +511 -0
- package/dist/index-UFX7xCg3.d.ts +351 -0
- package/dist/index-d8xS4ryI.d.ts +511 -0
- package/dist/index-p4FqSp8z.d.cts +351 -0
- package/dist/index-zDq-VlKx.d.cts +195 -0
- package/dist/index.cjs +1 -13
- package/dist/index.d.cts +4 -1387
- package/dist/index.d.ts +4 -1387
- package/dist/index.js +1 -13
- package/dist/interaction-DMJ3ZfaF.d.cts +45 -0
- package/dist/interaction-KX1h9a7V.d.ts +45 -0
- package/dist/interactions-DnfM3oe0.js +1 -0
- package/dist/interactions-EIXhNLf6.cjs +1 -0
- package/dist/interactions.cjs +1 -1
- package/dist/interactions.d.cts +2 -182
- package/dist/interactions.d.ts +2 -182
- package/dist/interactions.js +1 -1
- package/dist/openSso-D--Airj6.d.cts +1018 -0
- package/dist/openSso-DsKJ4y0j.d.ts +1018 -0
- package/dist/productTypes-BUkXJKZ7.cjs +1 -0
- package/dist/productTypes-CGb1MmBF.js +1 -0
- package/dist/src-B_xO0AR6.cjs +13 -0
- package/dist/src-D2d52OZa.js +13 -0
- package/dist/trackEvent-CHnYa85W.js +1 -0
- package/dist/trackEvent-GuQm_1Nm.cjs +1 -0
- package/package.json +23 -18
- package/src/actions/displayEmbeddedWallet.test.ts +194 -0
- package/src/actions/displayEmbeddedWallet.ts +20 -0
- package/src/actions/displayModal.test.ts +387 -0
- package/src/actions/displayModal.ts +131 -0
- package/src/actions/getProductInformation.test.ts +133 -0
- package/src/actions/getProductInformation.ts +14 -0
- package/src/actions/index.ts +29 -0
- package/src/actions/openSso.test.ts +407 -0
- package/src/actions/openSso.ts +116 -0
- package/src/actions/prepareSso.test.ts +223 -0
- package/src/actions/prepareSso.ts +48 -0
- package/src/actions/referral/processReferral.ts +230 -0
- package/src/actions/referral/referralInteraction.test.ts +153 -0
- package/src/actions/referral/referralInteraction.ts +57 -0
- package/src/actions/sendInteraction.test.ts +219 -0
- package/src/actions/sendInteraction.ts +32 -0
- package/src/actions/trackPurchaseStatus.test.ts +287 -0
- package/src/actions/trackPurchaseStatus.ts +53 -0
- package/src/actions/watchWalletStatus.test.ts +372 -0
- package/src/actions/watchWalletStatus.ts +94 -0
- package/src/actions/wrapper/modalBuilder.test.ts +253 -0
- package/src/actions/wrapper/modalBuilder.ts +212 -0
- package/src/actions/wrapper/sendTransaction.test.ts +164 -0
- package/src/actions/wrapper/sendTransaction.ts +62 -0
- package/src/actions/wrapper/siweAuthenticate.test.ts +290 -0
- package/src/actions/wrapper/siweAuthenticate.ts +94 -0
- package/src/bundle.ts +3 -0
- package/src/clients/DebugInfo.ts +182 -0
- package/src/clients/createIFrameFrakClient.ts +287 -0
- package/src/clients/index.ts +3 -0
- package/src/clients/setupClient.test.ts +343 -0
- package/src/clients/setupClient.ts +73 -0
- package/src/clients/transports/iframeLifecycleManager.test.ts +399 -0
- package/src/clients/transports/iframeLifecycleManager.ts +90 -0
- package/src/constants/interactionTypes.ts +44 -0
- package/src/constants/locales.ts +14 -0
- package/src/constants/productTypes.ts +33 -0
- package/src/index.ts +101 -0
- package/src/interactions/index.ts +5 -0
- package/src/interactions/pressEncoder.test.ts +215 -0
- package/src/interactions/pressEncoder.ts +53 -0
- package/src/interactions/purchaseEncoder.test.ts +291 -0
- package/src/interactions/purchaseEncoder.ts +99 -0
- package/src/interactions/referralEncoder.test.ts +170 -0
- package/src/interactions/referralEncoder.ts +47 -0
- package/src/interactions/retailEncoder.test.ts +107 -0
- package/src/interactions/retailEncoder.ts +37 -0
- package/src/interactions/webshopEncoder.test.ts +56 -0
- package/src/interactions/webshopEncoder.ts +30 -0
- package/src/types/client.ts +14 -0
- package/src/types/compression.ts +22 -0
- package/src/types/config.ts +111 -0
- package/src/types/context.ts +13 -0
- package/src/types/index.ts +71 -0
- package/src/types/lifecycle/client.ts +46 -0
- package/src/types/lifecycle/iframe.ts +35 -0
- package/src/types/lifecycle/index.ts +2 -0
- package/src/types/rpc/displayModal.ts +84 -0
- package/src/types/rpc/embedded/index.ts +68 -0
- package/src/types/rpc/embedded/loggedIn.ts +55 -0
- package/src/types/rpc/embedded/loggedOut.ts +28 -0
- package/src/types/rpc/interaction.ts +43 -0
- package/src/types/rpc/modal/final.ts +46 -0
- package/src/types/rpc/modal/generic.ts +46 -0
- package/src/types/rpc/modal/index.ts +20 -0
- package/src/types/rpc/modal/login.ts +32 -0
- package/src/types/rpc/modal/openSession.ts +25 -0
- package/src/types/rpc/modal/siweAuthenticate.ts +37 -0
- package/src/types/rpc/modal/transaction.ts +33 -0
- package/src/types/rpc/productInformation.ts +59 -0
- package/src/types/rpc/sso.ts +80 -0
- package/src/types/rpc/walletStatus.ts +35 -0
- package/src/types/rpc.ts +158 -0
- package/src/types/transport.ts +34 -0
- package/src/utils/FrakContext.test.ts +407 -0
- package/src/utils/FrakContext.ts +158 -0
- package/src/utils/compression/b64.test.ts +181 -0
- package/src/utils/compression/b64.ts +29 -0
- package/src/utils/compression/compress.test.ts +123 -0
- package/src/utils/compression/compress.ts +11 -0
- package/src/utils/compression/decompress.test.ts +145 -0
- package/src/utils/compression/decompress.ts +11 -0
- package/src/utils/compression/index.ts +3 -0
- package/src/utils/computeProductId.test.ts +80 -0
- package/src/utils/computeProductId.ts +11 -0
- package/src/utils/constants.test.ts +23 -0
- package/src/utils/constants.ts +4 -0
- package/src/utils/formatAmount.test.ts +113 -0
- package/src/utils/formatAmount.ts +18 -0
- package/src/utils/getCurrencyAmountKey.test.ts +44 -0
- package/src/utils/getCurrencyAmountKey.ts +15 -0
- package/src/utils/getSupportedCurrency.test.ts +51 -0
- package/src/utils/getSupportedCurrency.ts +14 -0
- package/src/utils/getSupportedLocale.test.ts +64 -0
- package/src/utils/getSupportedLocale.ts +16 -0
- package/src/utils/iframeHelper.test.ts +450 -0
- package/src/utils/iframeHelper.ts +143 -0
- package/src/utils/index.ts +21 -0
- package/src/utils/sso.test.ts +361 -0
- package/src/utils/sso.ts +119 -0
- package/src/utils/ssoUrlListener.ts +60 -0
- package/src/utils/trackEvent.test.ts +162 -0
- package/src/utils/trackEvent.ts +26 -0
- package/cdn/bundle.js +0 -19
- package/cdn/bundle.js.LICENSE.txt +0 -10
|
@@ -0,0 +1,372 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Tests for watchWalletStatus action
|
|
3
|
+
* Tests wallet status watching and side effects
|
|
4
|
+
*/
|
|
5
|
+
|
|
6
|
+
import { vi } from "vitest";
|
|
7
|
+
|
|
8
|
+
// Mock Deferred before imports
|
|
9
|
+
vi.mock("@frak-labs/frame-connector", () => ({
|
|
10
|
+
Deferred: class {
|
|
11
|
+
promise: Promise<any>;
|
|
12
|
+
resolve: (value: any) => void;
|
|
13
|
+
|
|
14
|
+
constructor() {
|
|
15
|
+
let resolveFunc: (value: any) => void;
|
|
16
|
+
this.promise = new Promise((resolve) => {
|
|
17
|
+
resolveFunc = resolve;
|
|
18
|
+
});
|
|
19
|
+
this.resolve = resolveFunc!;
|
|
20
|
+
}
|
|
21
|
+
},
|
|
22
|
+
}));
|
|
23
|
+
|
|
24
|
+
import type { Address } from "viem";
|
|
25
|
+
import {
|
|
26
|
+
afterEach,
|
|
27
|
+
beforeEach,
|
|
28
|
+
describe,
|
|
29
|
+
expect,
|
|
30
|
+
it,
|
|
31
|
+
} from "../../tests/vitest-fixtures";
|
|
32
|
+
import type { FrakClient, WalletStatusReturnType } from "../types";
|
|
33
|
+
import { watchWalletStatus } from "./watchWalletStatus";
|
|
34
|
+
|
|
35
|
+
describe("watchWalletStatus", () => {
|
|
36
|
+
let mockSessionStorage: {
|
|
37
|
+
getItem: ReturnType<typeof vi.fn>;
|
|
38
|
+
setItem: ReturnType<typeof vi.fn>;
|
|
39
|
+
removeItem: ReturnType<typeof vi.fn>;
|
|
40
|
+
};
|
|
41
|
+
|
|
42
|
+
beforeEach(() => {
|
|
43
|
+
// Mock sessionStorage
|
|
44
|
+
mockSessionStorage = {
|
|
45
|
+
getItem: vi.fn(),
|
|
46
|
+
setItem: vi.fn(),
|
|
47
|
+
removeItem: vi.fn(),
|
|
48
|
+
};
|
|
49
|
+
Object.defineProperty(window, "sessionStorage", {
|
|
50
|
+
value: mockSessionStorage,
|
|
51
|
+
writable: true,
|
|
52
|
+
configurable: true,
|
|
53
|
+
});
|
|
54
|
+
});
|
|
55
|
+
|
|
56
|
+
afterEach(() => {
|
|
57
|
+
vi.clearAllMocks();
|
|
58
|
+
});
|
|
59
|
+
|
|
60
|
+
describe("without callback", () => {
|
|
61
|
+
it("should make one-shot request", async () => {
|
|
62
|
+
const mockStatus: WalletStatusReturnType = {
|
|
63
|
+
key: "connected",
|
|
64
|
+
wallet: "0x1234567890123456789012345678901234567890" as Address,
|
|
65
|
+
interactionToken: "token-123",
|
|
66
|
+
};
|
|
67
|
+
|
|
68
|
+
const mockClient = {
|
|
69
|
+
request: vi.fn().mockResolvedValue(mockStatus),
|
|
70
|
+
openPanel: {
|
|
71
|
+
setGlobalProperties: vi.fn(),
|
|
72
|
+
},
|
|
73
|
+
} as unknown as FrakClient;
|
|
74
|
+
|
|
75
|
+
const result = await watchWalletStatus(mockClient);
|
|
76
|
+
|
|
77
|
+
expect(mockClient.request).toHaveBeenCalledWith({
|
|
78
|
+
method: "frak_listenToWalletStatus",
|
|
79
|
+
});
|
|
80
|
+
expect(result).toEqual(mockStatus);
|
|
81
|
+
});
|
|
82
|
+
|
|
83
|
+
it("should save interaction token to sessionStorage", async () => {
|
|
84
|
+
const mockStatus: WalletStatusReturnType = {
|
|
85
|
+
key: "connected",
|
|
86
|
+
wallet: "0x1234567890123456789012345678901234567890" as Address,
|
|
87
|
+
interactionToken: "token-abc",
|
|
88
|
+
};
|
|
89
|
+
|
|
90
|
+
const mockClient = {
|
|
91
|
+
request: vi.fn().mockResolvedValue(mockStatus),
|
|
92
|
+
openPanel: {
|
|
93
|
+
setGlobalProperties: vi.fn(),
|
|
94
|
+
},
|
|
95
|
+
} as unknown as FrakClient;
|
|
96
|
+
|
|
97
|
+
await watchWalletStatus(mockClient);
|
|
98
|
+
|
|
99
|
+
expect(mockSessionStorage.setItem).toHaveBeenCalledWith(
|
|
100
|
+
"frak-wallet-interaction-token",
|
|
101
|
+
"token-abc"
|
|
102
|
+
);
|
|
103
|
+
});
|
|
104
|
+
|
|
105
|
+
it("should remove interaction token when not present", async () => {
|
|
106
|
+
const mockStatus: WalletStatusReturnType = {
|
|
107
|
+
key: "not-connected",
|
|
108
|
+
};
|
|
109
|
+
|
|
110
|
+
const mockClient = {
|
|
111
|
+
request: vi.fn().mockResolvedValue(mockStatus),
|
|
112
|
+
openPanel: {
|
|
113
|
+
setGlobalProperties: vi.fn(),
|
|
114
|
+
},
|
|
115
|
+
} as unknown as FrakClient;
|
|
116
|
+
|
|
117
|
+
await watchWalletStatus(mockClient);
|
|
118
|
+
|
|
119
|
+
expect(mockSessionStorage.removeItem).toHaveBeenCalledWith(
|
|
120
|
+
"frak-wallet-interaction-token"
|
|
121
|
+
);
|
|
122
|
+
});
|
|
123
|
+
|
|
124
|
+
it("should update OpenPanel global properties", async () => {
|
|
125
|
+
const mockStatus: WalletStatusReturnType = {
|
|
126
|
+
key: "connected",
|
|
127
|
+
wallet: "0xabcdefabcdefabcdefabcdefabcdefabcdefabcd" as Address,
|
|
128
|
+
};
|
|
129
|
+
|
|
130
|
+
const mockClient = {
|
|
131
|
+
request: vi.fn().mockResolvedValue(mockStatus),
|
|
132
|
+
openPanel: {
|
|
133
|
+
setGlobalProperties: vi.fn(),
|
|
134
|
+
},
|
|
135
|
+
} as unknown as FrakClient;
|
|
136
|
+
|
|
137
|
+
await watchWalletStatus(mockClient);
|
|
138
|
+
|
|
139
|
+
expect(
|
|
140
|
+
mockClient.openPanel?.setGlobalProperties
|
|
141
|
+
).toHaveBeenCalledWith({
|
|
142
|
+
wallet: "0xabcdefabcdefabcdefabcdefabcdefabcdefabcd",
|
|
143
|
+
});
|
|
144
|
+
});
|
|
145
|
+
|
|
146
|
+
it("should set wallet to null when not connected", async () => {
|
|
147
|
+
const mockStatus: WalletStatusReturnType = {
|
|
148
|
+
key: "not-connected",
|
|
149
|
+
};
|
|
150
|
+
|
|
151
|
+
const mockClient = {
|
|
152
|
+
request: vi.fn().mockResolvedValue(mockStatus),
|
|
153
|
+
openPanel: {
|
|
154
|
+
setGlobalProperties: vi.fn(),
|
|
155
|
+
},
|
|
156
|
+
} as unknown as FrakClient;
|
|
157
|
+
|
|
158
|
+
await watchWalletStatus(mockClient);
|
|
159
|
+
|
|
160
|
+
expect(
|
|
161
|
+
mockClient.openPanel?.setGlobalProperties
|
|
162
|
+
).toHaveBeenCalledWith({
|
|
163
|
+
wallet: null,
|
|
164
|
+
});
|
|
165
|
+
});
|
|
166
|
+
|
|
167
|
+
it("should work without openPanel", async () => {
|
|
168
|
+
const mockStatus: WalletStatusReturnType = {
|
|
169
|
+
key: "connected",
|
|
170
|
+
wallet: "0x1234567890123456789012345678901234567890" as Address,
|
|
171
|
+
};
|
|
172
|
+
|
|
173
|
+
const mockClient = {
|
|
174
|
+
request: vi.fn().mockResolvedValue(mockStatus),
|
|
175
|
+
} as unknown as FrakClient;
|
|
176
|
+
|
|
177
|
+
const result = await watchWalletStatus(mockClient);
|
|
178
|
+
|
|
179
|
+
expect(result).toEqual(mockStatus);
|
|
180
|
+
});
|
|
181
|
+
});
|
|
182
|
+
|
|
183
|
+
describe("with callback", () => {
|
|
184
|
+
it("should setup listener request", async () => {
|
|
185
|
+
const mockStatus: WalletStatusReturnType = {
|
|
186
|
+
key: "connected",
|
|
187
|
+
wallet: "0x1234567890123456789012345678901234567890" as Address,
|
|
188
|
+
};
|
|
189
|
+
|
|
190
|
+
const mockCallback = vi.fn();
|
|
191
|
+
const mockClient = {
|
|
192
|
+
listenerRequest: vi.fn((_params, callback) => {
|
|
193
|
+
// Simulate status update
|
|
194
|
+
setTimeout(() => callback(mockStatus), 0);
|
|
195
|
+
}),
|
|
196
|
+
openPanel: {
|
|
197
|
+
setGlobalProperties: vi.fn(),
|
|
198
|
+
},
|
|
199
|
+
} as unknown as FrakClient;
|
|
200
|
+
|
|
201
|
+
const resultPromise = watchWalletStatus(mockClient, mockCallback);
|
|
202
|
+
|
|
203
|
+
expect(mockClient.listenerRequest).toHaveBeenCalled();
|
|
204
|
+
|
|
205
|
+
await resultPromise;
|
|
206
|
+
});
|
|
207
|
+
|
|
208
|
+
it("should call callback with status updates", async () => {
|
|
209
|
+
const mockStatus: WalletStatusReturnType = {
|
|
210
|
+
key: "connected",
|
|
211
|
+
wallet: "0x1234567890123456789012345678901234567890" as Address,
|
|
212
|
+
interactionToken: "token-123",
|
|
213
|
+
};
|
|
214
|
+
|
|
215
|
+
const mockCallback = vi.fn();
|
|
216
|
+
const mockClient = {
|
|
217
|
+
listenerRequest: vi.fn((_params, callback) => {
|
|
218
|
+
setTimeout(() => callback(mockStatus), 0);
|
|
219
|
+
}),
|
|
220
|
+
openPanel: {
|
|
221
|
+
setGlobalProperties: vi.fn(),
|
|
222
|
+
},
|
|
223
|
+
} as unknown as FrakClient;
|
|
224
|
+
|
|
225
|
+
await watchWalletStatus(mockClient, mockCallback);
|
|
226
|
+
|
|
227
|
+
expect(mockCallback).toHaveBeenCalledWith(mockStatus);
|
|
228
|
+
});
|
|
229
|
+
|
|
230
|
+
it("should resolve promise with first status", async () => {
|
|
231
|
+
const firstStatus: WalletStatusReturnType = {
|
|
232
|
+
key: "connected",
|
|
233
|
+
wallet: "0x1234567890123456789012345678901234567890" as Address,
|
|
234
|
+
};
|
|
235
|
+
|
|
236
|
+
const secondStatus: WalletStatusReturnType = {
|
|
237
|
+
key: "connected",
|
|
238
|
+
wallet: "0xabcdefabcdefabcdefabcdefabcdefabcdefabcd" as Address,
|
|
239
|
+
};
|
|
240
|
+
|
|
241
|
+
const mockCallback = vi.fn();
|
|
242
|
+
const mockClient = {
|
|
243
|
+
listenerRequest: vi.fn((_params, callback) => {
|
|
244
|
+
setTimeout(() => {
|
|
245
|
+
callback(firstStatus);
|
|
246
|
+
callback(secondStatus);
|
|
247
|
+
}, 0);
|
|
248
|
+
}),
|
|
249
|
+
openPanel: {
|
|
250
|
+
setGlobalProperties: vi.fn(),
|
|
251
|
+
},
|
|
252
|
+
} as unknown as FrakClient;
|
|
253
|
+
|
|
254
|
+
const result = await watchWalletStatus(mockClient, mockCallback);
|
|
255
|
+
|
|
256
|
+
expect(result).toEqual(firstStatus);
|
|
257
|
+
expect(mockCallback).toHaveBeenCalledTimes(2);
|
|
258
|
+
});
|
|
259
|
+
|
|
260
|
+
it("should handle side effects for each status update", async () => {
|
|
261
|
+
const firstStatus: WalletStatusReturnType = {
|
|
262
|
+
key: "connected",
|
|
263
|
+
wallet: "0x1234567890123456789012345678901234567890" as Address,
|
|
264
|
+
interactionToken: "token-1",
|
|
265
|
+
};
|
|
266
|
+
|
|
267
|
+
const secondStatus: WalletStatusReturnType = {
|
|
268
|
+
key: "connected",
|
|
269
|
+
wallet: "0x1234567890123456789012345678901234567890" as Address,
|
|
270
|
+
interactionToken: "token-2",
|
|
271
|
+
};
|
|
272
|
+
|
|
273
|
+
const mockCallback = vi.fn();
|
|
274
|
+
const mockClient = {
|
|
275
|
+
listenerRequest: vi.fn((_params, callback) => {
|
|
276
|
+
setTimeout(() => {
|
|
277
|
+
callback(firstStatus);
|
|
278
|
+
callback(secondStatus);
|
|
279
|
+
}, 0);
|
|
280
|
+
}),
|
|
281
|
+
openPanel: {
|
|
282
|
+
setGlobalProperties: vi.fn(),
|
|
283
|
+
},
|
|
284
|
+
} as unknown as FrakClient;
|
|
285
|
+
|
|
286
|
+
await watchWalletStatus(mockClient, mockCallback);
|
|
287
|
+
|
|
288
|
+
// Both tokens should be saved
|
|
289
|
+
expect(mockSessionStorage.setItem).toHaveBeenCalledWith(
|
|
290
|
+
"frak-wallet-interaction-token",
|
|
291
|
+
"token-1"
|
|
292
|
+
);
|
|
293
|
+
expect(mockSessionStorage.setItem).toHaveBeenCalledWith(
|
|
294
|
+
"frak-wallet-interaction-token",
|
|
295
|
+
"token-2"
|
|
296
|
+
);
|
|
297
|
+
});
|
|
298
|
+
|
|
299
|
+
it("should save and remove interaction token based on status", async () => {
|
|
300
|
+
const connectedStatus: WalletStatusReturnType = {
|
|
301
|
+
key: "connected",
|
|
302
|
+
wallet: "0x1234567890123456789012345678901234567890" as Address,
|
|
303
|
+
interactionToken: "token-123",
|
|
304
|
+
};
|
|
305
|
+
|
|
306
|
+
const disconnectedStatus: WalletStatusReturnType = {
|
|
307
|
+
key: "not-connected",
|
|
308
|
+
};
|
|
309
|
+
|
|
310
|
+
const mockCallback = vi.fn();
|
|
311
|
+
const mockClient = {
|
|
312
|
+
listenerRequest: vi.fn((_params, callback) => {
|
|
313
|
+
setTimeout(() => {
|
|
314
|
+
callback(connectedStatus);
|
|
315
|
+
callback(disconnectedStatus);
|
|
316
|
+
}, 0);
|
|
317
|
+
}),
|
|
318
|
+
openPanel: {
|
|
319
|
+
setGlobalProperties: vi.fn(),
|
|
320
|
+
},
|
|
321
|
+
} as unknown as FrakClient;
|
|
322
|
+
|
|
323
|
+
await watchWalletStatus(mockClient, mockCallback);
|
|
324
|
+
|
|
325
|
+
expect(mockSessionStorage.setItem).toHaveBeenCalledWith(
|
|
326
|
+
"frak-wallet-interaction-token",
|
|
327
|
+
"token-123"
|
|
328
|
+
);
|
|
329
|
+
expect(mockSessionStorage.removeItem).toHaveBeenCalledWith(
|
|
330
|
+
"frak-wallet-interaction-token"
|
|
331
|
+
);
|
|
332
|
+
});
|
|
333
|
+
|
|
334
|
+
it("should update OpenPanel properties with each status", async () => {
|
|
335
|
+
const firstStatus: WalletStatusReturnType = {
|
|
336
|
+
key: "connected",
|
|
337
|
+
wallet: "0x1111111111111111111111111111111111111111" as Address,
|
|
338
|
+
};
|
|
339
|
+
|
|
340
|
+
const secondStatus: WalletStatusReturnType = {
|
|
341
|
+
key: "connected",
|
|
342
|
+
wallet: "0x2222222222222222222222222222222222222222" as Address,
|
|
343
|
+
};
|
|
344
|
+
|
|
345
|
+
const mockCallback = vi.fn();
|
|
346
|
+
const mockClient = {
|
|
347
|
+
listenerRequest: vi.fn((_params, callback) => {
|
|
348
|
+
setTimeout(() => {
|
|
349
|
+
callback(firstStatus);
|
|
350
|
+
callback(secondStatus);
|
|
351
|
+
}, 0);
|
|
352
|
+
}),
|
|
353
|
+
openPanel: {
|
|
354
|
+
setGlobalProperties: vi.fn(),
|
|
355
|
+
},
|
|
356
|
+
} as unknown as FrakClient;
|
|
357
|
+
|
|
358
|
+
await watchWalletStatus(mockClient, mockCallback);
|
|
359
|
+
|
|
360
|
+
expect(
|
|
361
|
+
mockClient.openPanel?.setGlobalProperties
|
|
362
|
+
).toHaveBeenCalledWith({
|
|
363
|
+
wallet: "0x1111111111111111111111111111111111111111",
|
|
364
|
+
});
|
|
365
|
+
expect(
|
|
366
|
+
mockClient.openPanel?.setGlobalProperties
|
|
367
|
+
).toHaveBeenCalledWith({
|
|
368
|
+
wallet: "0x2222222222222222222222222222222222222222",
|
|
369
|
+
});
|
|
370
|
+
});
|
|
371
|
+
});
|
|
372
|
+
});
|
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
import { Deferred } from "@frak-labs/frame-connector";
|
|
2
|
+
import type { FrakClient } from "../types/client";
|
|
3
|
+
import type { WalletStatusReturnType } from "../types/rpc/walletStatus";
|
|
4
|
+
|
|
5
|
+
/**
|
|
6
|
+
* Function used to watch the current frak wallet status
|
|
7
|
+
* @param client - The current Frak Client
|
|
8
|
+
* @param callback - The callback that will receive any wallet status change
|
|
9
|
+
* @returns A promise resolving with the initial wallet status
|
|
10
|
+
*
|
|
11
|
+
* @description This function will return the current wallet status, and will listen to any change in the wallet status.
|
|
12
|
+
*
|
|
13
|
+
* @example
|
|
14
|
+
* await watchWalletStatus(frakConfig, (status: WalletStatusReturnType) => {
|
|
15
|
+
* if (status.key === "connected") {
|
|
16
|
+
* console.log("Wallet connected:", status.wallet);
|
|
17
|
+
* console.log("Current interaction session:", status.interactionSession);
|
|
18
|
+
* } else {
|
|
19
|
+
* console.log("Wallet not connected");
|
|
20
|
+
* }
|
|
21
|
+
* });
|
|
22
|
+
*/
|
|
23
|
+
export function watchWalletStatus(
|
|
24
|
+
client: FrakClient,
|
|
25
|
+
callback?: (status: WalletStatusReturnType) => void
|
|
26
|
+
): Promise<WalletStatusReturnType> {
|
|
27
|
+
// If no callback is provided, just do a request with deferred result
|
|
28
|
+
if (!callback) {
|
|
29
|
+
return client
|
|
30
|
+
.request({ method: "frak_listenToWalletStatus" })
|
|
31
|
+
.then((result) => {
|
|
32
|
+
// Handle side effects of this request
|
|
33
|
+
walletStatusSideEffect(client, result);
|
|
34
|
+
|
|
35
|
+
// Return the result
|
|
36
|
+
return result;
|
|
37
|
+
});
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
// Otherwise, listen to the wallet status and return the first one received
|
|
41
|
+
const firstResult = new Deferred<WalletStatusReturnType>();
|
|
42
|
+
let hasResolved = false;
|
|
43
|
+
|
|
44
|
+
// Start the listening request, and return the first result
|
|
45
|
+
client.listenerRequest(
|
|
46
|
+
{
|
|
47
|
+
method: "frak_listenToWalletStatus",
|
|
48
|
+
},
|
|
49
|
+
(status) => {
|
|
50
|
+
// Handle side effects of this request
|
|
51
|
+
walletStatusSideEffect(client, status);
|
|
52
|
+
|
|
53
|
+
// Transmit the status to the callback
|
|
54
|
+
callback(status);
|
|
55
|
+
|
|
56
|
+
// If the promise hasn't resolved yet, resolve it
|
|
57
|
+
if (!hasResolved) {
|
|
58
|
+
firstResult.resolve(status);
|
|
59
|
+
hasResolved = true;
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
);
|
|
63
|
+
|
|
64
|
+
return firstResult.promise;
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
/**
|
|
68
|
+
* Helper to save a potential interaction token
|
|
69
|
+
* @param interactionToken
|
|
70
|
+
*/
|
|
71
|
+
function walletStatusSideEffect(
|
|
72
|
+
client: FrakClient,
|
|
73
|
+
status: WalletStatusReturnType
|
|
74
|
+
) {
|
|
75
|
+
if (typeof window === "undefined") {
|
|
76
|
+
return;
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
// Update the global properties
|
|
80
|
+
client.openPanel?.setGlobalProperties({
|
|
81
|
+
wallet: status.wallet ?? null,
|
|
82
|
+
});
|
|
83
|
+
|
|
84
|
+
if (status.interactionToken) {
|
|
85
|
+
// If we got an interaction token, save it
|
|
86
|
+
window.sessionStorage.setItem(
|
|
87
|
+
"frak-wallet-interaction-token",
|
|
88
|
+
status.interactionToken
|
|
89
|
+
);
|
|
90
|
+
} else {
|
|
91
|
+
// Otherwise, remove it
|
|
92
|
+
window.sessionStorage.removeItem("frak-wallet-interaction-token");
|
|
93
|
+
}
|
|
94
|
+
}
|