* src/EditEventRef.py: switch to monitored widgets, place selector

* src/EventEdit.py: switch to monitored widgets, place selector
* src/GrampsWidgets.py: place selection widget
* src/GrampsDb/_GrampsDbBase.py: move completion widget, handle
place lists


svn: r5980
This commit is contained in:
Don Allingham 2006-02-24 05:05:46 +00:00
parent 583e83da27
commit 44c661a16b
6 changed files with 755 additions and 775 deletions

View File

@ -1,3 +1,10 @@
2006-02-23 Don Allingham <don@gramps-project.org>
* src/EditEventRef.py: switch to monitored widgets, place selector
* src/EventEdit.py: switch to monitored widgets, place selector
* src/GrampsWidgets.py: place selection widget
* src/GrampsDb/_GrampsDbBase.py: move completion widget, handle
place lists
2006-02-22 Don Allingham <don@gramps-project.org> 2006-02-22 Don Allingham <don@gramps-project.org>
* src/EditPlace.py: use monitored widgets * src/EditPlace.py: use monitored widgets
* src/EditSource.py: use monitored widgets * src/EditSource.py: use monitored widgets

View File

@ -69,26 +69,6 @@ for event_type in Utils.family_events.keys():
if not total_events.has_key(event_type): if not total_events.has_key(event_type):
total_events[event_type] = Utils.family_events[event_type] total_events[event_type] = Utils.family_events[event_type]
#-------------------------------------------------------------------------
#
# helper function
#
#-------------------------------------------------------------------------
def get_place(field,pmap,db):
text = unicode(field.get_text().strip())
if text:
if pmap.has_key(text):
return db.get_place_from_handle(pmap[text])
else:
place = RelLib.Place()
place.set_title(text)
trans = db.transaction_begin()
db.add_place(place,trans)
db.transaction_commit(trans,_("Add Place"))
return place
else:
return None
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
# #
# EditEventRef class # EditEventRef class
@ -110,27 +90,16 @@ class EditEventRef(DisplayState.ManagedWindow):
self.update = update self.update = update
self.pmap = {}
for key in self.db.get_place_handles():
title = self.db.get_place_from_handle(key).get_title()
self.pmap[title] = key
self.title = _('Event Reference Editor') self.title = _('Event Reference Editor')
self.top = gtk.glade.XML(const.gladeFile, "event_eref_edit","gramps") self.top = gtk.glade.XML(const.gladeFile, "event_eref_edit","gramps")
self.window = self.top.get_widget('event_eref_edit') self.window = self.top.get_widget('event_eref_edit')
self.ref_note_field = self.top.get_widget('eer_ref_note')
self.role_combo = self.top.get_widget('eer_role_combo')
self.date_field = self.top.get_widget("eer_date")
self.place_field = self.top.get_widget("eer_place")
self.cause_field = self.top.get_widget("eer_cause")
self.ev_note_field = self.top.get_widget("eer_ev_note")
self.type_combo = self.top.get_widget("eer_type_combo")
self.general_label = self.top.get_widget("eer_general_tab") self.general_label = self.top.get_widget("eer_general_tab")
self.ok = self.top.get_widget('ok') self.ok = self.top.get_widget('ok')
self.expander = self.top.get_widget("eer_expander") self.expander = self.top.get_widget("eer_expander")
self.warning = self.top.get_widget("eer_warning") self.warning = self.top.get_widget("eer_warning")
self.notebook = self.top.get_widget('notebook') self.notebook = self.top.get_widget('notebook')
self.notebook_ref = self.top.get_widget('notebook_ref')
if self.referent.__class__.__name__ == 'Person': if self.referent.__class__.__name__ == 'Person':
default_type = RelLib.Event.BIRTH default_type = RelLib.Event.BIRTH
@ -143,9 +112,12 @@ class EditEventRef(DisplayState.ManagedWindow):
ev_dict = Utils.family_events ev_dict = Utils.family_events
role_dict = Utils.family_event_roles role_dict = Utils.family_event_roles
Utils.set_titles(self.window,
self.top.get_widget('eer_title'),
self.title)
if self.event: if self.event:
self.event_added = False self.event_added = False
self.date = RelLib.Date(self.event.get_date_object())
if self.event_ref: if self.event_ref:
if self.event_ref.get_role()[0] == default_role: if self.event_ref.get_role()[0] == default_role:
self.expander.set_expanded(True) self.expander.set_expanded(True)
@ -159,7 +131,6 @@ class EditEventRef(DisplayState.ManagedWindow):
self.event.set_handle(self.db.create_id()) self.event.set_handle(self.db.create_id())
self.event.set_gramps_id(self.db.find_next_event_gramps_id()) self.event.set_gramps_id(self.db.find_next_event_gramps_id())
self.event_added = True self.event_added = True
self.date = RelLib.Date(None)
self.expander.set_expanded(True) self.expander.set_expanded(True)
self.warning.hide() self.warning.hide()
@ -168,67 +139,77 @@ class EditEventRef(DisplayState.ManagedWindow):
self.event_ref.set_role((default_role,role_dict[default_role])) self.event_ref.set_role((default_role,role_dict[default_role]))
self.event_ref.set_reference_handle(self.event.get_handle()) self.event_ref.set_reference_handle(self.event.get_handle())
self.cause_monitor = MonitoredEntry(self.cause_field,self.event.set_cause,
self.event.get_cause, False)
self.ref_privacy = PrivacyButton(self.top.get_widget('eer_ref_priv'),
self.event_ref)
self.descr_field = MonitoredEntry(self.top.get_widget("eer_description"),
self.event.set_description,
self.event.get_description, False)
self.ev_privacy = PrivacyButton(self.top.get_widget("eer_ev_priv"),
self.event)
Utils.set_titles(self.window,
self.top.get_widget('eer_title'),
self.title)
self.top.signal_autoconnect({
"on_eer_help_clicked" : self.on_help_clicked,
"on_eer_ok_clicked" : self.on_ok_clicked,
"on_eer_cancel_clicked" : self.close,
"on_eer_delete_event" : self.close,
})
self.role_selector = AutoComp.StandardCustomSelector(
role_dict,self.role_combo,
RelLib.EventRef.CUSTOM,default_role)
AutoComp.fill_entry(self.place_field,self.pmap.keys())
self.type_selector = AutoComp.StandardCustomSelector(
ev_dict,self.type_combo,
RelLib.Event.CUSTOM,default_type)
self.date_check = DateEdit.DateEdit(self.date,
self.date_field,
self.top.get_widget("eer_date_stat"),
self.window)
# set event_ref values # set event_ref values
self.role_selector.set_values(self.event_ref.get_role())
self.ref_note_field.get_buffer().set_text(self.event_ref.get_note())
# set event values
self.type_selector.set_values(self.event.get_type())
place_handle = self.event.get_place_handle()
if not place_handle:
place_name = u""
else:
place_name = self.db.get_place_from_handle(place_handle).get_title()
self.place_field.set_text(place_name)
self.date_field.set_text(_dd.display(self.date))
self._create_tabbed_pages() self._create_tabbed_pages()
self._setup_fields(self.state.get_place_completion(),role_dict)
self._connect_signals()
self.show() self.show()
def _setup_fields(self,place_values,role_dict):
self.cause_monitor = MonitoredEntry(
self.top.get_widget("eer_cause"),
self.event.set_cause,
self.event.get_cause,
self.db.readonly)
self.ref_privacy = PrivacyButton(
self.top.get_widget('eer_ref_priv'),
self.event_ref)
self.descr_field = MonitoredEntry(
self.top.get_widget("eer_description"),
self.event.set_description,
self.event.get_description,
self.db.readonly)
self.place_field = PlaceEntry(
self.top.get_widget("eer_place"),
self.event.get_place_handle(),
place_values,
self.db.readonly)
self.ev_privacy = PrivacyButton(
self.top.get_widget("eer_ev_priv"),
self.event)
self.role_selector = MonitoredType(
self.top.get_widget('eer_role_combo'),
self.event_ref.set_role,
self.event_ref.get_role,
role_dict,
RelLib.EventRef.CUSTOM)
self.event_menu = MonitoredType(
self.top.get_widget("eer_type_combo"),
self.event.set_type,
self.event.get_type,
dict(total_events),
RelLib.Event.CUSTOM)
self.date_check = DateEdit.DateEdit(
self.event.get_date_object(),
self.top.get_widget("eer_date"),
self.top.get_widget("eer_date_stat"),
self.window)
def _connect_signals(self):
self.top.get_widget('ok').connect('clicked',self.ok_clicked)
self.top.get_widget('cancel').connect('clicked',self.close)
self.top.get_widget('help').connect('clicked',self.help_clicked)
self.window.connect('delete-event',self.close)
def _add_page(self,page): def _add_page(self,page):
self.notebook.insert_page(page) self.notebook.insert_page(page)
self.notebook.set_tab_label(page,page.get_tab_widget()) self.notebook.set_tab_label(page,page.get_tab_widget())
return page return page
def _add_ref_page(self,page):
self.notebook_ref.insert_page(page)
self.notebook_ref.set_tab_label(page,page.get_tab_widget())
return page
def _create_tabbed_pages(self): def _create_tabbed_pages(self):
""" """
Creates the notebook tabs and inserts them into the main Creates the notebook tabs and inserts them into the main
@ -242,6 +223,9 @@ class EditEventRef(DisplayState.ManagedWindow):
self.note_tab = self._add_page(NoteTab( self.note_tab = self._add_page(NoteTab(
self.state, self.uistate, self.track, self.state, self.uistate, self.track,
self.event.get_note_object())) self.event.get_note_object()))
self.note_ref_tab = self._add_ref_page(NoteTab(
self.state, self.uistate, self.track,
self.event_ref.get_note_object()))
self.gallery_tab = self._add_page(GalleryTab( self.gallery_tab = self._add_page(GalleryTab(
self.state, self.uistate, self.track, self.state, self.uistate, self.track,
self.event.get_media_list())) self.event.get_media_list()))
@ -266,46 +250,35 @@ class EditEventRef(DisplayState.ManagedWindow):
else: else:
return id(self) return id(self)
def on_help_clicked(self,obj): def help_clicked(self,obj):
pass pass
def on_ok_clicked(self,obj): def ok_clicked(self,obj):
(need_new, handle) = self.place_field.get_place_info()
if need_new:
place_obj = RelLib.Place()
place_obj.set_title(handle)
self.event.set_place_handle(place_obj.get_handle())
else:
self.event.set_place_handle(handle)
# first, save event if changed
etype = self.type_selector.get_values()
eplace_obj = get_place(self.place_field,self.pmap,self.db)
self.update_event(etype,self.date,eplace_obj)
trans = self.db.transaction_begin() trans = self.db.transaction_begin()
self.db.commit_event(self.event,trans) self.db.commit_event(self.event,trans)
if self.event_added: if self.event_added:
if need_new:
self.db.add_place(place_obj,trans)
self.db.transaction_commit(trans,_("Add Event")) self.db.transaction_commit(trans,_("Add Event"))
else: else:
if need_new:
self.db.add_place(place_obj,trans)
self.db.transaction_commit(trans,_("Modify Event")) self.db.transaction_commit(trans,_("Modify Event"))
# then, set properties of the event_ref
self.event_ref.set_role(self.role_selector.get_values())
self.event_ref.set_privacy(self.ref_privacy.get_active())
self.close(None) self.close(None)
if self.update: if self.update:
self.update((self.event_ref,self.event)) self.update((self.event_ref,self.event))
def update_event(self,the_type,date,place):
if place:
if self.event.get_place_handle() != place.get_handle():
self.event.set_place_handle(place.get_handle())
else:
if self.event.get_place_handle():
self.event.set_place_handle("")
if self.event.get_type() != the_type:
self.event.set_type(the_type)
dobj = self.event.get_date_object()
if not dobj.is_equal(date):
self.event.set_date_object(date)
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
# #

