Vm state column with on/off, update state, blk icons
This commit is contained in:
parent
7f69338992
commit
a6f1ec8dda
@ -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>
|
||||||
|
@ -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)
|
||||||
|
Loading…
Reference in New Issue
Block a user