GEP 18: * fix bug with gid of citation not updating

* allow to add new citation from the citedin tab


svn: r22502
This commit is contained in:
Benny Malengier 2013-06-13 20:38:08 +00:00
parent 5ee5ef158e
commit 3135b2b304
2 changed files with 105 additions and 10 deletions

View File

@ -68,7 +68,8 @@ class CitedInTab(GrampsTab):
It shows these objects in a treeviewl and allows to load citations in the It shows these objects in a treeviewl and allows to load citations in the
top part of the source editor. top part of the source editor.
""" """
def __init__(self, dbstate, uistate, track, src, cite_apply_callback): def __init__(self, dbstate, uistate, track, src, cite_apply_callback,
cite_add_callback):
""" """
@param dbstate: The database state. Contains a reference to @param dbstate: The database state. Contains a reference to
the database, along with other state information. The GrampsTab the database, along with other state information. The GrampsTab
@ -83,12 +84,13 @@ class CitedInTab(GrampsTab):
@type track: list @type track: list
@param src: source which we manage in this tab @param src: source which we manage in this tab
@type src: gen.lib.Source @type src: gen.lib.Source
@param glade: glade objects with the needed widgets
""" """
self.src = src self.src = src
self.readonly = dbstate.db.readonly self.readonly = dbstate.db.readonly
self.srtdata = [] self.srtdata = []
self.cite_apply_callback = cite_apply_callback self.cite_apply_callback = cite_apply_callback
self.cite_add_callback = cite_add_callback
self.dirty_selection = False
GrampsTab.__init__(self, dbstate, uistate, track, _("Cited In")) GrampsTab.__init__(self, dbstate, uistate, track, _("Cited In"))
self._set_label() self._set_label()
@ -101,6 +103,7 @@ class CitedInTab(GrampsTab):
self.build_model() self.build_model()
self.setup_interface() self.setup_interface()
self.show_all() self.show_all()
self._selection_changed()
def get_icon_name(self): def get_icon_name(self):
return 'gramps-citation' return 'gramps-citation'
@ -122,15 +125,28 @@ class CitedInTab(GrampsTab):
#create the load button, add it to a hbox, and add that box to the #create the load button, add it to a hbox, and add that box to the
#tab page #tab page
self.load_btn = SimpleButton(Gtk.STOCK_APPLY, self.apply_button_clicked) self.load_btn = SimpleButton(Gtk.STOCK_APPLY, self.apply_button_clicked)
self.load_btn.set_label(_("Load Citation"))
self.load_btn.set_image(Gtk.Image.new_from_stock(Gtk.STOCK_APPLY,
Gtk.IconSize.BUTTON))
#self.load_btn.set_always_show_image(True)
self.load_btn.set_tooltip_text(_("Apply a selected citation so as to" self.load_btn.set_tooltip_text(_("Apply a selected citation so as to"
" edit it in the top part of this interface")) " edit it in the top part of this interface"))
self.add_btn = SimpleButton(Gtk.STOCK_ADD, self.add_button_clicked)
self.add_btn.set_label(_("Add New Cition"))
self.add_btn.set_image(Gtk.Image.new_from_stock(Gtk.STOCK_ADD,
Gtk.IconSize.BUTTON))
self.add_btn.set_tooltip_text(_("Add a new citation to this source"))
self.edit_btn = SimpleButton(Gtk.STOCK_EDIT, self.edit_button_clicked) self.edit_btn = SimpleButton(Gtk.STOCK_EDIT, self.edit_button_clicked)
self.edit_btn.set_label(_("Edit Cited In"))
self.edit_btn.set_image(Gtk.Image.new_from_stock(Gtk.STOCK_EDIT,
Gtk.IconSize.BUTTON))
self.edit_btn.set_tooltip_text(_("Edit the object containing the" self.edit_btn.set_tooltip_text(_("Edit the object containing the"
" selected citation")) " selected citation"))
hbox = Gtk.HBox() hbox = Gtk.HBox()
hbox.set_spacing(6) hbox.set_spacing(6)
hbox.pack_start(self.load_btn, False, True, 0) hbox.pack_start(self.load_btn, False, True, 0)
hbox.pack_start(self.add_btn, False, True, 0)
hbox.pack_start(self.edit_btn, False, True, 0) hbox.pack_start(self.edit_btn, False, True, 0)
hbox.show_all() hbox.show_all()
@ -149,6 +165,7 @@ class CitedInTab(GrampsTab):
self.tree.set_model(self.model) self.tree.set_model(self.model)
self.selection = self.tree.get_selection() self.selection = self.tree.get_selection()
self.selection.connect('changed', self._selection_changed)
# create the scrolled window, and attach the treeview # create the scrolled window, and attach the treeview
scroll = Gtk.ScrolledWindow() scroll = Gtk.ScrolledWindow()
@ -404,17 +421,22 @@ class CitedInTab(GrampsTab):
def apply_button_clicked(self, obj): def apply_button_clicked(self, obj):
""" """
Function called with the Load button is clicked. This function Function called with the Load button is clicked.
should be overridden by the derived class.
""" """
sel = self.get_selected() sel = self.get_selected()
if sel[0]: if sel[0]:
self.cite_apply_callback(sel[0]) self.cite_apply_callback(sel[0])
def add_button_clicked(self, obj):
"""
Function called with the Add button is clicked. This function
should be overridden by the derived class.
"""
self.cite_add_callback()
def edit_button_clicked(self, obj): def edit_button_clicked(self, obj):
""" """
Function called with the Load button is clicked. This function Function called with the Edit button is clicked.
should be overridden by the derived class.
""" """
sel = self.get_selected() sel = self.get_selected()
ref = sel[1] ref = sel[1]
@ -532,3 +554,50 @@ class CitedInTab(GrampsTab):
model.get_value(iter, 5)) model.get_value(iter, 5))
return None return None
def _selection_changed(self, obj=None):
"""
Attached to the selection's 'changed' signal.
Should we ever want to (in)activate the buttons depending on what is
selected, we should do it here
"""
# This method is called as callback on change, and can be called
# explicitly, dirty_selection must make sure they do not interact
if self.dirty_selection:
return
if self.get_selected() is not None:
#change what buttons are possible
self.load_btn.set_sensitive(True)
self.edit_btn.set_sensitive(True)
else:
self.load_btn.set_sensitive(False)
self.edit_btn.set_sensitive(False)
def rebuild(self):
"""
Rebuilds the data in the tab by creating a new model,
using the build_model function
"""
offset = self.tree.get_visible_rect()
#during rebuild, don't do _selection_changed
self.dirty_selection = True
(model, node) = self.selection.get_selected()
selectedpath = None
if node:
selectedpath = model.get_path(node)
self.tree.set_model(None)
if self.model and hasattr(self.model, 'destroy'):
self.model.destroy()
#actually rebuild things
self.generate_data()
self.build_model()
self.tree.set_model(self.model)
#reset previous select
if not selectedpath is None:
self.selection.select_path(selectedpath)
#model and tree are reset, allow _selection_changed again, and force it
self.dirty_selection = False
self._selection_changed()
if self.tree.get_realized():
GObject.idle_add(self.tree.scroll_to_point, offset.x, offset.y)

