* src/GrampsBSDDB.py: add upgrade to version 3 for new Name type
* src/NameEdit.py: add date editor field * src/ReadXML.py: read date field attached to a name * src/WriteXML.py: write date field attached to a name * src/RelLib.py: add date field to Name * src/gramps.glade: add date editor field to Name Editor dialog svn: r4121
This commit is contained in:
parent
49e549b5ae
commit
17dcd45d3c
16
ChangeLog
16
ChangeLog
@ -1,10 +1,18 @@
|
|||||||
|
2005-03-06 Don Allingham <dallingham@users.sourceforge.net>
|
||||||
|
* src/GrampsBSDDB.py: add upgrade to version 3 for new Name type
|
||||||
|
* src/NameEdit.py: add date editor field
|
||||||
|
* src/ReadXML.py: read date field attached to a name
|
||||||
|
* src/WriteXML.py: write date field attached to a name
|
||||||
|
* src/RelLib.py: add date field to Name
|
||||||
|
* src/gramps.glade: add date editor field to Name Editor dialog
|
||||||
|
|
||||||
2005-03-06 Alex Roitman <shura@alex.neuro.umn.edu>
|
2005-03-06 Alex Roitman <shura@alex.neuro.umn.edu>
|
||||||
* src/EditSource.py (display_references): List source's references
|
* src/EditSource.py (display_references): List source's references
|
||||||
from personal and family gallery objects.
|
from personal and family gallery objects.
|
||||||
|
|
||||||
2005-03-04 Alex Roitman <shura@alex.neuro.umn.edu>
|
2005-03-04 Alex Roitman <shura@alex.neuro.umn.edu>
|
||||||
* src/GenericFilter.py (HasAttribute.apply): Make work when no value
|
* src/GenericFilter.py (HasAttribute.apply): Make work when no value
|
||||||
is given; (HasFamilyAttribute.apply): Make work when no value is given.
|
is given; (HasFamilyAttribute.apply): Make work when no value is given.
|
||||||
|
|
||||||
2005-03-03 Alex Roitman <shura@alex.neuro.umn.edu>
|
2005-03-03 Alex Roitman <shura@alex.neuro.umn.edu>
|
||||||
* src/GenericFilter.py (HasAttribute.apply): Fix the rule.
|
* src/GenericFilter.py (HasAttribute.apply): Fix the rule.
|
||||||
|
@ -33,7 +33,7 @@ from RelLib import *
|
|||||||
from GrampsDbBase import *
|
from GrampsDbBase import *
|
||||||
from bsddb import dbshelve, db
|
from bsddb import dbshelve, db
|
||||||
|
|
||||||
_DBVERSION = 2
|
_DBVERSION = 3
|
||||||
|
|
||||||
def find_surname(key,data):
|
def find_surname(key,data):
|
||||||
return str(data[3].get_surname())
|
return str(data[3].get_surname())
|
||||||
@ -390,4 +390,18 @@ class GrampsBSDDB(GrampsDbBase):
|
|||||||
self.commit_person(person,None)
|
self.commit_person(person,None)
|
||||||
data = cursor.next()
|
data = cursor.next()
|
||||||
cursor.close()
|
cursor.close()
|
||||||
self.metadata['version'] = 2
|
if version < 3:
|
||||||
|
cursor = self.get_person_cursor()
|
||||||
|
data = cursor.first()
|
||||||
|
while data:
|
||||||
|
handle,info = data
|
||||||
|
person = Person()
|
||||||
|
person.unserialize(info)
|
||||||
|
|
||||||
|
person.primary_name.date = None
|
||||||
|
for name in person.alternate_names:
|
||||||
|
name.date = None
|
||||||
|
self.commit_person(person,None)
|
||||||
|
data = cursor.next()
|
||||||
|
cursor.close()
|
||||||
|
self.metadata['version'] = 3
|
||||||
|
@ -46,6 +46,8 @@ import AutoComp
|
|||||||
import Sources
|
import Sources
|
||||||
import RelLib
|
import RelLib
|
||||||
import NameDisplay
|
import NameDisplay
|
||||||
|
import DateEdit
|
||||||
|
import DateHandler
|
||||||
|
|
||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
#
|
#
|
||||||
@ -81,6 +83,13 @@ class NameEditor:
|
|||||||
self.suffix_field = self.top.get_widget("alt_suffix")
|
self.suffix_field = self.top.get_widget("alt_suffix")
|
||||||
self.patronymic_field = self.top.get_widget("patronymic")
|
self.patronymic_field = self.top.get_widget("patronymic")
|
||||||
self.combo = self.top.get_widget("alt_surname_list")
|
self.combo = self.top.get_widget("alt_surname_list")
|
||||||
|
self.date = self.top.get_widget('date')
|
||||||
|
self.date_obj = self.name.get_date_object()
|
||||||
|
self.date.set_text(DateHandler.displayer.display(self.date_obj))
|
||||||
|
|
||||||
|
self.date_check = DateEdit.DateEdit(
|
||||||
|
self.date_obj, self.date,
|
||||||
|
self.top.get_widget("date_stat"), self.window)
|
||||||
|
|
||||||
AutoComp.fill_combo(self.combo,self.parent.db.get_surname_list())
|
AutoComp.fill_combo(self.combo,self.parent.db.get_surname_list())
|
||||||
self.surname_field = self.combo.get_child()
|
self.surname_field = self.combo.get_child()
|
||||||
|
@ -154,7 +154,7 @@ def importData(database, filename, callback=None,cl=0,use_trans=True):
|
|||||||
for m_id in database.get_media_object_handles():
|
for m_id in database.get_media_object_handles():
|
||||||
mobject = database.get_object_from_handle(m_id)
|
mobject = database.get_object_from_handle(m_id)
|
||||||
oldfile = mobject.get_path()
|
oldfile = mobject.get_path()
|
||||||
if oldfile[0] != '/':
|
if oldfile and oldfile[0] != '/':
|
||||||
if first:
|
if first:
|
||||||
os.mkdir(img_dir)
|
os.mkdir(img_dir)
|
||||||
first = 0
|
first = 0
|
||||||
@ -979,6 +979,8 @@ class GrampsParser:
|
|||||||
dv = self.object.get_date_object()
|
dv = self.object.get_date_object()
|
||||||
elif self.address:
|
elif self.address:
|
||||||
dv = self.address.get_date_object()
|
dv = self.address.get_date_object()
|
||||||
|
elif self.name:
|
||||||
|
dv = self.name.get_date_object()
|
||||||
else:
|
else:
|
||||||
dv = self.event.get_date_object()
|
dv = self.event.get_date_object()
|
||||||
|
|
||||||
@ -1031,6 +1033,8 @@ class GrampsParser:
|
|||||||
dv = self.object.get_date_object()
|
dv = self.object.get_date_object()
|
||||||
elif self.address:
|
elif self.address:
|
||||||
dv = self.address.get_date_object()
|
dv = self.address.get_date_object()
|
||||||
|
elif self.name:
|
||||||
|
dv = self.name.get_date_object()
|
||||||
else:
|
else:
|
||||||
dv = self.event.get_date_object()
|
dv = self.event.get_date_object()
|
||||||
|
|
||||||
|
@ -2629,6 +2629,10 @@ class Name(DataObj):
|
|||||||
self.group_as = source.group_as
|
self.group_as = source.group_as
|
||||||
self.sort_as = source.sort_as
|
self.sort_as = source.sort_as
|
||||||
self.display_as = source.display_as
|
self.display_as = source.display_as
|
||||||
|
if source.date:
|
||||||
|
self.date = Date.Date(source.date)
|
||||||
|
else:
|
||||||
|
self.date = None
|
||||||
else:
|
else:
|
||||||
self.first_name = ""
|
self.first_name = ""
|
||||||
self.surname = ""
|
self.surname = ""
|
||||||
@ -2641,6 +2645,7 @@ class Name(DataObj):
|
|||||||
self.group_as = ""
|
self.group_as = ""
|
||||||
self.sort_as = self.DEF
|
self.sort_as = self.DEF
|
||||||
self.display_as = self.DEF
|
self.display_as = self.DEF
|
||||||
|
self.date = None
|
||||||
|
|
||||||
def set_group_as(self,name):
|
def set_group_as(self,name):
|
||||||
"""
|
"""
|
||||||
@ -2886,6 +2891,66 @@ class Name(DataObj):
|
|||||||
index += 1
|
index += 1
|
||||||
return True
|
return True
|
||||||
|
|
||||||
|
def set_date(self, date) :
|
||||||
|
"""
|
||||||
|
Sets the date of the L{Name} instance. The date is parsed into
|
||||||
|
a L{Date} instance.
|
||||||
|
|
||||||
|
@param date: String representation of a date. The locale specific
|
||||||
|
L{DateParser} is used to parse the string into a GRAMPS L{Date}
|
||||||
|
object.
|
||||||
|
@type date: str
|
||||||
|
"""
|
||||||
|
self.date = DateHandler.parser.parse(date)
|
||||||
|
|
||||||
|
def get_date(self) :
|
||||||
|
"""
|
||||||
|
Returns a string representation of the date of the L{Name} instance
|
||||||
|
based off the default date display format determined by the
|
||||||
|
locale's L{DateDisplay} instance.
|
||||||
|
|
||||||
|
@return: Returns a string representing the L{Name}'s date
|
||||||
|
@rtype: str
|
||||||
|
"""
|
||||||
|
if self.date:
|
||||||
|
return DateHandler.displayer.display(self.date)
|
||||||
|
return u""
|
||||||
|
|
||||||
|
def get_quote_date(self) :
|
||||||
|
"""
|
||||||
|
Returns a string representation of the date of the L{Name} instance
|
||||||
|
based off the default date display format determined by the
|
||||||
|
locale's L{DateDisplay} instance. The date is enclosed in
|
||||||
|
quotes if the L{Date} is not a valid date.
|
||||||
|
|
||||||
|
@return: Returns a string representing the L{Name}'s date
|
||||||
|
@rtype: str
|
||||||
|
"""
|
||||||
|
if self.date:
|
||||||
|
return DateHandler.displayer.quote_display(self.date)
|
||||||
|
return u""
|
||||||
|
|
||||||
|
def get_date_object(self):
|
||||||
|
"""
|
||||||
|
Returns the L{Date} object associated with the L{Name}.
|
||||||
|
|
||||||
|
@return: Returns a L{Name}'s L{Date} instance.
|
||||||
|
@rtype: L{Date}
|
||||||
|
"""
|
||||||
|
if not self.date:
|
||||||
|
self.date = Date.Date()
|
||||||
|
return self.date
|
||||||
|
|
||||||
|
def set_date_object(self,date):
|
||||||
|
"""
|
||||||
|
Sets the L{Date} object associated with the L{Name}.
|
||||||
|
|
||||||
|
@param date: L{Date} instance to be assigned to the L{Name}
|
||||||
|
@type date: L{Date}
|
||||||
|
"""
|
||||||
|
self.date = date
|
||||||
|
|
||||||
|
|
||||||
class Url:
|
class Url:
|
||||||
"""Contains information related to internet Uniform Resource Locators,
|
"""Contains information related to internet Uniform Resource Locators,
|
||||||
allowing gramps to store information about internet resources"""
|
allowing gramps to store information about internet resources"""
|
||||||
|
@ -674,6 +674,8 @@ class XmlWriter:
|
|||||||
self.write_line("suffix",name.get_suffix(),index+1)
|
self.write_line("suffix",name.get_suffix(),index+1)
|
||||||
self.write_line("patronymic",name.get_patronymic(),index+1)
|
self.write_line("patronymic",name.get_patronymic(),index+1)
|
||||||
self.write_line("title",name.get_title(),index+1)
|
self.write_line("title",name.get_title(),index+1)
|
||||||
|
if name.date:
|
||||||
|
self.write_date(name.date,4)
|
||||||
if name.get_note() != "":
|
if name.get_note() != "":
|
||||||
self.write_note("note",name.get_note_object(),index+1)
|
self.write_note("note",name.get_note_object(),index+1)
|
||||||
for s in name.get_source_references():
|
for s in name.get_source_references():
|
||||||
|
1759
src/gramps.glade
1759
src/gramps.glade
File diff suppressed because it is too large
Load Diff
Loading…
x
Reference in New Issue
Block a user