From 5c5e7badae5a046ca97c331a4b1d07461a31505b Mon Sep 17 00:00:00 2001 From: Keng Ye <40191153+kyleleow@users.noreply.github.com> Date: Wed, 19 Jul 2023 16:31:29 +0800 Subject: [PATCH] feature(ui): move states to context (#31) * feat: move states to context * chore: prettier --- .../src/components/SadoConnectKit.tsx | 15 +++------------ .../sado-connect/src/providers/SadoContext.tsx | 10 ++++++++++ 2 files changed, 13 insertions(+), 12 deletions(-) diff --git a/packages/sado-connect/src/components/SadoConnectKit.tsx b/packages/sado-connect/src/components/SadoConnectKit.tsx index e898e35a..87d71986 100644 --- a/packages/sado-connect/src/components/SadoConnectKit.tsx +++ b/packages/sado-connect/src/components/SadoConnectKit.tsx @@ -1,4 +1,3 @@ -import { useState } from "react"; import "./style.css"; import { useSadoContext } from "../providers/SadoContext"; import { PreConnectButton } from "./PreConnectButton"; @@ -24,16 +23,8 @@ export function SadoConnectKit({ customStyle, onViewWallet, }: SadoConnectKitProp) { - const [isOpen, setIsOpen] = useState(false); - const { address, network } = useSadoContext(); - - function closeModal() { - setIsOpen(false); - } - - async function openModal() { - setIsOpen(true); - } + const { address, network, isModalOpen, openModal, closeModal } = + useSadoContext(); return ( <> @@ -47,7 +38,7 @@ export function SadoConnectKit({ /> )} - + ); } diff --git a/packages/sado-connect/src/providers/SadoContext.tsx b/packages/sado-connect/src/providers/SadoContext.tsx index aba9d705..001b0677 100644 --- a/packages/sado-connect/src/providers/SadoContext.tsx +++ b/packages/sado-connect/src/providers/SadoContext.tsx @@ -20,6 +20,9 @@ interface SadoContextI { updateNetwork: (network: Network) => void; wallet: Wallet | null; updateWallet: (wallet: Wallet | null) => void; + isModalOpen: boolean; + openModal: () => void; + closeModal: () => void; } const SadoContext = createContext({ @@ -31,6 +34,9 @@ const SadoContext = createContext({ updateNetwork: () => {}, wallet: null, updateWallet: () => {}, + isModalOpen: false, + openModal: () => {}, + closeModal: () => {}, }); const ADDRESS = "address"; @@ -66,6 +72,7 @@ export function SadoConnectProvider({ const [network, setNetwork] = useState(Network.TESTNET); const [wallet, setWallet] = useState(null); const [publicKey, setPublicKey] = useState(null); + const [isModalOpen, setIsModalOpen] = useState(false); useEffect(() => { try { @@ -133,6 +140,9 @@ export function SadoConnectProvider({ updateNetwork: setNetwork, wallet, updateWallet: setWallet, + isModalOpen, + openModal: () => setIsModalOpen(true), + closeModal: () => setIsModalOpen(false), }; return (