View File

@ -307,9 +307,9 @@ class EditSource(EditPrimary):
def _setup_citation_fields(self): def _setup_citation_fields(self):
if self.citation_ready: if self.citation_ready:
raise Exception raise Exception
self.gid = MonitoredEntry( self.gid2 = MonitoredEntry(
self.glade.get_object('gid2'), self.citation.set_gramps_id, self.glade.get_object('gid2'), self.citation.set_gramps_id,
self.citation.get_gramps_id, self.db.readonly) self.get_citation_gramps_id, self.db.readonly)
self.type_mon = MonitoredMenu( self.type_mon = MonitoredMenu(
self.glade.get_object('confidence'), self.glade.get_object('confidence'),
@ -334,6 +334,17 @@ class EditSource(EditPrimary):
self.ref_privacy = PrivacyButton( self.ref_privacy = PrivacyButton(
self.glade.get_object('privacy'), self.citation, self.db.readonly) self.glade.get_object('privacy'), self.citation, self.db.readonly)
def get_citation_gramps_id(self):
"""
Monitered entry on None does nothing, while get_gramps_id returns None
for empty string! We convert here
"""
val = self.citation.get_gramps_id()
if val is None:
return ''
else:
return val
def update_attr(self): def update_attr(self):
""" """
Reaction to update on attributes Reaction to update on attributes
@ -439,7 +450,8 @@ class EditSource(EditPrimary):
self.track_ref_for_deletion("attr_tab") self.track_ref_for_deletion("attr_tab")
self.citedin_tab = CitedInTab(self.dbstate, self.uistate, self.citedin_tab = CitedInTab(self.dbstate, self.uistate,
self.track, self.obj, self.cite_apply_callback) self.track, self.obj, self.cite_apply_callback,
self.cite_add_callback)
self._add_tab(notebook, self.citedin_tab) self._add_tab(notebook, self.citedin_tab)
self.track_ref_for_deletion("citedin_tab") self.track_ref_for_deletion("citedin_tab")
@ -617,6 +629,9 @@ class EditSource(EditPrimary):
if not res: if not res:
return return
self.__base_save(only_cite=True) self.__base_save(only_cite=True)
#as a citation changed, we need to update some fields in source
#section
self.citedin_tab.rebuild()
#now close the citation part #now close the citation part
self.unload_citation() self.unload_citation()
@ -749,6 +764,14 @@ class EditSource(EditPrimary):
self.close_citation() self.close_citation()
self.load_citation(citation_handle) self.load_citation(citation_handle)
def cite_add_callback(self):
"""
User wants to add a new citation to the source.
"""
if self.citation_loaded:
self.close_citation()
self.load_citation(None)
def unload_citation(self): def unload_citation(self):
self.cinf.set_visible(False) self.cinf.set_visible(False)
self.btnclose_cite.set_sensitive(False) self.btnclose_cite.set_sensitive(False)
@ -759,6 +782,9 @@ class EditSource(EditPrimary):
self.citation.unserialize(Citation().serialize()) self.citation.unserialize(Citation().serialize())
def load_citation(self, chandle): def load_citation(self, chandle):
"""
Loading a citation in the top view
"""
#we switch current citatoin for the new one #we switch current citatoin for the new one
if not self.citation: if not self.citation:
#there is no citation yet, put an empty one #there is no citation yet, put an empty one
@ -789,7 +815,7 @@ class EditSource(EditPrimary):
#update source part that uses citation #update source part that uses citation
self.update_attr() self.update_attr()
#trigger update of the monitored fields #trigger update of the monitored fields
for field in [self.gid, self.type_mon, self.tags2, self.ref_privacy]: for field in [self.gid2, self.type_mon, self.tags2, self.ref_privacy]:
field.update() field.update()
#trigger update of the tab fields #trigger update of the tab fields
self.comment_tab.rebuild_callback(self.citation.get_note_list()) self.comment_tab.rebuild_callback(self.citation.get_note_list())