* src/MergeData.py: Files for places and sources.

* src/PlaceView.py (build_context_menu): Typo.
* src/SourceView.py (__init__,build_tree): Allow multiple,
selections; (merge): Add placeholder method (borrowed from places,
needs work.
* src/gramps_main.py (on_views_switch_page): Enable merge button;
(on_merge_activate): Call merge for sources.


svn: r4244
This commit is contained in:
Alex Roitman 2005-03-28 04:22:09 +00:00
parent eacd125000
commit 59e1448c9e
5 changed files with 107 additions and 42 deletions

View File

@ -1,3 +1,12 @@
2005-03-27 Alex Roitman <shura@gramps-project.org>
* src/MergeData.py: Files for places and sources.
* src/PlaceView.py (build_context_menu): Typo.
* src/SourceView.py (__init__,build_tree): Allow multiple,
selections; (merge): Add placeholder method (borrowed from places,
needs work.
* src/gramps_main.py (on_views_switch_page): Enable merge button;
(on_merge_activate): Call merge for sources.
2005-03-26 Alex Roitman <shura@gramps-project.org> 2005-03-26 Alex Roitman <shura@gramps-project.org>
* src/RelLib.py (Source.replace_source_references): Add method. * src/RelLib.py (Source.replace_source_references): Add method.
* src/MergeData.py (MergeSources.merge): Use new handle replacement. * src/MergeData.py (MergeSources.merge): Use new handle replacement.

View File

@ -1327,18 +1327,23 @@ class MergePlaces:
Merges to places into a single place. Displays a dialog box that Merges to places into a single place. Displays a dialog box that
allows the places to be combined into one. allows the places to be combined into one.
""" """
def __init__(self,database,place1,place2,update): def __init__(self,database,new_handle,old_handle,update):
self.db = database self.db = database
self.p1 = place1 self.new_handle = new_handle
self.p2 = place2 self.old_handle = old_handle
self.p1 = self.db.get_place_from_handle(self.new_handle)
self.p2 = self.db.get_place_from_handle(self.old_handle)
self.update = update self.update = update
self.trans = self.db.transaction_begin()
self.glade = gtk.glade.XML(const.mergeFile,"merge_places","gramps") self.glade = gtk.glade.XML(const.mergeFile,"merge_places","gramps")
self.top = self.glade.get_widget("merge_places") self.top = self.glade.get_widget("merge_places")
self.glade.get_widget("title1_text").set_text(place1.get_title()) Utils.set_titles(self.top,self.glade.get_widget('title'),
self.glade.get_widget("title2_text").set_text(place2.get_title()) _("Select title"))
self.glade.get_widget("title1_text").set_text(self.p1.get_title())
self.glade.get_widget("title2_text").set_text(self.p2.get_title())
self.t3 = self.glade.get_widget("title3_text") self.t3 = self.glade.get_widget("title3_text")
self.t3.set_text(place1.get_title()) self.t3.set_text(self.p1.get_title())
self.glade.signal_autoconnect({ self.glade.signal_autoconnect({
"destroy_passed_object" : Utils.destroy_passed_object, "destroy_passed_object" : Utils.destroy_passed_object,
@ -1352,8 +1357,6 @@ class MergePlaces:
""" """
t2active = self.glade.get_widget("title2").get_active() t2active = self.glade.get_widget("title2").get_active()
old_id = self.p1.get_handle()
if t2active: if t2active:
self.p1.set_title(self.p2.get_title()) self.p1.set_title(self.p2.get_title())
elif self.glade.get_widget("title3").get_active(): elif self.glade.get_widget("title3").get_active():
@ -1399,26 +1402,42 @@ class MergePlaces:
if not l.is_empty(): if not l.is_empty():
self.p1.add_alternate_locations(l) self.p1.add_alternate_locations(l)
# loop through people, changing event references to P2 to P1 # remove old and commit new source
for key in self.db.get_person_handles(sort_handles=False): self.db.remove_place(self.old_handle,self.trans)
p = self.db.get_person_from_handle(key) self.db.commit_place(self.p1,self.trans)
for event in [p.get_birth_handle(), p.get_death_handle()] + p.get_event_list():
if event.get_place_handle() == self.p2:
event.set_place_handle(self.p1)
# loop through families, changing event references to P2 to P1 # replace references in other objetcs
for f in self.db.get_family_handle_map().values(): # events
for event in f.get_event_list(): for handle in self.db.get_event_handles():
if event.get_place_handle() == self.p2: event = self.db.get_event_from_handle(handle)
event.set_place_handle(self.p1) if event.get_place_handle() == self.old_handle:
event.set_place_handle(self.new_handle)
self.db.remove_place(self.p2.get_handle())
self.db.build_place_display(self.p1.get_handle(),old_id) # personal LDS ordinances
for handle in self.db.get_person_handles(sort_handles=False):
self.update(self.p1.get_handle()) person = self.db.get_person_from_handle(handle)
ord_list = [ordinance for ordinance \
in [person.lds_bapt,person.lds_endow,person.lds_seal]
if (ordinance and \
ordinance.get_place_handle() == self.old_handle)
]
if ord_list:
for ordinance in ord_list:
ordinance.set_place_handle(self.new_handle)
self.db.commit_person(person,self.trans)
# family LDS ordinance
for handle in self.db.get_family_handles():
family = self.db.get_family_from_handle(handle)
if family.lds_seal and \
family.lds_seal.get_place_handle() == self.old_handle:
family.lds_seal.set_place_handle(self.new_handle)
self.db.commit_family(family,self.trans)
self.db.transaction_commit(self.trans,_("Merge Places"))
self.update()
Utils.destroy_passed_object(obj) Utils.destroy_passed_object(obj)
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
# #
# Merge Sources # Merge Sources
@ -1429,10 +1448,12 @@ class MergeSources:
Merges to places into a single place. Displays a dialog box that Merges to places into a single place. Displays a dialog box that
allows the places to be combined into one. allows the places to be combined into one.
""" """
def __init__(self,database,src1,src2,update): def __init__(self,database,new_handle,old_handle,update):
self.db = database self.db = database
self.p1 = src1 self.new_handle = new_handle
self.p2 = src2 self.old_handle = old_handle
self.src1 = self.db.get_source_from_handle(self.new_handle)
self.src2 = self.db.get_source_from_handle(self.old_handle)
self.update = update self.update = update
self.glade = gtk.glade.XML(const.mergeFile,"merge_sources","gramps") self.glade = gtk.glade.XML(const.mergeFile,"merge_sources","gramps")
@ -1465,6 +1486,7 @@ class MergeSources:
self.glade.get_widget('ok').connect('clicked',self.merge) self.glade.get_widget('ok').connect('clicked',self.merge)
self.glade.get_widget('close').connect('clicked',self.close) self.glade.get_widget('close').connect('clicked',self.close)
self.trans = self.db.transaction_begin()
self.top.show() self.top.show()
def close(self,obj): def close(self,obj):
@ -1472,7 +1494,7 @@ class MergeSources:
def merge(self,obj): def merge(self,obj):
""" """
Performs the merge of the places when the merge button is clicked. Performs the merge of the sources when the merge button is clicked.
""" """
use_title1 = self.glade.get_widget("title_btn1").get_active() use_title1 = self.glade.get_widget("title_btn1").get_active()
@ -1480,8 +1502,6 @@ class MergeSources:
use_abbrev1 = self.glade.get_widget("abbrev_btn1").get_active() use_abbrev1 = self.glade.get_widget("abbrev_btn1").get_active()
use_pub1 = self.glade.get_widget("pub_btn1").get_active() use_pub1 = self.glade.get_widget("pub_btn1").get_active()
use_gramps1 = self.glade.get_widget("gramps_btn1").get_active() use_gramps1 = self.glade.get_widget("gramps_btn1").get_active()
old_id = self.p1.get_handle()
if not use_title1: if not use_title1:
self.src1.set_title(self.src2.get_title()) self.src1.set_title(self.src2.get_title())
@ -1516,38 +1536,53 @@ class MergeSources:
if not src1_map.has_key(key): if not src1_map.has_key(key):
src1_map[key] = src2_map[key] src1_map[key] = src2_map[key]
# replace references in other objetcs
self.db.remove_source(self.old_handle,self.trans)
self.db.commit_source(self.src1,self.trans)
# replace handles # replace handles
old_handle = self.src2.get_handle()
new_handle = self.src1.get_handle()
# people # people
for handle in self.db.get_person_handles(sort_handles=False): for handle in self.db.get_person_handles(sort_handles=False):
person = self.db.get_person_from_handle(handle) person = self.db.get_person_from_handle(handle)
person.replace_source_references(old_handle,new_handle) if person.has_source_reference(self.old_handle):
person.replace_source_references(self.old_handle,self.new_handle)
self.db.commit_person(person,trans)
# family # family
for handle in self.db.get_family_handles(): for handle in self.db.get_family_handles():
family = self.db.get_family_from_handle(handle) family = self.db.get_family_from_handle(handle)
family.replace_source_references(old_handle,new_handle) if family.has_source_reference(self.old_handle):
family.replace_source_references(self.old_handle,self.new_handle)
self.db.commit_family(family,trans)
# events # events
for handle in self.db.get_event_handles(): for handle in self.db.get_event_handles():
event = self.db.get_event_from_handle(handle) event = self.db.get_event_from_handle(handle)
event.replace_source_references(old_handle,new_handle) if event.has_source_reference(self.old_handle):
event.replace_source_references(self.old_handle,self.new_handle)
self.db.commit_event(event,trans)
# sources # sources
for handle in self.db.get_source_handles(): for handle in self.db.get_source_handles():
source = self.db.get_source_from_handle(handle) source = self.db.get_source_from_handle(handle)
source.replace_source_references(old_handle,new_handle) if source.has_source_reference(self.old_handle):
source.replace_source_references(self.old_handle,self.new_handle)
self.db.commit_source(source,trans)
# places # places
for handle in self.db.get_place_handles(): for handle in self.db.get_place_handles():
place = self.db.get_place_from_handle(handle) place = self.db.get_place_from_handle(handle)
place.replace_source_references(old_handle,new_handle) if place.has_source_reference(self.old_handle):
place.replace_source_references(self.old_handle,self.new_handle)
self.db.commit_place(place,trans)
# media # media
for handle in self.db.get_media_object_handles(): for handle in self.db.get_media_object_handles():
obj = self.db.get_object_from_handle(handle) obj = self.db.get_object_from_handle(handle)
obj.replace_source_references(old_handle,new_handle) if obj.has_source_reference(self.old_handle):
obj.replace_source_references(self.old_handle,self.new_handle)
self.db.commit_media_object(obj,trans)
self.db.transaction_commit(self.trans,_("Merge Sources"))
self.top.destroy() self.top.destroy()

View File

@ -154,7 +154,7 @@ class PlaceView:
] ]
menu = gtk.Menu() menu = gtk.Menu()
menu.set_title(_('Source Menu')) menu.set_title(_('Place Menu'))
for stock_id,callback,sensitivity in entries: for stock_id,callback,sensitivity in entries:
item = gtk.ImageMenuItem(stock_id) item = gtk.ImageMenuItem(stock_id)
if callback: if callback:

View File

@ -37,7 +37,7 @@ import EditSource
import DisplayModels import DisplayModels
import const import const
import Utils import Utils
from QuestionDialog import QuestionDialog from QuestionDialog import QuestionDialog, ErrorDialog
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
# #
@ -72,6 +72,7 @@ class SourceView:
#self.list.set_property('fixed-height-mode',True) #self.list.set_property('fixed-height-mode',True)
self.list.connect('button-press-event',self.button_press) self.list.connect('button-press-event',self.button_press)
self.selection = self.list.get_selection() self.selection = self.list.get_selection()
self.selection.set_mode(gtk.SELECTION_MULTIPLE)
self.renderer = gtk.CellRendererText() self.renderer = gtk.CellRendererText()
@ -114,6 +115,7 @@ class SourceView:
self.model = DisplayModels.SourceModel(self.parent.db) self.model = DisplayModels.SourceModel(self.parent.db)
self.list.set_model(self.model) self.list.set_model(self.model)
self.selection = self.list.get_selection() self.selection = self.list.get_selection()
self.selection.set_mode(gtk.SELECTION_MULTIPLE)
def button_press(self,obj,event): def button_press(self,obj,event):
if event.type == gtk.gdk._2BUTTON_PRESS and event.button == 1: if event.type == gtk.gdk._2BUTTON_PRESS and event.button == 1:
@ -200,3 +202,20 @@ class SourceView:
def update_display(self,source): def update_display(self,source):
self.model.update_row_by_handle(source.get_handle()) self.model.update_row_by_handle(source.get_handle())
def merge(self):
ErrorDialog("NOT IMPLEMENTED",
"Need to correct SourceView.merge method.")
return
mlist = []
self.selection.selected_foreach(self.blist,mlist)
if len(mlist) != 2:
msg = _("Cannot merge sources.")
msg2 = _("Exactly two sources must be selected to perform a merge. "
"A second source can be selected by holding down the "
"control key while clicking on the desired source.")
ErrorDialog(msg,msg2)
else:
import MergeData
MergeData.MergeSources(self.parent.db,mlist[0],mlist[1],self.build_tree)

View File

@ -1018,6 +1018,8 @@ class Gramps:
self.update_after_edit) self.update_after_edit)
elif page == PLACE_VIEW: elif page == PLACE_VIEW:
self.place_view.merge() self.place_view.merge()
elif page == SOURCE_VIEW:
self.source_view.merge()
def delete_event(self,widget, event): def delete_event(self,widget, event):
"""Catch the destruction of the top window, prompt to save if needed""" """Catch the destruction of the top window, prompt to save if needed"""
@ -1582,7 +1584,7 @@ class Gramps:
self.pedigree_view.load_canvas(self.active_person) self.pedigree_view.load_canvas(self.active_person)
elif page == SOURCE_VIEW: elif page == SOURCE_VIEW:
self.enable_buttons(1) self.enable_buttons(1)
self.merge_button.set_sensitive(0) self.merge_button.set_sensitive(1)
elif page == PLACE_VIEW: elif page == PLACE_VIEW:
self.enable_buttons(1) self.enable_buttons(1)
self.merge_button.set_sensitive(1) self.merge_button.set_sensitive(1)