Vm state column with on/off, update state, blk icons

This commit is contained in:
Agnieszka Kostrzewa 2012-03-20 22:59:48 +01:00
parent 7f69338992
commit a6f1ec8dda
2 changed files with 85 additions and 34 deletions

View File

@ -150,7 +150,7 @@
</column> </column>
<column> <column>
<property name="text"> <property name="text">
<string>Up</string> <string>State</string>
</property> </property>
<property name="toolTip"> <property name="toolTip">
<string>Update info</string> <string>Update info</string>
@ -223,7 +223,7 @@
<property name="title"> <property name="title">
<string>View</string> <string>View</string>
</property> </property>
<addaction name="actionUpd"/> <addaction name="actionState"/>
<addaction name="actionTemplate"/> <addaction name="actionTemplate"/>
<addaction name="actionNetVM"/> <addaction name="actionNetVM"/>
<addaction name="actionCPU"/> <addaction name="actionCPU"/>
@ -515,7 +515,7 @@
<string>Global settings</string> <string>Global settings</string>
</property> </property>
</action> </action>
<action name="actionUpd"> <action name="actionState">
<property name="checkable"> <property name="checkable">
<bool>true</bool> <bool>true</bool>
</property> </property>
@ -523,7 +523,7 @@
<bool>true</bool> <bool>true</bool>
</property> </property>
<property name="text"> <property name="text">
<string>Upd</string> <string>State</string>
</property> </property>
</action> </action>
</widget> </widget>

View File

