Fixed bug in handling state changes

This commit is contained in:
Marta Marczykowska-Górecka 2018-12-07 18:07:45 +01:00
parent c0eb8b55ab
commit 24adad8094
No known key found for this signature in database
GPG Key ID: 9A752C30B26FD04B

View File

@ -171,6 +171,7 @@ class TemplateManagerWindow(
def clear_selection(self):
for row in self.rows_in_table.values():
if row.checkbox:
row.checkbox.setChecked(False)
def change_all_changed(self):
@ -179,7 +180,7 @@ class TemplateManagerWindow(
selected_template = self.change_all_combobox.currentText()
for row in self.rows_in_table.values():
if row.checkbox.isChecked():
if row.checkbox and row.checkbox.isChecked():
row.new_item.setCurrentIndex(
row.new_item.findText(selected_template))
@ -218,7 +219,9 @@ class TemplateManagerWindow(
def reset(self):
for row in self.rows_in_table.values():
if row.new_item:
row.new_item.reset_choice()
if row.checkbox:
row.checkbox.setChecked(False)
def cancel(self):
@ -227,7 +230,7 @@ class TemplateManagerWindow(
def apply(self):
errors = {}
for vm, row in self.rows_in_table.items():
if row.new_item.changed:
if row.new_item and row.new_item.changed:
try:
setattr(self.qubes_app.domains[vm],
'template', row.new_item.currentText())
@ -375,12 +378,14 @@ class VMRow:
if new_template:
self.table_widget.removeCellWidget(
row, column_names.index('New template'))
self.new_item = None
checkbox = self.table_widget.cellWidget(
row, column_names.index('State'))
if checkbox:
self.table_widget.removeCellWidget(
row, column_names.index('State'))
self.checkbox = None
# Bases on the original code by:
# Copyright (c) 2002-2007 Pascal Varet <p.varet@gmail.com>