From 0bb807edf52404a6e1634689f55c15ab9f7b7b03 Mon Sep 17 00:00:00 2001 From: godekina Date: Mon, 11 Nov 2024 13:20:07 +0100 Subject: [PATCH] update provider.tsx --- app/provider.tsx | 111 +++++++++++++++++++++++++++-------------------- 1 file changed, 63 insertions(+), 48 deletions(-) diff --git a/app/provider.tsx b/app/provider.tsx index 1e3c9114..f9344719 100644 --- a/app/provider.tsx +++ b/app/provider.tsx @@ -1,30 +1,30 @@ -"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'; // 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,11 +34,24 @@ 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: "Bitget Wallet" } }), - new InjectedConnector({ options: { id: "okxwallet", name: "Okx Wallet" } }), // Added okxwallet + new InjectedConnector({ + options: { + id: "bitkeep", + name: isBitgetWalletInstalled() + ? "Bitget Wallet" + : "Install Bitget Wallet", + icon: "", + }, + }), + new InjectedConnector({ options: { id: "okxwallet", name: "Okx Wallet" } }), new WebWalletConnector({ url: @@ -46,11 +59,13 @@ export const availableConnectors = [ ? "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"],} + 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" } }), @@ -58,7 +73,7 @@ export const availableConnectors = [ 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) => ({ @@ -69,33 +84,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', }, }, }, @@ -103,14 +118,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 }, }, }, @@ -130,7 +145,7 @@ export function Providers({ children }: { children: React.ReactNode }) { - {children} + {children} @@ -138,4 +153,4 @@ export function Providers({ children }: { children: React.ReactNode }) { ); -} +} \ No newline at end of file