Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

refac: Simplify wallet management system #961

Merged
merged 1 commit into from
Nov 26, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 2 additions & 2 deletions app/not-connected/page.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -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",
});

Expand All @@ -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);
};

Expand Down
120 changes: 43 additions & 77 deletions app/provider.tsx

Large diffs are not rendered by default.

100 changes: 8 additions & 92 deletions components/UI/iconsComponents/icons/walletIcons.tsx
Original file line number Diff line number Diff line change
@@ -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<WalletIconsProps> = ({ id }) => {
if (id === "argentX")
return (
<svg
className={styles.button_icon}
fill="currentColor"
viewBox="0 0 40 36"
xmlns="http://www.w3.org/2000/svg"
>
<path d="M24.7582 -3.97364e-07H14.6238C14.2851 -3.97364e-07 14.0138 0.281178 14.0064 0.630683C13.8017 10.4549 8.82234 19.7792 0.251893 26.3837C-0.0202046 26.5933 -0.0821946 26.9872 0.116734 27.2709L6.04623 35.734C6.24796 36.022 6.64099 36.087 6.91766 35.8754C12.2765 31.7728 16.5869 26.8236 19.691 21.338C22.7951 26.8236 27.1057 31.7728 32.4646 35.8754C32.741 36.087 33.1341 36.022 33.3361 35.734L39.2656 27.2709C39.4642 26.9872 39.4022 26.5933 39.1304 26.3837C30.5597 19.7792 25.5804 10.4549 25.3759 0.630683C25.3685 0.281178 25.0969 -3.97364e-07 24.7582 -3.97364e-07Z" />
</svg>
);

if (id === "braavos")
return (
<svg
viewBox="0 0 100 100"
fill="currentColor"
xmlns="http://www.w3.org/2000/svg"
className={styles.button_icon}
>
<path d="M62.705 13.9116C62.8359 14.1333 62.6621 14.407 62.4039 14.407C57.1807 14.407 52.9348 18.5427 52.8351 23.6817C51.0465 23.3477 49.1933 23.3226 47.3626 23.6311C47.2361 18.5156 43.0009 14.407 37.7948 14.407C37.5365 14.407 37.3625 14.1331 37.4935 13.9112C40.0217 9.62809 44.7204 6.75 50.0991 6.75C55.4781 6.75 60.1769 9.62826 62.705 13.9116Z" />
<path d="M78.7606 45.8718C80.2725 46.3297 81.7025 45.0055 81.1714 43.5222C76.4137 30.2334 61.3911 24.8039 50.0277 24.8039C38.6442 24.8039 23.2868 30.407 18.8754 43.5912C18.3824 45.0645 19.8083 46.3446 21.2978 45.8881L48.872 37.4381C49.5331 37.2355 50.2399 37.2344 50.9017 37.4348L78.7606 45.8718Z" />
<path d="M18.8132 48.1707L48.8935 39.0472C49.5506 38.8478 50.2524 38.8473 50.9098 39.0456L81.1781 48.1752C83.6912 48.9332 85.411 51.2483 85.411 53.8735V81.2233C85.2944 87.8991 79.2977 93.25 72.6245 93.25H61.5406C60.4449 93.25 59.5577 92.3637 59.5577 91.268V81.6789C59.5577 77.9031 61.7921 74.4855 65.2498 72.9729C69.8849 70.9454 75.3681 68.2028 76.3994 62.6992C76.7323 60.9229 75.5741 59.2094 73.8024 58.8573C69.3226 57.9667 64.3562 58.3107 60.1564 60.1893C55.3887 62.3219 54.1415 65.8694 53.6797 70.6337L53.1201 75.7662C52.9491 77.3349 51.4785 78.5366 49.9014 78.5366C48.2699 78.5366 47.0465 77.294 46.8696 75.6712L46.3204 70.6337C45.9249 66.5529 45.2079 62.5887 40.9895 60.7018C36.1776 58.5494 31.3419 57.8347 26.1976 58.8573C24.426 59.2094 23.2678 60.9229 23.6007 62.6992C24.641 68.2507 30.0812 70.9305 34.7503 72.9729C38.208 74.4855 40.4424 77.9031 40.4424 81.6789V91.2663C40.4424 92.362 39.5555 93.25 38.4599 93.25H27.3756C20.7024 93.25 14.7057 87.8991 14.5891 81.2233V53.8663C14.5891 51.2446 16.3045 48.9316 18.8132 48.1707Z" />
</svg>
);

if (id === "bitkeep")
return (
<svg
viewBox="0 0 36 36"
fill="currentColor"
xmlns="http://www.w3.org/2000/svg"
className={styles.button_icon}
>
<g clipPath="url(#clip0)">
<rect width="36" height="36" rx="18" fill="#54FFF5" />
<g filter="url(#filter0)">
<path d="M1.8957 27.9279C-4.1242 44.8644 28.0774 40.0809 44.9307 35.5721C62.1794 29.8479 50.2574 4.6153 37.8864 4.05686C25.5154 3.49843 39.4203 15.7243 28.9118 19.2162C18.4033 22.7081 9.42056 6.75722 1.8957 27.9279Z" fill="white" />
</g>
<g filter="url(#filter1)">
<path d="M12.0251 -6.44486C8.86728 -15.0727 -2.37922 -3.37541 -7.60774 3.55172C-12.5951 11.0869 0.423192 17.5984 5.52949 14.0667C10.6358 10.5349 1.09329 9.84779 4.13027 5.25529C7.16725 0.662788 15.9724 4.33996 12.0251 -6.44486Z" fill="#00FFF0" fillOpacity="0.67" />
</g>
<g filter="url(#filter2)">
<path d="M13.5675 31.6991C9.2602 17.2063 -9.29274 24.8386 -18.0308 30.4663C-26.4361 37.1299 -6.47874 56.2979 1.8102 55.3174C10.0991 54.3369 -4.83915 45.9925 0.279432 41.9292C5.39801 37.8658 18.9515 49.8152 13.5675 31.6991Z" fill="#9D81FF" />
</g>
<g filter="url(#filter3)">
<path d="M39.6731 -15.0985C30.3816 -26.1625 17.0806 -17.0133 11.5916 -11.0557C6.78848 -4.31133 31.5386 8.04621 38.4077 5.92842C45.2767 3.81064 29.0407 -0.571508 31.9636 -4.68304C34.8865 -8.79457 51.2875 -1.26834 39.6731 -15.0985Z" fill="#4D94FF" />
</g>
<path fillRule="evenodd" clipRule="evenodd" d="M13.1047 21.4925H19.2197L12.2637 14.4916L19.3092 7.49057L21.2281 5.625H14.8809L6.79724 13.7499C6.38929 14.1594 6.39139 14.8221 6.80142 15.2295L13.1047 21.4925ZM16.7808 14.508H16.7337L16.7803 14.5074L16.7808 14.508ZM16.7808 14.508L23.7363 21.5084L16.6908 28.5094L14.7719 30.375H21.1191L29.2027 22.2506C29.6107 21.8411 29.6086 21.1784 29.1986 20.771L22.8953 14.508H16.7808Z" fill="black" />
</g>
<defs>
<filter id="filter0" x="-12.6901" y="-9.80709" width="80.0941" height="63.4814" colorInterpolationFilters="sRGB">
<feFlood floodOpacity="0" />
<feBlend mode="normal" in2="BackgroundImageFix" result="shape" />
<feGaussianBlur stdDeviation="6.92308" result="effect1_foregroundBlur" />
</filter>
<filter id="filter1" x="-22.5718" y="-23.3422" width="49.4432" height="52.2431" colorInterpolationFilters="sRGB">
<feFlood floodOpacity="0" />
<feBlend mode="normal" in2="BackgroundImageFix" result="shape" />
<feGaussianBlur stdDeviation="6.92308" result="effect1_foregroundBlur" />
</filter>
<filter id="filter2" x="-33.9015" y="9.51127" width="62.5572" height="59.6884" colorInterpolationFilters="sRGB">
<feFlood floodOpacity="0" />
<feBlend mode="normal" in2="BackgroundImageFix" result="shape" />
<feGaussianBlur stdDeviation="6.92308" result="effect1_foregroundBlur" />
</filter>
<filter id="filter3" x="-2.86834" y="-34.1391" width="60.4956" height="54.1552" colorInterpolationFilters="sRGB">
<feFlood floodOpacity="0" />
<feBlend mode="normal" in2="BackgroundImageFix" result="shape" />
<feGaussianBlur stdDeviation="6.92308" result="effect1_foregroundBlur" />
</filter>
<clipPath id="clip0">
<rect width="36" height="36" rx="18" fill="white" />
</clipPath>
</defs>
</svg>
);


return (
<svg
const walletInfo = getWalletInfo(id);
return walletInfo?.icon ? (
<img
src={walletInfo.icon}
alt={walletInfo.name}
className={styles.button_icon}
fill="currentColor"
viewBox="0 0 20 20"
xmlns="http://www.w3.org/2000/svg"
>
<path
fillRule="evenodd"
d="M7 2a1 1 0 00-.707 1.707L7 4.414v3.758a1 1 0 01-.293.707l-4 4C.817 14.769 2.156 18 4.828 18h10.343c2.673 0 4.012-3.231 2.122-5.121l-4-4A1 1 0 0113 8.172V4.414l.707-.707A1 1 0 0013 2H7zm2 6.172V4h2v4.172a3 3 0 00.879 2.12l1.027 1.028a4 4 0 00-2.171.102l-.47.156a4 4 0 01-2.53 0l-.563-.187a1.993 1.993 0 00-.114-.035l1.063-1.063A3 3 0 009 8.172z"
clipRule="evenodd"
></path>
</svg>
);
/>
) : null;
};

