Unified tray baloons (#526)
This commit is contained in:
parent
b140d0e2cf
commit
8a296820ff
@ -22,6 +22,7 @@
|
|||||||
|
|
||||||
import sys
|
import sys
|
||||||
import os
|
import os
|
||||||
|
import dbus
|
||||||
from PyQt4.QtCore import *
|
from PyQt4.QtCore import *
|
||||||
from PyQt4.QtGui import *
|
from PyQt4.QtGui import *
|
||||||
|
|
||||||
@ -584,7 +585,7 @@ class VmShutdownMonitor(QObject):
|
|||||||
vm_start_time = vm.get_start_time()
|
vm_start_time = vm.get_start_time()
|
||||||
if not vm.is_running() or (vm_start_time and vm_start_time >= datetime.utcnow() - timedelta(0,vm_shutdown_timeout/1000)):
|
if not vm.is_running() or (vm_start_time and vm_start_time >= datetime.utcnow() - timedelta(0,vm_shutdown_timeout/1000)):
|
||||||
if vm.is_template():
|
if vm.is_template():
|
||||||
trayIcon.showMessage ("Qubes Manager", "You have just modified template '{0}'. You should now restart all the VMs based on it, so they could see the changes.".format(vm.name), msecs=8000)
|
trayIcon.showMessage ("Qubes VM Manager", "You have just modified template '{0}'. You should now restart all the VMs based on it, so they could see the changes.".format(vm.name), msecs=8000)
|
||||||
return
|
return
|
||||||
|
|
||||||
reply = QMessageBox.question(None, "VM Shutdown",
|
reply = QMessageBox.question(None, "VM Shutdown",
|
||||||
@ -939,7 +940,7 @@ class VmManagerWindow(Ui_VmManagerWindow, QMainWindow):
|
|||||||
res, msg = self.blk_manager.check_for_updates()
|
res, msg = self.blk_manager.check_for_updates()
|
||||||
if msg != None and len(msg) > 0:
|
if msg != None and len(msg) > 0:
|
||||||
str = "\n".join(msg)
|
str = "\n".join(msg)
|
||||||
trayIcon.showMessage ("Qubes Manager", str, msecs=5000)
|
trayIcon.showMessage ("Qubes VM Manager", str, msecs=5000)
|
||||||
return res
|
return res
|
||||||
|
|
||||||
|
|
||||||
@ -1062,7 +1063,7 @@ class VmManagerWindow(Ui_VmManagerWindow, QMainWindow):
|
|||||||
progress.hide()
|
progress.hide()
|
||||||
|
|
||||||
if thread_monitor.success:
|
if thread_monitor.success:
|
||||||
trayIcon.showMessage ("Qubes Manager", "VM '{0}' has been created.".format(vmname), msecs=3000)
|
trayIcon.showMessage ("Qubes VM Manager", "VM '{0}' has been created.".format(vmname), msecs=3000)
|
||||||
else:
|
else:
|
||||||
QMessageBox.warning (None, "Error creating AppVM!", "ERROR: {0}".format(thread_monitor.error_msg))
|
QMessageBox.warning (None, "Error creating AppVM!", "ERROR: {0}".format(thread_monitor.error_msg))
|
||||||
|
|
||||||
@ -1147,7 +1148,7 @@ class VmManagerWindow(Ui_VmManagerWindow, QMainWindow):
|
|||||||
progress.hide()
|
progress.hide()
|
||||||
|
|
||||||
if thread_monitor.success:
|
if thread_monitor.success:
|
||||||
trayIcon.showMessage ("Qubes Manager", "VM '{0}' has been removed.".format(vm.name), msecs=3000)
|
trayIcon.showMessage ("Qubes VM Manager", "VM '{0}' has been removed.".format(vm.name), msecs=3000)
|
||||||
else:
|
else:
|
||||||
QMessageBox.warning (None, "Error removing VM!", "ERROR: {0}".format(thread_monitor.error_msg))
|
QMessageBox.warning (None, "Error removing VM!", "ERROR: {0}".format(thread_monitor.error_msg))
|
||||||
|
|
||||||
@ -1189,14 +1190,14 @@ class VmManagerWindow(Ui_VmManagerWindow, QMainWindow):
|
|||||||
thread.daemon = True
|
thread.daemon = True
|
||||||
thread.start()
|
thread.start()
|
||||||
|
|
||||||
trayIcon.showMessage ("Qubes Manager", "Starting '{0}'...".format(vm.name), msecs=3000)
|
trayIcon.showMessage ("Qubes VM Manager", "Starting '{0}'...".format(vm.name), msecs=3000)
|
||||||
|
|
||||||
while not thread_monitor.is_finished():
|
while not thread_monitor.is_finished():
|
||||||
app.processEvents()
|
app.processEvents()
|
||||||
time.sleep (0.1)
|
time.sleep (0.1)
|
||||||
|
|
||||||
if thread_monitor.success:
|
if thread_monitor.success:
|
||||||
trayIcon.showMessage ("Qubes Manager", "VM '{0}' has been started.".format(vm.name), msecs=3000)
|
trayIcon.showMessage ("Qubes VM Manager", "VM '{0}' has been started.".format(vm.name), msecs=3000)
|
||||||
else:
|
else:
|
||||||
QMessageBox.warning (None, "Error starting VM!", "ERROR: {0}".format(thread_monitor.error_msg))
|
QMessageBox.warning (None, "Error starting VM!", "ERROR: {0}".format(thread_monitor.error_msg))
|
||||||
|
|
||||||
@ -1249,7 +1250,7 @@ class VmManagerWindow(Ui_VmManagerWindow, QMainWindow):
|
|||||||
QMessageBox.warning (None, "Error shutting down VM!", "ERROR: {0}".format(ex))
|
QMessageBox.warning (None, "Error shutting down VM!", "ERROR: {0}".format(ex))
|
||||||
return
|
return
|
||||||
|
|
||||||
trayIcon.showMessage ("Qubes Manager", "VM '{0}' is shutting down...".format(vm.name), msecs=3000)
|
trayIcon.showMessage ("Qubes VM Manager", "VM '{0}' is shutting down...".format(vm.name), msecs=3000)
|
||||||
|
|
||||||
self.shutdown_monitor[vm.qid] = VmShutdownMonitor (vm)
|
self.shutdown_monitor[vm.qid] = VmShutdownMonitor (vm)
|
||||||
QTimer.singleShot (vm_shutdown_timeout, self.shutdown_monitor[vm.qid].check_if_vm_has_shutdown)
|
QTimer.singleShot (vm_shutdown_timeout, self.shutdown_monitor[vm.qid].check_if_vm_has_shutdown)
|
||||||
@ -1274,7 +1275,7 @@ class VmManagerWindow(Ui_VmManagerWindow, QMainWindow):
|
|||||||
QMessageBox.critical (None, "Error while killing VM!", "<b>An exception ocurred while killing {0}.</b><br>ERROR: {1}".format(vm.name, ex))
|
QMessageBox.critical (None, "Error while killing VM!", "<b>An exception ocurred while killing {0}.</b><br>ERROR: {1}".format(vm.name, ex))
|
||||||
return
|
return
|
||||||
|
|
||||||
trayIcon.showMessage ("Qubes Manager", "VM '{0}' killed!".format(vm.name), msecs=3000)
|
trayIcon.showMessage ("Qubes VM Manager", "VM '{0}' killed!".format(vm.name), msecs=3000)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@ -1302,7 +1303,7 @@ class VmManagerWindow(Ui_VmManagerWindow, QMainWindow):
|
|||||||
QMessageBox.Yes | QMessageBox.Cancel)
|
QMessageBox.Yes | QMessageBox.Cancel)
|
||||||
if reply != QMessageBox.Yes:
|
if reply != QMessageBox.Yes:
|
||||||
return
|
return
|
||||||
trayIcon.showMessage ("Qubes Manager", "Starting '{0}'...".format(vm.name), msecs=3000)
|
trayIcon.showMessage ("Qubes VM Manager", "Starting '{0}'...".format(vm.name), msecs=3000)
|
||||||
|
|
||||||
app.processEvents()
|
app.processEvents()
|
||||||
|
|
||||||
@ -1654,13 +1655,13 @@ class QubesBlockDevicesManager():
|
|||||||
backend_vm_name = self.free_devs[dev]['backend_name']
|
backend_vm_name = self.free_devs[dev]['backend_name']
|
||||||
dev_id = self.free_devs[dev]['dev']
|
dev_id = self.free_devs[dev]['dev']
|
||||||
backend_vm = self.qvm_collection.get_vm_by_name(backend_vm_name)
|
backend_vm = self.qvm_collection.get_vm_by_name(backend_vm_name)
|
||||||
trayIcon.showMessage ("Qubes Manager", "{0} - attaching {1}".format(vm.name, dev), msecs=3000)
|
trayIcon.showMessage ("Qubes VM Manager", "{0} - attaching {1}".format(vm.name, dev), msecs=3000)
|
||||||
qubesutils.block_attach(vm, backend_vm, dev_id)
|
qubesutils.block_attach(vm, backend_vm, dev_id)
|
||||||
|
|
||||||
def detach_device(self, vm, dev_name):
|
def detach_device(self, vm, dev_name):
|
||||||
dev_id = self.attached_devs[dev_name]['attached_to']['devid']
|
dev_id = self.attached_devs[dev_name]['attached_to']['devid']
|
||||||
vm_xid = self.attached_devs[dev_name]['attached_to']['xid']
|
vm_xid = self.attached_devs[dev_name]['attached_to']['xid']
|
||||||
trayIcon.showMessage ("Qubes Manager", "{0} - detaching {1}".format(vm.name, dev_name), msecs=3000)
|
trayIcon.showMessage ("Qubes VM Manager", "{0} - detaching {1}".format(vm.name, dev_name), msecs=3000)
|
||||||
qubesutils.block_detach(None, dev_id, vm_xid)
|
qubesutils.block_detach(None, dev_id, vm_xid)
|
||||||
|
|
||||||
|
|
||||||
@ -1687,6 +1688,9 @@ class QubesTrayIcon(QSystemTrayIcon):
|
|||||||
|
|
||||||
self.connect (self, SIGNAL("activated (QSystemTrayIcon::ActivationReason)"), self.icon_clicked)
|
self.connect (self, SIGNAL("activated (QSystemTrayIcon::ActivationReason)"), self.icon_clicked)
|
||||||
|
|
||||||
|
self.tray_object = dbus.SessionBus().get_object("org.freedesktop.Notifications", "/org/freedesktop/Notifications")
|
||||||
|
self.tray_notifier = dbus.Interface(self.tray_object, "org.freedesktop.Notifications" )
|
||||||
|
|
||||||
def icon_clicked(self, reason):
|
def icon_clicked(self, reason):
|
||||||
if reason == QSystemTrayIcon.Context:
|
if reason == QSystemTrayIcon.Context:
|
||||||
# Handle the right click normally, i.e. display the context menu
|
# Handle the right click normally, i.e. display the context menu
|
||||||
@ -1701,6 +1705,8 @@ class QubesTrayIcon(QSystemTrayIcon):
|
|||||||
else:
|
else:
|
||||||
target.addAction(action)
|
target.addAction(action)
|
||||||
|
|
||||||
|
def showMessage(self, title, message, msecs):
|
||||||
|
self.tray_notifier.Notify("Qubes", 0, "/usr/share/qubes/icons/qubes.png", title, message, [], [], msecs)
|
||||||
|
|
||||||
def createAction(self, text, slot=None, shortcut=None, icon=None,
|
def createAction(self, text, slot=None, shortcut=None, icon=None,
|
||||||
tip=None, checkable=False, signal="triggered()"):
|
tip=None, checkable=False, signal="triggered()"):
|
||||||
|
Loading…
Reference in New Issue
Block a user