mirror of
https://github.com/boldsuck/haveno.git
synced 2025-01-10 10:04:35 +00:00
penalize menu only appears for arbitrator in failed trades view
This commit is contained in:
parent
25f85f9f8d
commit
e4f3d13660
1 changed files with 32 additions and 24 deletions
|
@ -27,6 +27,7 @@ import haveno.core.offer.Offer;
|
||||||
import haveno.core.trade.Contract;
|
import haveno.core.trade.Contract;
|
||||||
import haveno.core.trade.HavenoUtils;
|
import haveno.core.trade.HavenoUtils;
|
||||||
import haveno.core.trade.Trade;
|
import haveno.core.trade.Trade;
|
||||||
|
import haveno.core.user.User;
|
||||||
import haveno.core.xmr.wallet.XmrWalletService;
|
import haveno.core.xmr.wallet.XmrWalletService;
|
||||||
import haveno.desktop.common.view.ActivatableViewAndModel;
|
import haveno.desktop.common.view.ActivatableViewAndModel;
|
||||||
import haveno.desktop.common.view.FxmlView;
|
import haveno.desktop.common.view.FxmlView;
|
||||||
|
@ -98,15 +99,18 @@ public class FailedTradesView extends ActivatableViewAndModel<VBox, FailedTrades
|
||||||
private ChangeListener<String> filterTextFieldListener;
|
private ChangeListener<String> filterTextFieldListener;
|
||||||
private Scene scene;
|
private Scene scene;
|
||||||
private XmrWalletService xmrWalletService;
|
private XmrWalletService xmrWalletService;
|
||||||
|
private User user;
|
||||||
private ContextMenu contextMenu;
|
private ContextMenu contextMenu;
|
||||||
|
|
||||||
@Inject
|
@Inject
|
||||||
public FailedTradesView(FailedTradesViewModel model,
|
public FailedTradesView(FailedTradesViewModel model,
|
||||||
TradeDetailsWindow tradeDetailsWindow,
|
TradeDetailsWindow tradeDetailsWindow,
|
||||||
XmrWalletService xmrWalletService) {
|
XmrWalletService xmrWalletService,
|
||||||
|
User user) {
|
||||||
super(model);
|
super(model);
|
||||||
this.tradeDetailsWindow = tradeDetailsWindow;
|
this.tradeDetailsWindow = tradeDetailsWindow;
|
||||||
this.xmrWalletService = xmrWalletService;
|
this.xmrWalletService = xmrWalletService;
|
||||||
|
this.user = user;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -190,9 +194,33 @@ public class FailedTradesView extends ActivatableViewAndModel<VBox, FailedTrades
|
||||||
tableView.setItems(sortedList);
|
tableView.setItems(sortedList);
|
||||||
|
|
||||||
contextMenu = new ContextMenu();
|
contextMenu = new ContextMenu();
|
||||||
MenuItem item1 = new MenuItem(Res.get("support.contextmenu.penalize.msg", Res.get("shared.maker")));
|
boolean isArbitrator = user.getRegisteredArbitrator() != null;
|
||||||
MenuItem item2 = new MenuItem(Res.get("support.contextmenu.penalize.msg", Res.get("shared.taker")));
|
if (isArbitrator) {
|
||||||
contextMenu.getItems().addAll(item1, item2);
|
MenuItem item1 = new MenuItem(Res.get("support.contextmenu.penalize.msg", Res.get("shared.maker")));
|
||||||
|
MenuItem item2 = new MenuItem(Res.get("support.contextmenu.penalize.msg", Res.get("shared.taker")));
|
||||||
|
|
||||||
|
item1.setOnAction(event -> {
|
||||||
|
Trade selectedFailedTrade = tableView.getSelectionModel().getSelectedItem().getTrade();
|
||||||
|
handleContextMenu("portfolio.failed.penalty.msg",
|
||||||
|
Res.get(selectedFailedTrade.getMaker() == selectedFailedTrade.getBuyer() ? "shared.buyer" : "shared.seller"),
|
||||||
|
Res.get("shared.maker"),
|
||||||
|
selectedFailedTrade.getMaker().getSecurityDeposit(),
|
||||||
|
selectedFailedTrade.getMaker().getReserveTxHash(),
|
||||||
|
selectedFailedTrade.getMaker().getReserveTxHex());
|
||||||
|
});
|
||||||
|
|
||||||
|
item2.setOnAction(event -> {
|
||||||
|
Trade selectedFailedTrade = tableView.getSelectionModel().getSelectedItem().getTrade();
|
||||||
|
handleContextMenu("portfolio.failed.penalty.msg",
|
||||||
|
Res.get(selectedFailedTrade.getTaker() == selectedFailedTrade.getBuyer() ? "shared.buyer" : "shared.seller"),
|
||||||
|
Res.get("shared.taker"),
|
||||||
|
selectedFailedTrade.getTaker().getSecurityDeposit(),
|
||||||
|
selectedFailedTrade.getTaker().getReserveTxHash(),
|
||||||
|
selectedFailedTrade.getTaker().getReserveTxHex());
|
||||||
|
});
|
||||||
|
|
||||||
|
contextMenu.getItems().addAll(item1, item2);
|
||||||
|
}
|
||||||
|
|
||||||
tableView.setRowFactory(tv -> {
|
tableView.setRowFactory(tv -> {
|
||||||
TableRow<FailedTradesListItem> row = new TableRow<>();
|
TableRow<FailedTradesListItem> row = new TableRow<>();
|
||||||
|
@ -202,26 +230,6 @@ public class FailedTradesView extends ActivatableViewAndModel<VBox, FailedTrades
|
||||||
return row;
|
return row;
|
||||||
});
|
});
|
||||||
|
|
||||||
item1.setOnAction(event -> {
|
|
||||||
Trade selectedFailedTrade = tableView.getSelectionModel().getSelectedItem().getTrade();
|
|
||||||
handleContextMenu("portfolio.failed.penalty.msg",
|
|
||||||
Res.get(selectedFailedTrade.getMaker() == selectedFailedTrade.getBuyer() ? "shared.buyer" : "shared.seller"),
|
|
||||||
Res.get("shared.maker"),
|
|
||||||
selectedFailedTrade.getMaker().getSecurityDeposit(),
|
|
||||||
selectedFailedTrade.getMaker().getReserveTxHash(),
|
|
||||||
selectedFailedTrade.getMaker().getReserveTxHex());
|
|
||||||
});
|
|
||||||
|
|
||||||
item2.setOnAction(event -> {
|
|
||||||
Trade selectedFailedTrade = tableView.getSelectionModel().getSelectedItem().getTrade();
|
|
||||||
handleContextMenu("portfolio.failed.penalty.msg",
|
|
||||||
Res.get(selectedFailedTrade.getTaker() == selectedFailedTrade.getBuyer() ? "shared.buyer" : "shared.seller"),
|
|
||||||
Res.get("shared.taker"),
|
|
||||||
selectedFailedTrade.getTaker().getSecurityDeposit(),
|
|
||||||
selectedFailedTrade.getTaker().getReserveTxHash(),
|
|
||||||
selectedFailedTrade.getTaker().getReserveTxHex());
|
|
||||||
});
|
|
||||||
|
|
||||||
numItems.setText(Res.get("shared.numItemsLabel", sortedList.size()));
|
numItems.setText(Res.get("shared.numItemsLabel", sortedList.size()));
|
||||||
exportButton.setOnAction(event -> {
|
exportButton.setOnAction(event -> {
|
||||||
ObservableList<TableColumn<FailedTradesListItem, ?>> tableColumns = tableView.getColumns();
|
ObservableList<TableColumn<FailedTradesListItem, ?>> tableColumns = tableView.getColumns();
|
||||||
|
|
Loading…
Reference in a new issue