Date fixes, date and place handing in EditPerson, and breaking SourceView out of gramps_main
svn: r533
This commit is contained in:
parent
65ed5b743b
commit
021044856a
@ -696,7 +696,7 @@ class SingleDate:
|
|||||||
elif self.year == -1:
|
elif self.year == -1:
|
||||||
retval = "????%s%02d%s??" % (sep,self.month+1,sep)
|
retval = "????%s%02d%s??" % (sep,self.month+1,sep)
|
||||||
else:
|
else:
|
||||||
retval = "%04d%s%02d%s??" % (self.year,sep,self.month+1,sep)
|
retval = "%04d%s%02d" % (self.year,sep,self.month+1)
|
||||||
elif self.month == -1:
|
elif self.month == -1:
|
||||||
retval = "%04d%s??%s%02d" % (self.year,sep,sep,self.day)
|
retval = "%04d%s??%s%02d" % (self.year,sep,sep,self.day)
|
||||||
else:
|
else:
|
||||||
@ -891,6 +891,19 @@ class SingleDate:
|
|||||||
if match != None:
|
if match != None:
|
||||||
matches = match.groups()
|
matches = match.groups()
|
||||||
self.getMode(matches[0])
|
self.getMode(matches[0])
|
||||||
|
if Date.entryCode == 2:
|
||||||
|
try:
|
||||||
|
self.month = int(matches[2])-1
|
||||||
|
if self.month > 11:
|
||||||
|
raise Date.Error,text
|
||||||
|
except ValueError:
|
||||||
|
self.month = -1
|
||||||
|
try:
|
||||||
|
self.year = int(matches[1])
|
||||||
|
except ValueError:
|
||||||
|
self.year = -1
|
||||||
|
return 1
|
||||||
|
else:
|
||||||
try:
|
try:
|
||||||
self.month = int(matches[1])-1
|
self.month = int(matches[1])-1
|
||||||
if self.month > 11:
|
if self.month > 11:
|
||||||
|
@ -72,6 +72,8 @@ class EditPerson:
|
|||||||
self.path = db.getSavePath()
|
self.path = db.getSavePath()
|
||||||
self.not_loaded = 1
|
self.not_loaded = 1
|
||||||
self.lists_changed = 0
|
self.lists_changed = 0
|
||||||
|
self.update_birth = 0
|
||||||
|
self.update_death = 0
|
||||||
pid = "i%s" % person.getId()
|
pid = "i%s" % person.getId()
|
||||||
|
|
||||||
self.load_obj = None
|
self.load_obj = None
|
||||||
@ -275,17 +277,43 @@ class EditPerson:
|
|||||||
"""redraws the address list for the person"""
|
"""redraws the address list for the person"""
|
||||||
utils.redraw_list(self.plist,self.addr_list,disp_addr)
|
utils.redraw_list(self.plist,self.addr_list,disp_addr)
|
||||||
|
|
||||||
|
#---------------------------------------------------------------------
|
||||||
|
#
|
||||||
|
# redraw_event_list - Update both the birth and death place combo
|
||||||
|
# boxes for any changes that occurred in the 'Event Edit' window.
|
||||||
|
# Make sure not to allow the editing of a birth event to change
|
||||||
|
# any values in the death event, and vice versa. Since updating a
|
||||||
|
# combo list resets its present value, this code will have to save
|
||||||
|
# and restore the value for the event *not* being edited.
|
||||||
|
#
|
||||||
|
#---------------------------------------------------------------------
|
||||||
def redraw_event_list(self):
|
def redraw_event_list(self):
|
||||||
"""redraws the event list for the person"""
|
"""redraws the event list for the person"""
|
||||||
utils.redraw_list(self.elist,self.event_list,disp_event)
|
utils.redraw_list(self.elist,self.event_list,disp_event)
|
||||||
|
|
||||||
|
# Remember old combo list input
|
||||||
|
prev_btext = self.bpcombo.entry.get_text()
|
||||||
|
prev_dtext = self.dpcombo.entry.get_text()
|
||||||
|
|
||||||
|
# Update combo lists to add in any new places
|
||||||
plist = self.db.getPlaceMap().values()
|
plist = self.db.getPlaceMap().values()
|
||||||
if len(plist) > 0:
|
if len(plist) > 0:
|
||||||
utils.attach_places(plist,self.dpcombo,self.death.getPlace())
|
utils.attach_places(plist,self.dpcombo,self.death.getPlace())
|
||||||
utils.attach_places(plist,self.bpcombo,self.birth.getPlace())
|
utils.attach_places(plist,self.bpcombo,self.birth.getPlace())
|
||||||
self.bplace.set_text(self.birth.getPlaceName())
|
|
||||||
self.dplace.set_text(self.death.getPlaceName())
|
# Update birth with new values, make sure death values don't change
|
||||||
|
if (self.update_birth):
|
||||||
|
self.update_birth = 0
|
||||||
self.bdate.set_text(self.birth.getDate())
|
self.bdate.set_text(self.birth.getDate())
|
||||||
|
self.bplace.set_text(self.birth.getPlaceName())
|
||||||
|
self.dplace.set_text(prev_dtext)
|
||||||
|
|
||||||
|
# Update death with new values, make sure birth values don't change
|
||||||
|
if (self.update_death):
|
||||||
|
self.update_death = 0
|
||||||
self.ddate.set_text(self.death.getDate())
|
self.ddate.set_text(self.death.getDate())
|
||||||
|
self.dplace.set_text(self.death.getPlaceName())
|
||||||
|
self.bplace.set_text(prev_btext)
|
||||||
|
|
||||||
def on_add_addr_clicked(self,obj):
|
def on_add_addr_clicked(self,obj):
|
||||||
"""Invokes the address editor to add a new address"""
|
"""Invokes the address editor to add a new address"""
|
||||||
@ -318,6 +346,7 @@ class EditPerson:
|
|||||||
def on_edit_birth_clicked(self,obj):
|
def on_edit_birth_clicked(self,obj):
|
||||||
"""Brings up the EventEditor for the birth record, event name cannot be changed"""
|
"""Brings up the EventEditor for the birth record, event name cannot be changed"""
|
||||||
import EventEdit
|
import EventEdit
|
||||||
|
self.update_birth = 1
|
||||||
pname = self.person.getPrimaryName().getName()
|
pname = self.person.getPrimaryName().getName()
|
||||||
event = self.birth
|
event = self.birth
|
||||||
event.setDate(self.bdate.get_text())
|
event.setDate(self.bdate.get_text())
|
||||||
@ -333,6 +362,7 @@ class EditPerson:
|
|||||||
def on_edit_death_clicked(self,obj):
|
def on_edit_death_clicked(self,obj):
|
||||||
"""Brings up the EventEditor for the death record, event name cannot be changed"""
|
"""Brings up the EventEditor for the death record, event name cannot be changed"""
|
||||||
import EventEdit
|
import EventEdit
|
||||||
|
self.update_death = 1
|
||||||
pname = self.person.getPrimaryName().getName()
|
pname = self.person.getPrimaryName().getName()
|
||||||
event = self.death
|
event = self.death
|
||||||
event.setDate(self.ddate.get_text())
|
event.setDate(self.ddate.get_text())
|
||||||
@ -635,9 +665,10 @@ class EditPerson:
|
|||||||
bplace_obj = utils.get_place_from_list(self.bpcombo)
|
bplace_obj = utils.get_place_from_list(self.bpcombo)
|
||||||
bplace = string.strip(self.bplace.get_text())
|
bplace = string.strip(self.bplace.get_text())
|
||||||
if bplace_obj == None and bplace != "":
|
if bplace_obj == None and bplace != "":
|
||||||
p1 = Place()
|
bplace_obj = Place()
|
||||||
p1.set_title(bplace)
|
bplace_obj.set_title(bplace)
|
||||||
self.db.addPlace(p1)
|
self.db.addPlace(bplace_obj)
|
||||||
|
utils.modified()
|
||||||
self.birth.setPlace(bplace_obj)
|
self.birth.setPlace(bplace_obj)
|
||||||
|
|
||||||
if not self.person.getBirth().are_equal(self.birth):
|
if not self.person.getBirth().are_equal(self.birth):
|
||||||
@ -657,9 +688,10 @@ class EditPerson:
|
|||||||
dplace_obj = utils.get_place_from_list(self.dpcombo)
|
dplace_obj = utils.get_place_from_list(self.dpcombo)
|
||||||
dplace = string.strip(self.dplace.get_text())
|
dplace = string.strip(self.dplace.get_text())
|
||||||
if dplace_obj == None and dplace != "":
|
if dplace_obj == None and dplace != "":
|
||||||
p1 = Place()
|
dplace_obj = Place()
|
||||||
p1.set_title(dplace)
|
dplace_obj.set_title(dplace)
|
||||||
self.db.addPlace(p1)
|
self.db.addPlace(dplace_obj)
|
||||||
|
utils.modified()
|
||||||
self.death.setPlace(dplace_obj)
|
self.death.setPlace(dplace_obj)
|
||||||
|
|
||||||
if not self.person.getDeath().are_equal(self.death):
|
if not self.person.getDeath().are_equal(self.death):
|
||||||
|
140
gramps/src/SourceView.py
Normal file
140
gramps/src/SourceView.py
Normal file
@ -0,0 +1,140 @@
|
|||||||
|
#
|
||||||
|
# Gramps - a GTK+/GNOME based genealogy program
|
||||||
|
#
|
||||||
|
# Copyright (C) 2001 Donald N. Allingham
|
||||||
|
#
|
||||||
|
# This program is free software; you can redistribute it and/or modify
|
||||||
|
# it under the terms of the GNU General Public License as published by
|
||||||
|
# the Free Software Foundation; either version 2 of the License, or
|
||||||
|
# (at your option) any later version.
|
||||||
|
#
|
||||||
|
# This program is distributed in the hope that it will be useful,
|
||||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
# GNU General Public License for more details.
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU General Public License
|
||||||
|
# along with this program; if not, write to the Free Software
|
||||||
|
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
|
#
|
||||||
|
|
||||||
|
import GTK
|
||||||
|
import GDK
|
||||||
|
import gnome.ui
|
||||||
|
import gtk
|
||||||
|
import string
|
||||||
|
|
||||||
|
from RelLib import *
|
||||||
|
import intl
|
||||||
|
import EditSource
|
||||||
|
import utils
|
||||||
|
|
||||||
|
_ = intl.gettext
|
||||||
|
|
||||||
|
class SourceView:
|
||||||
|
def __init__(self,db,source_list,update):
|
||||||
|
self.source_list = source_list
|
||||||
|
self.db = db
|
||||||
|
self.update = update
|
||||||
|
|
||||||
|
def load_sources(self):
|
||||||
|
self.source_list.clear()
|
||||||
|
self.source_list.freeze()
|
||||||
|
|
||||||
|
if len(self.source_list.selection) > 0:
|
||||||
|
current_row = self.source_list.selection[0]
|
||||||
|
else:
|
||||||
|
current_row = 0
|
||||||
|
|
||||||
|
index = 0
|
||||||
|
for src in self.db.getSourceMap().values():
|
||||||
|
self.source_list.append([src.getTitle(),src.getAuthor()])
|
||||||
|
self.source_list.set_row_data(index,src)
|
||||||
|
index = index + 1
|
||||||
|
|
||||||
|
if index > 0:
|
||||||
|
self.source_list.select_row(current_row,0)
|
||||||
|
self.source_list.moveto(current_row)
|
||||||
|
|
||||||
|
self.source_list.thaw()
|
||||||
|
|
||||||
|
def on_button_press_event(self,obj,event):
|
||||||
|
if event.button == 1 and event.type == GDK._2BUTTON_PRESS:
|
||||||
|
if len(obj.selection) > 0:
|
||||||
|
index = obj.selection[0]
|
||||||
|
source = obj.get_row_data(index)
|
||||||
|
EditSource.EditSource(source,self.db,update_display_after_edit)
|
||||||
|
|
||||||
|
def on_add_source_clicked(self,obj):
|
||||||
|
EditSource.EditSource(Source(),self.db,self.new_source_after_edit)
|
||||||
|
|
||||||
|
def on_delete_source_clicked(self,obj):
|
||||||
|
import EditSource
|
||||||
|
|
||||||
|
if len(obj.selection) == 0:
|
||||||
|
return
|
||||||
|
else:
|
||||||
|
index = obj.selection[0]
|
||||||
|
|
||||||
|
source = obj.get_row_data(index)
|
||||||
|
|
||||||
|
if self.is_source_used(source):
|
||||||
|
msg = _("This source is currently being used. Delete anyway?")
|
||||||
|
ans = EditSource.DelSrcQuery(source,database,update_display)
|
||||||
|
GnomeQuestionDialog(msg,ans.query_response)
|
||||||
|
else:
|
||||||
|
map = self.db.getSourceMap()
|
||||||
|
del map[source.getId()]
|
||||||
|
utils.modified()
|
||||||
|
self.update(0)
|
||||||
|
|
||||||
|
def is_source_used(self,source):
|
||||||
|
for p in self.db.getPlaceMap().values():
|
||||||
|
for sref in p.getSourceRefList():
|
||||||
|
if sref.getBase() == source:
|
||||||
|
return 1
|
||||||
|
for p in self.db.getPersonMap().values():
|
||||||
|
for v in p.getEventList() + [p.getBirth(), p.getDeath()]:
|
||||||
|
for sref in v.getSourceRefList():
|
||||||
|
if sref.getBase() == source:
|
||||||
|
return 1
|
||||||
|
for v in p.getAttributeList():
|
||||||
|
for sref in v.getSourceRefList():
|
||||||
|
if sref.getBase() == source:
|
||||||
|
return 1
|
||||||
|
for v in p.getAlternateNames() + [p.getPrimaryName()]:
|
||||||
|
for sref in v.getSourceRefList():
|
||||||
|
if sref.getBase() == source:
|
||||||
|
return 1
|
||||||
|
for v in p.getAddressList():
|
||||||
|
for sref in v.getSourceRefList():
|
||||||
|
if sref.getBase() == source:
|
||||||
|
return 1
|
||||||
|
for p in self.db.getObjectMap().values():
|
||||||
|
for sref in p.getSourceRefList():
|
||||||
|
if sref.getBase() == source:
|
||||||
|
return 1
|
||||||
|
for p in self.db.getFamilyMap().values():
|
||||||
|
for v in p.getEventList():
|
||||||
|
for sref in v.getSourceRefList():
|
||||||
|
if sref.getBase() == source:
|
||||||
|
return 1
|
||||||
|
for v in p.getAttributeList():
|
||||||
|
for sref in v.getSourceRefList():
|
||||||
|
if sref.getBase() == source:
|
||||||
|
return 1
|
||||||
|
return 0
|
||||||
|
|
||||||
|
def on_edit_source_clicked(self,obj):
|
||||||
|
if len(obj.selection) > 0:
|
||||||
|
index = obj.selection[0]
|
||||||
|
source = obj.get_row_data(index)
|
||||||
|
EditSource.EditSource(source,self.db,self.update_display_after_edit)
|
||||||
|
|
||||||
|
def new_source_after_edit(self,source):
|
||||||
|
self.db.addSource(source)
|
||||||
|
self.update(0)
|
||||||
|
|
||||||
|
def update_display_after_edit(self,place):
|
||||||
|
self.update(0)
|
||||||
|
|
@ -53,6 +53,8 @@ import libglade
|
|||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
from RelLib import *
|
from RelLib import *
|
||||||
from PedView import PedigreeView
|
from PedView import PedigreeView
|
||||||
|
from PlaceView import PlaceView
|
||||||
|
from SourceView import SourceView
|
||||||
|
|
||||||
import ReadXML
|
import ReadXML
|
||||||
import Filter
|
import Filter
|
||||||
@ -94,6 +96,7 @@ id2col = {}
|
|||||||
alt2col = {}
|
alt2col = {}
|
||||||
|
|
||||||
pedigree_view = None
|
pedigree_view = None
|
||||||
|
place_view = None
|
||||||
|
|
||||||
bookmarks = None
|
bookmarks = None
|
||||||
topWindow = None
|
topWindow = None
|
||||||
@ -101,8 +104,6 @@ statusbar = None
|
|||||||
gtop = None
|
gtop = None
|
||||||
notebook = None
|
notebook = None
|
||||||
person_list = None
|
person_list = None
|
||||||
source_list = None
|
|
||||||
place_list = None
|
|
||||||
media_list = None
|
media_list = None
|
||||||
mid = None
|
mid = None
|
||||||
mtype = None
|
mtype = None
|
||||||
@ -116,13 +117,6 @@ idArrow = None
|
|||||||
deathArrow = None
|
deathArrow = None
|
||||||
dateArrow = None
|
dateArrow = None
|
||||||
|
|
||||||
place_arrow = None
|
|
||||||
place_id_arrow= None
|
|
||||||
city_arrow = None
|
|
||||||
county_arrow = None
|
|
||||||
state_arrow = None
|
|
||||||
country_arrow = None
|
|
||||||
|
|
||||||
merge_button = None
|
merge_button = None
|
||||||
sort_column = 5
|
sort_column = 5
|
||||||
sort_direct = SORT_ASCENDING
|
sort_direct = SORT_ASCENDING
|
||||||
@ -181,14 +175,7 @@ def on_merge_activate(obj):
|
|||||||
p2 = person_list.get_row_data(person_list.selection[1])
|
p2 = person_list.get_row_data(person_list.selection[1])
|
||||||
MergeData.MergePeople(database,p1[0],p2[0],merge_update)
|
MergeData.MergePeople(database,p1[0],p2[0],merge_update)
|
||||||
elif page == 4:
|
elif page == 4:
|
||||||
if len(place_list.selection) != 2:
|
place_view.merge()
|
||||||
msg = _("Exactly two places must be selected to perform a merge")
|
|
||||||
GnomeErrorDialog(msg)
|
|
||||||
else:
|
|
||||||
import MergeData
|
|
||||||
p1 = place_list.get_row_data(place_list.selection[0])
|
|
||||||
p2 = place_list.get_row_data(place_list.selection[1])
|
|
||||||
MergeData.MergePlaces(database,p1,p2,load_places)
|
|
||||||
|
|
||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
#
|
#
|
||||||
@ -419,8 +406,8 @@ def new_database_response(val):
|
|||||||
change_active_person(None)
|
change_active_person(None)
|
||||||
person_list.clear()
|
person_list.clear()
|
||||||
load_family()
|
load_family()
|
||||||
load_sources()
|
source_view.load_sources()
|
||||||
load_places()
|
place_view.load_places()
|
||||||
load_media()
|
load_media()
|
||||||
|
|
||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
@ -453,8 +440,8 @@ def full_update():
|
|||||||
clist.set_column_visibility(c_birth_order,Config.index_visible)
|
clist.set_column_visibility(c_birth_order,Config.index_visible)
|
||||||
apply_filter()
|
apply_filter()
|
||||||
load_family()
|
load_family()
|
||||||
load_sources()
|
source_view.load_sources()
|
||||||
load_places()
|
place_view.load_places()
|
||||||
pedigree_view.load_canvas(active_person)
|
pedigree_view.load_canvas(active_person)
|
||||||
load_media()
|
load_media()
|
||||||
|
|
||||||
@ -471,210 +458,12 @@ def update_display(changed):
|
|||||||
elif page == 2:
|
elif page == 2:
|
||||||
pedigree_view.load_canvas(active_person)
|
pedigree_view.load_canvas(active_person)
|
||||||
elif page == 3:
|
elif page == 3:
|
||||||
load_sources()
|
source_view.load_sources()
|
||||||
elif page == 4:
|
elif page == 4:
|
||||||
load_places()
|
place_view.load_places()
|
||||||
else:
|
else:
|
||||||
load_media()
|
load_media()
|
||||||
|
|
||||||
#-------------------------------------------------------------------------
|
|
||||||
#
|
|
||||||
#
|
|
||||||
#
|
|
||||||
#-------------------------------------------------------------------------
|
|
||||||
def load_sources():
|
|
||||||
source_list.clear()
|
|
||||||
source_list.freeze()
|
|
||||||
|
|
||||||
if len(source_list.selection) > 0:
|
|
||||||
current_row = source_list.selection[0]
|
|
||||||
else:
|
|
||||||
current_row = 0
|
|
||||||
|
|
||||||
index = 0
|
|
||||||
for src in database.getSourceMap().values():
|
|
||||||
source_list.append([src.getTitle(),src.getAuthor()])
|
|
||||||
source_list.set_row_data(index,src)
|
|
||||||
index = index + 1
|
|
||||||
|
|
||||||
if index > 0:
|
|
||||||
source_list.select_row(current_row,0)
|
|
||||||
source_list.moveto(current_row)
|
|
||||||
|
|
||||||
source_list.thaw()
|
|
||||||
|
|
||||||
#-------------------------------------------------------------------------
|
|
||||||
#
|
|
||||||
#
|
|
||||||
#
|
|
||||||
#-------------------------------------------------------------------------
|
|
||||||
def on_src_list_button_press_event(obj,event):
|
|
||||||
if event.button == 1 and event.type == GDK._2BUTTON_PRESS:
|
|
||||||
if len(obj.selection) > 0:
|
|
||||||
index = obj.selection[0]
|
|
||||||
source = obj.get_row_data(index)
|
|
||||||
EditSource.EditSource(source,database,update_display_after_edit)
|
|
||||||
|
|
||||||
#-------------------------------------------------------------------------
|
|
||||||
#
|
|
||||||
#
|
|
||||||
#
|
|
||||||
#-------------------------------------------------------------------------
|
|
||||||
def on_place_list_button_press_event(obj,event):
|
|
||||||
if event.button == 1 and event.type == GDK._2BUTTON_PRESS:
|
|
||||||
if len(obj.selection) > 0:
|
|
||||||
index = obj.selection[0]
|
|
||||||
place = obj.get_row_data(index)
|
|
||||||
EditPlace.EditPlace(place,database,update_display_after_edit)
|
|
||||||
|
|
||||||
#-------------------------------------------------------------------------
|
|
||||||
#
|
|
||||||
#
|
|
||||||
#
|
|
||||||
#-------------------------------------------------------------------------
|
|
||||||
def on_add_source_clicked(obj):
|
|
||||||
EditSource.EditSource(Source(),database,new_source_after_edit)
|
|
||||||
|
|
||||||
#-------------------------------------------------------------------------
|
|
||||||
#
|
|
||||||
#
|
|
||||||
#
|
|
||||||
#-------------------------------------------------------------------------
|
|
||||||
def on_add_place_clicked(obj):
|
|
||||||
EditPlace.EditPlace(Place(),database,new_place_after_edit)
|
|
||||||
|
|
||||||
#-------------------------------------------------------------------------
|
|
||||||
#
|
|
||||||
#
|
|
||||||
#
|
|
||||||
#-------------------------------------------------------------------------
|
|
||||||
def on_delete_place_clicked(obj):
|
|
||||||
if len(obj.selection) == 0:
|
|
||||||
return
|
|
||||||
elif len(obj.selection) > 1:
|
|
||||||
msg = _("Currently, you can only delete one place at a time")
|
|
||||||
topWindow.error(msg)
|
|
||||||
return
|
|
||||||
else:
|
|
||||||
index = obj.selection[0]
|
|
||||||
|
|
||||||
used = 0
|
|
||||||
place = obj.get_row_data(index)
|
|
||||||
for p in database.getPersonMap().values():
|
|
||||||
for event in [p.getBirth(), p.getDeath()] + p.getEventList():
|
|
||||||
if event.getPlace() == place:
|
|
||||||
used = 1
|
|
||||||
for f in database.getFamilyMap().values():
|
|
||||||
for event in f.getEventList():
|
|
||||||
if event.getPlace() == place:
|
|
||||||
used = 1
|
|
||||||
|
|
||||||
if used == 1:
|
|
||||||
import EditPlace
|
|
||||||
ans = EditPlace.DeletePlaceQuery(place,database,update_display)
|
|
||||||
msg = _("This place is currently being used. Delete anyway?")
|
|
||||||
GnomeQuestionDialog(msg,ans.query_response)
|
|
||||||
else:
|
|
||||||
map = database.getPlaceMap()
|
|
||||||
del map[place.getId()]
|
|
||||||
utils.modified()
|
|
||||||
update_display(0)
|
|
||||||
|
|
||||||
#-------------------------------------------------------------------------
|
|
||||||
#
|
|
||||||
#
|
|
||||||
#
|
|
||||||
#-------------------------------------------------------------------------
|
|
||||||
def on_delete_source_clicked(obj):
|
|
||||||
import EditSource
|
|
||||||
|
|
||||||
if len(obj.selection) == 0:
|
|
||||||
return
|
|
||||||
else:
|
|
||||||
index = obj.selection[0]
|
|
||||||
|
|
||||||
source = obj.get_row_data(index)
|
|
||||||
|
|
||||||
|
|
||||||
if is_source_used(source):
|
|
||||||
msg = _("This source is currently being used. Delete anyway?")
|
|
||||||
ans = EditSource.DelSrcQuery(source,database,update_display)
|
|
||||||
GnomeQuestionDialog(msg,ans.query_response)
|
|
||||||
else:
|
|
||||||
map = database.getSourceMap()
|
|
||||||
del map[source.getId()]
|
|
||||||
utils.modified()
|
|
||||||
update_display(0)
|
|
||||||
|
|
||||||
def is_source_used(source):
|
|
||||||
for p in database.getPlaceMap().values():
|
|
||||||
for sref in p.getSourceRefList():
|
|
||||||
if sref.getBase() == source:
|
|
||||||
return 1
|
|
||||||
for p in database.getPersonMap().values():
|
|
||||||
for v in p.getEventList() + [p.getBirth(), p.getDeath()]:
|
|
||||||
for sref in v.getSourceRefList():
|
|
||||||
if sref.getBase() == source:
|
|
||||||
return 1
|
|
||||||
for v in p.getAttributeList():
|
|
||||||
for sref in v.getSourceRefList():
|
|
||||||
if sref.getBase() == source:
|
|
||||||
return 1
|
|
||||||
for v in p.getAlternateNames() + [p.getPrimaryName()]:
|
|
||||||
for sref in v.getSourceRefList():
|
|
||||||
if sref.getBase() == source:
|
|
||||||
return 1
|
|
||||||
for v in p.getAddressList():
|
|
||||||
for sref in v.getSourceRefList():
|
|
||||||
if sref.getBase() == source:
|
|
||||||
return 1
|
|
||||||
for p in database.getObjectMap().values():
|
|
||||||
for sref in p.getSourceRefList():
|
|
||||||
if sref.getBase() == source:
|
|
||||||
return 1
|
|
||||||
for p in database.getFamilyMap().values():
|
|
||||||
for v in p.getEventList():
|
|
||||||
for sref in v.getSourceRefList():
|
|
||||||
if sref.getBase() == source:
|
|
||||||
return 1
|
|
||||||
for v in p.getAttributeList():
|
|
||||||
for sref in v.getSourceRefList():
|
|
||||||
if sref.getBase() == source:
|
|
||||||
return 1
|
|
||||||
return 0
|
|
||||||
|
|
||||||
#-------------------------------------------------------------------------
|
|
||||||
#
|
|
||||||
# Edit callbacks
|
|
||||||
#
|
|
||||||
#-------------------------------------------------------------------------
|
|
||||||
def on_edit_source_clicked(obj):
|
|
||||||
if len(obj.selection) > 0:
|
|
||||||
index = obj.selection[0]
|
|
||||||
source = obj.get_row_data(index)
|
|
||||||
EditSource.EditSource(source,database,update_display_after_edit)
|
|
||||||
|
|
||||||
def on_edit_place_clicked(obj):
|
|
||||||
"""Display the selected places in the EditPlace display"""
|
|
||||||
if len(obj.selection) > 5:
|
|
||||||
msg = _("You requested too many places to edit at the same time")
|
|
||||||
GnomeErrorDialog(msg)
|
|
||||||
else:
|
|
||||||
for p in obj.selection:
|
|
||||||
place = obj.get_row_data(p)
|
|
||||||
EditPlace.EditPlace(place,database,update_display_after_edit)
|
|
||||||
|
|
||||||
def new_source_after_edit(source):
|
|
||||||
database.addSource(source)
|
|
||||||
update_display(0)
|
|
||||||
|
|
||||||
def new_place_after_edit(place):
|
|
||||||
database.addPlace(place)
|
|
||||||
update_display(0)
|
|
||||||
|
|
||||||
def update_display_after_edit(place):
|
|
||||||
update_display(0)
|
|
||||||
|
|
||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
#
|
#
|
||||||
#
|
#
|
||||||
@ -965,41 +754,6 @@ def on_person_list_click_column(obj,column):
|
|||||||
row = person_list.find_row_from_data(id2col[active_person])
|
row = person_list.find_row_from_data(id2col[active_person])
|
||||||
person_list.moveto(row)
|
person_list.moveto(row)
|
||||||
|
|
||||||
|
|
||||||
def on_place_list_click_column(obj,column):
|
|
||||||
global p_sort_direct, p_sort_column
|
|
||||||
|
|
||||||
obj.freeze()
|
|
||||||
if len(obj.selection):
|
|
||||||
sel = obj.get_row_data(obj.selection[0])
|
|
||||||
else:
|
|
||||||
sel = None
|
|
||||||
|
|
||||||
place_arrows = [ place_arrow, place_id_arrow, city_arrow,
|
|
||||||
county_arrow, state_arrow, country_arrow ]
|
|
||||||
|
|
||||||
for a in place_arrows:
|
|
||||||
a.hide()
|
|
||||||
arrow = place_arrows[column]
|
|
||||||
if p_sort_column == column:
|
|
||||||
if p_sort_direct == SORT_DESCENDING:
|
|
||||||
p_sort_direct = SORT_ASCENDING
|
|
||||||
arrow.set(GTK.ARROW_DOWN,2)
|
|
||||||
else:
|
|
||||||
p_sort_direct = SORT_DESCENDING
|
|
||||||
arrow.set(GTK.ARROW_UP,2)
|
|
||||||
else:
|
|
||||||
p_sort_direct = SORT_ASCENDING
|
|
||||||
arrow.set(GTK.ARROW_DOWN,2)
|
|
||||||
p_sort_column = column
|
|
||||||
place_list.set_sort_type(p_sort_direct)
|
|
||||||
place_list.set_sort_column(p_sort_column + 6)
|
|
||||||
arrow.show()
|
|
||||||
place_list.sort()
|
|
||||||
if sel:
|
|
||||||
place_list.moveto(place_list.find_row_from_data(sel))
|
|
||||||
obj.thaw()
|
|
||||||
|
|
||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
#
|
#
|
||||||
#
|
#
|
||||||
@ -1405,53 +1159,14 @@ def on_notebook1_switch_page(obj,junk,page):
|
|||||||
pedigree_view.load_canvas(active_person)
|
pedigree_view.load_canvas(active_person)
|
||||||
elif page == 3:
|
elif page == 3:
|
||||||
merge_button.set_sensitive(0)
|
merge_button.set_sensitive(0)
|
||||||
load_sources()
|
source_view.load_sources()
|
||||||
elif page == 4:
|
elif page == 4:
|
||||||
merge_button.set_sensitive(1)
|
merge_button.set_sensitive(1)
|
||||||
load_places()
|
place_view.load_places()
|
||||||
elif page == 5:
|
elif page == 5:
|
||||||
merge_button.set_sensitive(0)
|
merge_button.set_sensitive(0)
|
||||||
load_media()
|
load_media()
|
||||||
|
|
||||||
#-------------------------------------------------------------------------
|
|
||||||
#
|
|
||||||
#
|
|
||||||
#
|
|
||||||
#-------------------------------------------------------------------------
|
|
||||||
def load_places():
|
|
||||||
place_list.freeze()
|
|
||||||
place_list.clear()
|
|
||||||
|
|
||||||
if len(place_list.selection) == 0:
|
|
||||||
current_row = 0
|
|
||||||
else:
|
|
||||||
current_row = place_list.selection[0]
|
|
||||||
|
|
||||||
index = 0
|
|
||||||
places = database.getPlaceMap().values()
|
|
||||||
|
|
||||||
u = string.upper
|
|
||||||
for src in places:
|
|
||||||
title = src.get_title()
|
|
||||||
id = src.getId()
|
|
||||||
mloc = src.get_main_location()
|
|
||||||
city = mloc.get_city()
|
|
||||||
county = mloc.get_county()
|
|
||||||
state = mloc.get_state()
|
|
||||||
country = mloc.get_country()
|
|
||||||
place_list.append([title,id,city,county,state,country,
|
|
||||||
u(title), u(id), u(city), u(county), u(state), u(country)])
|
|
||||||
place_list.set_row_data(index,src)
|
|
||||||
index = index + 1
|
|
||||||
|
|
||||||
place_list.sort()
|
|
||||||
|
|
||||||
if index > 0:
|
|
||||||
place_list.select_row(current_row,0)
|
|
||||||
place_list.moveto(current_row)
|
|
||||||
|
|
||||||
place_list.thaw()
|
|
||||||
|
|
||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
#
|
#
|
||||||
#
|
#
|
||||||
@ -2285,18 +2000,17 @@ def on_media_list_drag_data_received(w, context, x, y, data, info, time):
|
|||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
|
|
||||||
def main(arg):
|
def main(arg):
|
||||||
global pedigree_view
|
global pedigree_view, place_view, source_view
|
||||||
global database, gtop
|
global database, gtop
|
||||||
global statusbar,notebook
|
global statusbar,notebook
|
||||||
global person_list, source_list, place_list, canvas, media_list
|
global person_list, source_list, canvas, media_list
|
||||||
global topWindow, preview, merge_button
|
global topWindow, preview, merge_button
|
||||||
global nameArrow, dateArrow, deathArrow, idArrow
|
global nameArrow, dateArrow, deathArrow, idArrow
|
||||||
global cNameArrow, cDateArrow
|
global cNameArrow, cDateArrow
|
||||||
global place_arrow, place_id_arrow, city_arrow, county_arrow
|
|
||||||
global state_arrow, country_arrow
|
|
||||||
global mid, mtype, mdesc, mpath, mdetails
|
global mid, mtype, mdesc, mpath, mdetails
|
||||||
|
|
||||||
rc_parse(const.gtkrcFile)
|
rc_parse(const.gtkrcFile)
|
||||||
|
database = RelDataBase()
|
||||||
|
|
||||||
Plugins.load_plugins(const.pluginsDir)
|
Plugins.load_plugins(const.pluginsDir)
|
||||||
Plugins.load_plugins(os.path.expanduser("~/.gramps/plugins"))
|
Plugins.load_plugins(os.path.expanduser("~/.gramps/plugins"))
|
||||||
@ -2314,7 +2028,6 @@ def main(arg):
|
|||||||
topWindow = gtop.get_widget("gramps")
|
topWindow = gtop.get_widget("gramps")
|
||||||
person_list = gtop.get_widget("person_list")
|
person_list = gtop.get_widget("person_list")
|
||||||
source_list = gtop.get_widget("source_list")
|
source_list = gtop.get_widget("source_list")
|
||||||
place_list = gtop.get_widget("place_list")
|
|
||||||
media_list = gtop.get_widget("media_list")
|
media_list = gtop.get_widget("media_list")
|
||||||
mid = gtop.get_widget("mid")
|
mid = gtop.get_widget("mid")
|
||||||
mtype = gtop.get_widget("mtype")
|
mtype = gtop.get_widget("mtype")
|
||||||
@ -2329,17 +2042,13 @@ def main(arg):
|
|||||||
dateArrow = gtop.get_widget("dateSort")
|
dateArrow = gtop.get_widget("dateSort")
|
||||||
deathArrow = gtop.get_widget("deathSort")
|
deathArrow = gtop.get_widget("deathSort")
|
||||||
merge_button= gtop.get_widget("merge")
|
merge_button= gtop.get_widget("merge")
|
||||||
place_arrow = gtop.get_widget("place_arrow")
|
|
||||||
place_id_arrow= gtop.get_widget("place_id_arrow")
|
|
||||||
city_arrow = gtop.get_widget("city_arrow")
|
|
||||||
county_arrow = gtop.get_widget("county_arrow")
|
|
||||||
state_arrow = gtop.get_widget("state_arrow")
|
|
||||||
country_arrow = gtop.get_widget("country_arrow")
|
|
||||||
|
|
||||||
canvas = gtop.get_widget("canvas1")
|
canvas = gtop.get_widget("canvas1")
|
||||||
pedigree_view = PedigreeView(canvas,modify_statusbar,\
|
pedigree_view = PedigreeView(canvas,modify_statusbar,\
|
||||||
statusbar,change_active_person,\
|
statusbar,change_active_person,\
|
||||||
load_person)
|
load_person)
|
||||||
|
place_view = PlaceView(database,gtop,update_display)
|
||||||
|
source_view = SourceView(database,source_list,update_display)
|
||||||
|
|
||||||
t = [ ('STRING', 0, 0),
|
t = [ ('STRING', 0, 0),
|
||||||
('text/plain',0,0),
|
('text/plain',0,0),
|
||||||
@ -2356,15 +2065,6 @@ def main(arg):
|
|||||||
person_list.set_sort_column(sort_column)
|
person_list.set_sort_column(sort_column)
|
||||||
person_list.set_sort_type(sort_direct)
|
person_list.set_sort_type(sort_direct)
|
||||||
|
|
||||||
place_list.set_column_visibility(6,0)
|
|
||||||
place_list.set_column_visibility(7,0)
|
|
||||||
place_list.set_column_visibility(8,0)
|
|
||||||
place_list.set_column_visibility(9,0)
|
|
||||||
place_list.set_column_visibility(10,0)
|
|
||||||
place_list.set_column_visibility(11,0)
|
|
||||||
place_list.set_sort_column(p_sort_column +6 )
|
|
||||||
place_list.set_sort_type(p_sort_direct)
|
|
||||||
|
|
||||||
fw = gtop.get_widget('filter')
|
fw = gtop.get_widget('filter')
|
||||||
filter_list.set_menu(Filter.build_filter_menu(on_filter_name_changed,fw))
|
filter_list.set_menu(Filter.build_filter_menu(on_filter_name_changed,fw))
|
||||||
|
|
||||||
@ -2382,8 +2082,8 @@ def main(arg):
|
|||||||
"on_add_bookmark_activate" : on_add_bookmark_activate,
|
"on_add_bookmark_activate" : on_add_bookmark_activate,
|
||||||
"on_add_child_clicked" : on_add_child_clicked,
|
"on_add_child_clicked" : on_add_child_clicked,
|
||||||
"on_add_new_child_clicked" : on_add_new_child_clicked,
|
"on_add_new_child_clicked" : on_add_new_child_clicked,
|
||||||
"on_add_place_clicked" : on_add_place_clicked,
|
"on_add_place_clicked" : place_view.on_add_place_clicked,
|
||||||
"on_add_source_clicked" : on_add_source_clicked,
|
"on_add_source_clicked" : source_view.on_add_source_clicked,
|
||||||
"on_add_sp_clicked" : on_add_sp_clicked,
|
"on_add_sp_clicked" : on_add_sp_clicked,
|
||||||
"on_addperson_clicked" : load_new_person,
|
"on_addperson_clicked" : load_new_person,
|
||||||
"on_apply_filter_clicked" : on_apply_filter_clicked,
|
"on_apply_filter_clicked" : on_apply_filter_clicked,
|
||||||
@ -2398,8 +2098,8 @@ def main(arg):
|
|||||||
"on_default_person_activate" : on_default_person_activate,
|
"on_default_person_activate" : on_default_person_activate,
|
||||||
"on_delete_parents_clicked" : on_delete_parents_clicked,
|
"on_delete_parents_clicked" : on_delete_parents_clicked,
|
||||||
"on_delete_person_clicked" : on_delete_person_clicked,
|
"on_delete_person_clicked" : on_delete_person_clicked,
|
||||||
"on_delete_place_clicked" : on_delete_place_clicked,
|
"on_delete_place_clicked" : place_view.on_delete_place_clicked,
|
||||||
"on_delete_source_clicked" : on_delete_source_clicked,
|
"on_delete_source_clicked" : source_view.on_delete_source_clicked,
|
||||||
"on_delete_media_clicked" : on_delete_media_clicked,
|
"on_delete_media_clicked" : on_delete_media_clicked,
|
||||||
"on_delete_sp_clicked" : on_delete_sp_clicked,
|
"on_delete_sp_clicked" : on_delete_sp_clicked,
|
||||||
"on_edit_active_person" : load_active_person,
|
"on_edit_active_person" : load_active_person,
|
||||||
@ -2408,8 +2108,8 @@ def main(arg):
|
|||||||
"on_edit_father_clicked" : on_edit_father_clicked,
|
"on_edit_father_clicked" : on_edit_father_clicked,
|
||||||
"on_edit_media_clicked" : on_edit_media_clicked,
|
"on_edit_media_clicked" : on_edit_media_clicked,
|
||||||
"on_edit_mother_clicked" : on_edit_mother_clicked,
|
"on_edit_mother_clicked" : on_edit_mother_clicked,
|
||||||
"on_edit_place_clicked" : on_edit_place_clicked,
|
"on_edit_place_clicked" : place_view.on_edit_place_clicked,
|
||||||
"on_edit_source_clicked" : on_edit_source_clicked,
|
"on_edit_source_clicked" : source_view.on_edit_source_clicked,
|
||||||
"on_edit_sp_clicked" : on_edit_sp_clicked,
|
"on_edit_sp_clicked" : on_edit_sp_clicked,
|
||||||
"on_edit_spouse_clicked" : on_edit_spouse_clicked,
|
"on_edit_spouse_clicked" : on_edit_spouse_clicked,
|
||||||
"on_exit_activate" : on_exit_activate,
|
"on_exit_activate" : on_exit_activate,
|
||||||
@ -2428,8 +2128,8 @@ def main(arg):
|
|||||||
"on_person_list_button_press" : on_person_list_button_press,
|
"on_person_list_button_press" : on_person_list_button_press,
|
||||||
"on_person_list_click_column" : on_person_list_click_column,
|
"on_person_list_click_column" : on_person_list_click_column,
|
||||||
"on_person_list_select_row" : on_person_list_select_row,
|
"on_person_list_select_row" : on_person_list_select_row,
|
||||||
"on_place_list_button_press_event" : on_place_list_button_press_event,
|
"on_place_list_button_press_event" : place_view.on_button_press_event,
|
||||||
"on_place_list_click_column" : on_place_list_click_column,
|
"on_place_list_click_column" : place_view.on_click_column,
|
||||||
"on_main_key_release_event" : on_main_key_release_event,
|
"on_main_key_release_event" : on_main_key_release_event,
|
||||||
"on_add_media_clicked" : create_add_dialog,
|
"on_add_media_clicked" : create_add_dialog,
|
||||||
"on_media_activate" : on_media_activate,
|
"on_media_activate" : on_media_activate,
|
||||||
@ -2445,7 +2145,7 @@ def main(arg):
|
|||||||
"on_revert_activate" : on_revert_activate,
|
"on_revert_activate" : on_revert_activate,
|
||||||
"on_save_activate" : on_save_activate,
|
"on_save_activate" : on_save_activate,
|
||||||
"on_save_as_activate" : on_save_as_activate,
|
"on_save_as_activate" : on_save_as_activate,
|
||||||
"on_source_list_button_press_event" : on_src_list_button_press_event,
|
"on_source_list_button_press_event" : source_view.on_button_press_event,
|
||||||
"on_sources_activate" : on_sources_activate,
|
"on_sources_activate" : on_sources_activate,
|
||||||
"on_spouselist_changed" : on_spouselist_changed,
|
"on_spouselist_changed" : on_spouselist_changed,
|
||||||
"on_swap_clicked" : on_swap_clicked,
|
"on_swap_clicked" : on_swap_clicked,
|
||||||
@ -2453,7 +2153,6 @@ def main(arg):
|
|||||||
"on_writing_extensions_activate" : on_writing_extensions_activate,
|
"on_writing_extensions_activate" : on_writing_extensions_activate,
|
||||||
})
|
})
|
||||||
|
|
||||||
database = RelDataBase()
|
|
||||||
Config.loadConfig(full_update)
|
Config.loadConfig(full_update)
|
||||||
person_list.set_column_visibility(1,Config.id_visible)
|
person_list.set_column_visibility(1,Config.id_visible)
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user