aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--h-client/hclient.py49
-rw-r--r--h-client/hlibrary.py8
2 files changed, 47 insertions, 10 deletions
diff --git a/h-client/hclient.py b/h-client/hclient.py
index 57a5cbd..cc4e150 100644
--- a/h-client/hclient.py
+++ b/h-client/hclient.py
@@ -131,6 +131,8 @@ class hclient:
#set the pyGTK device entries
def setEntries(self):
if self.currentDevice != None:
+ #set the type entry
+ self.setTypeEntry()
#set the model entry
self.setModelEntry()
#set the other names entry
@@ -155,6 +157,15 @@ class hclient:
self.setDescriptionEntry()
+ #set the subtype entry (in the case pf printers)
+ def setTypeEntry(self):
+ if self.currentDevice.getType() in self.client.getTypes():
+ index = self.client.getTypes().index(self.currentDevice.getType())
+ else:
+ index = 0
+
+ self.typeCombo.set_active(index)
+
#set the model name entry
def setModelEntry(self):
self.modelNameEntry.set_text(self.currentDevice.getModel())
@@ -831,35 +842,53 @@ class hclient:
label_base = gtk.Label("Base")
label_adv = gtk.Label("Advanced")
- self.rightTable = gtk.Table(4, 2, False)
+ self.rightTable = gtk.Table(5, 2, False)
self.rightTableAdvances = gtk.Table(6, 2, False)
self.rightTable.set_border_width(5)
self.rightTableAdvances.set_border_width(5)
+
+ self.rightTable.set_row_spacings(3)
+ self.rightTableAdvances.set_row_spacings(3)
notebook.append_page(self.rightTable, label_base)
notebook.append_page(self.rightTableAdvances, label_adv)
+
+ ###type entry
+ #year of commercialization label
+ self.typeLabel = gtk.Label("Select the device category (if not correct):")
+ self.typeLabel.set_alignment(0.75,0.5)
+ #add the label
+ self.rightTable.attach(self.typeLabel, 0, 1, 0, 1)
+
+ self.typeCombo = gtk.combo_box_new_text()
+
+ for dtype in self.client.getTypes():
+ self.typeCombo.append_text(dtype)
+
+ #add the combo to the table
+ self.rightTable.attach(self.typeCombo, 1, 2, 0, 1)
### model
#model name label
self.modelNameLabel = gtk.Label("Model name:")
self.modelNameLabel.set_alignment(0.94,0.5)
#add the label
- self.rightTable.attach(self.modelNameLabel, 0, 1, 0, 1)
+ self.rightTable.attach(self.modelNameLabel, 0, 1, 1, 2)
#model name input
self.modelNameEntry = gtk.Entry()
#add the input to the table
- self.rightTable.attach(self.modelNameEntry, 1, 2, 0, 1)
+ self.rightTable.attach(self.modelNameEntry, 1, 2, 1, 2)
### other names
#other names label
self.otherNamesLabel = gtk.Label("Possible other names of the device:\n( <i>write one name per row</i> )")
self.otherNamesLabel.set_use_markup(True)
- self.otherNamesLabel.set_alignment(0.76,0.5)
+ self.otherNamesLabel.set_alignment(0.83,0.5)
self.otherNamesLabel.set_justify(gtk.JUSTIFY_RIGHT)
- self.rightTable.attach(self.otherNamesLabel, 0, 1, 1, 2)
+ self.rightTable.attach(self.otherNamesLabel, 0, 1, 2, 3)
#other names text area
s = gtk.ScrolledWindow()
@@ -876,7 +905,7 @@ class hclient:
s.add(self.otherNamesText)
s.show()
s.show_all()
- self.rightTable.attach(s, 1, 2, 1, 2)
+ self.rightTable.attach(s, 1, 2, 2, 3)
### vendorid:productid
@@ -942,7 +971,7 @@ class hclient:
self.distributionLabel = gtk.Label("Distribution used: ")
self.distributionLabel.set_alignment(0.95,0.5)
#add the label
- self.rightTable.attach(self.distributionLabel, 0, 1, 2, 3)
+ self.rightTable.attach(self.distributionLabel, 0, 1, 3, 4)
#distribution input
self.distributionEntry = gtk.Entry()
@@ -950,7 +979,7 @@ class hclient:
#add the input
- self.rightTable.attach(self.distributionEntry, 1, 2, 2, 3)
+ self.rightTable.attach(self.distributionEntry, 1, 2, 3, 4)
### kernel
@@ -971,12 +1000,12 @@ class hclient:
self.howItWorksLabel = gtk.Label("Does it work?")
self.howItWorksLabel.set_alignment(0.95,0.5)
#add the label
- self.rightTable.attach(self.howItWorksLabel, 0, 1, 3, 4)
+ self.rightTable.attach(self.howItWorksLabel, 0, 1, 4, 5)
self.howItWorksCombo = gtk.combo_box_new_text()
#add the combo to the table
- self.rightTable.attach(self.howItWorksCombo, 1, 2, 3, 4)
+ self.rightTable.attach(self.howItWorksCombo, 1, 2, 4, 5)
### driver
diff --git a/h-client/hlibrary.py b/h-client/hlibrary.py
index e8b577b..85faca6 100644
--- a/h-client/hlibrary.py
+++ b/h-client/hlibrary.py
@@ -569,6 +569,14 @@ class Client:
)
+ #get the list of types
+ def getTypes(self):
+ types = []
+ for Class,struct in self._types.iteritems():
+ if struct['type'] not in types:
+ types.append(struct['type'])
+ return types
+
#check if a distro code is allowed or not
def distroIsAllowed(self,distroCode):
allowedDistroCodes = self.allowedDistros.keys()