mirror of
https://github.com/monero-project/monero-gui.git
synced 2025-01-24 11:36:14 +00:00
main: ask whether to stop local node upon switching to remote node
This commit is contained in:
parent
2f5c47e95f
commit
a9a59fd314
2 changed files with 38 additions and 24 deletions
61
main.qml
61
main.qml
|
@ -469,14 +469,18 @@ ApplicationWindow {
|
||||||
leftPanel.networkStatus.connected = status
|
leftPanel.networkStatus.connected = status
|
||||||
|
|
||||||
// update local daemon status.
|
// update local daemon status.
|
||||||
if(walletManager.isDaemonLocal(currentDaemonAddress))
|
const isDisconnected = status === Wallet.ConnectionStatus_Disconnected;
|
||||||
daemonRunning = status;
|
if (walletManager.isDaemonLocal(currentDaemonAddress)) {
|
||||||
|
daemonRunning = !isDisconnected;
|
||||||
|
} else {
|
||||||
|
daemonRunning = false;
|
||||||
|
}
|
||||||
|
|
||||||
// Update fee multiplier dropdown on transfer page
|
// Update fee multiplier dropdown on transfer page
|
||||||
middlePanel.transferView.updatePriorityDropdown();
|
middlePanel.transferView.updatePriorityDropdown();
|
||||||
|
|
||||||
// If wallet isnt connected, advanced wallet mode and no daemon is running - Ask
|
// If wallet isnt connected, advanced wallet mode and no daemon is running - Ask
|
||||||
if (appWindow.walletMode >= 2 && walletManager.isDaemonLocal(currentDaemonAddress) && !walletInitialized && status === Wallet.ConnectionStatus_Disconnected) {
|
if (appWindow.walletMode >= 2 && walletManager.isDaemonLocal(currentDaemonAddress) && !walletInitialized && isDisconnected) {
|
||||||
daemonManager.runningAsync(persistentSettings.nettype, function(running) {
|
daemonManager.runningAsync(persistentSettings.nettype, function(running) {
|
||||||
if (!running) {
|
if (!running) {
|
||||||
daemonManagerDialog.open();
|
daemonManagerDialog.open();
|
||||||
|
@ -598,10 +602,19 @@ ApplicationWindow {
|
||||||
|
|
||||||
function connectRemoteNode() {
|
function connectRemoteNode() {
|
||||||
console.log("connecting remote node");
|
console.log("connecting remote node");
|
||||||
persistentSettings.useRemoteNode = true;
|
|
||||||
currentDaemonAddress = persistentSettings.remoteNodeAddress;
|
const callback = function() {
|
||||||
currentWallet.initAsync(currentDaemonAddress, isTrustedDaemon());
|
persistentSettings.useRemoteNode = true;
|
||||||
walletManager.setDaemonAddressAsync(currentDaemonAddress);
|
currentDaemonAddress = persistentSettings.remoteNodeAddress;
|
||||||
|
currentWallet.initAsync(currentDaemonAddress, isTrustedDaemon());
|
||||||
|
walletManager.setDaemonAddressAsync(currentDaemonAddress);
|
||||||
|
};
|
||||||
|
|
||||||
|
if (typeof daemonManager != "undefined" && daemonRunning) {
|
||||||
|
showDaemonIsRunningDialog(callback);
|
||||||
|
} else {
|
||||||
|
callback();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function disconnectRemoteNode() {
|
function disconnectRemoteNode() {
|
||||||
|
@ -1916,6 +1929,23 @@ ApplicationWindow {
|
||||||
statusMessage.visible = true
|
statusMessage.visible = true
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function showDaemonIsRunningDialog(onClose) {
|
||||||
|
// Show confirmation dialog
|
||||||
|
confirmationDialog.title = qsTr("Local node is running") + translationManager.emptyString;
|
||||||
|
confirmationDialog.text = qsTr("Do you want to stop local node or keep it running in the background?") + translationManager.emptyString;
|
||||||
|
confirmationDialog.icon = StandardIcon.Question;
|
||||||
|
confirmationDialog.cancelText = qsTr("Force stop") + translationManager.emptyString;
|
||||||
|
confirmationDialog.okText = qsTr("Keep it running") + translationManager.emptyString;
|
||||||
|
confirmationDialog.onAcceptedCallback = function() {
|
||||||
|
onClose();
|
||||||
|
}
|
||||||
|
confirmationDialog.onRejectedCallback = function() {
|
||||||
|
daemonManager.stop(persistentSettings.nettype);
|
||||||
|
onClose();
|
||||||
|
};
|
||||||
|
confirmationDialog.open();
|
||||||
|
}
|
||||||
|
|
||||||
onClosing: {
|
onClosing: {
|
||||||
close.accepted = false;
|
close.accepted = false;
|
||||||
console.log("blocking close event");
|
console.log("blocking close event");
|
||||||
|
@ -1937,27 +1967,12 @@ ApplicationWindow {
|
||||||
|
|
||||||
// If daemon is running - prompt user before exiting
|
// If daemon is running - prompt user before exiting
|
||||||
if(typeof daemonManager != "undefined" && daemonRunning) {
|
if(typeof daemonManager != "undefined" && daemonRunning) {
|
||||||
// Show confirmation dialog
|
|
||||||
confirmationDialog.title = qsTr("Daemon is running") + translationManager.emptyString;
|
|
||||||
confirmationDialog.text = qsTr("Daemon will still be running in background when GUI is closed.");
|
|
||||||
confirmationDialog.icon = StandardIcon.Question
|
|
||||||
confirmationDialog.cancelText = qsTr("Stop daemon")
|
|
||||||
confirmationDialog.onAcceptedCallback = function() {
|
|
||||||
closeAccepted();
|
|
||||||
}
|
|
||||||
|
|
||||||
confirmationDialog.onRejectedCallback = function() {
|
|
||||||
daemonManager.stop(persistentSettings.nettype);
|
|
||||||
closeAccepted();
|
|
||||||
};
|
|
||||||
|
|
||||||
if (appWindow.walletMode == 0) {
|
if (appWindow.walletMode == 0) {
|
||||||
stopDaemon();
|
stopDaemon();
|
||||||
closeAccepted();
|
closeAccepted();
|
||||||
} else {
|
} else {
|
||||||
confirmationDialog.open();
|
showDaemonIsRunningDialog(closeAccepted);
|
||||||
}
|
}
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
closeAccepted();
|
closeAccepted();
|
||||||
}
|
}
|
||||||
|
|
|
@ -253,7 +253,6 @@ Rectangle{
|
||||||
cursorShape: Qt.PointingHandCursor
|
cursorShape: Qt.PointingHandCursor
|
||||||
anchors.fill: parent
|
anchors.fill: parent
|
||||||
onClicked: {
|
onClicked: {
|
||||||
persistentSettings.useRemoteNode = true;
|
|
||||||
appWindow.connectRemoteNode();
|
appWindow.connectRemoteNode();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue