@aptos-labs/wallet-adapter-core 4.25.0 → 5.0.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 (70) hide show
  1. package/README.md +10 -0
  2. package/dist/WalletCore.d.ts +71 -112
  3. package/dist/WalletCore.d.ts.map +1 -1
  4. package/dist/constants.d.ts +4 -14
  5. package/dist/constants.d.ts.map +1 -1
  6. package/dist/error/index.d.ts +3 -0
  7. package/dist/error/index.d.ts.map +1 -1
  8. package/dist/index.d.ts +3 -3
  9. package/dist/index.d.ts.map +1 -1
  10. package/dist/index.js +379 -859
  11. package/dist/index.js.map +1 -1
  12. package/dist/index.mjs +408 -894
  13. package/dist/index.mjs.map +1 -1
  14. package/dist/{AIP62StandardWallets/registry.d.ts → registry.d.ts} +1 -1
  15. package/dist/registry.d.ts.map +1 -0
  16. package/dist/sdkWallets.d.ts +3 -0
  17. package/dist/sdkWallets.d.ts.map +1 -0
  18. package/dist/utils/helpers.d.ts +7 -7
  19. package/dist/utils/helpers.d.ts.map +1 -1
  20. package/dist/utils/index.d.ts +1 -1
  21. package/dist/utils/index.d.ts.map +1 -1
  22. package/dist/utils/localStorage.d.ts +1 -2
  23. package/dist/utils/localStorage.d.ts.map +1 -1
  24. package/dist/utils/types.d.ts +26 -0
  25. package/dist/utils/types.d.ts.map +1 -0
  26. package/dist/utils/walletSelector.d.ts +18 -19
  27. package/dist/utils/walletSelector.d.ts.map +1 -1
  28. package/dist/version.d.ts +1 -1
  29. package/dist/version.d.ts.map +1 -1
  30. package/package.json +4 -5
  31. package/src/WalletCore.ts +474 -686
  32. package/src/constants.ts +3 -13
  33. package/src/error/index.ts +4 -0
  34. package/src/index.ts +3 -3
  35. package/src/{AIP62StandardWallets/registry.ts → registry.ts} +19 -6
  36. package/src/{AIP62StandardWallets/sdkWallets.ts → sdkWallets.ts} +6 -6
  37. package/src/utils/helpers.ts +46 -32
  38. package/src/utils/index.ts +1 -1
  39. package/src/utils/localStorage.ts +1 -3
  40. package/src/{AIP62StandardWallets → utils}/types.ts +22 -3
  41. package/src/utils/walletSelector.ts +32 -26
  42. package/src/version.ts +1 -1
  43. package/dist/AIP62StandardWallets/WalletStandard.d.ts +0 -44
  44. package/dist/AIP62StandardWallets/WalletStandard.d.ts.map +0 -1
  45. package/dist/AIP62StandardWallets/index.d.ts +0 -3
  46. package/dist/AIP62StandardWallets/index.d.ts.map +0 -1
  47. package/dist/AIP62StandardWallets/registry.d.ts.map +0 -1
  48. package/dist/AIP62StandardWallets/sdkWallets.d.ts +0 -4
  49. package/dist/AIP62StandardWallets/sdkWallets.d.ts.map +0 -1
  50. package/dist/AIP62StandardWallets/types.d.ts +0 -12
  51. package/dist/AIP62StandardWallets/types.d.ts.map +0 -1
  52. package/dist/LegacyWalletPlugins/WalletCoreV1.d.ts +0 -50
  53. package/dist/LegacyWalletPlugins/WalletCoreV1.d.ts.map +0 -1
  54. package/dist/LegacyWalletPlugins/conversion.d.ts +0 -21
  55. package/dist/LegacyWalletPlugins/conversion.d.ts.map +0 -1
  56. package/dist/LegacyWalletPlugins/index.d.ts +0 -4
  57. package/dist/LegacyWalletPlugins/index.d.ts.map +0 -1
  58. package/dist/LegacyWalletPlugins/types.d.ts +0 -116
  59. package/dist/LegacyWalletPlugins/types.d.ts.map +0 -1
  60. package/dist/__tests__/WalletCore.test.d.ts +0 -2
  61. package/dist/__tests__/WalletCore.test.d.ts.map +0 -1
  62. package/dist/utils/scopePollingDetectionStrategy.d.ts +0 -2
  63. package/dist/utils/scopePollingDetectionStrategy.d.ts.map +0 -1
  64. package/src/AIP62StandardWallets/WalletStandard.ts +0 -242
  65. package/src/AIP62StandardWallets/index.ts +0 -2
  66. package/src/LegacyWalletPlugins/WalletCoreV1.ts +0 -258
  67. package/src/LegacyWalletPlugins/conversion.ts +0 -124
  68. package/src/LegacyWalletPlugins/index.ts +0 -3
  69. package/src/LegacyWalletPlugins/types.ts +0 -188
  70. package/src/utils/scopePollingDetectionStrategy.ts +0 -46
