diff options
Diffstat (limited to 'h-client')
-rw-r--r-- | h-client/credits.txt | 2 | ||||
-rw-r--r-- | h-client/hclient.py | 119 | ||||
-rw-r--r-- | h-client/hlibrary.py | 21 | ||||
-rwxr-xr-x | h-client/img/devices/big/unknown.png | bin | 0 -> 3913 bytes |
4 files changed, 68 insertions, 74 deletions
diff --git a/h-client/credits.txt b/h-client/credits.txt index e89d30b..b880447 100644 --- a/h-client/credits.txt +++ b/h-client/credits.txt @@ -15,3 +15,5 @@ icons taken from the Crystal Projects icons (http://www.everaldo.com/crystal/?ac img/devices/small/videocard.png +img/devices/big/videocard.png + diff --git a/h-client/hclient.py b/h-client/hclient.py index 64c59e3..f97cbd3 100644 --- a/h-client/hclient.py +++ b/h-client/hclient.py @@ -90,6 +90,12 @@ class hclient: self.resetButton.set_sensitive(True) self.submitButton.set_sensitive(True) + self.tihbox.show() + self.bigIcon.set_from_file("img/devices/big/"+self.currentDevice.getIcon()) + if self.client.devices[code][2] == 'insert': + self.deviceInfoLabel.set_markup("this device is not present in the server database,\n would you like to <b>insert</b> it?") + else: + self.deviceInfoLabel.set_markup("this device is already present in the server database,\n would you like to <b>update</b> it?") #self.updateStatus() else: @@ -99,6 +105,7 @@ class hclient: self.submitButton.set_sensitive(False) self.currentDevice = None self.currentDeviceCode = None + #self.updateStatus() @@ -201,6 +208,7 @@ class hclient: #set the node def setNode(self,widget): self.client.logout() + self.client.errors = [] self.client.setNode(self.serverEntry.get_text()) self.updateStatus() @@ -214,11 +222,10 @@ class hclient: self.updateStatus() if self._submitFlag: - if self.client.isLogged() != -2: - if self.client.isLogged(): - self.applyChanges(None) - self.client.submit(self.currentDeviceCode) - self.printErrors() + if self.client.isLogged(): + self.applyChanges(None) + self.client.submit(self.currentDeviceCode) + self.printErrors() self._submitFlag = False @@ -230,12 +237,11 @@ class hclient: self.applyChanges(None) self.licenseNoticeWindow.destroy() - if self.client.isLogged() != -2: - if self.client.isLogged(): - self.client.submit(self.currentDeviceCode) - else: - self._submitFlag = True - self.openLoginWindow(None) + if self.client.isLogged(): + self.client.submit(self.currentDeviceCode) + else: + self._submitFlag = True + self.openLoginWindow(None) self.printErrors() @@ -261,35 +267,16 @@ class hclient: self.infoWindow.destroy() def openInfoWindow(self,widget): - self.infoWindow = gtk.Window(gtk.WINDOW_TOPLEVEL) - self.infoWindow.set_title("info") - self.infoWindow.set_position(gtk.WIN_POS_CENTER) - self.infoWindow.set_icon_from_file("img/icon.png") - #self.infoWindow.set_size_request(300, -1) - - vbox = gtk.VBox(False, 0) - vbox.set_border_width(10) - self.infoWindow.add(vbox) - - label = gtk.Label("<b>h-node client</b>") - label.set_use_markup(True) - vbox.pack_start(label, False, True, 5) + about = gtk.AboutDialog() + about.set_program_name("h-node client") + #about.set_version("") + about.set_copyright("(c) Antonio Gallo") + about.set_comments("simple client for h-node.com, licensed under the GPLv3") + about.set_website("http://www.h-node.com") + #about.set_logo(gtk.gdk.pixbuf_new_from_file("battery.png")) + about.run() + about.destroy() - label = gtk.Label("Copyright (C) 2011 Antonio Gallo") - label.set_use_markup(True) - vbox.pack_start(label, False, True, 5) - - label = gtk.Label("GPLv3") - label.set_use_markup(True) - vbox.pack_start(label, False, True, 5) - - closeButton = gtk.Button(stock=gtk.STOCK_CLOSE) - closeButton.connect("clicked", self.closeInfoWindowWindow) - vbox.pack_start(closeButton, False, True, 5) - - self.infoWindow.show_all() - - #start the window containing the license notice def openLicenseNoticeWindow(self,widget): #window for preferences @@ -333,7 +320,7 @@ class hclient: hbox = gtk.HBox(False, 0) hbox.set_border_width(10) applyButton = gtk.Button(stock=gtk.STOCK_APPLY) - closeButton = gtk.Button(stock=gtk.STOCK_CLOSE) + closeButton = gtk.Button(stock=gtk.STOCK_CANCEL) applyButton.connect("clicked", self.submit) closeButton.connect("clicked", self.closeLicenseNoticeWindow) hbox.pack_end(applyButton, False, True, 0) @@ -396,7 +383,7 @@ class hclient: hbox = gtk.HBox(False, 0) hbox.set_border_width(10) applyButton = gtk.Button(stock=gtk.STOCK_APPLY) - closeButton = gtk.Button(stock=gtk.STOCK_CLOSE) + closeButton = gtk.Button(stock=gtk.STOCK_CANCEL) applyButton.connect("clicked", self.login) closeButton.connect("clicked", self.closeLoginWindow) hbox.pack_end(applyButton, False, True, 0) @@ -484,33 +471,24 @@ class hclient: self.logoutButton.show() info = self.client.getUserInfo() if info != False: - if info != -2: - self.statusLabel.set_markup("<i>hello</i> <b>"+info['username']+"</b>, <i>you are logged in</i>") + self.statusLabel.set_markup("<i>hello</i> <b>"+info['username']+"</b>, <i>you are logged in</i>") if self.currentDeviceCode != None: self.submitButton.set_sensitive(True) - self.printErrors() + else: - self.printErrors() self.loginButton.show() self.logoutButton.hide() self.statusLabel.set_markup("<i>you are not logged in</i>") - #def setTreeViewCell(self,column, cell_renderer, model, iter): - ##img = model.get_value(iter, 3) - ##imgFlag = model.get_value(iter, 5) - #print model - ##self.devices.clear_attributes(cell_renderer) - ##if imgFlag == 'image': - ###print True - ##cell_renderer.set_property('pixbuf', img) - #return + self.printErrors() + #delete event of the login window def delete_event_login(self, widget, event, data=None): self._submitFlag = False return False - #another callback + def delete_event(self, widget, event, data=None): gtk.main_quit() return False @@ -521,7 +499,7 @@ class hclient: self._submitFlag = False #start the client object - self.client = Client('http://www.h-node.com') + self.client = Client('h-source') self.client.createDevices() # Create the main window @@ -530,7 +508,7 @@ class hclient: self.window.set_title("h-client") self.window.set_icon_from_file("img/icon.png") - self.window.set_size_request(550, -1) + self.window.set_size_request(600, -1) self.window.set_position(gtk.WIN_POS_CENTER) self.window.connect("delete_event", self.delete_event) @@ -663,11 +641,20 @@ class hclient: self.statusLabel.set_use_markup(True) rthbox.pack_end(self.statusLabel, False, True, 0) + #top image + self.tihbox = gtk.HBox(False, 0) + self.bigIcon = gtk.Image() + self.bigIcon.set_from_file("img/devices/big/unknown.png") + self.tihbox.pack_end(self.bigIcon, False, True, 0) - self.rightTable = gtk.Table(8, 2, True) + self.deviceInfoLabel = gtk.Label("rrr") + self.deviceInfoLabel.set_use_markup(True) + self.tihbox.pack_start(self.deviceInfoLabel, False, True, 3) #create the entries + self.rightTable = gtk.Table(8, 2, True) + ### model #model name label self.modelNameLabel = gtk.Label("Model name:") @@ -790,6 +777,8 @@ class hclient: self.descriptionText = gtk.TextView() self.descriptionText.set_wrap_mode(gtk.WRAP_CHAR) + self.descriptionText.set_left_margin(5) + self.descriptionText.set_right_margin(5) sw.add(self.descriptionText) sw.show() @@ -826,7 +815,8 @@ class hclient: #start the left vertical box self.rightWindow = gtk.VBox(False, 0) - self.rightWindow.pack_start(self.rightTable, False, True, 10) + self.rightWindow.pack_start(self.tihbox, True, True, 3) + self.rightWindow.pack_start(self.rightTable, False, True, 3) self.rightWindow.pack_start(self.descriptionLabel, False, True, 3) self.rightWindow.pack_start(sw, False, True, 0) self.rightWindow.pack_start(hboxBelowEntries, False, True, 10) @@ -843,8 +833,6 @@ class hclient: rvbox.pack_start(rthbox, True, True, 0) rvbox.pack_start(rFrame, True, True, 0) - - self.centerWindow.pack_start(rvbox, True, True, 0) #self.rframe.add(self.rightWindow) @@ -856,6 +844,15 @@ class hclient: self.window.show() self.synchronize(None) self.updateStatus() + + #select the first device + self.tree.get_selection().select_path(0) + ts, itera = self.tree.get_selection().get_selected() + if itera: + next = ts.iter_nth_child(itera, 0) + path = ts.get_path(next) + self.tree.get_selection().select_path(path) + #self.logoutButton.hide() def main(): diff --git a/h-client/hlibrary.py b/h-client/hlibrary.py index c3ade68..cc25edc 100644 --- a/h-client/hlibrary.py +++ b/h-client/hlibrary.py @@ -432,12 +432,10 @@ class Client: result = self.request.perform('users/login/en') self.request.setPost(None) if result: - result_login = self.isLogged() - if result_login != -2: - if result_login: - return True - else: - self.errors.append("wrong username or password") + if self.isLogged(): + return True + else: + self.errors.append("wrong username or password") else: self.errors.append("unable to connect to server") @@ -474,7 +472,7 @@ class Client: return {'status':status,'username':username,'token':token,'groups':groups} except: self.errors.append("the server is not up-to-date: unable to parse the xml database") - return -2 + return False else: self.errors.append("unable to connect to server") return False @@ -484,12 +482,9 @@ class Client: info = self.getUserInfo() if info != False: - if info != -2: - if info['status'] == 'logged': - return True - else: - return -2 - + if info['status'] == 'logged': + return True + return False #return the license info diff --git a/h-client/img/devices/big/unknown.png b/h-client/img/devices/big/unknown.png Binary files differnew file mode 100755 index 0000000..c2ab531 --- /dev/null +++ b/h-client/img/devices/big/unknown.png |