@ -62,9 +62,9 @@ class QubesConfigFileWatcher(ProcessEvent):
def process_IN_MODIFY (self, event): def process_IN_MODIFY (self, event):
self.update_func() self.update_func()
class VmStatusIcon(QLabel): class VmLabelWidget(QLabel):
def __init__(self, vm, parent=None): def __init__(self, vm, parent=None):
super (VmStatusIcon, self).__init__(parent) super (VmLabelWidget, self).__init__(parent)
self.vm = vm self.vm = vm
(icon_pixmap, icon_sz) = self.set_vm_icon(self.vm) (icon_pixmap, icon_sz) = self.set_vm_icon(self.vm)
self.setPixmap (icon_pixmap) self.setPixmap (icon_pixmap)
@ -99,11 +99,35 @@ class VmStatusIcon(QLabel):
return (icon_pixmap, icon_sz) return (icon_pixmap, icon_sz)
class VmInfoWidget (QWidget): class VmStatusIcon(QLabel):
def __init__(self, vm, parent=None):
super (VmStatusIcon, self).__init__(parent)
self.vm = vm
self.set_on_icon()
self.previous_power_state = vm.last_power_state
class VmInfoItem (QTableWidgetItem): def update(self):
if self.previous_power_state != self.vm.last_power_state:
self.set_on_icon()
self.previous_power_state = self.vm.last_power_state
def set_on_icon(self):
icon = QIcon(":/on.png")
icon_sz = QSize (VmManagerWindow.row_height * 0.5, VmManagerWindow.row_height * 0.5)
if self.vm.last_power_state:
icon_pixmap = icon.pixmap(icon_sz)
else:
icon_pixmap = icon.pixmap(icon_sz, QIcon.Disabled)
self.setPixmap (icon_pixmap)
self.setFixedSize (icon_sz)
class VmNameWidget (QWidget):
class VmNameItem (QTableWidgetItem):
def __init__(self, name, qid): def __init__(self, name, qid):
super(VmInfoWidget.VmInfoItem, self).__init__() super(VmNameWidget.VmNameItem, self).__init__()
self.value = (name, qid) self.value = (name, qid)
def set_value(self, value): def set_value(self, value):
@ -114,33 +138,54 @@ class VmInfoWidget (QWidget):
def __init__(self, vm, parent = None): def __init__(self, vm, parent = None):
super (VmInfoWidget, self).__init__(parent) super (VmNameWidget, self).__init__(parent)
layout = QHBoxLayout () layout = QHBoxLayout ()
self.label_name = QLabel (vm.name) self.label_name = QLabel (vm.name)
self.vm_icon = VmStatusIcon(vm) self.vm_icon = VmLabelWidget(vm)
self.blk_icon = VmIconWidget(":/mount.png")
layout.addWidget(self.vm_icon) layout.addWidget(self.vm_icon)
layout.addSpacing (10) layout.addSpacing (10)
layout.addWidget(self.label_name, alignment=Qt.AlignLeft) layout.addWidget(self.label_name, alignment=Qt.AlignLeft)
layout.addSpacing (10)
layout.addWidget(self.blk_icon, alignment=Qt.AlignRight)
self.setLayout(layout) self.setLayout(layout)
self.tableItem = self.VmNameItem(vm.name, vm.qid)
def update_vm_state (self, vm):
self.vm_icon.update()
class VmInfoWidget (QWidget):
def __init__(self, vm, parent = None):
super (VmInfoWidget, self).__init__(parent)
layout = QHBoxLayout ()
self.on_icon = VmStatusIcon(vm)
self.upd_info = VmUpdateInfoWidget(vm, show_text=False)
self.blk_icon = VmIconWidget(":/mount.png")
layout.addWidget(self.on_icon)
layout.addWidget(self.upd_info)
layout.addItem(QSpacerItem(0, 10, QSizePolicy.Expanding, QtGui.QSizePolicy.Expanding))
layout.addWidget(self.blk_icon)
layout.setContentsMargins(5,0,5,0)
self.setLayout(layout)
self.blk_icon.setVisible(False) self.blk_icon.setVisible(False)
self.tableItem = self.VmInfoItem(vm.name, vm.qid) self.tableItem = self.upd_info.tableItem
def update_vm_state (self, vm, blk_visible): def update_vm_state(self, vm, blk_visible):
self.vm_icon.update() self.on_icon.update()
self.upd_info.update_outdated(vm)
if blk_visible != None: if blk_visible != None:
self.blk_icon.setVisible(blk_visible) self.blk_icon.setVisible(blk_visible)
class VmTemplateItem (QTableWidgetItem): class VmTemplateItem (QTableWidgetItem):
def __init__(self, vm): def __init__(self, vm):
@ -169,12 +214,12 @@ class VmTemplateItem (QTableWidgetItem):
class VmIconWidget (QWidget): class VmIconWidget (QWidget):
def __init__(self, icon_path, enabled=True, parent=None): def __init__(self, icon_path, enabled=True, size_multiplier=0.7, parent=None):
super(VmIconWidget, self).__init__(parent) super(VmIconWidget, self).__init__(parent)
label_icon = QLabel() label_icon = QLabel()
icon = QIcon (icon_path) icon = QIcon (icon_path)
icon_sz = QSize (VmManagerWindow.row_height * 0.7, VmManagerWindow.row_height * 0.7) icon_sz = QSize (VmManagerWindow.row_height * size_multiplier, VmManagerWindow.row_height * size_multiplier)
icon_pixmap = icon.pixmap(icon_sz, QIcon.Disabled if not enabled else QIcon.Normal) icon_pixmap = icon.pixmap(icon_sz, QIcon.Disabled if not enabled else QIcon.Normal)
label_icon.setPixmap (icon_pixmap) label_icon.setPixmap (icon_pixmap)
label_icon.setFixedSize (icon_sz) label_icon.setFixedSize (icon_sz)
@ -398,7 +443,7 @@ class VmUpdateInfoWidget(QWidget):
else: else:
self.layout().removeWidget(self.icon) self.layout().removeWidget(self.icon)
self.icon.deleteLater() self.icon.deleteLater()
self.icon = VmIconWidget(icon_path, True) self.icon = VmIconWidget(icon_path, True, 0.7)
self.icon.setToolTip(tooltip_text) self.icon.setToolTip(tooltip_text)
self.layout().addWidget(self.icon, alignment=Qt.AlignCenter) self.layout().addWidget(self.icon, alignment=Qt.AlignCenter)
@ -414,13 +459,17 @@ class VmRowInTable(object):
table.setRowHeight (row_no, VmManagerWindow.row_height) table.setRowHeight (row_no, VmManagerWindow.row_height)
self.info_widget = VmInfoWidget(vm) self.name_widget = VmNameWidget(vm)
table.setCellWidget(row_no, 0, self.info_widget) table.setCellWidget(row_no, 0, self.name_widget)
table.setItem(row_no, 0, self.info_widget.tableItem) table.setItem(row_no, 0, self.name_widget.tableItem)
self.upd_widget = VmUpdateInfoWidget(vm, False) self.info_widget = VmInfoWidget(vm)
table.setCellWidget(row_no, 1, self.upd_widget) table.setCellWidget(row_no, 1, self.info_widget)
table.setItem(row_no, 1, self.upd_widget.tableItem) table.setItem(row_no, 1, self.info_widget.tableItem)
#self.upd_widget = VmUpdateInfoWidget(vm, False)
#table.setCellWidget(row_no, 1, self.upd_widget)
#table.setItem(row_no, 1, self.upd_widget.tableItem)
self.template_widget = VmTemplateItem(vm) self.template_widget = VmTemplateItem(vm)
table.setItem(row_no, 2, self.template_widget) table.setItem(row_no, 2, self.template_widget)
@ -449,13 +498,14 @@ class VmRowInTable(object):
def update(self, counter, blk_visible = None, cpu_load = None): def update(self, counter, blk_visible = None, cpu_load = None):
self.name_widget.update_vm_state(self.vm)
self.info_widget.update_vm_state(self.vm, blk_visible) self.info_widget.update_vm_state(self.vm, blk_visible)
if cpu_load is not None: if cpu_load is not None:
self.cpu_usage_widget.update_load(self.vm, cpu_load) self.cpu_usage_widget.update_load(self.vm, cpu_load)
self.mem_usage_widget.update_load(self.vm, None) self.mem_usage_widget.update_load(self.vm, None)
self.load_widget.update_load(self.vm, cpu_load) self.load_widget.update_load(self.vm, cpu_load)
self.mem_widget.update_load(self.vm, None) self.mem_widget.update_load(self.vm, None)
self.upd_widget.update_outdated(self.vm) #self.upd_widget.update_outdated(self.vm)
class NewAppVmDlg (QDialog, ui_newappvmdlg.Ui_NewAppVMDlg): class NewAppVmDlg (QDialog, ui_newappvmdlg.Ui_NewAppVMDlg):
def __init__(self, parent = None): def __init__(self, parent = None):
@ -493,7 +543,7 @@ class VmManagerWindow(Ui_VmManagerWindow, QMainWindow):
update_interval = 1000 # in msec update_interval = 1000 # in msec
show_inactive_vms = True show_inactive_vms = True
columns_indices = { "Name": 0, columns_indices = { "Name": 0,
"Upd": 1, "State": 1,
"Template": 2, "Template": 2,
"NetVM": 3, "NetVM": 3,
"CPU": 4, "CPU": 4,
@ -527,7 +577,8 @@ class VmManagerWindow(Ui_VmManagerWindow, QMainWindow):
self.actionCPU_Graph.setChecked(False) self.actionCPU_Graph.setChecked(False)
self.table.setColumnHidden( self.columns_indices["MEM Graph"], True) self.table.setColumnHidden( self.columns_indices["MEM Graph"], True)
self.actionMEM_Graph.setChecked(False) self.actionMEM_Graph.setChecked(False)
self.table.setColumnWidth(self.columns_indices["Upd"], 40) self.table.setColumnWidth(self.columns_indices["State"], 80)
self.table.setColumnWidth(self.columns_indices["Name"], 170)
self.table.horizontalHeader().setResizeMode(QHeaderView.Fixed) self.table.horizontalHeader().setResizeMode(QHeaderView.Fixed)
@ -1153,8 +1204,8 @@ class VmManagerWindow(Ui_VmManagerWindow, QMainWindow):
self.table.setColumnHidden( col_num, not show) self.table.setColumnHidden( col_num, not show)
self.update_table_columns() self.update_table_columns()
def on_actionUpd_toggled(self, checked): def on_actionState_toggled(self, checked):
self.showhide_collumn( self.columns_indices['Upd'], checked) self.showhide_collumn( self.columns_indices['State'], checked)
def on_actionTemplate_toggled(self, checked): def on_actionTemplate_toggled(self, checked):
self.showhide_collumn( self.columns_indices['Template'], checked) self.showhide_collumn( self.columns_indices['Template'], checked)