+
@@ -366,4 +351,4 @@ const Navbar: FunctionComponent = () => {
);
};
-export default Navbar;
\ No newline at end of file
+export default Navbar;
diff --git a/tests/utils/connectors.test.js b/tests/utils/connectors.test.js
deleted file mode 100644
index d560b6a0..00000000
--- a/tests/utils/connectors.test.js
+++ /dev/null
@@ -1,58 +0,0 @@
-import { sortConnectors } from "../../utils/connectors";
-class MockConnector {
- constructor(id, name, isAvailable) {
- this.id = id;
- this.name = name;
- this.isAvailable = isAvailable;
- }
- available() {
- return this.isAvailable;
- }
-}
-
-describe("sortConnectors function", () => {
- it("should place available connectors first, followed by unavailable ones", () => {
- const connectors = [
- new MockConnector("okxwallet", "Okx Wallet", false),
- new MockConnector("braavos", "Braavos", true),
- new MockConnector("bitkeep", "Bitget Wallet", false),
- new MockConnector("argentX", "Argent X", true),
- ];
-
- const sortedConnectors = sortConnectors(connectors);
-
- expect(sortedConnectors[0].name).toBe("Braavos");
- expect(sortedConnectors[1].name).toBe("Argent X");
- expect(sortedConnectors[2].name).toBe("Okx Wallet");
- expect(sortedConnectors[3].name).toBe("Bitget Wallet");
- });
-
- it("should return an empty array if no connectors are provided", () => {
- const sortedConnectors = sortConnectors([]);
- expect(sortedConnectors).toEqual([]);
- });
-
- it("should handle the case when all connectors are available", () => {
- const connectors = [
- new MockConnector("braavos", "Braavos", true),
- new MockConnector("argentX", "Argent X", true),
- ];
-
- const sortedConnectors = sortConnectors(connectors);
-
- expect(sortedConnectors[0].name).toBe("Braavos");
- expect(sortedConnectors[1].name).toBe("Argent X");
- });
-
- it("should handle the case when all connectors are unavailable", () => {
- const connectors = [
- new MockConnector("okxwallet", "Okx Wallet", false),
- new MockConnector("bitkeep", "Bitget Wallet", false),
- ];
-
- const sortedConnectors = sortConnectors(connectors);
-
- expect(sortedConnectors[0].name).toBe("Okx Wallet");
- expect(sortedConnectors[1].name).toBe("Bitget Wallet");
- });
-});
diff --git a/tests/utils/walletConfig.test.js b/tests/utils/walletConfig.test.js
new file mode 100644
index 00000000..befc29ca
--- /dev/null
+++ b/tests/utils/walletConfig.test.js
@@ -0,0 +1,148 @@
+import {
+ sortConnectors,
+ getConnectorIcon,
+ getConnectorName,
+ getConnectorDiscovery,
+} from "../../utils/walletConfig";
+class MockConnector {
+ constructor(id, name, isAvailable) {
+ this.id = id;
+ this.name = name;
+ this.isAvailable = isAvailable;
+ }
+ available() {
+ return this.isAvailable;
+ }
+}
+
+describe("sortConnectors function", () => {
+ it("should place available connectors first, followed by unavailable ones", () => {
+ const connectors = [
+ new MockConnector("okxwallet", "Okx Wallet", false),
+ new MockConnector("braavos", "Braavos", true),
+ new MockConnector("bitkeep", "Bitget Wallet", false),
+ new MockConnector("argentX", "Argent X", true),
+ ];
+
+ const sortedConnectors = sortConnectors(connectors);
+
+ expect(sortedConnectors[0].name).toBe("Braavos");
+ expect(sortedConnectors[1].name).toBe("Argent X");
+ expect(sortedConnectors[2].name).toBe("Okx Wallet");
+ expect(sortedConnectors[3].name).toBe("Bitget Wallet");
+ });
+
+ it("should return an empty array if no connectors are provided", () => {
+ const sortedConnectors = sortConnectors([]);
+ expect(sortedConnectors).toEqual([]);
+ });
+
+ it("should handle the case when all connectors are available", () => {
+ const connectors = [
+ new MockConnector("braavos", "Braavos", true),
+ new MockConnector("argentX", "Argent X", true),
+ ];
+
+ const sortedConnectors = sortConnectors(connectors);
+
+ expect(sortedConnectors[0].name).toBe("Braavos");
+ expect(sortedConnectors[1].name).toBe("Argent X");
+ });
+
+ it("should handle the case when all connectors are unavailable", () => {
+ const connectors = [
+ new MockConnector("okxwallet", "Okx Wallet", false),
+ new MockConnector("bitkeep", "Bitget Wallet", false),
+ ];
+
+ const sortedConnectors = sortConnectors(connectors);
+
+ expect(sortedConnectors[0].name).toBe("Okx Wallet");
+ expect(sortedConnectors[1].name).toBe("Bitget Wallet");
+ });
+});
+
+describe("getConnectorIcon function", () => {
+ it("should return the icon for a wallet when the ID matches", () => {
+ expect(getConnectorIcon("argentX")).toBe(
+ "",
+ );
+ expect(getConnectorIcon("braavos")).toBe(
+ "",
+ );
+ });
+
+ it("should return the ID itself if no wallet matches the ID", () => {
+ expect(getConnectorIcon("wallet4")).toBe("wallet4");
+ expect(getConnectorIcon("wallet5")).toBe("wallet5");
+ });
+
+ it("should handle cases where the wallet ID is undefined", () => {
+ expect(getConnectorIcon(undefined)).toBe(undefined);
+ });
+
+ it("should handle cases where the wallet ID is empty", () => {
+ expect(getConnectorIcon("")).toBe("");
+ });
+});
+
+describe("getConnectorName function", () => {
+ it("should return the name for a wallet when the ID matches", () => {
+ expect(getConnectorName("argentX")).toBe("Argent X");
+ expect(getConnectorName("braavos")).toBe("Braavos");
+ expect(getConnectorName("bitkeep")).toBe("Bitget Wallet");
+ expect(getConnectorName("okxwallet")).toBe("OKX Wallet");
+ expect(getConnectorName("argentMobile")).toBe("Argent (mobile)");
+ expect(getConnectorName("argentWebWallet")).toBe("Email");
+ });
+
+ it("should return the ID itself if no wallet matches the ID", () => {
+ expect(getConnectorName("wallet")).toBe("wallet");
+ });
+
+ it("should handle cases where the wallet ID is undefined", () => {
+ expect(getConnectorName(undefined)).toBe(undefined);
+ });
+
+ it("should handle cases where the wallet ID is empty", () => {
+ expect(getConnectorName("")).toBe("");
+ });
+});
+
+describe("getConnectorDiscovery function", () => {
+ beforeEach(() => {
+ global.navigator = {
+ userAgent:
+ "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/58.0.3029.110 Safari/537.36",
+ };
+ });
+
+ afterEach(() => {
+ global.navigator = undefined;
+ });
+
+ it("should return the wallet's website URL when no downloads are available", () => {
+ expect(getConnectorDiscovery("argentWebWallet")).toBe(
+ "https://www.argent.xyz/argent-x/",
+ );
+ });
+
+ it("should return the correct download link for the user's browser if available", () => {
+ expect(getConnectorDiscovery("braavos")).toBe(
+ "https://chrome.google.com/webstore/detail/braavos-wallet/jnlgamecbpmbajjfhmmmlhejkemejdma",
+ );
+ });
+
+ it("should return the ecosystem website if no wallet data is found", () => {
+ expect(getConnectorDiscovery("wallet")).toBe(
+ "https://www.starknet-ecosystem.com",
+ );
+ });
+
+ it("should return the wallet's website when navigator is undefined", () => {
+ Object.defineProperty(global, "navigator", { value: undefined });
+ expect(getConnectorDiscovery("argentX")).toBe(
+ "https://www.argent.xyz/argent-x/",
+ );
+ });
+});
diff --git a/types/frontTypes.d.ts b/types/frontTypes.d.ts
index d0f9c6bf..ab8934d2 100644
--- a/types/frontTypes.d.ts
+++ b/types/frontTypes.d.ts
@@ -349,8 +349,8 @@ type Call = {
};
type ChartItem = {
- color: string,
- itemLabel: string,
- itemValue: string,
- itemValueSymbol: string
-}
\ No newline at end of file
+ color: string;
+ itemLabel: string;
+ itemValue: string;
+ itemValueSymbol: string;
+};
diff --git a/utils/connectors.ts b/utils/connectors.ts
deleted file mode 100644
index dbc85fd1..00000000
--- a/utils/connectors.ts
+++ /dev/null
@@ -1,24 +0,0 @@
-import { Connector } from "starknetkit";
-
-export const sortConnectors = (connectors: Connector[]): Connector[] => {
- const available: Connector[] = [];
- const notAvailable: Connector[] = [];
-
- // Sort connectors
- connectors.forEach((connector) => {
- if (connector.available()) {
- available.push(connector);
- } else {
- notAvailable.push(connector);
- }
- });
-
- return [
- ...available,
- // Reorganized not available connectors
- ...notAvailable.sort((a, b) => {
- const order = ["okxwallet", "bitkeep"]; // desired order
- return order.indexOf(a.id) - order.indexOf(b.id);
- }),
- ];
-};
\ No newline at end of file
diff --git a/utils/walletConfig.ts b/utils/walletConfig.ts
new file mode 100644
index 00000000..857dd4a0
--- /dev/null
+++ b/utils/walletConfig.ts
@@ -0,0 +1,173 @@
+import { constants } from "starknet";
+import { InjectedConnector } from "starknetkit/injected";
+import { WebWalletConnector } from "starknetkit/webwallet";
+import { Connector, StarknetWindowObject } from "starknetkit";
+import { ArgentMobileConnector } from "starknetkit/argentMobile";
+import { getCurrentNetwork } from "./network";
+import { getBrowser } from "./browserService";
+
+export type WalletStore = "chrome" | "firefox" | "edge" | "safari";
+type WalletDownload = Partial>;
+
+type Wallet = {
+ id: string;
+ name: string;
+ icon: string;
+ downloads?: WalletDownload;
+ website: string;
+};
+
+export const wallets: Wallet[] = [
+ {
+ id: "argentX",
+ name: "Argent X",
+ icon: ``,
+ downloads: {
+ chrome:
+ "https://chrome.google.com/webstore/detail/argent-x-starknet-wallet/dlcobpjiigpikoobohmabehhmhfoodbb",
+ firefox: "https://addons.mozilla.org/en-US/firefox/addon/argent-x",
+ edge: "https://microsoftedge.microsoft.com/addons/detail/argent-x/ajcicjlkibolbeaaagejfhnofogocgcj",
+ },
+ website: "https://www.argent.xyz/argent-x/",
+ },
+ {
+ id: "argentMobile",
+ name: "Argent (mobile)",
+ icon: "",
+ website: "https://www.argent.xyz/argent-x/",
+ },
+ {
+ id: "argentWebWallet",
+ name: "Email",
+ icon: "",
+ website: "https://www.argent.xyz/argent-x/",
+ },
+ {
+ id: "braavos",
+ name: "Braavos",
+ icon: "",
+ downloads: {
+ chrome:
+ "https://chrome.google.com/webstore/detail/braavos-wallet/jnlgamecbpmbajjfhmmmlhejkemejdma",
+ firefox: "https://addons.mozilla.org/en-US/firefox/addon/braavos-wallet",
+ edge: "https://microsoftedge.microsoft.com/addons/detail/braavos-wallet/hkkpjehhcnhgefhbdcgfkeegglpjchdc",
+ },
+ website: "https://braavos.app/",
+ },
+ {
+ id: "bitkeep",
+ name: "Bitget Wallet",
+ icon: "",
+ downloads: {
+ chrome:
+ "https://chromewebstore.google.com/detail/bitget-wallet-formerly-bi/jiidiaalihmmhddjgbnbgdfflelocpak",
+ },
+ website: "https://web3.bitget.com/",
+ },
+ {
+ id: "okxwallet",
+ name: "OKX Wallet",
+ icon: "",
+ downloads: {
+ chrome:
+ "https://chrome.google.com/webstore/detail/mcohilncbfahbmgdjkbpemcciiolgcge",
+ firefox: "https://addons.mozilla.org/en-US/firefox/addon/okexwallet",
+ edge: "https://microsoftedge.microsoft.com/addons/detail/%E6%AC%A7%E6%98%93-web3-%E9%92%B1%E5%8C%85/pbpjkcldjiffchgbbndmhojiacbgflha",
+ safari: "https://apps.apple.com/us/app/okx-wallet/id6463797825",
+ },
+ website: "https://www.okx.com/",
+ },
+ {
+ id: "keplr",
+ name: "Keplr Wallet",
+ icon: "/visuals/kepler_logo.svg",
+ downloads: {
+ chrome:
+ "https://chromewebstore.google.com/detail/keplr/dmkamcknogkgcdfhhbddcghachkejeap",
+ firefox: "https://addons.mozilla.org/en-US/firefox/addon/keplr/",
+ edge: "https://microsoftedge.microsoft.com/addons/detail/keplr/ocodgmmffbkkeecmadcijjhkmeohinei",
+ },
+ website: "https://www.keplr.app/",
+ },
+];
+
+// Check if the Bitget wallet is available on the window object
+const isBitgetWalletInstalled = () =>
+ typeof window !== "undefined" && window.bitget !== undefined;
+
+export const getConnectors = () => {
+ const connectors = [
+ new InjectedConnector({ options: { id: "braavos", name: "Braavos" } }),
+ new InjectedConnector({ options: { id: "argentX", name: "Argent X" } }),
+ new InjectedConnector({
+ options: {
+ id: "bitkeep",
+ name: isBitgetWalletInstalled()
+ ? "Bitget Wallet"
+ : "Install Bitget Wallet",
+ icon: "",
+ },
+ }),
+ new InjectedConnector({ options: { id: "okxwallet", name: "Okx Wallet" } }),
+
+ new WebWalletConnector({
+ url:
+ getCurrentNetwork() === "TESTNET"
+ ? "https://web.hydrogen.argent47.net"
+ : "https://web.argent.xyz/",
+ }),
+ ArgentMobileConnector.init({
+ options: {
+ dappName: "Starknet Quest",
+ url: process.env.NEXT_PUBLIC_APP_LINK as string,
+ chainId: constants.NetworkName.SN_MAIN,
+ icons: ["https://starknet.quest/visuals/starknetquestLogo.svg"],
+ },
+ }),
+
+ new InjectedConnector({ options: { id: "keplr", name: "Keplr" } }),
+ ];
+
+ return connectors;
+};
+
+export const getWalletInfo = (id: string) => {
+ return wallets.find((wallet) => wallet.id === id);
+};
+
+export const sortConnectors = (connectors: Connector[]): Connector[] => {
+ const available: Connector[] = [];
+ const notAvailable: Connector[] = [];
+
+ connectors.forEach((connector) => {
+ connector.available()
+ ? available.push(connector)
+ : notAvailable.push(connector);
+ });
+
+ return [
+ ...available,
+ ...notAvailable.sort((a, b) => {
+ const order = ["okxwallet", "bitkeep"];
+ return order.indexOf(a.id) - order.indexOf(b.id);
+ }),
+ ];
+};
+
+export const getConnectorIcon = (id: string) => getWalletInfo(id)?.icon ?? id;
+
+export const getConnectorName = (id: string) => getWalletInfo(id)?.name ?? id;
+
+export const getConnectorDiscovery = (id: string) => {
+ const walletData = getWalletInfo(id);
+
+ if (!walletData || !walletData.website)
+ return "https://www.starknet-ecosystem.com";
+
+ if (walletData.downloads && typeof navigator !== "undefined") {
+ const browser = getBrowser(navigator.userAgent);
+ return walletData.downloads[browser as WalletStore] ?? walletData.website;
+ }
+
+ return walletData.website;
+};