From 98b4fe0d91d6342332daf65871b428449924007c Mon Sep 17 00:00:00 2001 From: sqrrm Date: Sun, 16 Jun 2019 00:07:20 +0200 Subject: [PATCH 1/3] Show failed ballots as failed, fix #2704 --- .../governance/result/ProposalListItem.java | 32 ++++++++++++++----- .../dao/governance/result/VoteResultView.java | 3 ++ 2 files changed, 27 insertions(+), 8 deletions(-) diff --git a/desktop/src/main/java/bisq/desktop/main/dao/governance/result/ProposalListItem.java b/desktop/src/main/java/bisq/desktop/main/dao/governance/result/ProposalListItem.java index 3f9aaecb480..64697f011a0 100644 --- a/desktop/src/main/java/bisq/desktop/main/dao/governance/result/ProposalListItem.java +++ b/desktop/src/main/java/bisq/desktop/main/dao/governance/result/ProposalListItem.java @@ -40,9 +40,13 @@ import javafx.scene.control.Label; import javafx.scene.control.TableRow; +import javafx.scene.layout.HBox; +import javafx.scene.layout.StackPane; import lombok.Getter; +import org.jetbrains.annotations.NotNull; + public class ProposalListItem { @Getter @@ -50,16 +54,18 @@ public class ProposalListItem { @Getter private final Proposal proposal; private final Vote vote; + private final boolean isMyBallotIncluded; private final BsqFormatter bsqFormatter; private TableRow tableRow; - ProposalListItem(EvaluatedProposal evaluatedProposal, Ballot ballot, BsqFormatter bsqFormatter) { + ProposalListItem(EvaluatedProposal evaluatedProposal, Ballot ballot, boolean isMyBallotIncluded, + BsqFormatter bsqFormatter) { this.evaluatedProposal = evaluatedProposal; proposal = evaluatedProposal.getProposal(); vote = ballot.getVote(); - + this.isMyBallotIncluded = isMyBallotIncluded; this.bsqFormatter = bsqFormatter; } @@ -68,16 +74,26 @@ public Label getMyVoteIcon() { Label myVoteIcon; if (vote != null) { if ((vote).isAccepted()) { - myVoteIcon = FormBuilder.getIcon(AwesomeIcon.THUMBS_UP); - myVoteIcon.getStyleClass().add("dao-accepted-icon"); + myVoteIcon = getIcon(AwesomeIcon.THUMBS_UP, "dao-accepted-icon"); } else { - myVoteIcon = FormBuilder.getIcon(AwesomeIcon.THUMBS_DOWN); - myVoteIcon.getStyleClass().add("dao-rejected-icon"); + myVoteIcon = getIcon(AwesomeIcon.THUMBS_DOWN, "dao-rejected-icon"); } } else { - myVoteIcon = FormBuilder.getIcon(AwesomeIcon.MINUS); - myVoteIcon.getStyleClass().add("dao-ignored-icon"); + myVoteIcon = getIcon(AwesomeIcon.MINUS, "dao-ignored-icon"); } + if (!isMyBallotIncluded) { + Label notIncluded = FormBuilder.getIcon(AwesomeIcon.BAN_CIRCLE); + return new Label("", new HBox(10, new StackPane(myVoteIcon, notIncluded), + getIcon(AwesomeIcon.MINUS, "dao-ignored-icon"))); + } + return myVoteIcon; + } + + @NotNull + private Label getIcon(AwesomeIcon awesomeIcon, String s) { + Label myVoteIcon; + myVoteIcon = FormBuilder.getIcon(awesomeIcon); + myVoteIcon.getStyleClass().add(s); return myVoteIcon; } diff --git a/desktop/src/main/java/bisq/desktop/main/dao/governance/result/VoteResultView.java b/desktop/src/main/java/bisq/desktop/main/dao/governance/result/VoteResultView.java index 37e9df16c14..ca5a7d4061f 100644 --- a/desktop/src/main/java/bisq/desktop/main/dao/governance/result/VoteResultView.java +++ b/desktop/src/main/java/bisq/desktop/main/dao/governance/result/VoteResultView.java @@ -460,6 +460,9 @@ private void createProposalsTable() { }) .map(evaluatedProposal -> new ProposalListItem(evaluatedProposal, ballotByProposalTxIdMap.get(evaluatedProposal.getProposalTxId()), + voteListItemList.stream() + .anyMatch(voteListItem -> + bsqWalletService.getTransaction(voteListItem.getBlindVoteTxId()) != null), bsqFormatter)) .collect(Collectors.toList())); GUIUtil.setFitToRowsForTableView(proposalsTableView, 25, 28, 6, 6); From 12e46f027acf4a9d3e69aa1b11cd915f78154d29 Mon Sep 17 00:00:00 2001 From: sqrrm Date: Sun, 16 Jun 2019 00:34:49 +0200 Subject: [PATCH 2/3] Indicate when vote wasn't included in result in proposalDisplay --- core/src/main/resources/i18n/displayStrings.properties | 3 ++- .../bisq/desktop/main/dao/governance/ProposalDisplay.java | 7 ++++++- .../main/overlays/windows/ProposalResultsWindow.java | 2 +- 3 files changed, 9 insertions(+), 3 deletions(-) diff --git a/core/src/main/resources/i18n/displayStrings.properties b/core/src/main/resources/i18n/displayStrings.properties index 44443f9b156..e996fec422b 100644 --- a/core/src/main/resources/i18n/displayStrings.properties +++ b/core/src/main/resources/i18n/displayStrings.properties @@ -1788,7 +1788,8 @@ dao.proposal.table.icon.tooltip.changeVote=Current vote: ''{0}''. Change vote to dao.proposal.display.myVote.accepted=Accepted dao.proposal.display.myVote.rejected=Rejected dao.proposal.display.myVote.ignored=Ignored -dao.proposal.myVote.summary=Voted: {0}; Vote weight: {1} (earned: {2} + stake: {3}); +dao.proposal.display.myVote.unCounted=Vote was not included in result +dao.proposal.myVote.summary=Voted: {0}; Vote weight: {1} (earned: {2} + stake: {3}) {4} dao.proposal.myVote.invalid=Vote was invalid dao.proposal.voteResult.success=Accepted diff --git a/desktop/src/main/java/bisq/desktop/main/dao/governance/ProposalDisplay.java b/desktop/src/main/java/bisq/desktop/main/dao/governance/ProposalDisplay.java index 0981633b2ce..0779dc3cc62 100644 --- a/desktop/src/main/java/bisq/desktop/main/dao/governance/ProposalDisplay.java +++ b/desktop/src/main/java/bisq/desktop/main/dao/governance/ProposalDisplay.java @@ -477,6 +477,10 @@ public void applyEvaluatedProposal(@Nullable EvaluatedProposal evaluatedProposal } public void applyBallotAndVoteWeight(@Nullable Ballot ballot, long merit, long stake) { + applyBallotAndVoteWeight(ballot, merit, stake, true); + } + + public void applyBallotAndVoteWeight(@Nullable Ballot ballot, long merit, long stake, boolean ballotIncluded) { boolean ballotIsNotNull = ballot != null; boolean hasVoted = stake > 0; if (hasVoted) { @@ -487,11 +491,12 @@ public void applyBallotAndVoteWeight(@Nullable Ballot ballot, long merit, long s Res.get("dao.proposal.display.myVote.rejected"); } + String voteIncluded = ballotIncluded ? "" : " - " + Res.get("dao.proposal.display.myVote.unCounted"); String meritString = bsqFormatter.formatCoinWithCode(Coin.valueOf(merit)); String stakeString = bsqFormatter.formatCoinWithCode(Coin.valueOf(stake)); String weight = bsqFormatter.formatCoinWithCode(Coin.valueOf(merit + stake)); String myVoteSummary = Res.get("dao.proposal.myVote.summary", myVote, - weight, meritString, stakeString); + weight, meritString, stakeString, voteIncluded); myVoteTextField.setText(myVoteSummary); GridPane.setRowSpan(myVoteTitledGroup, votingBoxRowSpan - 1); diff --git a/desktop/src/main/java/bisq/desktop/main/overlays/windows/ProposalResultsWindow.java b/desktop/src/main/java/bisq/desktop/main/overlays/windows/ProposalResultsWindow.java index 1a0ce45f28f..5229240439b 100644 --- a/desktop/src/main/java/bisq/desktop/main/overlays/windows/ProposalResultsWindow.java +++ b/desktop/src/main/java/bisq/desktop/main/overlays/windows/ProposalResultsWindow.java @@ -160,7 +160,7 @@ private void addContent(EvaluatedProposal evaluatedProposal, Ballot ballot) { Tuple2 meritAndStakeTuple = daoFacade.getMeritAndStakeForProposal(proposal.getTxId()); long merit = meritAndStakeTuple.first; long stake = meritAndStakeTuple.second; - proposalDisplay.applyBallotAndVoteWeight(ballot, merit, stake); + proposalDisplay.applyBallotAndVoteWeight(ballot, merit, stake, isVoteIncludedInResult); Region spacer = new Region(); GridPane.setVgrow(spacer, Priority.ALWAYS); From 8c278a650a4b7184c83fd178d2f7010486a63d81 Mon Sep 17 00:00:00 2001 From: sqrrm Date: Tue, 18 Jun 2019 15:02:41 +0200 Subject: [PATCH 3/3] Fix check for vote inclusion --- .../governance/result/ProposalListItem.java | 16 +++++++++----- .../dao/governance/result/VoteResultView.java | 21 ++++++++++++------- 2 files changed, 25 insertions(+), 12 deletions(-) diff --git a/desktop/src/main/java/bisq/desktop/main/dao/governance/result/ProposalListItem.java b/desktop/src/main/java/bisq/desktop/main/dao/governance/result/ProposalListItem.java index 64697f011a0..6c91dc49182 100644 --- a/desktop/src/main/java/bisq/desktop/main/dao/governance/result/ProposalListItem.java +++ b/desktop/src/main/java/bisq/desktop/main/dao/governance/result/ProposalListItem.java @@ -43,6 +43,8 @@ import javafx.scene.layout.HBox; import javafx.scene.layout.StackPane; +import javafx.geometry.Insets; + import lombok.Getter; import org.jetbrains.annotations.NotNull; @@ -78,13 +80,17 @@ public Label getMyVoteIcon() { } else { myVoteIcon = getIcon(AwesomeIcon.THUMBS_DOWN, "dao-rejected-icon"); } + if (!isMyBallotIncluded) { + Label notIncluded = FormBuilder.getIcon(AwesomeIcon.BAN_CIRCLE); + return new Label("", new HBox(10, new StackPane(myVoteIcon, notIncluded), + getIcon(AwesomeIcon.MINUS, "dao-ignored-icon"))); + } } else { myVoteIcon = getIcon(AwesomeIcon.MINUS, "dao-ignored-icon"); - } - if (!isMyBallotIncluded) { - Label notIncluded = FormBuilder.getIcon(AwesomeIcon.BAN_CIRCLE); - return new Label("", new HBox(10, new StackPane(myVoteIcon, notIncluded), - getIcon(AwesomeIcon.MINUS, "dao-ignored-icon"))); + if (!isMyBallotIncluded) { + myVoteIcon.setPadding(new Insets(0, 0, 0, 25)); + return myVoteIcon; + } } return myVoteIcon; } diff --git a/desktop/src/main/java/bisq/desktop/main/dao/governance/result/VoteResultView.java b/desktop/src/main/java/bisq/desktop/main/dao/governance/result/VoteResultView.java index ca5a7d4061f..a4491293a5a 100644 --- a/desktop/src/main/java/bisq/desktop/main/dao/governance/result/VoteResultView.java +++ b/desktop/src/main/java/bisq/desktop/main/dao/governance/result/VoteResultView.java @@ -143,6 +143,7 @@ public class VoteResultView extends ActivatableView implements D private ChangeListener selectedVoteResultListItemListener; private ResultsOfCycle resultsOfCycle; private ProposalListItem selectedProposalListItem; + private boolean isVoteIncludedInResult; /////////////////////////////////////////////////////////////////////////////////////////// @@ -253,6 +254,18 @@ private void onResultsListItemSelected(CycleListItem item) { if (item != null) { resultsOfCycle = item.getResultsOfCycle(); + // Check if my vote is included in result + isVoteIncludedInResult = false; + resultsOfCycle.getEvaluatedProposals().forEach(evProposal -> resultsOfCycle.getDecryptedVotesForCycle() + .forEach(decryptedBallotsWithMerits -> { + // Iterate through all included votes to see if any of those are ours + if (!isVoteIncludedInResult) { + isVoteIncludedInResult = bsqWalletService.isWalletTransaction(decryptedBallotsWithMerits + .getVoteRevealTxId()).isPresent(); + } + })); + + maybeShowVoteResultErrors(item.getResultsOfCycle().getCycle()); createProposalsTable(); @@ -327,10 +340,6 @@ private void onSelectProposalResultListItem(ProposalListItem item) { .findAny(); Ballot ballot = optionalBallot.orElse(null); - // Check if my vote is included in result - boolean isVoteIncludedInResult = voteListItemList.stream() - .anyMatch(voteListItem -> bsqWalletService.getTransaction(voteListItem.getBlindVoteTxId()) != null); - voteListItemList.clear(); resultsOfCycle.getEvaluatedProposals().stream() .filter(evProposal -> evProposal.getProposal().equals(selectedProposalListItem.getEvaluatedProposal().getProposal())) @@ -460,9 +469,7 @@ private void createProposalsTable() { }) .map(evaluatedProposal -> new ProposalListItem(evaluatedProposal, ballotByProposalTxIdMap.get(evaluatedProposal.getProposalTxId()), - voteListItemList.stream() - .anyMatch(voteListItem -> - bsqWalletService.getTransaction(voteListItem.getBlindVoteTxId()) != null), + isVoteIncludedInResult, bsqFormatter)) .collect(Collectors.toList())); GUIUtil.setFitToRowsForTableView(proposalsTableView, 25, 28, 6, 6);