Dynamically find pages

svn: r1232
This commit is contained in:
Don Allingham 2002-12-29 05:44:35 +00:00
parent 1b2724bb8e
commit 537578f0d2
4 changed files with 104 additions and 78 deletions

View File

@ -257,7 +257,9 @@ class Date:
else: else:
d1 = func(self.start) d1 = func(self.start)
d2 = func(self.stop) d2 = func(self.stop)
return "%s %s %s %s" % ( _("from"),d1,_("to"),d2 ) return _("from %(start_date)s to %(stop_date)s") % {
'start_date' : d1,
'stop_date' : d2 }
def getDate(self): def getDate(self):
return self.get_fmt(SingleDate.getDate) return self.get_fmt(SingleDate.getDate)
@ -283,7 +285,9 @@ class Date:
else: else:
d1 = _func(self.start) d1 = _func(self.start)
d2 = _func(self.stop) d2 = _func(self.stop)
return "%s %s %s %s" % ( _("from"),d1,_("to"), d2) return _("from %(start_date)s to %(stop_date)s") % {
'start_date' : d1,
'stop_date' : d2 }
def get_quote_date(self,month_map,cal_str): def get_quote_date(self,month_map,cal_str):
if self.range == 0: if self.range == 0:
@ -296,11 +300,14 @@ class Date:
else: else:
d1 = self.start.display_calendar(month_map) d1 = self.start.display_calendar(month_map)
d2 = self.stop.display_calendar(month_map) d2 = self.stop.display_calendar(month_map)
return "%s %s %s %s (%s)" % ( _("from"),d1,_("to"), d2,cal_str) return _("from %(start_date)s to %(stop_date)s (%(calendar)s)") % {
'start_date' : d1,
'stop_data' :d2,
'calendar' : cal_str}
def isEmpty(self): def isEmpty(self):
s = self.start s = self.start
return s.year==UNDEF and s.month==UNDEF and s.day==UNDEF return s.year==UNDEF and s.month==UNDEF and s.day==UNDEF and not s.text
def isValid(self): def isValid(self):
return self.range != -1 return self.range != -1

View File

@ -33,7 +33,7 @@ class ListModel:
self.new_model() self.new_model()
self.selection = self.tree.get_selection() self.selection = self.tree.get_selection()
self.selection.set_mode(mode) self.selection.set_mode(mode)
self.mode = mode
self.data_index = l self.data_index = l
self.cids = [] self.cids = []
@ -87,6 +87,21 @@ class ListModel:
def get_selected(self): def get_selected(self):
return self.selection.get_selected() return self.selection.get_selected()
def get_selected_objects(self):
if self.mode == gtk.SELECTION_SINGLE:
store,iter = self.selection.get_selected()
if iter:
return [self.model.get_value(iter,self.data_index)]
else:
return []
else:
mlist = []
self.selection.selected_foreach(self.blist,mlist)
return mlist
def blist(self,store,path,iter,list):
list.append(self.model.get_value(iter,self.data_index))
def clear(self): def clear(self):
self.model.clear() self.model.clear()
@ -112,6 +127,7 @@ class ListModel:
self.model.set_value(iter,col,info) self.model.set_value(iter,col,info)
if select: if select:
self.selection.select_iter(iter) self.selection.select_iter(iter)
return iter
def add_and_select(self,data,info=None): def add_and_select(self,data,info=None):
iter = self.model.append() iter = self.model.append()

View File

