Skip to content

Commit

Permalink
Added busy_cursor()
Browse files Browse the repository at this point in the history
  • Loading branch information
donob4n committed Mar 31, 2019
1 parent 9750d99 commit 8e383e3
Show file tree
Hide file tree
Showing 3 changed files with 36 additions and 16 deletions.
13 changes: 12 additions & 1 deletion qubesmanager/common_threads.py
Original file line number Diff line number Diff line change
Expand Up @@ -20,10 +20,21 @@
#


from PyQt4 import QtCore # pylint: disable=import-error
from PyQt4 import QtCore, QtGui # pylint: disable=import-error
from contextlib import contextmanager

from qubesadmin import exc


@contextmanager
def busy_cursor():
try:
QtGui.QApplication.setOverrideCursor(QtCore.Qt.BusyCursor)
yield
finally:
QtGui.QApplication.restoreOverrideCursor()


# pylint: disable=too-few-public-methods
class RemoveVMThread(QtCore.QThread):
def __init__(self, vm):
Expand Down
34 changes: 20 additions & 14 deletions qubesmanager/qube_manager.py
Original file line number Diff line number Diff line change
Expand Up @@ -741,7 +741,8 @@ def table_selection_changed(self):
# noinspection PyArgumentList
@QtCore.pyqtSlot(name='on_action_createvm_triggered')
def action_createvm_triggered(self): # pylint: disable=no-self-use
create_window = create_new_vm.NewVmDlg(self.qt_app, self.qubes_app)
with common_threads.busy_cursor():
create_window = create_new_vm.NewVmDlg(self.qt_app, self.qubes_app)
create_window.exec_()

def get_selected_vm(self):
Expand Down Expand Up @@ -976,8 +977,9 @@ def action_killvm_triggered(self):
def action_settings_triggered(self):
vm = self.get_selected_vm()
if vm:
settings_window = settings.VMSettingsWindow(
vm, self.qt_app, "basic")
with common_threads.busy_cursor():
settings_window = settings.VMSettingsWindow(
vm, self.qt_app, "basic")
settings_window.exec_()

vm_deleted = False
Expand All @@ -1003,11 +1005,11 @@ def action_settings_triggered(self):
def action_appmenus_triggered(self):
vm = self.get_selected_vm()
if vm:
settings_window = settings.VMSettingsWindow(
vm, self.qt_app, "applications")
with common_threads.busy_cursor():
settings_window = settings.VMSettingsWindow(
vm, self.qt_app, "applications")
settings_window.exec_()


# noinspection PyArgumentList
@QtCore.pyqtSlot(name='on_action_updatevm_triggered')
def action_updatevm_triggered(self):
Expand Down Expand Up @@ -1056,16 +1058,18 @@ def action_set_keyboard_layout_triggered(self):
# noinspection PyArgumentList
@QtCore.pyqtSlot(name='on_action_editfwrules_triggered')
def action_editfwrules_triggered(self):
vm = self.get_selected_vm()
settings_window = settings.VMSettingsWindow(vm, self.qt_app, "firewall")
with common_threads.busy_cursor():
vm = self.get_selected_vm()
settings_window = settings.VMSettingsWindow(vm, self.qt_app, "firewall")
settings_window.exec_()

# noinspection PyArgumentList
@QtCore.pyqtSlot(name='on_action_global_settings_triggered')
def action_global_settings_triggered(self): # pylint: disable=invalid-name
global_settings_window = global_settings.GlobalSettingsWindow(
self.qt_app,
self.qubes_app)
with common_threads.busy_cursor():
global_settings_window = global_settings.GlobalSettingsWindow(
self.qt_app,
self.qubes_app)
global_settings_window.exec_()

# noinspection PyArgumentList
Expand All @@ -1085,14 +1089,16 @@ def action_show_network_triggered(self):
# noinspection PyArgumentList
@QtCore.pyqtSlot(name='on_action_restore_triggered')
def action_restore_triggered(self):
restore_window = restore.RestoreVMsWindow(self.qt_app, self.qubes_app)
with common_threads.busy_cursor():
restore_window = restore.RestoreVMsWindow(self.qt_app, self.qubes_app)
restore_window.exec_()

# noinspection PyArgumentList
@QtCore.pyqtSlot(name='on_action_backup_triggered')
def action_backup_triggered(self):
backup_window = backup.BackupVMsWindow(self.qt_app, self.qubes_app,
self.dispatcher, self)
with common_threads.busy_cursor():
backup_window = backup.BackupVMsWindow(self.qt_app, self.qubes_app,
self.dispatcher, self)
backup_window.show()

# noinspection PyArgumentList
Expand Down
5 changes: 4 additions & 1 deletion qubesmanager/settings.py
100755 → 100644
Original file line number Diff line number Diff line change
Expand Up @@ -278,10 +278,13 @@ def save_changes(self):
self.tr("ERROR: {0}").format('\n'.join(error)))

def apply(self):
with common_threads.busy_cursor():
self.save_changes()
self.save_changes()

def save_and_apply(self):
self.save_changes()
with common_threads.busy_cursor():
self.save_changes()
self.done(0)

def __save_changes__(self):
Expand Down

0 comments on commit 8e383e3

Please sign in to comment.