* src/AttrEdit.py: use DisplayTabs
* src/NameEdit.py: use DisplayTabs * src/gramps.glade: use DisplayTabs svn: r5882
This commit is contained in:
parent
c944cbd013
commit
bb9731bea7
@ -1,4 +1,7 @@
|
||||
2006-02-03 Don Allingham <don@gramps-project.org>
|
||||
* src/AttrEdit.py: use DisplayTabs
|
||||
* src/NameEdit.py: use DisplayTabs
|
||||
* src/gramps.glade: use DisplayTabs
|
||||
* src/DisplayTabs.py: Handle notes properly
|
||||
* src/EventEdit.py: commit modified events
|
||||
* src/PeopleModel.py: remove unused functions
|
||||
|
@ -60,6 +60,7 @@ import DisplayState
|
||||
|
||||
from QuestionDialog import WarningDialog
|
||||
from WindowUtils import GladeIf
|
||||
from DisplayTabs import *
|
||||
|
||||
#-------------------------------------------------------------------------
|
||||
#
|
||||
@ -93,36 +94,17 @@ class AttributeEditor(DisplayState.ManagedWindow):
|
||||
return
|
||||
|
||||
self.top = gtk.glade.XML(const.gladeFile, "attr_edit","gramps")
|
||||
self.slist = self.top.get_widget("slist")
|
||||
self.value_field = self.top.get_widget("attr_value")
|
||||
self.note_field = self.top.get_widget("attr_note")
|
||||
self.spell = Spell.Spell(self.note_field)
|
||||
self.attrib_menu = self.top.get_widget("attr_menu")
|
||||
# self.type_field = self.attrib_menu.child
|
||||
self.source_field = self.top.get_widget("attr_source")
|
||||
self.priv = self.top.get_widget("priv")
|
||||
self.general_label = self.top.get_widget("general_tab")
|
||||
self.sources_label = self.top.get_widget("sources_tab")
|
||||
self.notes_label = self.top.get_widget("note_tab")
|
||||
self.flowed = self.top.get_widget("attr_flowed")
|
||||
self.preform = self.top.get_widget("attr_preform")
|
||||
self.notebook = self.top.get_widget("notebook")
|
||||
|
||||
self.window = self.top.get_widget("attr_edit")
|
||||
self.type_selector = AutoComp.StandardCustomSelector(
|
||||
Utils.personal_attributes,self.attrib_menu,
|
||||
RelLib.Attribute.CUSTOM,RelLib.Attribute.DESCRIPTION)
|
||||
|
||||
if attrib:
|
||||
self.srcreflist = self.attrib.get_source_references()
|
||||
else:
|
||||
self.srcreflist = []
|
||||
|
||||
self.sourcetab = Sources.SourceTab(
|
||||
self.state, self.uistate, self.track,
|
||||
self.srcreflist, self, self.top, self.window, self.slist,
|
||||
self.top.get_widget('add_src'), self.top.get_widget('edit_src'),
|
||||
self.top.get_widget('del_src'), self.db.readonly)
|
||||
|
||||
if title == ", ":
|
||||
title = _("Attribute Editor")
|
||||
else:
|
||||
@ -134,16 +116,6 @@ class AttributeEditor(DisplayState.ManagedWindow):
|
||||
self.type_selector.set_values(attrib.get_type())
|
||||
self.value_field.set_text(attrib.get_value())
|
||||
self.priv.set_active(attrib.get_privacy())
|
||||
|
||||
if attrib.get_note():
|
||||
self.note_field.get_buffer().set_text(attrib.get_note())
|
||||
Utils.bold_label(self.notes_label)
|
||||
if attrib.get_note_format() == 1:
|
||||
self.preform.set_active(True)
|
||||
else:
|
||||
self.flowed.set_active(True)
|
||||
else:
|
||||
Utils.unbold_label(self.notes_label)
|
||||
else:
|
||||
self.attrib = RelLib.Attribute()
|
||||
|
||||
@ -152,32 +124,41 @@ class AttributeEditor(DisplayState.ManagedWindow):
|
||||
self.gladeif.connect('button116', 'clicked', self.close_window)
|
||||
self.gladeif.connect('button115', 'clicked', self.on_ok_clicked)
|
||||
self.gladeif.connect('button127', 'clicked', self.on_help_clicked)
|
||||
self.gladeif.connect('notebook', 'switch_page', self.on_switch_page)
|
||||
|
||||
if self.db.readonly:
|
||||
w = self.top.get_widget("button115")
|
||||
w.set_sensitive(False)
|
||||
self.value_field.set_editable(False)
|
||||
self.note_field.set_editable(False)
|
||||
self.attrib_menu.set_sensitive(False)
|
||||
self.priv.set_sensitive(False)
|
||||
self.flowed.set_sensitive(False)
|
||||
self.preform.set_sensitive(False)
|
||||
|
||||
self.update_note_page()
|
||||
self.window.set_transient_for(self.parent_window)
|
||||
self.window.show()
|
||||
|
||||
self._create_tabbed_pages()
|
||||
self.show()
|
||||
|
||||
def _create_tabbed_pages(self):
|
||||
vbox = self.top.get_widget('vbox')
|
||||
|
||||
self.notebook = gtk.Notebook()
|
||||
self.srcref_list = self._add_page(SourceEmbedList(
|
||||
self.state,self.uistate, self.track,
|
||||
self.attrib.source_list))
|
||||
self.note_tab = self._add_page(NoteTab(
|
||||
self.state, self.uistate, self.track,
|
||||
self.attrib.get_note_object()))
|
||||
self.notebook.show_all()
|
||||
vbox.pack_start(self.notebook,True)
|
||||
|
||||
def _add_page(self,page):
|
||||
self.notebook.insert_page(page)
|
||||
self.notebook.set_tab_label(page,page.get_tab_widget())
|
||||
return page
|
||||
|
||||
def on_delete_event(self,obj,b):
|
||||
self.gladeif.close()
|
||||
self.close()
|
||||
gc.collect()
|
||||
|
||||
def close_window(self,obj):
|
||||
self.gladeif.close()
|
||||
self.close()
|
||||
self.window.destroy()
|
||||
gc.collect()
|
||||
|
||||
def build_menu_names(self, attrib):
|
||||
if not attrib:
|
||||
@ -201,10 +182,6 @@ class AttributeEditor(DisplayState.ManagedWindow):
|
||||
attr_data = self.type_selector.get_values()
|
||||
value = unicode(self.value_field.get_text())
|
||||
|
||||
buf = self.note_field.get_buffer()
|
||||
note = unicode(buf.get_text(buf.get_start_iter(),
|
||||
buf.get_end_iter(),False))
|
||||
format = self.preform.get_active()
|
||||
priv = self.priv.get_active()
|
||||
|
||||
if (attr_data[0] == RelLib.Attribute.CUSTOM and
|
||||
@ -216,7 +193,6 @@ class AttributeEditor(DisplayState.ManagedWindow):
|
||||
self.alist.append(attr_data[1])
|
||||
self.alist.sort()
|
||||
|
||||
self.attrib.set_source_reference_list(self.srcreflist)
|
||||
self.update(attr_data,value,note,format,priv)
|
||||
self.callback(self.attrib)
|
||||
self.close_window(obj)
|
||||
@ -231,19 +207,4 @@ class AttributeEditor(DisplayState.ManagedWindow):
|
||||
"""Compares the data items, and updates if necessary"""
|
||||
self.check(self.attrib.get_type,self.attrib.set_type,attr_data)
|
||||
self.check(self.attrib.get_value,self.attrib.set_value,value)
|
||||
self.check(self.attrib.get_note,self.attrib.set_note,note)
|
||||
self.check(self.attrib.get_note_format,self.attrib.set_note_format,format)
|
||||
self.check(self.attrib.get_privacy,self.attrib.set_privacy,priv)
|
||||
|
||||
def on_switch_page(self,obj,a,page):
|
||||
self.update_note_page()
|
||||
|
||||
def update_note_page(self):
|
||||
buf = self.note_field.get_buffer()
|
||||
start = buf.get_start_iter()
|
||||
end = buf.get_end_iter()
|
||||
text = unicode(buf.get_text(start,end,False))
|
||||
if text:
|
||||
Utils.bold_label(self.notes_label)
|
||||
else:
|
||||
Utils.unbold_label(self.notes_label)
|
||||
|
@ -52,6 +52,7 @@ import DateHandler
|
||||
import Spell
|
||||
import GrampsDisplay
|
||||
import DisplayState
|
||||
from DisplayTabs import *
|
||||
|
||||
from WindowUtils import GladeIf
|
||||
|
||||
@ -65,6 +66,7 @@ class NameEditor(DisplayState.ManagedWindow):
|
||||
def __init__(self, dbstate, uistate, track, name, callback):
|
||||
|
||||
self.db = dbstate.db
|
||||
self.dbstate = dbstate
|
||||
self.uistate = uistate
|
||||
self.state = dbstate
|
||||
self.callback = callback
|
||||
@ -90,16 +92,13 @@ class NameEditor(DisplayState.ManagedWindow):
|
||||
self.suffix_field.set_editable(not self.db.readonly)
|
||||
self.patronymic_field = self.top.get_widget("patronymic")
|
||||
self.patronymic_field.set_editable(not self.db.readonly)
|
||||
self.combo = self.top.get_widget("alt_surname_list")
|
||||
self.combo.set_sensitive(not self.db.readonly)
|
||||
self.surname_field = self.top.get_widget("alt_surname")
|
||||
self.date = self.top.get_widget('date')
|
||||
self.date.set_editable(not self.db.readonly)
|
||||
|
||||
if self.name:
|
||||
self.srcreflist = self.name.get_source_references()
|
||||
self.date_obj = self.name.get_date_object()
|
||||
else:
|
||||
self.srcreflist = []
|
||||
self.date_obj = RelLib.Date()
|
||||
self.name = RelLib.Name()
|
||||
|
||||
@ -111,27 +110,16 @@ class NameEditor(DisplayState.ManagedWindow):
|
||||
self.date_obj, self.date,
|
||||
date_stat, self.window)
|
||||
|
||||
AutoComp.fill_combo(self.combo,self.db.get_surname_list())
|
||||
self.surname_field = self.combo.get_child()
|
||||
self.prefix_field = self.top.get_widget("alt_prefix")
|
||||
self.prefix_field.set_editable(not self.db.readonly)
|
||||
|
||||
self.type_combo = self.top.get_widget("name_type")
|
||||
self.type_combo.set_sensitive(not self.db.readonly)
|
||||
self.note_field = self.top.get_widget("alt_note")
|
||||
self.note_field.set_editable(not self.db.readonly)
|
||||
self.spell = Spell.Spell(self.note_field)
|
||||
|
||||
self.slist = self.top.get_widget('slist')
|
||||
self.priv = self.top.get_widget("priv")
|
||||
self.notebook = self.top.get_widget("notebook")
|
||||
self.general_label = self.top.get_widget("general_tab")
|
||||
self.sources_label = self.top.get_widget("sources_tab")
|
||||
self.notes_label = self.top.get_widget("note_tab")
|
||||
self.priv.set_sensitive(not self.db.readonly)
|
||||
self.flowed = self.top.get_widget("alt_flowed")
|
||||
self.flowed.set_sensitive(not self.db.readonly)
|
||||
self.preform = self.top.get_widget("alt_preform")
|
||||
self.preform.set_sensitive(not self.db.readonly)
|
||||
self.group_over = self.top.get_widget('group_over')
|
||||
self.group_over.set_sensitive(not self.db.readonly)
|
||||
|
||||
@ -150,21 +138,12 @@ class NameEditor(DisplayState.ManagedWindow):
|
||||
|
||||
Utils.set_titles(self.window, alt_title, tmsg, _('Name Editor'))
|
||||
|
||||
self.sourcetab = Sources.SourceTab(
|
||||
self.state, self.uistate, self.track,
|
||||
self.srcreflist, self, self.top, self.window, self.slist,
|
||||
self.top.get_widget('add_src'), self.top.get_widget('edit_src'),
|
||||
self.top.get_widget('del_src'), self.db.readonly)
|
||||
|
||||
self.note_buffer = self.note_field.get_buffer()
|
||||
|
||||
self.gladeif.connect('name_edit','delete_event',self.on_delete_event)
|
||||
self.gladeif.connect('button119','clicked',self.close_window)
|
||||
self.gladeif.connect('button118','clicked',self.on_name_edit_ok_clicked)
|
||||
okbtn = self.top.get_widget('button118')
|
||||
okbtn.set_sensitive(not self.db.readonly)
|
||||
self.gladeif.connect('button131','clicked',self.on_help_clicked)
|
||||
self.gladeif.connect('notebook3','switch_page',self.on_switch_page)
|
||||
self.gladeif.connect('group_over','toggled',self.on_group_over_toggled)
|
||||
|
||||
if name != None:
|
||||
@ -177,15 +156,6 @@ class NameEditor(DisplayState.ManagedWindow):
|
||||
self.patronymic_field.set_text(name.get_patronymic())
|
||||
self.priv.set_active(name.get_privacy())
|
||||
Utils.bold_label(self.general_label)
|
||||
if name.get_note():
|
||||
self.note_buffer.set_text(name.get_note())
|
||||
Utils.bold_label(self.notes_label)
|
||||
if name.get_note_format() == 1:
|
||||
self.preform.set_active(1)
|
||||
else:
|
||||
self.flowed.set_active(1)
|
||||
else:
|
||||
Utils.unbold_label(self.notes_label)
|
||||
self.display_as.set_active(name.get_display_as())
|
||||
self.sort_as.set_active(name.get_display_as())
|
||||
grp_as = name.get_group_as()
|
||||
@ -196,14 +166,17 @@ class NameEditor(DisplayState.ManagedWindow):
|
||||
else:
|
||||
self.display_as.set_active(0)
|
||||
self.sort_as.set_active(0)
|
||||
Utils.unbold_label(self.notes_label)
|
||||
Utils.unbold_label(self.sources_label)
|
||||
Utils.unbold_label(self.general_label)
|
||||
|
||||
self.surname_field.connect('changed',self.update_group_as)
|
||||
|
||||
self.window.set_transient_for(self.parent_window)
|
||||
self.window.show()
|
||||
self.srcref_list = self._add_page(SourceEmbedList(
|
||||
self.dbstate,self.uistate, self.track,
|
||||
self.name.source_list))
|
||||
self.note_tab = self._add_page(NoteTab(
|
||||
self.dbstate, self.uistate, self.track,
|
||||
self.name.get_note_object()))
|
||||
|
||||
self.show()
|
||||
|
||||
def build_menu_names(self,name):
|
||||
if name:
|
||||
@ -214,6 +187,11 @@ class NameEditor(DisplayState.ManagedWindow):
|
||||
menu_label = _('Name Editor')
|
||||
return (menu_label,submenu_label)
|
||||
|
||||
def _add_page(self,page):
|
||||
self.notebook.insert_page(page)
|
||||
self.notebook.set_tab_label(page,page.get_tab_widget())
|
||||
return page
|
||||
|
||||
def update_group_as(self,obj):
|
||||
if not self.group_over.get_active():
|
||||
if self.name and self.name.get_group_as() != self.name.get_surname():
|
||||
@ -237,7 +215,6 @@ class NameEditor(DisplayState.ManagedWindow):
|
||||
def on_delete_event(self,*obj):
|
||||
self.gladeif.close()
|
||||
self.close()
|
||||
gc.collect()
|
||||
|
||||
def close_window(self,*obj):
|
||||
self.gladeif.close()
|
||||
@ -256,9 +233,6 @@ class NameEditor(DisplayState.ManagedWindow):
|
||||
prefix = unicode(self.prefix_field.get_text())
|
||||
suffix = unicode(self.suffix_field.get_text())
|
||||
patronymic = unicode(self.patronymic_field.get_text())
|
||||
note = unicode(self.note_buffer.get_text(self.note_buffer.get_start_iter(),
|
||||
self.note_buffer.get_end_iter(),False))
|
||||
format = self.preform.get_active()
|
||||
priv = self.priv.get_active()
|
||||
|
||||
the_type = self.type_selector.get_values()
|
||||
@ -271,8 +245,6 @@ class NameEditor(DisplayState.ManagedWindow):
|
||||
|
||||
self.name.set_date_object(self.date_obj)
|
||||
|
||||
self.name.set_source_reference_list(self.srcreflist)
|
||||
|
||||
grp_as = unicode(self.group_as.get_text())
|
||||
srn = unicode(self.surname_field.get_text())
|
||||
|
||||
@ -306,11 +278,12 @@ class NameEditor(DisplayState.ManagedWindow):
|
||||
else:
|
||||
self.name.set_group_as(grp_as)
|
||||
|
||||
self.update_name(first,last,suffix,patronymic,title,the_type,note,format,priv)
|
||||
self.update_name(first,last,suffix,patronymic,title,the_type,priv)
|
||||
self.callback(self.name)
|
||||
self.close_window(obj)
|
||||
|
||||
def update_name(self,first,last,suffix,patronymic,title,the_type,note,format,priv):
|
||||
def update_name(self,first,last,suffix,patronymic,title,
|
||||
the_type,priv):
|
||||
|
||||
if self.name.get_first_name() != first:
|
||||
self.name.set_first_name(first)
|
||||
@ -330,20 +303,6 @@ class NameEditor(DisplayState.ManagedWindow):
|
||||
if self.name.get_type() != the_type:
|
||||
self.name.set_type(the_type)
|
||||
|
||||
if self.name.get_note() != note:
|
||||
self.name.set_note(note)
|
||||
|
||||
if self.name.get_note_format() != format:
|
||||
self.name.set_note_format(format)
|
||||
|
||||
if self.name.get_privacy() != priv:
|
||||
self.name.set_privacy(priv)
|
||||
|
||||
def on_switch_page(self,obj,a,page):
|
||||
start = self.note_buffer.get_start_iter()
|
||||
stop = self.note_buffer.get_end_iter()
|
||||
text = unicode(self.note_buffer.get_text(start, stop, False))
|
||||
if text:
|
||||
Utils.bold_label(self.notes_label)
|
||||
else:
|
||||
Utils.unbold_label(self.notes_label)
|
||||
|
File diff suppressed because it is too large
Load Diff
Loading…
x
Reference in New Issue
Block a user