@ -81,9 +81,16 @@ try:
except: except:
zodb_ok = 0 zodb_ok = 0
pl_titles = [ (_('Name'),5,250), (_('ID'),1,50), #-------------------------------------------------------------------------
(_('Gender'),2,70), (_('Birth Date'),6,150), #
(_('Death Date'),7,150), ('',5,0), ('',6,0), ('',7,0) ] # Constants
#
#-------------------------------------------------------------------------
pl_titles = [ (_('Name'),5,250), (_('ID'),1,50),(_('Gender'),2,70),
(_('Birth Date'),6,150),(_('Death Date'),7,150), ('',5,0),
('',6,0), ('',7,0) ]
_sel_mode = gtk.SELECTION_MULTIPLE
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
# #
@ -174,13 +181,15 @@ class Gramps:
self.ptabs = self.gtop.get_widget("ptabs") self.ptabs = self.gtop.get_widget("ptabs")
self.pl_other = self.gtop.get_widget("pl_other") self.pl_other = self.gtop.get_widget("pl_other")
self.ptabs.set_show_tabs(0)
self.pl_page = [ self.pl_page = [
ListModel.ListModel(self.pl_other, pl_titles, self.row_changed, ListModel.ListModel(self.pl_other, pl_titles, self.row_changed,
self.alpha_event, gtk.SELECTION_MULTIPLE), self.alpha_event, _sel_mode),
] ]
self.person_tree = self.pl_page[0]
self.person_list = self.pl_page[0].tree self.person_list = self.pl_page[0].tree
self.person_selection = self.pl_page[0].selection
self.person_model = self.pl_page[0].model self.person_model = self.pl_page[0].model
self.default_list = self.pl_page[-1] self.default_list = self.pl_page[-1]
@ -189,7 +198,6 @@ class Gramps:
self.model2page = {} self.model2page = {}
self.tab_list = [] self.tab_list = []
self.filter_list = self.gtop.get_widget("filter_list") self.filter_list = self.gtop.get_widget("filter_list")
self.notebook = self.gtop.get_widget("notebook1") self.notebook = self.gtop.get_widget("notebook1")
self.merge_button= self.gtop.get_widget("merge") self.merge_button= self.gtop.get_widget("merge")
@ -309,8 +317,8 @@ class Gramps:
"use at your own risk.") "use at your own risk.")
def change_alpha_page(self,obj,junk,page): def change_alpha_page(self,obj,junk,page):
self.person_tree = self.pl_page[page]
self.person_list = self.pl_page[page].tree self.person_list = self.pl_page[page].tree
self.person_selection = self.pl_page[page].selection
self.person_model = self.pl_page[page].model self.person_model = self.pl_page[page].model
def edit_button_clicked(self,obj): def edit_button_clicked(self,obj):
@ -352,10 +360,9 @@ class Gramps:
self.editbtn.set_sensitive(val) self.editbtn.set_sensitive(val)
def row_changed(self,obj): def row_changed(self,obj):
mlist = [] mlist = self.person_tree.get_selected_objects()
self.person_selection.selected_foreach(self.blist,mlist)
if mlist: if mlist:
self.change_active_person(mlist[0]) self.change_active_person(self.db.getPerson(mlist[0]))
def on_show_plugin_status(self,obj): def on_show_plugin_status(self,obj):
Plugins.PluginStatus() Plugins.PluginStatus()
@ -458,24 +465,21 @@ class Gramps:
import gnome.url import gnome.url
gnome.url.show("http://sourceforge.net/tracker/?group_id=25770&atid=385137") gnome.url.show("http://sourceforge.net/tracker/?group_id=25770&atid=385137")
def blist(self,store,path,iter,list):
id = self.db.getPerson(store.get_value(iter,1))
list.append(id)
def on_merge_activate(self,obj): def on_merge_activate(self,obj):
"""Calls up the merge dialog for the selection""" """Calls up the merge dialog for the selection"""
page = self.notebook.get_current_page() page = self.notebook.get_current_page()
if page == 0: if page == 0:
mlist = [] mlist = self.person_tree.get_selected_objects()
self.person_selection.selected_foreach(self.blist,mlist)
if len(mlist) != 2: if len(mlist) != 2:
msg = _("Exactly two people must be selected to perform a merge") msg = _("Exactly two people must be selected to perform a merge")
ErrorDialog(msg) ErrorDialog(msg)
else: else:
import MergeData import MergeData
MergeData.MergePeople(self.db,mlist[0],mlist[1],self.merge_update, p1 = self.db.getPerson(mlist[0])
p2 = self.db.getPerson(mlist[2])
MergeData.MergePeople(self.db,p1,p2,self.merge_update,
self.update_after_edit) self.update_after_edit)
elif page == 4: elif page == 4:
self.place_view.merge() self.place_view.merge()
@ -561,7 +565,14 @@ class Gramps:
for i in range(0,len(self.tab_list)): for i in range(0,len(self.tab_list)):
self.ptabs.remove_page(0) self.ptabs.remove_page(0)
self.ptabs.set_show_tabs(0)
self.tab_list = [] self.tab_list = []
self.alpha_page = {}
self.model2page = {}
self.person_tree = self.pl_page[-1]
self.person_list = self.pl_page[-1].tree
self.person_model = self.pl_page[-1].model
if zodb == 1: if zodb == 1:
self.db = GrampsZODB() self.db = GrampsZODB()
@ -794,8 +805,7 @@ class Gramps:
except (IOError,OSError),msg: except (IOError,OSError),msg:
self.status_text("%s - %s" % (_("autosave failed"),msg)) self.status_text("%s - %s" % (_("autosave failed"),msg))
except: except:
import traceback DisplayTrace.DisplayTrace()
traceback.print_exc()
return 0 return 0
def load_selected_people(self,obj): def load_selected_people(self,obj):
@ -815,9 +825,11 @@ class Gramps:
DisplayTrace.DisplayTrace() DisplayTrace.DisplayTrace()
def delete_person_clicked(self,obj): def delete_person_clicked(self,obj):
sel = self.person_selection.get_selected() mlist = self.person_tree.get_selected_objects()
if sel:
name = GrampsCfg.nameof(self.active_person) for sel in mlist:
p = self.db.getPerson(sel)
name = GrampsCfg.nameof(p)
msg = _("Do you really wish to delete %s?") % name msg = _("Do you really wish to delete %s?") % name
QuestionDialog(_('Delete Person'), msg, self.delete_person_response) QuestionDialog(_('Delete Person'), msg, self.delete_person_response)
@ -858,7 +870,7 @@ class Gramps:
if self.id2col.has_key(del_id): if self.id2col.has_key(del_id):
(model,iter,page) = self.id2col[del_id] (model,iter,page) = self.id2col[del_id]
model.model.remove(iter) model.remove(iter)
del self.id2col[del_id] del self.id2col[del_id]
if person == self.active_person: if person == self.active_person:
@ -1176,13 +1188,12 @@ class Gramps:
else: else:
model = self.default_list model = self.default_list
iter = model.model.append() iter = model.add([val[0],val[1],val[2],val[3],val[4],val[5],
val[6],val[7]],key)
page = self.model2page[model] page = self.model2page[model]
self.id2col[key] = (model,iter) self.id2col[key] = (model,iter)
model.model.set(iter, 0, val[0], 1, val[1], 2, val[2],
3, val[3], 4, val[4], 5, val[5],
6, val[6], 7, val[7])
if change: if change:
self.change_active_person(person) self.change_active_person(person)
self.goto_active_person() self.goto_active_person()
@ -1239,7 +1250,7 @@ class Gramps:
res = self.db.getResearcher() res = self.db.getResearcher()
owner = GrampsCfg.get_researcher() owner = GrampsCfg.get_researcher()
if res.getName() == "" and owner.getName() != "": if res.getName() == "" and owner.getName():
self.db.setResearcher(owner) self.db.setResearcher(owner)
Utils.modified() Utils.modified()
@ -1349,13 +1360,10 @@ class Gramps:
else: else:
model = self.default_list model = self.default_list
iter = model.model.append() iter = model.add([val[0],val[1],val[2],val[3],val[4],val[5],
val[6],val[7]],key)
page = self.model2page[model] page = self.model2page[model]
self.id2col[key] = (model,iter) self.id2col[key] = (model,iter)
model.model.set(iter, 0, val[0], 1, val[1], 2, val[2],
3, val[3], 4, val[4], 5, val[5],
6, val[6], 7, val[7])
else: else:
if self.id2col.has_key(key): if self.id2col.has_key(key):
(model,iter) = self.id2col[key] (model,iter) = self.id2col[key]
@ -1371,17 +1379,20 @@ class Gramps:
display.add_with_viewport(tree) display.add_with_viewport(tree)
display.show() display.show()
model = ListModel.ListModel(tree,pl_titles,self.row_changed, model = ListModel.ListModel(tree,pl_titles,self.row_changed,
self.alpha_event,gtk.SELECTION_MULTIPLE) self.alpha_event,_sel_mode)
self.pl_page.append(model)
self.alpha_page[pg] = model self.alpha_page[pg] = model
for index in range(0,len(self.tab_list)): for index in range(0,len(self.tab_list)):
if pg < self.tab_list[index]: if pg < self.tab_list[index]:
self.ptabs.insert_page(display,gtk.Label(pg),index) self.ptabs.insert_page(display,gtk.Label(pg),index)
self.ptabs.set_show_tabs(1)
self.tab_list.insert(index,pg) self.tab_list.insert(index,pg)
self.pl_page.insert(index,model)
break break
else: else:
self.ptabs.insert_page(display,gtk.Label(pg),len(self.tab_list)) self.ptabs.insert_page(display,gtk.Label(pg),len(self.tab_list))
self.ptabs.set_show_tabs(1)
self.tab_list.append(pg) self.tab_list.append(pg)
self.pl_page = self.pl_page[0:-1] + [model,self.default_list]
for index in range(0,len(self.tab_list)): for index in range(0,len(self.tab_list)):
model = self.alpha_page[self.tab_list[index]] model = self.alpha_page[self.tab_list[index]]