View File

@ -67,26 +67,6 @@ for event_type in Utils.family_events.keys():
if not total_events.has_key(event_type): if not total_events.has_key(event_type):
total_events[event_type] = Utils.family_events[event_type] total_events[event_type] = Utils.family_events[event_type]
#-------------------------------------------------------------------------
#
# helper function
#
#-------------------------------------------------------------------------
def get_place(field,pmap,db):
text = unicode(field.get_text().strip())
if text:
if pmap.has_key(text):
return db.get_place_from_handle(pmap[text])
else:
place = RelLib.Place()
place.set_title(text)
trans = db.transaction_begin()
db.add_place(place,trans)
db.transaction_commit(trans,_("Add Place"))
return place
else:
return None
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
# #
# EventEditor class # EventEditor class
@ -122,17 +102,6 @@ class EventEditor(DisplayState.ManagedWindow):
Utils.set_titles(self.window,title_label, etitle, Utils.set_titles(self.window,title_label, etitle,
_('Event Editor')) _('Event Editor'))
self.place_field = self.top.get_widget("eventPlace")
self.place_field.set_editable(not self.db.readonly)
place_handle = event.get_place_handle()
if not place_handle:
place_name = u""
else:
place_name = self.db.get_place_from_handle(place_handle).get_title()
self.place_field.set_text(place_name)
self.place_field.set_completion(self.dbstate.get_place_completion())
self._create_tabbed_pages() self._create_tabbed_pages()
self._setup_fields() self._setup_fields()
self._connect_signals() self._connect_signals()
@ -147,6 +116,12 @@ class EventEditor(DisplayState.ManagedWindow):
ok.connect('clicked',self.on_event_edit_ok_clicked) ok.connect('clicked',self.on_event_edit_ok_clicked)
def _setup_fields(self): def _setup_fields(self):
self.place_field = PlaceEntry(
self.top.get_widget("eventPlace"),
self.event.get_place_handle(),
self.dbstate.get_place_completion(),
self.db.readonly)
self.cause_monitor = MonitoredEntry( self.cause_monitor = MonitoredEntry(
self.top.get_widget("eventCause"), self.top.get_widget("eventCause"),
self.event.set_cause, self.event.set_cause,
@ -157,7 +132,6 @@ class EventEditor(DisplayState.ManagedWindow):
self.event.set_description, self.event.set_description,
self.event.get_description, self.db.readonly) self.event.get_description, self.db.readonly)
self.priv = PrivacyButton( self.priv = PrivacyButton(
self.top.get_widget("private"), self.top.get_widget("private"),
self.event, self.db.readonly) self.event, self.db.readonly)
@ -234,18 +208,26 @@ class EventEditor(DisplayState.ManagedWindow):
def on_event_edit_ok_clicked(self,obj): def on_event_edit_ok_clicked(self,obj):
eplace_obj = get_place(self.place_field,self.pmap,self.db) (need_new, handle) = self.place_field.get_place_info()
if need_new:
self.update_event(eplace_obj) place_obj = RelLib.Place()
place_obj.set_title(handle)
self.event.set_place_handle(place_obj.get_handle())
else:
self.event.set_place_handle(handle)
if self.event.handle == None: if self.event.handle == None:
trans = self.db.transaction_begin() trans = self.db.transaction_begin()
if need_new:
self.db.add_place(place_obj,trans)
self.db.add_event(self.event,trans) self.db.add_event(self.event,trans)
self.db.transaction_commit(trans,_("Add Event")) self.db.transaction_commit(trans,_("Add Event"))
else: else:
orig = self.dbstate.db.get_event_from_handle(self.event.handle) orig = self.dbstate.db.get_event_from_handle(self.event.handle)
if cmp(self.event.serialize(),orig.serialize()): if cmp(self.event.serialize(),orig.serialize()):
trans = self.db.transaction_begin() trans = self.db.transaction_begin()
if need_new:
self.db.add_place(place_obj,trans)
self.db.commit_event(self.event,trans) self.db.commit_event(self.event,trans)
self.db.transaction_commit(trans,_("Edit Event")) self.db.transaction_commit(trans,_("Edit Event"))
@ -253,15 +235,6 @@ class EventEditor(DisplayState.ManagedWindow):
self.callback(self.event) self.callback(self.event)
self.close(obj) self.close(obj)
def update_event(self,place):
# FIXME: commented because we no longer have parent
if place:
if self.event.get_place_handle() != place.get_handle():
self.event.set_place_handle(place.get_handle())
else:
if self.event.get_place_handle():
self.event.set_place_handle("")
def commit(self,event,trans): def commit(self,event,trans):
self.db.commit_event(event,trans) self.db.commit_event(event,trans)

