From af9764e6ec397632ab065166a1dff2ec380b9672 Mon Sep 17 00:00:00 2001 From: hans Date: Fri, 17 Dec 2021 22:26:32 -0800 Subject: [PATCH 1/2] added: UI additions --- packages/react-app/src/App.jsx | 48 ++++--- packages/react-app/src/components/Account.jsx | 103 +++------------ packages/react-app/src/components/Header.jsx | 19 +-- .../react-app/src/routes/create/Create.jsx | 123 +++++++++--------- packages/react-app/src/routes/home/Home.jsx | 58 ++++----- packages/react-app/src/routes/party/Party.jsx | 53 +++++--- .../routes/party/components/Distribute.jsx | 13 +- .../src/routes/party/components/Vote.jsx | 9 +- 8 files changed, 180 insertions(+), 246 deletions(-) diff --git a/packages/react-app/src/App.jsx b/packages/react-app/src/App.jsx index d14cceac..1720d576 100644 --- a/packages/react-app/src/App.jsx +++ b/packages/react-app/src/App.jsx @@ -5,7 +5,7 @@ import WalletLink from "walletlink"; import { Alert, Button } from "antd"; import "antd/dist/antd.css"; import React, { useCallback, useEffect, useState } from "react"; -import { BrowserRouter, Route, Switch } from "react-router-dom"; +import { BrowserRouter, Route, Switch, useHistory } from "react-router-dom"; import Web3Modal from "web3modal"; import "./App.css"; import { Account, Contract, Header, Footer } from "./components"; @@ -21,7 +21,7 @@ import Portis from "@portis/web3"; import Fortmatic from "fortmatic"; import Authereum from "authereum"; -import { Box } from "@chakra-ui/react"; +import { Box, HStack, Flex, Spacer } from "@chakra-ui/react"; import NotConnectedCard from "./components/Cards/NotConnectedCard"; import CenteredFrame from "./components/layout/CenteredFrame"; @@ -115,8 +115,7 @@ const web3Modal = new Web3Modal({ // }, "custom-walletlink": { display: { - logo: - "https://play-lh.googleusercontent.com/PjoJoG27miSglVBXoXrxBSLveV6e3EeBPpNY55aiUUBM9Q1RCETKCOqdOkX2ZydqVf0", + logo: "https://play-lh.googleusercontent.com/PjoJoG27miSglVBXoXrxBSLveV6e3EeBPpNY55aiUUBM9Q1RCETKCOqdOkX2ZydqVf0", name: "Coinbase", description: "Connect to Coinbase Wallet (not Coinbase App)", }, @@ -409,23 +408,30 @@ function App(props) { }, [yourLocalBalance]); return ( -
- {networkDisplay} - -
- -
-
+
+ + + + +
+ + + + + + + + {address && address !== "" ? ( diff --git a/packages/react-app/src/components/Account.jsx b/packages/react-app/src/components/Account.jsx index 5bed00e7..f63e8089 100644 --- a/packages/react-app/src/components/Account.jsx +++ b/packages/react-app/src/components/Account.jsx @@ -1,44 +1,7 @@ -import { Button } from "antd"; import React from "react"; import { useThemeSwitcher } from "react-css-theme-switcher"; -import Address from "./Address"; -import Balance from "./Balance"; -import Wallet from "./Wallet"; -import { Text, Heading, VStack, HStack, Divider as ChDivider, Button as ChButton, Avatar } from "@chakra-ui/react"; - -/* - ~ What it does? ~ - - Displays an Address, Balance, and Wallet as one Account component, - also allows users to log in to existing accounts and log out - - ~ How can I use? ~ - - - - ~ Features ~ - - - Provide address={address} and get balance corresponding to the given address - - Provide localProvider={localProvider} to access balance on local network - - Provide userProvider={userProvider} to display a wallet - - Provide mainnetProvider={mainnetProvider} and your address will be replaced by ENS name - (ex. "0xa870" => "user.eth") - - Provide price={price} of ether and get your balance converted to dollars - - Provide web3Modal={web3Modal}, loadWeb3Modal={loadWeb3Modal}, logoutOfWeb3Modal={logoutOfWeb3Modal} - to be able to log in/log out to/from existing accounts - - Provide blockExplorer={blockExplorer}, click on address and get the link - (ex. by default "https://etherscan.io/" or for xdai "https://blockscout.com/poa/xdai/") -*/ +import { Box, Button } from "@chakra-ui/react"; +import { useLookupAddress } from "eth-hooks/dapps/ens"; export default function Account({ address, @@ -52,30 +15,32 @@ export default function Account({ logoutOfWeb3Modal, blockExplorer, }) { + const lookup = useLookupAddress(mainnetProvider, address); + const ensSplit = lookup?.split("."); + const validEnsCheck = ensSplit && ensSplit[ensSplit.length - 1] === "eth"; + + let displayAddress = "Loading..."; + + if (validEnsCheck) { + displayAddress = lookup; + } else { + displayAddress = + address !== undefined + ? `${address.substr(0, 5)}...${address.substr(address.length - 6, address.length)}` + : "Loading..."; + } + const modalButtons = []; if (web3Modal) { if (web3Modal.cachedProvider) { modalButtons.push( - , ); } else { modalButtons.push( - , ); @@ -84,31 +49,5 @@ export default function Account({ const { currentTheme } = useThemeSwitcher(); - const display = minimized ? ( - "" - ) : ( - - {address ? ( -
- ) : ( - "Connecting..." - )} - {/* */} - {/* */} - - ); - - return ( - - {display} - {modalButtons} - - ); + return {modalButtons}; } diff --git a/packages/react-app/src/components/Header.jsx b/packages/react-app/src/components/Header.jsx index 7350c1e2..a756f3cb 100644 --- a/packages/react-app/src/components/Header.jsx +++ b/packages/react-app/src/components/Header.jsx @@ -7,19 +7,12 @@ import QDIcon from "./Icons/QDIcon"; export default function Header() { const headingColor = useColorModeValue("yellow.600", "yellow.500"); return ( - - - - - - - pay.party - - - - by MOONSHOT COLLECTIVE - - + + + + + pay.party + ); diff --git a/packages/react-app/src/routes/create/Create.jsx b/packages/react-app/src/routes/create/Create.jsx index 154ec644..7ad71280 100644 --- a/packages/react-app/src/routes/create/Create.jsx +++ b/packages/react-app/src/routes/create/Create.jsx @@ -1,12 +1,5 @@ -import { - Box, - Button, - FormControl, - FormLabel, - Input, - Textarea, - Select, -} from "@chakra-ui/react"; +import { Box, Button, FormControl, FormLabel, Input, Textarea, Select } from "@chakra-ui/react"; +import { ArrowBackIcon } from "@chakra-ui/icons"; import React, { useState } from "react"; import { useHistory } from "react-router-dom"; import MongoDBController from "../../controllers/mongodbController"; @@ -18,14 +11,13 @@ const Create = ({ address, mainnetProvider, userSigner, tx, readContracts, write const db = new MongoDBController(); const [loading, setLoading] = useState(false); - const [partyObj, setPartyObj] = useState({ name: "", description: "", - receipts: [], + receipts: [], config: { - strategy: "", - nvotes: 0 + strategy: "", + nvotes: 0, }, participants: [], candidates: [], @@ -35,71 +27,76 @@ const Create = ({ address, mainnetProvider, userSigner, tx, readContracts, write const onSubmit = async event => { event.preventDefault(); setLoading(true); - db.newParty(partyObj) - .then(d => { - setLoading(false); - }) - .catch(err => { - console.log(err); - }); + userSigner.signMessage(`Create party:\n${partyObj.name}`).then(sig => { + // TODO: Do something with this + db.newParty(partyObj) + .then(d => { + setLoading(false); + }) + .catch(err => { + console.log(err); + }); + }); }; return ( - + -
- - Name - (partyObj.name = e.currentTarget.value)} /> + + + + Name + (partyObj.name = e.currentTarget.value)} /> - Desciption - + Participants + + Candidates +