From 748abff020e6b03169b13ca908215bd3b2774508 Mon Sep 17 00:00:00 2001 From: chaojun Date: Thu, 17 Oct 2024 15:19:54 +0800 Subject: [PATCH] fix: kusama society vote result popup, #1034 --- next/components/loadingField.js | 5 ++ next/components/postDetail/postResults.js | 34 ++++++++++--- .../common/voteCountOptionList.js | 24 +++++---- .../strategyResult/onePersonOneVoteResult.js | 13 ++++- .../strategyResult/societyVoteResult.js | 13 ++++- next/components/postResult/index.js | 12 ++++- next/components/postResult/popup.js | 6 +-- next/components/postResult/societyPopup.js | 50 +++++++++++++++++++ 8 files changed, 134 insertions(+), 23 deletions(-) create mode 100644 next/components/loadingField.js create mode 100644 next/components/postResult/societyPopup.js diff --git a/next/components/loadingField.js b/next/components/loadingField.js new file mode 100644 index 00000000..427d682b --- /dev/null +++ b/next/components/loadingField.js @@ -0,0 +1,5 @@ +import { ReactComponent as LoadingSvg } from "public/imgs/icons/loading.svg"; + +export default function LoadingField({ children, isLoading }) { + return isLoading ? : children; +} diff --git a/next/components/postDetail/postResults.js b/next/components/postDetail/postResults.js index 362e7203..42d8e3f5 100644 --- a/next/components/postDetail/postResults.js +++ b/next/components/postDetail/postResults.js @@ -14,10 +14,12 @@ import { hasSocietyVoteStrategyOnly, } from "frontedUtils/strategy"; import QuorumSocietyVoteResult from "./strategyResult/quorumSocietyVoteResult"; +import isNil from "lodash.isnil"; +import LoadingField from "../loadingField"; -export default function PostResult({ data, voteStatus, space }) { - const votedAmount = data?.votedWeights?.balanceOf || 0; - const societyVotedAmount = data?.votedWeights?.societyVote || 0; +export function InnerPostResult({ data, voteStatus, space }) { + const votedAmount = data?.votedWeights?.balanceOf; + const societyVotedAmount = data?.votedWeights?.societyVote; const results = data?.weightStrategy?.map((strategy) => { if (strategy === "balance-of") { @@ -97,7 +99,9 @@ export default function PostResult({ data, voteStatus, space }) {
Voted
- + + +
); @@ -105,24 +109,40 @@ export default function PostResult({ data, voteStatus, space }) { voted = (
Voted
-
{societyVotedAmount} VOTE
+
+ + {societyVotedAmount} VOTE + +
); } return ( - + <>
{voted}
Voters
-
{data?.votesCount}
+
+ + {data?.votesCount} + +
{results} {biasedVoting} + + ); +} + +export default function PostResultPanel({ data, voteStatus, space }) { + return ( + + ); } diff --git a/next/components/postDetail/strategyResult/common/voteCountOptionList.js b/next/components/postDetail/strategyResult/common/voteCountOptionList.js index 21c820e6..f3611e43 100644 --- a/next/components/postDetail/strategyResult/common/voteCountOptionList.js +++ b/next/components/postDetail/strategyResult/common/voteCountOptionList.js @@ -9,6 +9,8 @@ import { ResultHead, ResultName, } from "./styled"; +import isNil from "lodash.isnil"; +import LoadingField from "@/components/loadingField"; export default function VoteCountOptionList({ optionList, strategy, total }) { return ( @@ -25,16 +27,18 @@ export default function VoteCountOptionList({ optionList, strategy, total }) { {vote.choice} - -
{vote.voteBalance} VOTE
-
- {vote.icon && <> {vote.icon}} + + +
{vote.voteBalance} VOTE
+
+ {vote.icon && <> {vote.icon}} +
diff --git a/next/components/postDetail/strategyResult/onePersonOneVoteResult.js b/next/components/postDetail/strategyResult/onePersonOneVoteResult.js index 529bd632..3473a6e4 100644 --- a/next/components/postDetail/strategyResult/onePersonOneVoteResult.js +++ b/next/components/postDetail/strategyResult/onePersonOneVoteResult.js @@ -5,7 +5,7 @@ import VoteCountOptionList from "./common/voteCountOptionList"; export default function OnePersonOneVoteResult({ proposal, voteStatus }) { let winnerChoice = null; - for (let item of voteStatus) { + for (let item of voteStatus || []) { if (new BigNumber(item.onePersonOneVote).isZero()) { continue; } @@ -25,6 +25,17 @@ export default function OnePersonOneVoteResult({ proposal, voteStatus }) { const optionList = []; proposal?.choices?.forEach((choice, index) => { + if (!voteStatus) { + optionList.push({ + index: index + 1, + choice, + voteBalance: null, + percentage: "0", + icon: null, + }); + return; + } + for (let voteStat of voteStatus) { if (voteStat.choice !== choice) { continue; diff --git a/next/components/postDetail/strategyResult/societyVoteResult.js b/next/components/postDetail/strategyResult/societyVoteResult.js index 00c672d4..54d14528 100644 --- a/next/components/postDetail/strategyResult/societyVoteResult.js +++ b/next/components/postDetail/strategyResult/societyVoteResult.js @@ -13,7 +13,7 @@ export default function SocietyVoteResult({ proposal, voteStatus }) { const total = proposal?.votedWeights?.societyVote || 0; let winnerChoice = null; - for (let item of voteStatus) { + for (let item of voteStatus || []) { if (new BigNumber(item.societyVote).isZero()) { continue; } @@ -32,6 +32,17 @@ export default function SocietyVoteResult({ proposal, voteStatus }) { const optionList = []; proposal?.choices?.forEach((choice, index) => { + if (!voteStatus) { + optionList.push({ + index: index + 1, + choice, + voteBalance: null, + percentage: "0", + icon: null, + }); + return; + } + for (let voteStat of voteStatus) { if (voteStat.choice !== choice) { continue; diff --git a/next/components/postResult/index.js b/next/components/postResult/index.js index 8cf7bc50..f3c1f887 100644 --- a/next/components/postResult/index.js +++ b/next/components/postResult/index.js @@ -4,6 +4,11 @@ import { useRef, useState } from "react"; import { ReactComponent as StatusSvg } from "public/imgs/icons/status.svg"; import { useOffset } from "frontedUtils/hooks"; import Popup from "./popup"; +import SocietyPopup from "./societyPopup"; +import { + hasOnePersonOneVoteStrategyOnly, + hasSocietyVoteStrategyOnly, +} from "frontedUtils/strategy"; const Wrapper = styled.div` position: relative; @@ -32,6 +37,11 @@ export default function ResultPopup({ data, space }) { const { top } = useOffset(ref); const [show, setShow] = useState(false); + const isSocietyProposal = + hasSocietyVoteStrategyOnly(data?.weightStrategy) || + hasOnePersonOneVoteStrategyOnly(data?.weightStrategy); + const PopupComponent = isSocietyProposal ? SocietyPopup : Popup; + return ( - {show && 400} />} + {show && 400} />} ); } diff --git a/next/components/postResult/popup.js b/next/components/postResult/popup.js index 8b0680fd..abbd6151 100644 --- a/next/components/postResult/popup.js +++ b/next/components/postResult/popup.js @@ -8,7 +8,7 @@ import { votesSelector, fetchVote } from "store/reducers/voteSlice"; import { ReactComponent as LoadingSvg } from "public/imgs/icons/loading.svg"; import BigNumber from "bignumber.js"; -const ResultWrapper = styled.div` +export const ResultWrapper = styled.div` z-index: 999; position: absolute; background: var(--fillBgPrimary); @@ -27,7 +27,7 @@ const ResultWrapper = styled.div` `} `; -const Triangle = styled.div` +export const Triangle = styled.div` position: absolute; width: 0; height: 0; @@ -38,7 +38,7 @@ const Triangle = styled.div` top: 100%; `; -const TriangleTop = styled(Triangle)` +export const TriangleTop = styled(Triangle)` border-top: 0; border-bottom: 8px solid var(--fillBgPrimary); top: -8px; diff --git a/next/components/postResult/societyPopup.js b/next/components/postResult/societyPopup.js new file mode 100644 index 00000000..ffcb2c00 --- /dev/null +++ b/next/components/postResult/societyPopup.js @@ -0,0 +1,50 @@ +import { useEffect } from "react"; +import { useSelector, useDispatch } from "react-redux"; + +import { votesSelector, fetchVote } from "store/reducers/voteSlice"; +import { InnerPostResult } from "../postDetail/postResults"; +import { ResultWrapper, Triangle, TriangleTop } from "./popup"; + +export default function SocietyPopup({ data, isTop, space }) { + const votes = useSelector(votesSelector); + const dispatch = useDispatch(); + + const vote = votes[data?.cid]; + + useEffect(() => { + if (data?.cid && !votes[data?.cid]) { + dispatch(fetchVote(data?.cid, data?.space)); + } + }, [votes, data, dispatch]); + + const votesCount = vote?.reduce( + (pre, cur) => pre + Number(cur.votesCount ?? 0), + 0, + ); + const totalSocietyVote = vote?.reduce( + (pre, cur) => pre + Number(cur.societyVote ?? 0), + 0, + ); + const totalOnePersonOneVote = vote?.reduce( + (pre, cur) => pre + Number(cur.onePersonOneVote ?? 0), + 0, + ); + + return ( + + + {isTop ? : } + + ); +}