From 6cbc0f18de994280ea2bd8ca3526c039f5af08b7 Mon Sep 17 00:00:00 2001 From: Abeeujah <100226788+Abeeujah@users.noreply.github.com> Date: Tue, 26 Nov 2024 03:12:59 +0100 Subject: [PATCH] refac: Simplify wallet management system by creating a centralized configuration (#961) --- app/not-connected/page.tsx | 4 +- app/provider.tsx | 120 +++++------- .../UI/iconsComponents/icons/walletIcons.tsx | 100 +--------- components/UI/navbar.tsx | 75 +++----- tests/utils/connectors.test.js | 58 ------ tests/utils/walletConfig.test.js | 148 +++++++++++++++ types/frontTypes.d.ts | 10 +- utils/connectors.ts | 24 --- utils/walletConfig.ts | 173 ++++++++++++++++++ 9 files changed, 409 insertions(+), 303 deletions(-) delete mode 100644 tests/utils/connectors.test.js create mode 100644 tests/utils/walletConfig.test.js delete mode 100644 utils/connectors.ts create mode 100644 utils/walletConfig.ts diff --git a/app/not-connected/page.tsx b/app/not-connected/page.tsx index 7886c4ce..1e6ceada 100644 --- a/app/not-connected/page.tsx +++ b/app/not-connected/page.tsx @@ -12,7 +12,7 @@ export default function Page() { const { connectAsync } = useConnect(); const { push } = useRouter(); const { starknetkitConnectModal } = useStarknetkitConnectModal({ - connectors: availableConnectors as any, + connectors: availableConnectors as any, modalTheme: "dark", }); @@ -25,7 +25,7 @@ export default function Page() { if (!connector) { return; } - await connectAsync({ connector: connector as Connector }); // Type casted + await connectAsync({ connector: connector as Connector }); // Type casted localStorage.setItem("SQ-connectedWallet", connector.id); }; diff --git a/app/provider.tsx b/app/provider.tsx index 0ec6b2fb..e6af9378 100644 --- a/app/provider.tsx +++ b/app/provider.tsx @@ -1,30 +1,31 @@ -'use client'; +"use client"; -import React from 'react'; -import { InjectedConnector } from 'starknetkit/injected'; -import { WebWalletConnector } from 'starknetkit/webwallet'; -import { ArgentMobileConnector } from 'starknetkit/argentMobile'; -import { Chain, mainnet, sepolia } from '@starknet-react/chains'; +import React from "react"; +import { InjectedConnector } from "starknetkit/injected"; +import { WebWalletConnector } from "starknetkit/webwallet"; +import { ArgentMobileConnector } from "starknetkit/argentMobile"; +import { Chain, mainnet, sepolia } from "@starknet-react/chains"; import { Connector, StarknetConfig, jsonRpcProvider, -} from '@starknet-react/core'; -import { StarknetIdJsProvider } from '@context/StarknetIdJsProvider'; -import { ThemeProvider, createTheme } from '@mui/material'; -import { QuestsContextProvider } from '@context/QuestsProvider'; -import { getCurrentNetwork } from '@utils/network'; -import { constants } from 'starknet'; -import { PostHogProvider } from 'posthog-js/react'; -import posthog from 'posthog-js'; -import { NotificationProvider } from '@context/NotificationProvider'; -import { LocalizationProvider } from '@mui/x-date-pickers'; -import { AdapterDayjs } from '@mui/x-date-pickers/AdapterDayjs'; +} from "@starknet-react/core"; +import { StarknetIdJsProvider } from "@context/StarknetIdJsProvider"; +import { ThemeProvider, createTheme } from "@mui/material"; +import { QuestsContextProvider } from "@context/QuestsProvider"; +import { getCurrentNetwork } from "@utils/network"; +import { constants } from "starknet"; +import { PostHogProvider } from "posthog-js/react"; +import posthog from "posthog-js"; +import { NotificationProvider } from "@context/NotificationProvider"; +import { LocalizationProvider } from "@mui/x-date-pickers"; +import { AdapterDayjs } from "@mui/x-date-pickers/AdapterDayjs"; +import { getConnectors } from "@utils/walletConfig"; // Traffic measures -if (typeof window !== 'undefined') { +if (typeof window !== "undefined") { posthog.init(process.env.NEXT_PUBLIC_POSTHOG_KEY as string, { - api_host: 'https://app.posthog.com', + api_host: "https://app.posthog.com", session_recording: { recordCrossOriginIframes: true, }, @@ -34,46 +35,11 @@ if (typeof window !== 'undefined') { (window as any).posthog = posthog; } -function isBitgetWalletInstalled() { - // Check if the Bitget wallet is available on the window object - return typeof window !== "undefined" && window.bitget !== undefined; -} - -export const availableConnectors = [ - 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' } }), -]; +export const availableConnectors = getConnectors(); export function Providers({ children }: { children: React.ReactNode }) { const network = getCurrentNetwork(); - const chains = [network === 'TESTNET' ? sepolia : mainnet]; + const chains = [network === "TESTNET" ? sepolia : mainnet]; const provider = jsonRpcProvider({ // eslint-disable-next-line @typescript-eslint/no-unused-vars rpc: (_chain: Chain) => ({ @@ -84,33 +50,33 @@ export function Providers({ children }: { children: React.ReactNode }) { const theme = createTheme({ palette: { primary: { - main: '#6affaf', - light: '#5ce3fe', + main: "#6affaf", + light: "#5ce3fe", }, secondary: { - main: '#f4faff', - dark: '#eae0d5', + main: "#f4faff", + dark: "#eae0d5", }, background: { - default: '#29282b', + default: "#29282b", }, }, components: { MuiTabs: { styleOverrides: { root: { - '& .MuiTabs-flexContainer': { - display: 'flex', - flexDirection: 'column', // For mobile versions - alignItems: 'center', - ['@media (min-width:768px)']: { - flexDirection: 'row', // For desktop versions + "& .MuiTabs-flexContainer": { + display: "flex", + flexDirection: "column", // For mobile versions + alignItems: "center", + ["@media (min-width:768px)"]: { + flexDirection: "row", // For desktop versions }, }, }, // Overrides the styles for the selected tab indicator indicator: { - backgroundColor: 'transparent', + backgroundColor: "transparent", }, }, }, @@ -118,14 +84,14 @@ export function Providers({ children }: { children: React.ReactNode }) { styleOverrides: { // Overrides the styles for unselected tabs root: { - color: '#E1DCEA', // Text color for unselected tabs - width: '100%', - ['@media (min-width:768px)']: { - width: 'fit-content', + color: "#E1DCEA", // Text color for unselected tabs + width: "100%", + ["@media (min-width:768px)"]: { + width: "fit-content", }, - '&.Mui-selected': { - color: '#000', // Text color for the selected tab - backgroundColor: '#fff', // Background of the selected tab + "&.Mui-selected": { + color: "#000", // Text color for the selected tab + backgroundColor: "#fff", // Background of the selected tab }, }, }, @@ -145,7 +111,7 @@ export function Providers({ children }: { children: React.ReactNode }) { - {children} + {children} @@ -153,4 +119,4 @@ export function Providers({ children }: { children: React.ReactNode }) { ); -} \ No newline at end of file +} diff --git a/components/UI/iconsComponents/icons/walletIcons.tsx b/components/UI/iconsComponents/icons/walletIcons.tsx index efc72565..81564608 100644 --- a/components/UI/iconsComponents/icons/walletIcons.tsx +++ b/components/UI/iconsComponents/icons/walletIcons.tsx @@ -1,105 +1,21 @@ import React from "react"; import { FunctionComponent } from "react"; import styles from "../../../../styles/components/icons.module.css"; +import { getWalletInfo } from "@utils/walletConfig"; type WalletIconsProps = { id: string; }; const WalletIcons: FunctionComponent = ({ id }) => { - if (id === "argentX") - return ( - - - - ); - - if (id === "braavos") - return ( - - - - - - ); - - if (id === "bitkeep") - return ( - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - ); - - - return ( - - - - ); + /> + ) : null; }; export default WalletIcons; diff --git a/components/UI/navbar.tsx b/components/UI/navbar.tsx index 51615cc6..c25a3b19 100644 --- a/components/UI/navbar.tsx +++ b/components/UI/navbar.tsx @@ -31,7 +31,7 @@ import { PendingBoostClaim } from "types/backTypes"; import Typography from "./typography/typography"; import { TEXT_TYPE } from "@constants/typography"; import Hamburger from "./hamburger"; -import { sortConnectors } from "@utils/connectors"; +import { sortConnectors } from "@utils/walletConfig"; const Navbar: FunctionComponent = () => { const currentNetwork = getCurrentNetwork(); @@ -180,24 +180,18 @@ const Navbar: FunctionComponent = () => { return ( <> -