diff --git a/ChangeLog b/ChangeLog index 79388b063..663177536 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,7 @@ +2006-01-06 Richard Taylor + * src/Assistant.py: converted to gobject and added signals + * src/GrampsLogger/_ErrorReportAssistant.py: uses new Assistant signals + 2006-01-06 Richard Taylor * src/gramps.py, src/gramps_main.py: integration of logging framework. diff --git a/src/Assistant.py b/src/Assistant.py index bce7c55fb..e7e3ae292 100644 --- a/src/Assistant.py +++ b/src/Assistant.py @@ -22,6 +22,7 @@ from gettext import gettext as _ import gtk import gtk.gdk +import gobject import const @@ -29,9 +30,28 @@ _gramps_png = "%s/gramps.png" % const.rootDir _splash_jpg = "%s/splash.jpg" % const.rootDir _format = '%s' -class Assistant: +class Assistant(gtk.Object): + """ A tabbed dialog box used to implement Assistant interfaces.""" + __gproperties__ = {} + + __gsignals__ = { 'page-changed' : (gobject.SIGNAL_RUN_LAST, gobject.TYPE_NONE, + (gobject.TYPE_INT,)), + 'before-page-next' : (gobject.SIGNAL_RUN_LAST, gobject.TYPE_NONE, + (gobject.TYPE_INT,)), + 'after-page-next' : (gobject.SIGNAL_RUN_LAST, gobject.TYPE_NONE, + (gobject.TYPE_INT,)), + 'before-page-back' : (gobject.SIGNAL_RUN_LAST, gobject.TYPE_NONE, + (gobject.TYPE_INT,)), + 'after-page-back' : (gobject.SIGNAL_RUN_LAST, gobject.TYPE_NONE, + (gobject.TYPE_INT,)), + 'complete' : (gobject.SIGNAL_RUN_LAST, gobject.TYPE_NONE, + ()) + } + def __init__(self,title,complete): + gobject.GObject.__init__(self) + self.complete = complete self.fg_color = gtk.gdk.color_parse('#7d684a') self.bg_color = gtk.gdk.color_parse('#e1dbc5') @@ -40,7 +60,6 @@ class Assistant: self.current_page = 0 self.max_page = 1 - self.page_callbacks = {} self.window = gtk.Window() titlebox = gtk.HBox() @@ -85,11 +104,21 @@ class Assistant: self.window.add(vbox) + def do_get_property(self, prop): + '''Return the gproperty's value.''' + raise AttributeError, 'unknown property %s' % prop.name + + def do_set_property(self, prop, value): + '''Set the property of writable properties.''' + raise AttributeError, 'unknown or read only property %s' % prop.name + + def update_title(self): self.title.set_label(self.title_text[self.current_page]) self.title.set_use_markup(True) def back_clicked(self,obj): + self.emit('before-page-back',self.notebook.get_current_page()) if self.current_page == 1: self.back.show() self.back.set_sensitive(False) @@ -100,11 +129,14 @@ class Assistant: self.next.set_label(gtk.STOCK_GO_FORWARD) self.next.set_use_stock(True) self.cancel.show() - - self.call_page_callback() + + self.emit('after-page-back',self.notebook.get_current_page()) + self.emit('page-changed',self.notebook.get_current_page()) def next_clicked(self,obj): + self.emit('before-page-next',self.notebook.get_current_page()) if self.current_page == self.max_page: + self.emit('complete') self.complete() self.window.destroy() else: @@ -123,14 +155,8 @@ class Assistant: self.back.set_sensitive(True) self.cancel.show() - self.call_page_callback() - - def call_page_callback(self): - # If the page has a callback then call it. - if self.page_callbacks.has_key( - self.notebook.get_nth_page(self.notebook.get_current_page())): - self.page_callbacks[ - self.notebook.get_nth_page(self.notebook.get_current_page())]() + self.emit('after-page-next',self.notebook.get_current_page()) + self.emit('page-changed',self.notebook.get_current_page()) def set_intro(self,text): hbox = gtk.HBox(spacing=12) @@ -145,12 +171,10 @@ class Assistant: def set_conclusion(self,title,text): self.conclude_text = text - def add_page(self, title, child, callback=None): + def add_page(self, title, child): self.title_text.append(_format % title) self.notebook.append_page(child) self.max_page += 1 - if callback is not None: - self.page_callbacks[child] = callback def show(self): self.title_text.append(_format % _('Finished')) @@ -164,13 +188,16 @@ class Assistant: self.notebook.append_page(hbox) self.window.show_all() self.notebook.set_current_page(0) - - self.call_page_callback() + + self.emit('page-changed',self.notebook.get_current_page()) def destroy(self): self.window.destroy() - + +if gtk.pygtk_version < (2,8,0): + gobject.type_register(Assistant) + if __name__ == "__main__": def complete(): diff --git a/src/GrampsLogger/_ErrorReportAssistant.py b/src/GrampsLogger/_ErrorReportAssistant.py index 4391b0a69..30d116762 100644 --- a/src/GrampsLogger/_ErrorReportAssistant.py +++ b/src/GrampsLogger/_ErrorReportAssistant.py @@ -32,10 +32,13 @@ class ErrorReportAssistant: "exactly what information is being sent.")) - self.w.add_page(_("Error Details"), self.build_page2()) - self.w.add_page(_("System Information"), self.build_page3()) - self.w.add_page(_("Further Information"), self.build_page4()) - self.w.add_page(_("Summary"), self.build_page5(),self.page5_update) + self.w.add_page(_("Error Details"), self.build_page1()) + self.w.add_page(_("System Information"), self.build_page2()) + self.w.add_page(_("Further Information"), self.build_page3()) + + page4 = self.build_page4() + self.w.add_page(_("Summary"), page4) + self.cb = {4:self.page4_update} self.w.set_conclusion(_('Complete'), _('The error report will be copied to your clipboard when you click OK. \n' @@ -45,8 +48,14 @@ class ErrorReportAssistant: 'depends on the users. User feedback is important. ' 'Thankyou for taking the time to submit a bug report.')) + self.w.connect('page-changed',self.on_page_changed) + self.w.show() + def on_page_changed(self,obj,page,data=None): + if self.cb.has_key(page): + self.cb[page]() + def complete(self): clipboard = gtk.Clipboard() clipboard.set_text( @@ -70,7 +79,7 @@ class ErrorReportAssistant: os.uname()[0], os.uname()[2]) - def build_page2(self): + def build_page1(self): box = gtk.VBox() @@ -102,7 +111,7 @@ class ErrorReportAssistant: return box - def build_page3(self): + def build_page2(self): box = gtk.VBox() @@ -131,7 +140,7 @@ class ErrorReportAssistant: return box - def build_page4(self): + def build_page3(self): box = gtk.VBox() @@ -158,7 +167,7 @@ class ErrorReportAssistant: return box - def build_page5(self): + def build_page4(self): box = gtk.VBox() @@ -190,7 +199,7 @@ class ErrorReportAssistant: return box - def page5_update(self): + def page4_update(self): self._final_report_text_buffer.set_text( "System Information: \n\n" +