@instadapp/avocado-base 0.0.0-dev.083a57a → 0.0.0-dev.0cd0f72

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.
@@ -1,13 +1,10 @@
1
1
  <script lang="ts" setup>
2
2
 
3
- const props = defineProps<{
3
+ defineProps<{
4
4
  metadata: any;
5
5
  chain_id: number | string;
6
- compact?: boolean;
7
6
  }>();
8
7
 
9
- provide('compact', props.compact);
10
-
11
8
  </script>
12
9
 
13
10
  <template>
@@ -5,8 +5,6 @@ const props = defineProps<{
5
5
  chain_id: number | string
6
6
  }>();
7
7
 
8
- const compact = inject('compact');
9
-
10
8
  const toToken = asyncComputed(() =>
11
9
  fetchTokenByAddress(props.metadata?.toToken, props.metadata?.toChainId)
12
10
  );
@@ -24,12 +22,12 @@ const bridgeAmountFormatted = computed(() =>
24
22
  class="flex gap-5 items-center"
25
23
  v-if="metadata.type === 'bridge' && toToken"
26
24
  >
27
- <span v-if="!compact" class="capitalize text-xs sm:text-sm">{{ metadata.type }}</span>
25
+ <span class="capitalize text-xs sm:text-sm">{{ metadata.type }}</span>
28
26
  <span class="inline-flex gap-2.5 items-center">
29
27
  <img width="20" height="20" class="w-5 h-5" :src="toToken.logo_url" />
30
28
  {{ bridgeAmountFormatted }}
31
29
  <span class="uppercase">{{ toToken?.symbol }}</span>
32
- <SvgoBridge class="text-slate-400 w-4 h-4" />
30
+ <SvgoBridge class="text-slate-400 w-5 h-5" />
33
31
  <span class="flex items-center gap-2.5">
34
32
  <ChainLogo class="w-5" :chain="metadata.toChainId" />
35
33
  <span>{{ chainIdToName(metadata.toChainId) }}</span>
@@ -5,8 +5,6 @@ const props = defineProps<{
5
5
  chain_id: number | string
6
6
  }>();
7
7
 
8
- const compact = inject('compact');
9
-
10
8
  const fromToken = asyncComputed(() => {
11
9
  if (!props?.chain_id) return null;
12
10
 
@@ -29,7 +27,7 @@ const formattedFromAmount = computed(() =>
29
27
  </div>
30
28
  <div class="flex gap-5 flex-col" v-else>
31
29
  <div class="flex items-center gap-5">
32
- <span v-if="!compact" class="capitalize text-xs sm:text-sm">Cross-chain send</span>
30
+ <span class="capitalize text-xs sm:text-sm">Cross-chain send</span>
33
31
  <span class="inline-flex gap-2.5 items-center">
34
32
  <img width="20" height="20" class="w-5 h-5" :src="fromToken?.logo_url" />
35
33
  {{ formattedFromAmount }}
@@ -9,8 +9,6 @@ const token = asyncComputed(() =>
9
9
  fetchTokenByAddress(props.metadata?.token, props?.chain_id)
10
10
  );
11
11
 
12
- const compact = inject('compact');
13
-
14
12
  const formattedAmount = computed(() =>
15
13
  formatDecimal(
16
14
  fromWei(props.metadata?.amount, token?.value?.decimals).toFixed()
@@ -21,7 +19,7 @@ const formattedAmount = computed(() =>
21
19
  <template>
22
20
  <div v-if="!token" class="rounded-5 w-24 h-4 loading-box" />
23
21
  <div class="flex items-center gap-5" v-else>
24
- <span v-if="!compact" class="capitalize text-xs sm:text-sm">{{ metadata.type }}</span>
22
+ <span class="capitalize text-xs sm:text-sm">{{ metadata.type }}</span>
25
23
  <span class="inline-flex gap-2.5 items-center">
26
24
  <img width="20" height="20" class="w-5 h-5" :src="token?.logo_url" />
27
25
  {{ formattedAmount }}
@@ -5,7 +5,6 @@ const props = defineProps<{
5
5
  chain_id: number | string
6
6
  }>();
7
7
 
8
- const compact = inject('compact');
9
8
 
10
9
  const buyToken = asyncComputed(() =>
11
10
  fetchTokenByAddress(props.metadata?.buyToken, props?.chain_id)
@@ -46,7 +45,7 @@ const formatProtocol = (protocol: string) => {
46
45
  class="flex items-center gap-5"
47
46
  v-else
48
47
  >
49
- <span v-if="!compact" class="capitalize text-xs sm:text-sm">{{ metadata.type }}</span>
48
+ <span class="capitalize text-xs sm:text-sm">{{ metadata.type }}</span>
50
49
  <span class="inline-flex gap-2.5 items-center">
51
50
  <img width="20" height="20" class="w-5 h-5" :src="sellToken?.logo_url" />
52
51
  {{ sellAmountFormatted }}
@@ -57,7 +56,7 @@ const formatProtocol = (protocol: string) => {
57
56
  <span class="uppercase">{{ buyToken?.symbol }}</span>
58
57
  <span
59
58
  class="capitalize hidden sm:flex items-center gap-2.5"
60
- v-if="metadata.protocol && !compact"
59
+ v-if="metadata.protocol"
61
60
  >
62
61
  On <ProtocolLogo class="w-5 h-5" :name="metadata.protocol" />
63
62
  {{ formatProtocol(metadata.protocol) }}
@@ -5,7 +5,6 @@ const props = defineProps<{
5
5
  chain_id: number | string
6
6
  }>();
7
7
 
8
- const compact = inject('compact');
9
8
 
10
9
  const token = asyncComputed(() => {
11
10
  if (!props?.chain_id) return null;
@@ -26,21 +25,19 @@ const formattedAmount = computed(() =>
26
25
  <template>
27
26
  <div v-if="!token" class="rounded-5 w-24 h-4 loading-box" />
28
27
  <div class="flex items-center gap-5" v-else>
29
- <span v-if="!compact" class="capitalize text-xs sm:text-sm">{{ metadata.type }}</span>
28
+ <span class="capitalize text-xs sm:text-sm">{{ metadata.type }}</span>
30
29
  <span class="inline-flex gap-2.5 items-center">
31
30
  <img width="20" height="20" class="w-5 h-5" :src="token?.logo_url" />
32
31
  {{ formattedAmount }}
33
32
  <span class="uppercase">{{ token?.symbol }}</span>
34
33
  <SvgoArrowRight class="w-4 h-4 text-slate-400 mx-2" />
35
- <NuxtLink
34
+ <a
36
35
  class="text-primary"
37
- target="_blank"
38
- external
39
- :to="
36
+ :href="
40
37
  getExplorerUrl(chain_id, `/address/${metadata.receiver}`)
41
38
  "
42
- >{{ shortenHash(metadata.receiver) }}
43
- </NuxtLink>
39
+ >{{ shortenHash(metadata.receiver) }}</a
40
+ >
44
41
  </span>
45
42
  </div>
46
43
  </template>
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@instadapp/avocado-base",
3
- "version": "0.0.0-dev.083a57a",
3
+ "version": "0.0.0-dev.0cd0f72",
4
4
  "type": "module",
5
5
  "main": "./nuxt.config.ts",
6
6
  "types": "global.d.ts",
package/utils/metadata.ts CHANGED
@@ -242,217 +242,189 @@ export const encodeMultipleActions = (...actionData: string[]) => {
242
242
  return ethers.utils.defaultAbiCoder.encode(multiMetadataTypes, [actionData]);
243
243
  };
244
244
 
245
- export const decodeData = (data: string) => {
245
+ export const decodeMetadata = (data: string) => {
246
246
  try {
247
- const metadata = getMetadataFromData(data) || "0x";
248
-
249
- return parseMetadata(metadata);
250
- } catch (e) {
251
- // console.log(e);
252
- return null;
253
- }
254
- };
255
-
256
- export const decodeMetadata = (metadata: string) => {
257
- try {
258
- return parseMetadata(metadata);
259
- } catch (e) {
260
- return null;
261
- }
262
- };
263
-
264
- const getMetadataFromData = (data: string) => {
265
- const iface = Forwarder__factory.createInterface();
266
- let metadata = "0x";
267
-
268
- if (data.startsWith("0x18e7f485")) {
269
- const executeData = iface.decodeFunctionData("execute", data);
270
- if (executeData.metadata_ === "0x" || !executeData.metadata_) {
271
- return null;
247
+ const iface = Forwarder__factory.createInterface();
248
+ let metadata = "0x";
249
+ let payload = {};
250
+
251
+ if (!data) return payload;
252
+
253
+ if (data.startsWith("0x18e7f485")) {
254
+ const executeData = iface.decodeFunctionData("execute", data);
255
+ if (executeData.metadata_ === "0x" || !executeData.metadata_) {
256
+ return null;
257
+ } else {
258
+ metadata = executeData.metadata_;
259
+ }
260
+ } else if (data.startsWith("0x14f80a8d")) {
261
+ const executeDataV2 = iface.decodeFunctionData("executeV2", data);
262
+ if (
263
+ executeDataV2.params_.metadata === "0x" ||
264
+ !executeDataV2.params_.metadata
265
+ ) {
266
+ return null;
267
+ } else {
268
+ metadata = executeDataV2.params_.metadata;
269
+ }
270
+ } else if (data.startsWith("0x85114d53")) {
271
+ const executeDataV3 = iface.decodeFunctionData("executeV3", data);
272
+ if (
273
+ executeDataV3.params_.metadata === "0x" ||
274
+ !executeDataV3.params_.metadata
275
+ ) {
276
+ return null;
277
+ } else {
278
+ metadata = executeDataV3.params_.metadata;
279
+ }
272
280
  } else {
273
- metadata = executeData.metadata_;
281
+ const executeDataMultisigV3 = iface.decodeFunctionData(
282
+ "executeMultisigV3",
283
+ data
284
+ );
285
+ if (
286
+ executeDataMultisigV3.params_.metadata === "0x" ||
287
+ !executeDataMultisigV3.params_.metadata
288
+ ) {
289
+ return null;
290
+ } else {
291
+ metadata = executeDataMultisigV3.params_.metadata;
292
+ }
274
293
  }
275
- } else if (data.startsWith("0x14f80a8d")) {
276
- const executeDataV2 = iface.decodeFunctionData("executeV2", data);
277
- if (
278
- executeDataV2.params_.metadata === "0x" ||
279
- !executeDataV2.params_.metadata
280
- ) {
281
- return null;
282
- } else {
283
- metadata = executeDataV2.params_.metadata;
284
- }
285
- } else if (data.startsWith("0x85114d53")) {
286
- const executeDataV3 = iface.decodeFunctionData("executeV3", data);
287
- if (
288
- executeDataV3.params_.metadata === "0x" ||
289
- !executeDataV3.params_.metadata
290
- ) {
291
- return null;
292
- } else {
293
- metadata = executeDataV3.params_.metadata;
294
- }
295
- } else {
296
- const executeDataMultisigV3 = iface.decodeFunctionData(
297
- "executeMultisigV3",
298
- data
299
- );
300
- if (
301
- executeDataMultisigV3.params_.metadata === "0x" ||
302
- !executeDataMultisigV3.params_.metadata
303
- ) {
304
- return null;
305
- } else {
306
- metadata = executeDataMultisigV3.params_.metadata;
307
- }
308
- }
309
-
310
- return metadata;
311
- };
312
294
 
313
- const parseMetadata = (metadata: string) => {
314
- const metadataArr = [];
315
- let payload = {};
316
-
317
- const [decodedMultiMetadata = []] =
318
- (ethers.utils.defaultAbiCoder.decode(
319
- multiMetadataTypes,
320
- metadata
321
- ) as string[]) || [];
322
-
323
- for (let metadata of decodedMultiMetadata) {
324
- const decodedMetadata = ethers.utils.defaultAbiCoder.decode(
325
- metadataTypes,
326
- metadata
327
- );
328
-
329
- const type = ethers.utils.parseBytes32String(
330
- decodedMetadata.type
331
- ) as keyof typeof actionMetadataTypes;
332
-
333
- const decodedData = ethers.utils.defaultAbiCoder.decode(
334
- actionMetadataTypes[type],
335
- decodedMetadata.data
336
- );
337
-
338
- switch (type) {
339
- case "transfer":
340
- payload = {
341
- type,
342
- token: decodedData.token,
343
- amount: toBN(decodedData.amount).toFixed(),
344
- receiver: decodedData.receiver,
345
- };
346
- break;
347
- case "bridge":
348
- payload = {
349
- type,
350
- amount: toBN(decodedData.amount).toFixed(),
351
- receiver: decodedData.receiver,
352
- toToken: decodedData.toToken,
353
- fromToken: decodedData.fromToken,
354
- toChainId: decodedData.toChainId
355
- ? decodedData.toChainId.toString()
356
- : null,
357
- bridgeFee: toBN(decodedData.bridgeFee).toFixed(),
358
- };
359
- break;
360
- case "swap":
361
- payload = {
362
- type,
363
- buyAmount: toBN(decodedData.buyAmount).toFixed(),
364
- sellAmount: toBN(decodedData.sellAmount).toFixed(),
365
- buyToken: decodedData.buyToken,
366
- sellToken: decodedData.sellToken,
367
- receiver: decodedData.receiver,
368
- protocol: utils.parseBytes32String(decodedData?.protocol || ""),
369
- };
370
- break;
371
- case "upgrade":
372
- payload = {
373
- type,
374
- version: utils.parseBytes32String(decodedData?.version || ""),
375
- walletImpl: decodedData?.walletImpl,
376
- };
377
- break;
378
- case "gas-topup":
379
- payload = {
380
- type,
381
- amount: toBN(decodedData.amount).toFixed(),
382
- token: decodedData.token,
383
- onBehalf: decodedData.onBehalf,
384
- };
385
- break;
386
- case "dapp":
387
- payload = {
388
- type,
389
- name: decodedData?.name,
390
- url: decodedData?.url,
391
- };
392
- break;
393
- case "deploy":
394
- payload = {
395
- type,
396
- };
397
- break;
398
-
399
- case "permit2":
400
- payload = {
401
- type,
402
- token: decodedData.token,
403
- spender: decodedData.spender,
404
- amount: toBN(decodedData.amount).toFixed(),
405
- expiration: decodedData.expiration,
406
- };
407
- break;
408
-
409
- case "cross-transfer":
410
- payload = {
411
- type,
412
- fromToken: decodedData.fromToken,
413
- toToken: decodedData.toToken,
414
- toChainId: decodedData.toChainId
415
- ? decodedData.toChainId.toString()
416
- : null,
417
- amount: toBN(decodedData.amount).toFixed(),
418
- receiver: decodedData.receiver,
419
- };
420
-
421
- break;
422
- case "auth":
423
- payload = {
424
- type: decodedData.remove ? "remove-authority" : "add-authority",
425
- address: decodedData.address,
426
- chainId: decodedData.chainId ? decodedData.chainId.toString() : null,
427
- remove: decodedData.remove,
428
- };
429
-
430
- break;
431
- case "instadapp-pro":
432
- payload = {
433
- type,
434
- castDetails: decodedData.castDetails,
435
- };
436
-
437
- break;
295
+ const metadataArr = [];
296
+
297
+ const [decodedMultiMetadata = []] =
298
+ (ethers.utils.defaultAbiCoder.decode(
299
+ multiMetadataTypes,
300
+ metadata
301
+ ) as string[]) || [];
302
+
303
+ for (let metadata of decodedMultiMetadata) {
304
+ const decodedMetadata = ethers.utils.defaultAbiCoder.decode(
305
+ metadataTypes,
306
+ metadata
307
+ );
308
+
309
+ const type = ethers.utils.parseBytes32String(
310
+ decodedMetadata.type
311
+ ) as keyof typeof actionMetadataTypes;
312
+
313
+ const decodedData = ethers.utils.defaultAbiCoder.decode(
314
+ actionMetadataTypes[type],
315
+ decodedMetadata.data
316
+ );
317
+
318
+ switch (type) {
319
+ case "transfer":
320
+ payload = {
321
+ type,
322
+ token: decodedData.token,
323
+ amount: toBN(decodedData.amount).toFixed(),
324
+ receiver: decodedData.receiver,
325
+ };
326
+ break;
327
+ case "bridge":
328
+ payload = {
329
+ type,
330
+ amount: toBN(decodedData.amount).toFixed(),
331
+ receiver: decodedData.receiver,
332
+ toToken: decodedData.toToken,
333
+ fromToken: decodedData.fromToken,
334
+ toChainId: decodedData.toChainId
335
+ ? decodedData.toChainId.toString()
336
+ : null,
337
+ bridgeFee: toBN(decodedData.bridgeFee).toFixed(),
338
+ };
339
+ break;
340
+ case "swap":
341
+ payload = {
342
+ type,
343
+ buyAmount: toBN(decodedData.buyAmount).toFixed(),
344
+ sellAmount: toBN(decodedData.sellAmount).toFixed(),
345
+ buyToken: decodedData.buyToken,
346
+ sellToken: decodedData.sellToken,
347
+ receiver: decodedData.receiver,
348
+ protocol: utils.parseBytes32String(decodedData?.protocol || ""),
349
+ };
350
+ break;
351
+ case "upgrade":
352
+ payload = {
353
+ type,
354
+ version: utils.parseBytes32String(decodedData?.version || ""),
355
+ walletImpl: decodedData?.walletImpl,
356
+ };
357
+ break;
358
+ case "gas-topup":
359
+ payload = {
360
+ type,
361
+ amount: toBN(decodedData.amount).toFixed(),
362
+ token: decodedData.token,
363
+ onBehalf: decodedData.onBehalf,
364
+ };
365
+ break;
366
+ case "dapp":
367
+ payload = {
368
+ type,
369
+ name: decodedData?.name,
370
+ url: decodedData?.url,
371
+ };
372
+ break;
373
+ case "deploy":
374
+ payload = {
375
+ type,
376
+ };
377
+ break;
378
+
379
+ case "permit2":
380
+ payload = {
381
+ type,
382
+ token: decodedData.token,
383
+ spender: decodedData.spender,
384
+ amount: toBN(decodedData.amount).toFixed(),
385
+ expiration: decodedData.expiration,
386
+ };
387
+ break;
388
+
389
+ case "cross-transfer":
390
+ payload = {
391
+ type,
392
+ fromToken: decodedData.fromToken,
393
+ toToken: decodedData.toToken,
394
+ toChainId: decodedData.toChainId
395
+ ? decodedData.toChainId.toString()
396
+ : null,
397
+ amount: toBN(decodedData.amount).toFixed(),
398
+ receiver: decodedData.receiver,
399
+ };
400
+
401
+ break;
402
+ case "auth":
403
+ payload = {
404
+ type: decodedData.remove ? "remove-authority" : "add-authority",
405
+ address: decodedData.address,
406
+ chainId: decodedData.chainId
407
+ ? decodedData.chainId.toString()
408
+ : null,
409
+ remove: decodedData.remove,
410
+ };
411
+
412
+ break;
413
+ case "instadapp-pro":
414
+ payload = {
415
+ type,
416
+ castDetails: decodedData.castDetails,
417
+ };
418
+
419
+ break;
420
+ }
421
+
422
+ metadataArr.push(payload);
438
423
  }
439
424
 
440
- metadataArr.push(payload);
425
+ return metadataArr;
426
+ } catch (e) {
427
+ // console.log(e);
428
+ return null;
441
429
  }
442
-
443
- return metadataArr;
444
- };
445
-
446
- /**
447
- * Replaces hyphens with spaces and capitalizes the first letter of each word in a sentence.
448
- * @param {string} txType - The input sentence to modify
449
- *
450
- * @returns {string} - The modified sentence with hyphens replaced with spaces and the first letter of each word capitalized.
451
- */
452
- export const formatTxType = (txType: string) => {
453
- const finalSentence = txType
454
- .replace("-", " ")
455
- .replace(/(^\w{1})|(\s+\w{1})/g, (letter) => letter.toUpperCase());
456
-
457
- return finalSentence;
458
430
  };