package/src/constants.ts CHANGED
@@ -1,21 +1,11 @@
1
1
  export enum WalletReadyState {
2
2
  /**
3
- * User-installable wallets can typically be detected by scanning for an API
4
- * that they've injected into the global context. If such an API is present,
5
- * we consider the wallet to have been installed.
3
+ * Wallet can only be in one of two states - installed or not installed
4
+ * Installed: wallets are detected by the browser event listeners and means they are installed on the user's browser.
5
+ * NotDetected: wallets are not detected by the browser event listeners and means they are not installed on the user's browser.
6
6
  */
7
7
  Installed = "Installed",
8
8
  NotDetected = "NotDetected",
9
- /**
10
- * Loadable wallets are always available to you. Since you can load them at
11
- * any time, it's meaningless to say that they have been detected.
12
- */
13
- Loadable = "Loadable",
14
- /**
15
- * If a wallet is not supported on a given platform (eg. server-rendering, or
16
- * mobile) then it will stay in the `Unsupported` state.
17
- */
18
- Unsupported = "Unsupported",
19
9
  }
20
10
 
21
11
  export enum NetworkName {
@@ -105,3 +105,7 @@ export class WalletNotSupportedMethod extends WalletError {
105
105
  export class WalletChangeNetworkError extends WalletError {
106
106
  name = "WalletChangeNetworkError";
107
107
  }
108
+
109
+ export class WalletSubmitTransactionError extends WalletError {
110
+ name = "WalletSubmitTransactionError";
111
+ }
package/src/index.ts CHANGED
@@ -1,10 +1,10 @@
1
1
  import { WALLET_ADAPTER_CORE_VERSION } from "./version";
2
2
 
3
- export { type AnyAptosWallet, type DappConfig, WalletCore } from "./WalletCore";
4
- export * from "./LegacyWalletPlugins";
3
+ export * from "./WalletCore";
5
4
  export * from "./constants";
6
5
  export * from "./utils";
7
- export * from "./AIP62StandardWallets";
6
+ export * from "./sdkWallets";
7
+ export * from "./registry";
8
8
 
9
9
  // inject adapter core version to the window
10
10
  if (typeof window !== "undefined") {
@@ -1,6 +1,5 @@
1
- import { WalletName } from "../LegacyWalletPlugins/types";
2
- import { WalletReadyState } from "../constants";
3
- import { AptosStandardSupportedWallet } from "./types";
1
+ import { WalletReadyState } from "./constants";
2
+ import { AptosStandardSupportedWallet } from "./utils/types";
4
3
 
5
4
  /**
6
5
  * Registry of AIP-62 wallet standard supported wallets.
@@ -19,7 +18,7 @@ import { AptosStandardSupportedWallet } from "./types";
19
18
  export const aptosStandardSupportedWalletList: Array<AptosStandardSupportedWallet> =
20
19
  [
21
20
  {
22
- name: "Nightly" as WalletName<"Nightly">,
21
+ name: "Nightly",
23
22
  url: "https://nightly.app/",
24
23
  icon: "",
25
24
  readyState: WalletReadyState.NotDetected,
@@ -27,7 +26,7 @@ export const aptosStandardSupportedWalletList: Array<AptosStandardSupportedWalle
27
26
  deeplinkProvider: "nightly://v1?network=aptos&url=",
28
27
  },
29
28
  {
30
- name: "Petra" as WalletName<"Petra">,
29
+ name: "Petra",
31
30
  url: "https://chromewebstore.google.com/detail/petra-aptos-wallet/ejjladinnckdgjemekebdpeokbikhfci?hl=en",
32
31
  icon: "",
33
32
  readyState: WalletReadyState.NotDetected,
@@ -35,10 +34,24 @@ export const aptosStandardSupportedWalletList: Array<AptosStandardSupportedWalle
35
34
  deeplinkProvider: "https://petra.app/explore?link=",
36
35
  },
37
36
  {
38
- name: "Pontem Wallet" as WalletName<"Pontem Wallet">,
37
+ name: "Pontem Wallet",
39
38
  url: "https://pontem.network/pontem-wallet",
40
39
  icon: "",
41
40
  readyState: WalletReadyState.NotDetected,
42
41
  isAIP62Standard: true,
43
42
  },
43
+ {
44
+ name: "Rimosafe",
45
+ url: "https://chromewebstore.google.com/detail/rimo-safe-wallet/kiicddjcakdmobjkcpppkgcjbpakcagp",
46
+ icon: "",
47
+ readyState: WalletReadyState.NotDetected,
48
+ isAIP62Standard: true,
49
+ },
50
+ {
51
+ name: "OKX Wallet",
52
+ url: "https://chromewebstore.google.com/detail/okx-wallet/mcohilncbfahbmgdjkbpemcciiolgcge",
53
+ icon: "",
54
+ readyState: WalletReadyState.NotDetected,
55
+ isAIP62Standard: true,
56
+ },
44
57
  ];
@@ -5,11 +5,10 @@ import {
5
5
  import { Network } from "@aptos-labs/ts-sdk";
6
6
  import { DevTWallet, TWallet } from "@atomrigslab/aptos-wallet-adapter";
7
7
  import { MizuWallet } from "@mizuwallet-sdk/aptos-wallet-adapter";
8
- import { DappConfig } from "../WalletCore";
9
- import { AptosStandardWallet } from "./WalletStandard";
8
+ import { DappConfig, AdapterWallet } from "./WalletCore";
10
9
 
11
10
  export function getSDKWallets(dappConfig?: DappConfig) {
12
- const sdkWallets: AptosStandardWallet[] = [];
11
+ const sdkWallets: AdapterWallet[] = [];
13
12
 
14
13
  // Need to check window is defined for AptosConnect
15
14
  if (typeof window !== "undefined") {
@@ -23,7 +22,7 @@ export function getSDKWallets(dappConfig?: DappConfig) {
23
22
  network: dappConfig?.network,
24
23
  dappId: dappConfig?.aptosConnectDappId,
25
24
  ...dappConfig?.aptosConnect,
26
- }),
25
+ })
27
26
  );
28
27
 
29
28
  if (
@@ -33,10 +32,11 @@ export function getSDKWallets(dappConfig?: DappConfig) {
33
32
  ) {
34
33
  sdkWallets.push(
35
34
  new MizuWallet({
36
- network: dappConfig.network as any,
35
+ // mizo supports only TESTNET and MAINNET and holds a custom type for network
36
+ network: dappConfig.network as Network.MAINNET | Network.TESTNET,
37
37
  manifestURL: dappConfig.mizuwallet.manifestURL,
38
38
  appId: dappConfig.mizuwallet.appId,
39
- }) as any,
39
+ })
40
40
  );
41
41
  }
42
42
  }
@@ -1,35 +1,32 @@
1
1
  import {
2
2
  Aptos,
3
3
  AptosConfig,
4
- EntryFunctionArgumentTypes,
5
4
  Hex,
6
5
  Network,
7
6
  NetworkToNodeAPI,
8
- Serializable,
9
- SimpleEntryFunctionArgumentTypes,
10
7
  } from "@aptos-labs/ts-sdk";
11
- import { NetworkInfo as StandardNetworkInfo } from "@aptos-labs/wallet-standard";
12
- import { convertNetwork } from "../LegacyWalletPlugins/conversion";
13
8
  import {
14
- InputTransactionData,
15
9
  NetworkInfo,
16
- } from "../LegacyWalletPlugins/types";
10
+ NetworkInfo as StandardNetworkInfo,
11
+ } from "@aptos-labs/wallet-standard";
12
+
17
13
  import { DappConfig } from "../WalletCore";
18
14
  import { WalletSignAndSubmitMessageError } from "../error";
15
+ import { InputTransactionData } from "./types";
19
16
 
20
17
  export function isMobile(): boolean {
21
18
  return /Mobile|iP(hone|od|ad)|Android|BlackBerry|IEMobile|Kindle|NetFront|Silk-Accelerated|(hpw|web)OS|Fennec|Minimo|Opera M(obi|ini)|Blazer|Dolfin|Dolphin|Skyfire|Zune/i.test(
22
- navigator.userAgent,
19
+ navigator.userAgent
23
20
  );
24
21
  }
25
22
 
26
23
  export function isInAppBrowser(): boolean {
27
24
  const isIphone = /(iPhone|iPod|iPad).*AppleWebKit(?!.*Safari)/i.test(
28
- navigator.userAgent,
25
+ navigator.userAgent
29
26
  );
30
27
 
31
28
  const isAndroid = /(Android).*Version\/[\d.]+.*Chrome\/[^\s]+ Mobile/i.test(
32
- navigator.userAgent,
29
+ navigator.userAgent
33
30
  );
34
31
 
35
32
  return isIphone || isAndroid;
@@ -50,22 +47,6 @@ export function generalizedErrorMessage(error: any): string {
50
47
  : error;
51
48
  }
52
49
 
53
- // Helper function to check if input arguments are BCS serialized arguments.
54
- // In @aptos-labs/ts-sdk each move representative class extends
55
- // Serializable, so if each argument is of an instance of a class
56
- // the extends Serializable - we know these are BCS arguments
57
- export const areBCSArguments = (
58
- args: Array<EntryFunctionArgumentTypes | SimpleEntryFunctionArgumentTypes>,
59
- ): boolean => {
60
- // `every` returns true if the array is empty, so
61
- // first check the array length
62
- if (args.length === 0) return false;
63
- return args.every(
64
- (arg: EntryFunctionArgumentTypes | SimpleEntryFunctionArgumentTypes) =>
65
- arg instanceof Serializable,
66
- );
67
- };
68
-
69
50
  /**
70
51
  * Helper function to get AptosConfig that supports Aptos and Custom networks
71
52
  *
@@ -74,8 +55,8 @@ export const areBCSArguments = (
74
55
  * @returns AptosConfig
75
56
  */
76
57
  export const getAptosConfig = (
77
- networkInfo: NetworkInfo | StandardNetworkInfo | null,
78
- dappConfig: DappConfig | undefined,
58
+ networkInfo: NetworkInfo | null,
59
+ dappConfig: DappConfig | undefined
79
60
  ): AptosConfig => {
80
61
  if (!networkInfo) {
81
62
  throw new Error("Undefined network");
@@ -97,9 +78,26 @@ export const getAptosConfig = (
97
78
  });
98
79
  }
99
80
 
81
+ const knownNetworks = {
82
+ okx: "https://wallet.okx.com/fullnode/aptos/discover/rpc",
83
+ };
84
+
85
+ if (networkInfo.url) {
86
+ const isKnownNetwork = Object.values(knownNetworks).includes(
87
+ networkInfo.url
88
+ );
89
+
90
+ if (isKnownNetwork) {
91
+ return new AptosConfig({
92
+ network: Network.CUSTOM,
93
+ fullnode: networkInfo.url,
94
+ });
95
+ }
96
+ }
97
+
100
98
  // Custom networks are not supported, please ensure that the wallet is returning the appropriate network Mainnet, Testnet, Devnet, Local
101
99
  throw new Error(
102
- "Invalid network, custom network not supported with Aptos wallet adapter to prevent user from using an unexpected network.",
100
+ `Invalid network, network ${networkInfo.name} not supported with Aptos wallet adapter to prevent user from using an unexpected network.`
103
101
  );
104
102
  };
105
103
 
@@ -110,7 +108,7 @@ export const getAptosConfig = (
110
108
  * @returns boolean
111
109
  */
112
110
  export const isAptosNetwork = (
113
- networkInfo: NetworkInfo | StandardNetworkInfo | null,
111
+ networkInfo: NetworkInfo | StandardNetworkInfo | null
114
112
  ): boolean => {
115
113
  if (!networkInfo) {
116
114
  throw new Error("Undefined network");
@@ -140,7 +138,7 @@ export const fetchDevnetChainId = async (): Promise<number> => {
140
138
  * as a string, this function converts the string to Uint8Array.
141
139
  */
142
140
  export const handlePublishPackageTransaction = (
143
- transactionInput: InputTransactionData,
141
+ transactionInput: InputTransactionData
144
142
  ) => {
145
143
  // convert the first argument, metadataBytes, to uint8array if is a string
146
144
  let metadataBytes = transactionInput.data.functionArguments[0];
@@ -159,9 +157,25 @@ export const handlePublishPackageTransaction = (
159
157
  });
160
158
  } else {
161
159
  throw new WalletSignAndSubmitMessageError(
162
- "The bytecode argument must be an array.",
160
+ "The bytecode argument must be an array."
163
161
  ).message;
164
162
  }
165
163
 
166
164
  return { metadataBytes, byteCode };
167
165
  };
166
+
167
+ // old => new
168
+ export function convertNetwork(networkInfo: NetworkInfo | null): Network {
169
+ switch (networkInfo?.name) {
170
+ case "mainnet" as Network:
171
+ return Network.MAINNET;
172
+ case "testnet" as Network:
173
+ return Network.TESTNET;
174
+ case "devnet" as Network:
175
+ return Network.DEVNET;
176
+ case "local" as Network:
177
+ return Network.LOCAL;
178
+ default:
179
+ throw new Error("Invalid Aptos network name");
180
+ }
181
+ }
@@ -1,4 +1,4 @@
1
1
  export * from "./helpers";
2
2
  export * from "./localStorage";
3
- export { scopePollingDetectionStrategy } from "./scopePollingDetectionStrategy";
4
3
  export * from "./walletSelector";
4
+ export * from "./types";
@@ -1,8 +1,6 @@
1
- import { WalletName } from "../LegacyWalletPlugins/types";
2
-
3
1
  const LOCAL_STORAGE_ITEM_KEY = "AptosWalletName";
4
2
 
5
- export function setLocalStorage(walletName: WalletName) {
3
+ export function setLocalStorage(walletName: string) {
6
4
  localStorage.setItem(LOCAL_STORAGE_ITEM_KEY, walletName);
7
5
  }
8
6
 
@@ -1,9 +1,13 @@
1
- import { WalletName } from "../LegacyWalletPlugins/types";
1
+ import {
2
+ AccountAddressInput,
3
+ InputGenerateTransactionOptions,
4
+ } from "@aptos-labs/ts-sdk";
5
+ import { InputGenerateTransactionPayloadData } from "@aptos-labs/ts-sdk";
2
6
  import { WalletReadyState } from "../constants";
3
7
 
4
- export interface AptosStandardSupportedWallet<Name extends string = string> {
8
+ export interface AptosStandardSupportedWallet {
5
9
  // The name of your wallet cast to WalletName (Ex. "Petra" as WalletName<"Petra">)
6
- name: WalletName<Name>;
10
+ name: string;
7
11
  // The link to your chrome extension or main website where new users can create an account with your wallet.
8
12
  url: string;
9
13
  // An icon for your wallet. Can be one of 4 data types. Be sure to follow the below format exactly (including the "," after base64).
@@ -27,3 +31,18 @@ export type AvailableWallets =
27
31
  | "Pontem Wallet"
28
32
  | "Mizu Wallet"
29
33
  | "Continue with Google";
34
+
35
+ export type InputTransactionData = {
36
+ sender?: AccountAddressInput;
37
+ data: InputGenerateTransactionPayloadData;
38
+ options?: InputGenerateTransactionOptions & {
39
+ expirationSecondsFromNow?: number;
40
+ expirationTimestamp?: number;
41
+ };
42
+ };
43
+
44
+ export type WalletInfo = {
45
+ name: string;
46
+ icon: string;
47
+ url: string;
48
+ };
@@ -1,6 +1,5 @@
1
- import { AptosStandardWallet } from "../AIP62StandardWallets";
2
- import { WalletInfo } from "../LegacyWalletPlugins";
3
- import { AnyAptosWallet } from "../WalletCore";
1
+ import { WalletInfo } from "./types";
2
+ import { AdapterNotDetectedWallet, AdapterWallet } from "../WalletCore";
4
3
  import { APTOS_CONNECT_BASE_URL, WalletReadyState } from "../constants";
5
4
  import { isRedirectable } from "./helpers";
6
5
 
@@ -10,35 +9,36 @@ import { isRedirectable } from "./helpers";
10
9
  * You can pass your own partition function if you wish to customize this behavior.
11
10
  */
12
11
  export function partitionWallets(
13
- wallets: ReadonlyArray<AnyAptosWallet>,
12
+ wallets: ReadonlyArray<AdapterWallet | AdapterNotDetectedWallet>,
14
13
  partitionFunction: (
15
- wallet: AnyAptosWallet,
16
- ) => boolean = isInstalledOrLoadable,
14
+ wallet: AdapterWallet | AdapterNotDetectedWallet
15
+ ) => boolean = isInstalledOrLoadable
17
16
  ) {
18
- const defaultWallets: Array<AnyAptosWallet> = [];
19
- const moreWallets: Array<AnyAptosWallet> = [];
17
+ const defaultWallets: Array<AdapterWallet> = [];
18
+ const moreWallets: Array<AdapterNotDetectedWallet> = [];
20
19
 
21
20
  for (const wallet of wallets) {
22
- if (partitionFunction(wallet)) defaultWallets.push(wallet);
23
- else moreWallets.push(wallet);
21
+ if (partitionFunction(wallet)) defaultWallets.push(wallet as AdapterWallet);
22
+ else moreWallets.push(wallet as AdapterNotDetectedWallet);
24
23
  }
25
24
 
26
25
  return { defaultWallets, moreWallets };
27
26
  }
28
27
 
29
28
  /** Returns true if the wallet is installed or loadable. */
30
- export function isInstalledOrLoadable(wallet: AnyAptosWallet) {
31
- return (
32
- wallet.readyState === WalletReadyState.Installed ||
33
- wallet.readyState === WalletReadyState.Loadable
34
- );
29
+ export function isInstalledOrLoadable(
30
+ wallet: AdapterWallet | AdapterNotDetectedWallet
31
+ ) {
32
+ return wallet.readyState === WalletReadyState.Installed;
35
33
  }
36
34
 
37
35
  /**
38
36
  * Returns true if the user is on desktop and the provided wallet requires installation of a browser extension.
39
37
  * This can be used to decide whether to show a "Connect" button or "Install" link in the UI.
40
38
  */
41
- export function isInstallRequired(wallet: AnyAptosWallet) {
39
+ export function isInstallRequired(
40
+ wallet: AdapterWallet | AdapterNotDetectedWallet
41
+ ) {
42
42
  const isWalletReady = isInstalledOrLoadable(wallet);
43
43
  const isMobile = !isWalletReady && isRedirectable();
44
44
 
@@ -52,9 +52,7 @@ export function truncateAddress(address: string | undefined) {
52
52
  }
53
53
 
54
54
  /** Returns `true` if the provided wallet is an Aptos Connect wallet. */
55
- export function isAptosConnectWallet(
56
- wallet: WalletInfo | AnyAptosWallet | AptosStandardWallet,
57
- ) {
55
+ export function isAptosConnectWallet(wallet: WalletInfo | AdapterWallet) {
58
56
  if (!wallet.url) return false;
59
57
  return wallet.url.startsWith(APTOS_CONNECT_BASE_URL);
60
58
  }
@@ -63,21 +61,29 @@ export function isAptosConnectWallet(
63
61
  * Partitions the `wallets` array so that Aptos Connect wallets are grouped separately from the rest.
64
62
  * Aptos Connect is a web wallet that uses social login to create accounts on the blockchain.
65
63
  */
66
- export function getAptosConnectWallets(wallets: ReadonlyArray<AnyAptosWallet>) {
64
+ export function getAptosConnectWallets(
65
+ wallets: ReadonlyArray<AdapterWallet | AdapterNotDetectedWallet>
66
+ ) {
67
67
  const { defaultWallets, moreWallets } = partitionWallets(
68
68
  wallets,
69
- isAptosConnectWallet,
69
+ isAptosConnectWallet
70
70
  );
71
71
  return { aptosConnectWallets: defaultWallets, otherWallets: moreWallets };
72
72
  }
73
73
 
74
74
  export interface WalletSortingOptions {
75
75
  /** An optional function for sorting Aptos Connect wallets. */
76
- sortAptosConnectWallets?: (a: AnyAptosWallet, b: AnyAptosWallet) => number;
76
+ sortAptosConnectWallets?: (a: AdapterWallet, b: AdapterWallet) => number;
77
77
  /** An optional function for sorting wallets that are currently installed or loadable. */
78
- sortAvailableWallets?: (a: AnyAptosWallet, b: AnyAptosWallet) => number;
78
+ sortAvailableWallets?: (
79
+ a: AdapterWallet | AdapterNotDetectedWallet,
80
+ b: AdapterWallet | AdapterNotDetectedWallet
81
+ ) => number;
79
82
  /** An optional function for sorting wallets that are NOT currently installed or loadable. */
80
- sortInstallableWallets?: (a: AnyAptosWallet, b: AnyAptosWallet) => number;
83
+ sortInstallableWallets?: (
84
+ a: AdapterWallet | AdapterNotDetectedWallet,
85
+ b: AdapterWallet | AdapterNotDetectedWallet
86
+ ) => number;
81
87
  }
82
88
 
83
89
  /**
@@ -94,8 +100,8 @@ export interface WalletSortingOptions {
94
100
  * Additionally, these wallet groups can be sorted by passing sort functions via the `options` argument.
95
101
  */
96
102
  export function groupAndSortWallets(
97
- wallets: ReadonlyArray<AnyAptosWallet>,
98
- options?: WalletSortingOptions,
103
+ wallets: ReadonlyArray<AdapterWallet | AdapterNotDetectedWallet>,
104
+ options?: WalletSortingOptions
99
105
  ) {
100
106
  const { aptosConnectWallets, otherWallets } = getAptosConnectWallets(wallets);
101
107
  const { defaultWallets, moreWallets } = partitionWallets(otherWallets);
package/src/version.ts CHANGED
@@ -1 +1 @@
1
- export const WALLET_ADAPTER_CORE_VERSION = "4.25.0";
1
+ export const WALLET_ADAPTER_CORE_VERSION = "5.0.1";
@@ -1,44 +0,0 @@
1
- import { AptosSignTransactionInputV1_1, AptosSignTransactionOutput, AptosSignMessageOutput, AptosSignMessageInput, AptosWallet, AptosSignAndSubmitTransactionOutput, AccountInfo as StandardAccountInfo, AptosSignTransactionOutputV1_1 } from "@aptos-labs/wallet-standard";
2
- import { AnyRawTransaction, Aptos } from "@aptos-labs/ts-sdk";
3
- import { WalletReadyState } from "../constants";
4
- import { AccountInfo, InputTransactionData, Wallet } from "../LegacyWalletPlugins";
5
- export type AptosStandardWallet = AptosWallet & {
6
- readyState?: WalletReadyState;
7
- };
8
- export declare class WalletStandardCore {
9
- connect(wallet: Wallet): Promise<StandardAccountInfo>;
10
- /**
11
- * Signs and submits a transaction to chain
12
- *
13
- * @param transactionInput InputTransactionData
14
- * @returns PendingTransactionResponse
15
- */
16
- signAndSubmitTransaction(transactionInput: InputTransactionData, aptos: Aptos, account: AccountInfo, wallet: Wallet, standardWallets: ReadonlyArray<AptosStandardWallet>): Promise<AptosSignAndSubmitTransactionOutput>;
17
- /**
18
- * Signs a transaction
19
- *
20
- * To support both existing wallet adapter V1 and V2, we support 2 input types
21
- *
22
- * @param transactionOrPayload AnyRawTransaction
23
- * @param options asFeePayer. To sign a transaction as the fee payer sponsor
24
- *
25
- * @returns AptosSignTransactionOutput
26
- */
27
- signTransaction(transaction: AnyRawTransaction, wallet: Wallet, asFeePayer?: boolean): Promise<AptosSignTransactionOutput>;
28
- signTransaction(input: AptosSignTransactionInputV1_1, wallet: Wallet): Promise<AptosSignTransactionOutputV1_1>;
29
- /**
30
- * Sign message
31
- *
32
- * @param message AptosSignMessageInput
33
- * @return AptosSignMessageOutput
34
- * @throws WalletSignMessageError
35
- */
36
- signMessage(message: AptosSignMessageInput, wallet: Wallet): Promise<AptosSignMessageOutput>;
37
- /**
38
- * Signs a message and verifies the signer
39
- * @param message AptosSignMessageInput
40
- * @returns boolean
41
- */
42
- signMessageAndVerify(message: AptosSignMessageInput, wallet: Wallet): Promise<boolean>;
43
- }
44
- //# sourceMappingURL=WalletStandard.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"WalletStandard.d.ts","sourceRoot":"","sources":["../../src/AIP62StandardWallets/WalletStandard.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,6BAA6B,EAC7B,0BAA0B,EAC1B,sBAAsB,EACtB,qBAAqB,EACrB,WAAW,EAEX,mCAAmC,EACnC,WAAW,IAAI,mBAAmB,EAElC,8BAA8B,EAC/B,MAAM,6BAA6B,CAAC;AACrC,OAAO,EAGL,iBAAiB,EAEjB,KAAK,EAGN,MAAM,oBAAoB,CAAC;AAE5B,OAAO,EAAE,gBAAgB,EAAE,MAAM,cAAc,CAAC;AAOhD,OAAO,EACL,WAAW,EACX,oBAAoB,EACpB,MAAM,EACP,MAAM,wBAAwB,CAAC;AAGhC,MAAM,MAAM,mBAAmB,GAAG,WAAW,GAAG;IAC9C,UAAU,CAAC,EAAE,gBAAgB,CAAC;CAC/B,CAAC;AAEF,qBAAa,kBAAkB;IACvB,OAAO,CAAC,MAAM,EAAE,MAAM;IAU5B;;;;;OAKG;IACG,wBAAwB,CAC5B,gBAAgB,EAAE,oBAAoB,EACtC,KAAK,EAAE,KAAK,EACZ,OAAO,EAAE,WAAW,EACpB,MAAM,EAAE,MAAM,EACd,eAAe,EAAE,aAAa,CAAC,mBAAmB,CAAC,GAClD,OAAO,CAAC,mCAAmC,CAAC;IAsD/C;;;;;;;;;OASG;IACG,eAAe,CACnB,WAAW,EAAE,iBAAiB,EAC9B,MAAM,EAAE,MAAM,EACd,UAAU,CAAC,EAAE,OAAO,GACnB,OAAO,CAAC,0BAA0B,CAAC;IAChC,eAAe,CACnB,KAAK,EAAE,6BAA6B,EACpC,MAAM,EAAE,MAAM,GACb,OAAO,CAAC,8BAA8B,CAAC;IAgB1C;;;;;;OAMG;IACG,WAAW,CACf,OAAO,EAAE,qBAAqB,EAC9B,MAAM,EAAE,MAAM,GACb,OAAO,CAAC,sBAAsB,CAAC;IAgBlC;;;;OAIG;IACG,oBAAoB,CACxB,OAAO,EAAE,qBAAqB,EAC9B,MAAM,EAAE,MAAM,GACb,OAAO,CAAC,OAAO,CAAC;CAuDpB"}
@@ -1,3 +0,0 @@
1
- export * from "./types";
2
- export * from "./WalletStandard";
3
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/AIP62StandardWallets/index.ts"],"names":[],"mappings":"AAAA,cAAc,SAAS,CAAC;AACxB,cAAc,kBAAkB,CAAC"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"registry.d.ts","sourceRoot":"","sources":["../../src/AIP62StandardWallets/registry.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,4BAA4B,EAAE,MAAM,SAAS,CAAC;AAEvD;;;;;;;;;;;;;GAaG;AACH,eAAO,MAAM,gCAAgC,EAAE,KAAK,CAAC,4BAA4B,CAyB9E,CAAC"}
@@ -1,4 +0,0 @@
1
- import { DappConfig } from "../WalletCore";
2
- import { AptosStandardWallet } from "./WalletStandard";
3
- export declare function getSDKWallets(dappConfig?: DappConfig): AptosStandardWallet[];
4
- //# sourceMappingURL=sdkWallets.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"sdkWallets.d.ts","sourceRoot":"","sources":["../../src/AIP62StandardWallets/sdkWallets.ts"],"names":[],"mappings":"AAOA,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAC3C,OAAO,EAAE,mBAAmB,EAAE,MAAM,kBAAkB,CAAC;AAEvD,wBAAgB,aAAa,CAAC,UAAU,CAAC,EAAE,UAAU,yBA8CpD"}
@@ -1,12 +0,0 @@
1
- import { WalletName } from "../LegacyWalletPlugins/types";
2
- import { WalletReadyState } from "../constants";
3
- export interface AptosStandardSupportedWallet<Name extends string = string> {
4
- name: WalletName<Name>;
5
- url: string;
6
- icon: `data:image/${"svg+xml" | "webp" | "png" | "gif"};base64,${string}`;
7
- readyState: WalletReadyState.NotDetected;
8
- isAIP62Standard: true;
9
- deeplinkProvider?: string;
10
- }
11
- export type AvailableWallets = "Nightly" | "Petra" | "T wallet" | "Pontem Wallet" | "Mizu Wallet" | "Continue with Google";
12
- //# sourceMappingURL=types.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/AIP62StandardWallets/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,8BAA8B,CAAC;AAC1D,OAAO,EAAE,gBAAgB,EAAE,MAAM,cAAc,CAAC;AAEhD,MAAM,WAAW,4BAA4B,CAAC,IAAI,SAAS,MAAM,GAAG,MAAM;IAExE,IAAI,EAAE,UAAU,CAAC,IAAI,CAAC,CAAC;IAEvB,GAAG,EAAE,MAAM,CAAC;IAEZ,IAAI,EAAE,cAAc,SAAS,GAAG,MAAM,GAAG,KAAK,GAAG,KAAK,WAAW,MAAM,EAAE,CAAC;IAG1E,UAAU,EAAE,gBAAgB,CAAC,WAAW,CAAC;IAGzC,eAAe,EAAE,IAAI,CAAC;IAGtB,gBAAgB,CAAC,EAAE,MAAM,CAAC;CAC3B;AAGD,MAAM,MAAM,gBAAgB,GACxB,SAAS,GACT,OAAO,GACP,UAAU,GACV,eAAe,GACf,aAAa,GACb,sBAAsB,CAAC"}
@@ -1,50 +0,0 @@
1
- import { TxnBuilderTypes, Types } from "aptos";
2
- import EventEmitter from "eventemitter3";
3
- import { InputGenerateTransactionPayloadData } from "@aptos-labs/ts-sdk";
4
- import { Wallet, WalletCoreEvents, TransactionOptions, NetworkInfo, InputTransactionData, AccountInfo, SignMessagePayload } from "./types";
5
- import { DappConfig } from "../WalletCore";
6
- export declare class WalletCoreV1 extends EventEmitter<WalletCoreEvents> {
7
- connect(wallet: Wallet): Promise<any>;
8
- /**
9
- * Resolve the transaction type (BCS arguments or Simple arguments)
10
- *
11
- * @param payloadData
12
- * @param network
13
- * @param wallet
14
- * @param transactionInput
15
- *
16
- * @returns
17
- */
18
- resolveSignAndSubmitTransaction(payloadData: InputGenerateTransactionPayloadData, network: NetworkInfo | null, wallet: Wallet, transactionInput: InputTransactionData, dappConfig?: DappConfig): Promise<any>;
19
- /**
20
- Sign and submit an entry (not bcs serialized) transaction type to chain.
21
- @param transaction a non-bcs serialized transaction
22
- @param options max_gas_amount and gas_unit_limit
23
- @return response from the wallet's signAndSubmitTransaction function
24
- @throws WalletSignAndSubmitMessageError
25
- */
26
- signAndSubmitTransaction(transaction: Types.TransactionPayload, wallet: Wallet, options?: TransactionOptions): Promise<any>;
27
- /**
28
- Sign and submit a bsc serialized transaction type to chain.
29
- @param transaction a bcs serialized transaction
30
- @param options max_gas_amount and gas_unit_limit
31
- @return response from the wallet's signAndSubmitBCSTransaction function
32
- @throws WalletSignAndSubmitMessageError
33
- */
34
- signAndSubmitBCSTransaction(transaction: TxnBuilderTypes.TransactionPayload, wallet: Wallet, options?: TransactionOptions): Promise<any>;
35
- /**
36
- Sign transaction
37
- @param transaction
38
- @param options max_gas_amount and gas_unit_limit
39
- @return response from the wallet's signTransaction function
40
- @throws WalletSignTransactionError
41
- */
42
- signTransaction(transaction: Types.TransactionPayload, wallet: Wallet, options?: TransactionOptions): Promise<Uint8Array | null>;
43
- /**
44
- * Signs a message and verifies the signer
45
- * @param message SignMessagePayload
46
- * @returns boolean
47
- */
48
- signMessageAndVerify(message: SignMessagePayload, wallet: Wallet, account: AccountInfo): Promise<boolean>;
49
- }
50
- //# sourceMappingURL=WalletCoreV1.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"WalletCoreV1.d.ts","sourceRoot":"","sources":["../../src/LegacyWalletPlugins/WalletCoreV1.ts"],"names":[],"mappings":"AAAA,OAAO,EAAa,eAAe,EAAE,KAAK,EAAE,MAAM,OAAO,CAAC;AAC1D,OAAO,YAAY,MAAM,eAAe,CAAC;AAEzC,OAAO,EAEL,mCAAmC,EAEpC,MAAM,oBAAoB,CAAC;AAQ5B,OAAO,EACL,MAAM,EACN,gBAAgB,EAChB,kBAAkB,EAClB,WAAW,EACX,oBAAoB,EACpB,WAAW,EACX,kBAAkB,EAEnB,MAAM,SAAS,CAAC;AAWjB,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAE3C,qBAAa,YAAa,SAAQ,YAAY,CAAC,gBAAgB,CAAC;IACxD,OAAO,CAAC,MAAM,EAAE,MAAM;IAK5B;;;;;;;;;OASG;IACG,+BAA+B,CACnC,WAAW,EAAE,mCAAmC,EAChD,OAAO,EAAE,WAAW,GAAG,IAAI,EAC3B,MAAM,EAAE,MAAM,EACd,gBAAgB,EAAE,oBAAoB,EACtC,UAAU,CAAC,EAAE,UAAU;IAuCzB;;;;;;MAME;IACI,wBAAwB,CAC5B,WAAW,EAAE,KAAK,CAAC,kBAAkB,EACrC,MAAM,EAAE,MAAM,EACd,OAAO,CAAC,EAAE,kBAAkB,GAC3B,OAAO,CAAC,GAAG,CAAC;IAcf;;;;;;OAMG;IACG,2BAA2B,CAC/B,WAAW,EAAE,eAAe,CAAC,kBAAkB,EAC/C,MAAM,EAAE,MAAM,EACd,OAAO,CAAC,EAAE,kBAAkB,GAC3B,OAAO,CAAC,GAAG,CAAC;IAmBf;;;;;;OAMG;IACG,eAAe,CACnB,WAAW,EAAE,KAAK,CAAC,kBAAkB,EACrC,MAAM,EAAE,MAAM,EACd,OAAO,CAAC,EAAE,kBAAkB,GAC3B,OAAO,CAAC,UAAU,GAAG,IAAI,CAAC;IAc7B;;;;OAIG;IACG,oBAAoB,CACxB,OAAO,EAAE,kBAAkB,EAC3B,MAAM,EAAE,MAAM,EACd,OAAO,EAAE,WAAW,GACnB,OAAO,CAAC,OAAO,CAAC;CAuEpB"}
@@ -1,21 +0,0 @@
1
- import { Network, TransactionPayload, InputGenerateTransactionPayloadData, AptosConfig, InputEntryFunctionData, TransactionPayloadEntryFunction } from "@aptos-labs/ts-sdk";
2
- import { NetworkInfo as StandardNetworkInfo } from "@aptos-labs/wallet-standard";
3
- import { TxnBuilderTypes, Types } from "aptos";
4
- import { NetworkInfo } from "./types";
5
- export declare function convertNetwork(networkInfo: NetworkInfo | StandardNetworkInfo | null): Network;
6
- export declare function convertV2TransactionPayloadToV1BCSPayload(payload: TransactionPayload): TxnBuilderTypes.TransactionPayload;
7
- export declare function convertV2PayloadToV1JSONPayload(payload: InputGenerateTransactionPayloadData): Types.TransactionPayload;
8
- export declare function convertPayloadInputV1ToV2(inputV1: Types.TransactionPayload): InputEntryFunctionData;
9
- export declare function generateTransactionPayloadFromV1Input(aptosConfig: AptosConfig, inputV1: Types.TransactionPayload): Promise<TransactionPayloadEntryFunction>;
10
- export interface CompatibleTransactionOptions {
11
- expireTimestamp?: number;
12
- expirationSecondsFromNow?: number;
13
- expirationTimestamp?: number;
14
- gasUnitPrice?: number;
15
- gas_unit_price?: number;
16
- maxGasAmount?: number;
17
- max_gas_amount?: number;
18
- sender?: string;
19
- sequenceNumber?: number;
20
- }
21
- //# sourceMappingURL=conversion.d.ts.map