export default WalletIcons;
75 changes: 30 additions & 45 deletions components/UI/navbar.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -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();
Expand Down Expand Up @@ -181,33 +181,27 @@ const Navbar: FunctionComponent = () => {

return (
<>
<div
className={`fixed w-full z-20`}
id='nav'
>
<div className={`fixed w-full z-20`} id="nav">
<div
className={`${styles.navbarContainer} ${
navbarBg ? styles.navbarScrolled : ""
}`}
>
<div className={styles.navbarLogo}>
<Link
href='/'
className='modified-cursor-pointer'
>
<Link href="/" className="modified-cursor-pointer">
<Image
className={styles.logo}
src='/visuals/starknetquestLogo.svg'
alt='Starknet.id Logo'
src="/visuals/starknetquestLogo.svg"
alt="Starknet.id Logo"
width={70}
height={70}
priority
/>
</Link>
</div>
<div>
<ul className='hidden lg:flex uppercase items-center '>
<Link href='/'>
<ul className="hidden lg:flex uppercase items-center ">
<Link href="/">
<li className={styles.menuItem}>Quests</li>
</Link>
<Link href={`/discover/defi`}>
Expand All @@ -228,13 +222,13 @@ const Navbar: FunctionComponent = () => {
informationNotifications[0]?.title?.length > 0) &&
address ? (
<NotificationUnreadIcon
width='24'
width="24"
color={theme.palette.secondary.dark}
secondColor='#D32F2F'
secondColor="#D32F2F"
></NotificationUnreadIcon>
) : (
<NotificationIcon
width='24'
width="24"
color={theme.palette.secondary.dark}
/>
)}
Expand All @@ -248,11 +242,8 @@ const Navbar: FunctionComponent = () => {
disconnectByClick={disconnectByClick}
/>
</ul>
<div className='lg:hidden'>
<Hamburger
active={nav}
onClick={handleNav}
/>
<div className="lg:hidden">
<Hamburger active={nav} onClick={handleNav} />
</div>
</div>
</div>
Expand All @@ -270,18 +261,18 @@ const Navbar: FunctionComponent = () => {
nav ? styles.mobileNavbarShown : styles.mobileNavbarHidden
}`}
>
<div className='h-full flex flex-col'>
<div className='py-4 my-auto text-center font-extrabold'>
<ul className='uppercase text-babe-blue'>
<Link href='/'>
<div className="h-full flex flex-col">
<div className="py-4 my-auto text-center font-extrabold">
<ul className="uppercase text-babe-blue">
<Link href="/">
<li
onClick={() => setNav(false)}
className={styles.menuItemSmall}
>
Quests
</li>
</Link>
<Link href='/discover/defi'>
<Link href="/discover/defi">
<li
onClick={() => setNav(false)}
className={styles.menuItemSmall}
Expand All @@ -302,33 +293,27 @@ const Navbar: FunctionComponent = () => {
</ul>
</div>
</div>
<div className='flex flex-col items-center my-4 w-full'>
<div className="flex flex-col items-center my-4 w-full">
<div className={styles.connectButtonContainer}>
<Button onClick={onTopButtonClick}>{topButtonText()}</Button>
</div>
<div className='flex'>
<div className="flex">
<div className={styles.socialIconContainer}>
<a
href='https://twitter.com/starknet_quest'
target='_blank'
rel='noreferrer'
href="https://twitter.com/starknet_quest"
target="_blank"
rel="noreferrer"
>
<FaTwitter
size={28}
color={theme.palette.secondary.main}
/>
<FaTwitter size={28} color={theme.palette.secondary.main} />
</a>
</div>
<div className={styles.socialIconContainer}>
<a
href='https://discord.gg/byEGk6w6T6'
target='_blank'
rel='noreferrer'
href="https://discord.gg/byEGk6w6T6"
target="_blank"
rel="noreferrer"
>
<FaDiscord
size={28}
color={theme.palette.secondary.main}
/>
<FaDiscord size={28} color={theme.palette.secondary.main} />
</a>
</div>
</div>
Expand All @@ -341,12 +326,12 @@ const Navbar: FunctionComponent = () => {
title={"Wrong network"}
closeModal={() => setIsWrongNetwork(false)}
message={
<div className='mt-3 flex flex-col items-center justify-center text-center'>
<div className="mt-3 flex flex-col items-center justify-center text-center">
<Typography type={TEXT_TYPE.BODY_DEFAULT}>
This app only supports Starknet {network}, you have to change your
network to be able use it.
</Typography>
<div className='mt-3'>
<div className="mt-3">
<Button onClick={() => disconnectByClick()}>
{`Disconnect`}
</Button>
Expand All @@ -366,4 +351,4 @@ const Navbar: FunctionComponent = () => {
);
};

export default Navbar;
export default Navbar;
58 changes: 0 additions & 58 deletions tests/utils/connectors.test.js

This file was deleted.

Loading