* 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:
parent
583e83da27
commit
44c661a16b
@ -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
|
||||||
|
@ -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)
|
|
||||||
|
|
||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
#
|
#
|
||||||
|
@ -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)
|
||||||
|
|
||||||
|
@ -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
|
|
||||||
|
@ -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
Loading…
x
Reference in New Issue
Block a user