Skip to content

Commit

Permalink
update provider.tsx
Browse files Browse the repository at this point in the history
  • Loading branch information
godekina committed Nov 11, 2024
1 parent b7f9491 commit 0bb807e
Showing 1 changed file with 63 additions and 48 deletions.
111 changes: 63 additions & 48 deletions app/provider.tsx
Original file line number Diff line number Diff line change
@@ -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,
},
Expand All @@ -34,31 +34,46 @@ 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:
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"],}
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 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) => ({
Expand All @@ -69,48 +84,48 @@ 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',
},
},
},
MuiTab: {
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
},
},
},
Expand All @@ -130,12 +145,12 @@ export function Providers({ children }: { children: React.ReactNode }) {
<NotificationProvider>
<ThemeProvider theme={theme}>
<PostHogProvider client={posthog}>
<QuestsContextProvider>{children}</QuestsContextProvider>
<QuestsContextProvider>{children}</QuestsContextProvider>
</PostHogProvider>
</ThemeProvider>
</NotificationProvider>
</LocalizationProvider>
</StarknetIdJsProvider>
</StarknetConfig>
);
}
}

0 comments on commit 0bb807e

Please sign in to comment.