View File

@ -67,6 +67,12 @@ _calmap = {
Date.JULIAN : (_month, '@#JULIAN@'), Date.JULIAN : (_month, '@#JULIAN@'),
} }
_caldef = {
Date.SingleDate.about : "ABT",
Date.SingleDate.about : "BEF",
Date.SingleDate.about : "AFT",
}
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
# #
# #
@ -170,7 +176,7 @@ def sortById(first,second):
# #
# #
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
def make_date(subdate,mmap): def make_date(subdate):
retval = "" retval = ""
day = subdate.getDay() day = subdate.getDay()
mon = subdate.getMonth() mon = subdate.getMonth()
@ -180,35 +186,42 @@ def make_date(subdate,mmap):
mon_valid = subdate.getMonthValid() mon_valid = subdate.getMonthValid()
year_valid = subdate.getYearValid() year_valid = subdate.getYearValid()
if _calmap.has_key(subdate.calendar):
(mmap,prefix) = _calmap[subdate.calendar]
else:
mmap = _month
prefix = ""
if not day_valid: if not day_valid:
try: try:
if not mon_valid: if not mon_valid:
retval = str(year) retval = '(%d)' % year
elif not year_valid: elif not year_valid:
retval = mmap[mon] retval = '(%s)' % mmap[mon]
else: else:
retval = "%s %d" % (mmap[mon],year) retval = "(%s %d)" % (mmap[mon],year)
except IndexError: except IndexError:
print "Month index error - %d" % mon print "Month index error - %d" % mon
retval = str(year) retval = '(%d)' % year
elif not mon_valid: elif not mon_valid:
retval = str(year) retval = '(%d)' % year
else: else:
try: try:
month = mmap[mon] month = mmap[mon]
if not year_valid: if not year_valid:
retval = "%d %s ????" % (day,month) retval = "(%d %s)" % (day,month)
else: else:
retval = "%d %s %d" % (day,month,year) retval = "%d %s %d" % (day,month,year)
except IndexError: except IndexError:
print "Month index error - %d" % mon print "Month index error - %d" % mon
retval = str(year) retval = str(year)
if mode == Date.SingleDate.about:
retval = "ABT %s" % retval if prefix:
elif mode == Date.SingleDate.before: retval = "%s %s" % (prefix, retval)
retval = "BEF %s" % retval
elif mode == Date.SingleDate.after: if _caldef.has_key(mode):
retval = "AFT %s" % retval retval = "%s %s" % (_caldef[mode],retval)
return retval return retval
def fmtline(text,limit,level): def fmtline(text,limit,level):
@ -861,31 +874,10 @@ class GedcomWriter:
val = date.getText() val = date.getText()
if val != "": if val != "":
self.g.write("%s %s\n" % (prefix,self.cnvtxt(val))) self.g.write("%s %s\n" % (prefix,self.cnvtxt(val)))
elif date.get_calendar() == Date.GREGORIAN: else:
if date.isRange(): if date.isRange():
val = "FROM %s TO %s" % (make_date(start,_month), val = "FROM %s TO %s" % (make_date(start),
make_date(date.get_stop_date(),_month)) make_date(date.get_stop_date()))
else:
val = make_date(start,_month)
self.g.write("%s %s\n" % (prefix,val))
else:
if self.cal == CALENDAR_YES:
(mlist,cal) = _calmap[date.get_calendar()]
if date.isRange():
stop = date.get_stop_date()
val = "FROM %s TO %s" % (make_date(start,mlist),
make_date(stop,mlist))
else:
val = make_date(start,mlist)
self.g.write("%s %s %s\n" % (prefix,cal,val))
else:
mydate = Date.Date(date)
mydate.set_calendar(Date.GREGORIAN)
start = mydate.get_start_date()
if mydate.isRange():
stop = mydate.get_stop_date()
val = "FROM %s TO %s" % (make_date(start,_month),
make_date(stop,_month))
else: else:
val = make_date(start,_month) val = make_date(start,_month)
self.g.write("%s %s\n" % (prefix,val)) self.g.write("%s %s\n" % (prefix,val))