mirror of
https://github.com/sparrowwallet/sparrow.git
synced 2024-11-05 05:46:44 +00:00
remember and select previously selected tab when closing a tab
This commit is contained in:
parent
8b42399423
commit
e59ee47624
1 changed files with 10 additions and 1 deletions
|
@ -187,6 +187,8 @@ public class AppController implements Initializable {
|
||||||
|
|
||||||
private Timeline statusTimeline;
|
private Timeline statusTimeline;
|
||||||
|
|
||||||
|
private Tab previouslySelectedTab;
|
||||||
|
|
||||||
private final Set<Wallet> loadingWallets = new LinkedHashSet<>();
|
private final Set<Wallet> loadingWallets = new LinkedHashSet<>();
|
||||||
|
|
||||||
private final Set<Wallet> emptyLoadingWallets = new LinkedHashSet<>();
|
private final Set<Wallet> emptyLoadingWallets = new LinkedHashSet<>();
|
||||||
|
@ -231,7 +233,10 @@ public class AppController implements Initializable {
|
||||||
rootStack.getStyleClass().removeAll(DRAG_OVER_CLASS);
|
rootStack.getStyleClass().removeAll(DRAG_OVER_CLASS);
|
||||||
});
|
});
|
||||||
|
|
||||||
tabs.getSelectionModel().selectedItemProperty().addListener((observable, old_val, selectedTab) -> {
|
tabs.getSelectionModel().selectedItemProperty().addListener((observable, previouslySelectedTab, selectedTab) -> {
|
||||||
|
if(tabs.getTabs().contains(previouslySelectedTab)) {
|
||||||
|
this.previouslySelectedTab = previouslySelectedTab;
|
||||||
|
}
|
||||||
tabs.getTabs().forEach(tab -> ((Label)tab.getGraphic()).getGraphic().setOpacity(TAB_LABEL_GRAPHIC_OPACITY_INACTIVE));
|
tabs.getTabs().forEach(tab -> ((Label)tab.getGraphic()).getGraphic().setOpacity(TAB_LABEL_GRAPHIC_OPACITY_INACTIVE));
|
||||||
if(selectedTab != null) {
|
if(selectedTab != null) {
|
||||||
Label tabLabel = (Label)selectedTab.getGraphic();
|
Label tabLabel = (Label)selectedTab.getGraphic();
|
||||||
|
@ -250,6 +255,10 @@ public class AppController implements Initializable {
|
||||||
//tabs.setTabDragPolicy(TabPane.TabDragPolicy.REORDER);
|
//tabs.setTabDragPolicy(TabPane.TabDragPolicy.REORDER);
|
||||||
tabs.getTabs().addListener((ListChangeListener<Tab>) c -> {
|
tabs.getTabs().addListener((ListChangeListener<Tab>) c -> {
|
||||||
if(c.next() && (c.wasAdded() || c.wasRemoved())) {
|
if(c.next() && (c.wasAdded() || c.wasRemoved())) {
|
||||||
|
if(c.wasRemoved() && previouslySelectedTab != null) {
|
||||||
|
tabs.getSelectionModel().select(previouslySelectedTab);
|
||||||
|
}
|
||||||
|
|
||||||
boolean walletAdded = c.getAddedSubList().stream().anyMatch(tab -> ((TabData)tab.getUserData()).getType() == TabData.TabType.WALLET);
|
boolean walletAdded = c.getAddedSubList().stream().anyMatch(tab -> ((TabData)tab.getUserData()).getType() == TabData.TabType.WALLET);
|
||||||
boolean walletRemoved = c.getRemoved().stream().anyMatch(tab -> ((TabData)tab.getUserData()).getType() == TabData.TabType.WALLET);
|
boolean walletRemoved = c.getRemoved().stream().anyMatch(tab -> ((TabData)tab.getUserData()).getType() == TabData.TabType.WALLET);
|
||||||
if(walletAdded || walletRemoved) {
|
if(walletAdded || walletRemoved) {
|
||||||
|
|
Loading…
Reference in a new issue