View File

@ -1999,20 +1999,23 @@ class DbState(GrampsDBCallback):
data = cursor.next() data = cursor.next()
while data: while data:
if data[1][2]: if data[1][2]:
self.places[data[1][2]] = data[0] self.places[data[0]] = data[1][2]
data = cursor.next() data = cursor.next()
cursor.close() cursor.close()
def _place_add(self,handle): def _place_add(self,handle_list):
place = self.db.get_place_from_handle(handle) for handle in handle_list:
self.places[place.get_title()] = handle place = self.db.get_place_from_handle(handle)
self.places[place.get_title()] = handle
def _place_update(self,handle): def _place_update(self,handle_list):
place = self.db.get_place_from_handle(handle) for handle in handle_list:
self.places[handle] = place.get_title() place = self.db.get_place_from_handle(handle)
self.places[handle] = place.get_title()
def _place_delete(self,handle): def _place_delete(self,handle_list):
del self.places[handle] for handle in handle_list:
del self.places[handle]
def change_active_person(self,person): def change_active_person(self,person):
self.active = person self.active = person
@ -2047,16 +2050,5 @@ class DbState(GrampsDBCallback):
self.emit('no-database') self.emit('no-database')
def get_place_completion(self): def get_place_completion(self):
import locale return self.places
store = gtk.ListStore(str,str)
foo = []
for val in self.places.keys():
foo.append((locale.strxform(self.places[val]),val))
foo.sort()
for val in foo:
self.store.append(row=[val[1],val[0]])
self.completion = gtk.EntryCompletion()
self.completion.set_text_column(0)
self.completion.set_model(store)
return self.completion

View File

@ -21,6 +21,7 @@
# $Id$ # $Id$
import cgi import cgi
import locale
from gettext import gettext as _ from gettext import gettext as _
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
@ -334,3 +335,42 @@ class MonitoredDate:
field.set_text(DateHandler.displayer.display(self.date)) field.set_text(DateHandler.displayer.display(self.date))
class PlaceEntry:
def __init__(self, obj, handle, place_map, read_only=False):
self.obj = obj
self.handle = handle
self.places = place_map
if handle:
name = place_map[handle]
else:
name = u""
if read_only:
self.obj.set_editable(False)
else:
self.obj.set_editable(True)
store = gtk.ListStore(str)
foo = self.places.values()
foo.sort(locale.strcoll)
for val in foo:
store.append(row=[val[0]])
completion = gtk.EntryCompletion()
completion.set_text_column(0)
completion.set_model(store)
obj.set_completion(completion)
obj.set_text(name)
def get_place_info(self):
text = unicode(self.obj.get_text().strip())
if text:
for key in self.places.keys():
if text == self.places[key]:
return (False,key)
return (True,text)
else:
return (False,u"")

File diff suppressed because it is too large Load Diff