* src/EditPerson.py: more readonly support

* src/NoteEdit.py: more readonly support
* src/Sources.py: more readonly support
* src/gramps_main.py: more readonly support
* src/gramps.glade: more readonly support


svn: r4046
This commit is contained in:
Don Allingham 2005-02-18 04:49:59 +00:00
parent 9ba1e69000
commit 37e3d0d2e3
6 changed files with 1959 additions and 60 deletions

View File

@ -1,3 +1,10 @@
2005-02-17 Don Allingham <dallingham@users.sourceforge.net>
* src/EditPerson.py: more readonly support
* src/NoteEdit.py: more readonly support
* src/Sources.py: more readonly support
* src/gramps_main.py: more readonly support
* src/gramps.glade: more readonly support
2005-02-17 Alex Roitman <shura@alex.neuro.umn.edu> 2005-02-17 Alex Roitman <shura@alex.neuro.umn.edu>
* src/docgen/LPRDoc.py (write_at): Correct vertical offset. * src/docgen/LPRDoc.py (write_at): Correct vertical offset.
* src/docgen/PdfDoc.py (write_at,draw_bar): Add functions. * src/docgen/PdfDoc.py (write_at,draw_bar): Add functions.

View File

@ -128,6 +128,8 @@ class EditPerson:
p = db.get_place_from_handle(key).get_display_info() p = db.get_place_from_handle(key).get_display_info()
self.pdmap[p[0]] = key self.pdmap[p[0]] = key
mod = not self.db.readonly
self.load_obj = None self.load_obj = None
self.top = gtk.glade.XML(const.editPersonFile, "editPerson","gramps") self.top = gtk.glade.XML(const.editPersonFile, "editPerson","gramps")
self.window = self.get_widget("editPerson") self.window = self.get_widget("editPerson")
@ -139,6 +141,7 @@ class EditPerson:
self.db, self, self.window) self.db, self, self.window)
self.complete = self.get_widget('complete') self.complete = self.get_widget('complete')
self.complete.set_sensitive(mod)
self.name_delete_btn = self.top.get_widget('aka_delete') self.name_delete_btn = self.top.get_widget('aka_delete')
self.name_edit_btn = self.top.get_widget('aka_edit') self.name_edit_btn = self.top.get_widget('aka_edit')
self.web_delete_btn = self.top.get_widget('delete_url') self.web_delete_btn = self.top.get_widget('delete_url')
@ -151,8 +154,11 @@ class EditPerson:
self.addr_edit_btn = self.top.get_widget('addr_edit_btn') self.addr_edit_btn = self.top.get_widget('addr_edit_btn')
self.notes_field = self.get_widget("personNotes") self.notes_field = self.get_widget("personNotes")
self.notes_field.set_editable(mod)
self.flowed = self.get_widget("flowed") self.flowed = self.get_widget("flowed")
self.flowed.set_sensitive(mod)
self.preform = self.get_widget("preform") self.preform = self.get_widget("preform")
self.preform.set_sensitive(mod)
self.event_name_field = self.get_widget("eventName") self.event_name_field = self.get_widget("eventName")
self.event_place_field = self.get_widget("eventPlace") self.event_place_field = self.get_widget("eventPlace")
self.event_cause_field = self.get_widget("eventCause") self.event_cause_field = self.get_widget("eventCause")
@ -191,19 +197,33 @@ class EditPerson:
self.alt_prefix_field = self.get_widget("alt_prefix") self.alt_prefix_field = self.get_widget("alt_prefix")
self.name_type_field = self.get_widget("name_type") self.name_type_field = self.get_widget("name_type")
self.ntype_field = self.get_widget("ntype") self.ntype_field = self.get_widget("ntype")
self.ntype_field.set_sensitive(mod)
self.suffix = self.get_widget("suffix") self.suffix = self.get_widget("suffix")
self.suffix.set_editable(mod)
self.prefix = self.get_widget("prefix") self.prefix = self.get_widget("prefix")
self.prefix.set_editable(mod)
self.given = self.get_widget("givenName") self.given = self.get_widget("givenName")
self.given.set_editable(mod)
self.nick = self.get_widget("nickname") self.nick = self.get_widget("nickname")
self.nick.set_editable(mod)
self.title = self.get_widget("title") self.title = self.get_widget("title")
self.title.set_editable(mod)
self.bdate = self.get_widget("birthDate") self.bdate = self.get_widget("birthDate")
self.bdate.set_editable(mod)
self.bplace = self.get_widget("birth_place") self.bplace = self.get_widget("birth_place")
self.bplace.set_editable(mod)
self.surname = self.get_widget("surname") self.surname = self.get_widget("surname")
self.surname.set_editable(mod)
self.ddate = self.get_widget("deathDate") self.ddate = self.get_widget("deathDate")
self.ddate.set_editable(mod)
self.dplace = self.get_widget("death_place") self.dplace = self.get_widget("death_place")
self.dplace.set_editable(mod)
self.is_male = self.get_widget("genderMale") self.is_male = self.get_widget("genderMale")
self.is_male.set_sensitive(mod)
self.is_female = self.get_widget("genderFemale") self.is_female = self.get_widget("genderFemale")
self.is_female.set_sensitive(mod)
self.is_unknown = self.get_widget("genderUnknown") self.is_unknown = self.get_widget("genderUnknown")
self.is_unknown.set_sensitive(mod)
self.addr_note = self.get_widget("addr_note") self.addr_note = self.get_widget("addr_note")
self.addr_source = self.get_widget("addr_source") self.addr_source = self.get_widget("addr_source")
self.attr_note = self.get_widget("attr_note") self.attr_note = self.get_widget("attr_note")
@ -211,6 +231,7 @@ class EditPerson:
self.name_note = self.get_widget("name_note") self.name_note = self.get_widget("name_note")
self.name_source = self.get_widget("name_source") self.name_source = self.get_widget("name_source")
self.gid = self.get_widget("gid") self.gid = self.get_widget("gid")
self.gid.set_editable(mod)
self.slist = self.get_widget("slist") self.slist = self.get_widget("slist")
self.general_label = self.get_widget("general_label") self.general_label = self.get_widget("general_label")
self.names_label = self.get_widget("names_label") self.names_label = self.get_widget("names_label")
@ -621,18 +642,37 @@ class EditPerson:
may cases is hidden.""" may cases is hidden."""
self.ldsbap_date = self.get_widget("ldsbapdate") self.ldsbap_date = self.get_widget("ldsbapdate")
self.ldsbap_date.set_editable(not self.db.readonly)
self.ldsbap_temple = self.get_widget("ldsbaptemple") self.ldsbap_temple = self.get_widget("ldsbaptemple")
self.ldsbap_temple.set_sensitive(not self.db.readonly)
self.ldsbapplace = self.get_widget("lds_bap_place")
self.ldsbapplace.set_editable(not self.db.readonly)
self.ldsend_date = self.get_widget("endowdate") self.ldsend_date = self.get_widget("endowdate")
self.ldsend_date.set_editable(not self.db.readonly)
self.ldsend_temple = self.get_widget("endowtemple") self.ldsend_temple = self.get_widget("endowtemple")
self.ldsend_temple.set_sensitive(not self.db.readonly)
self.ldsendowplace = self.get_widget("lds_end_place")
self.ldsendowplace.set_editable(not self.db.readonly)
self.ldsendowstat = self.get_widget("endowstat")
self.ldsendowstat.set_sensitive(not self.db.readonly)
self.ldsseal_date = self.get_widget("sealdate") self.ldsseal_date = self.get_widget("sealdate")
self.ldsseal_temple = self.get_widget("sealtemple") self.ldsseal_temple = self.get_widget("sealtemple")
self.ldsseal_fam = self.get_widget("sealparents")
self.ldsbapstat = self.get_widget("ldsbapstat")
self.ldssealstat = self.get_widget("sealstat")
self.ldsendowstat = self.get_widget("endowstat")
self.ldsbapplace = self.get_widget("lds_bap_place")
self.ldssealplace = self.get_widget("lds_seal_place") self.ldssealplace = self.get_widget("lds_seal_place")
self.ldsendowplace = self.get_widget("lds_end_place") self.ldsseal_date.set_editable(not self.db.readonly)
self.ldsseal_temple.set_sensitive(not self.db.readonly)
self.ldssealplace.set_editable(not self.db.readonly)
self.ldsseal_fam = self.get_widget("sealparents")
self.ldsseal_fam.set_sensitive(not self.db.readonly)
self.ldsbapstat = self.get_widget("ldsbapstat")
self.ldsbapstat.set_sensitive(not self.db.readonly)
self.ldssealstat = self.get_widget("sealstat")
self.ldssealstat.set_sensitive(not self.db.readonly)
self.bstat = self.lds_field(self.lds_baptism, self.bstat = self.lds_field(self.lds_baptism,
self.ldsbap_temple, self.ldsbap_temple,
@ -1789,7 +1829,8 @@ class EditPerson:
def on_ldsbap_note_clicked(self,obj): def on_ldsbap_note_clicked(self,obj):
import NoteEdit import NoteEdit
NoteEdit.NoteEditor(self.lds_baptism,self,self.window) NoteEdit.NoteEditor(self.lds_baptism,self,self.window,
readonly=self.db.readonly)
def on_ldsendow_source_clicked(self,obj): def on_ldsendow_source_clicked(self,obj):
Sources.SourceSelector(self.lds_endowment.get_source_references(), Sources.SourceSelector(self.lds_endowment.get_source_references(),
@ -1801,7 +1842,8 @@ class EditPerson:
def on_ldsendow_note_clicked(self,obj): def on_ldsendow_note_clicked(self,obj):
import NoteEdit import NoteEdit
NoteEdit.NoteEditor(self.lds_endowment,self,self.window) NoteEdit.NoteEditor(self.lds_endowment,self,self.window,
readonly=self.db.readonly)
def on_ldsseal_source_clicked(self,obj): def on_ldsseal_source_clicked(self,obj):
Sources.SourceSelector(self.lds_sealing.get_source_references(), Sources.SourceSelector(self.lds_sealing.get_source_references(),
@ -1813,7 +1855,8 @@ class EditPerson:
def on_ldsseal_note_clicked(self,obj): def on_ldsseal_note_clicked(self,obj):
import NoteEdit import NoteEdit
NoteEdit.NoteEditor(self.lds_sealing,self,self.window) NoteEdit.NoteEditor(self.lds_sealing,self,self.window,
readonly=self.db.readonly)
def load_person_image(self): def load_person_image(self):
media_list = self.person.get_media_list() media_list = self.person.get_media_list()

View File

@ -44,7 +44,8 @@ import Utils
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
class NoteEditor: class NoteEditor:
"""Displays a simple text editor that allows a person to edit a note""" """Displays a simple text editor that allows a person to edit a note"""
def __init__(self,data,parent,parent_window=None,callback=None): def __init__(self,data,parent,parent_window=None,callback=None,
readonly=False):
self.parent = parent self.parent = parent
self.callback = callback self.callback = callback
@ -59,6 +60,7 @@ class NoteEditor:
self.data = data self.data = data
self.parent_window = parent_window self.parent_window = parent_window
self.glade = gtk.glade.XML(const.gladeFile,"note_edit") self.glade = gtk.glade.XML(const.gladeFile,"note_edit")
self.readonly = readonly
self.draw() self.draw()
def draw(self): def draw(self):
@ -72,15 +74,17 @@ class NoteEditor:
if self.callback: if self.callback:
self.title_entry = self.glade.get_widget('title') self.title_entry = self.glade.get_widget('title')
self.title_entry.set_text(self.data.get_description()) self.title_entry.set_text(self.data.get_description())
self.title_entry.set_editable(not self.readonly)
else: else:
self.glade.get_widget('tbox').hide() self.glade.get_widget('tbox').hide()
self.entry = self.glade.get_widget('note') self.entry = self.glade.get_widget('note')
self.entry.set_editable(gtk.TRUE)
self.entry.get_buffer().set_text(self.data.get_note()) self.entry.get_buffer().set_text(self.data.get_note())
self.entry.set_editable(not self.readonly)
cancel_button = self.glade.get_widget('cancel') cancel_button = self.glade.get_widget('cancel')
ok_button = self.glade.get_widget('ok') ok_button = self.glade.get_widget('ok')
ok_button.set_sensitive(not self.readonly)
cancel_button.connect("clicked",self.close) cancel_button.connect("clicked",self.close)
ok_button.connect("clicked",self.on_save_note_clicked) ok_button.connect("clicked",self.on_save_note_clicked)
self.top.connect("delete_event",self.on_delete_event) self.top.connect("delete_event",self.on_delete_event)

View File

@ -92,9 +92,12 @@ class SourceSelector:
self.slist = self.top.get_widget("slist") self.slist = self.top.get_widget("slist")
self.edit = self.top.get_widget('edit') self.edit = self.top.get_widget('edit')
self.delete = self.top.get_widget('delete') self.delete = self.top.get_widget('delete')
self.delete.set_sensitive(not self.db.readonly)
self.selection = self.slist.get_selection() self.selection = self.slist.get_selection()
self.model = gtk.ListStore(gobject.TYPE_STRING, gobject.TYPE_STRING) self.model = gtk.ListStore(gobject.TYPE_STRING, gobject.TYPE_STRING)
self.slist.set_model(self.model) self.slist.set_model(self.model)
self.top.get_widget('add').set_sensitive(not self.db.readonly)
self.top.get_widget('ok').set_sensitive(not self.db.readonly)
colno = 0 colno = 0
for title in [ (_('ID'),0,100), (_('Title'),1,150)]: for title in [ (_('ID'),0,100), (_('Title'),1,150)]:

File diff suppressed because it is too large Load Diff

View File

@ -1096,36 +1096,38 @@ class Gramps:
_('You do not have write access to the selected ' _('You do not have write access to the selected '
'file.')) 'file.'))
# try: try:
# if self.load_database(filename,callback,mode=mode) == 1:
# if filename[-1] == '/':
# filename = filename[:-1]
# name = os.path.basename(filename)
# self.topWindow.set_title("%s - GRAMPS" % name)
# else:
# GrampsKeys.save_last_file("")
# ErrorDialog(_('Cannot open database'),
# _('The database file specified could not be opened.'))
# return 0
# except db.DBAccessError, msg:
# ErrorDialog(_('Cannot open database'),
# _('%s could not be opened.' % filename) + '\n' + msg[1])
# return 0
if self.load_database(filename,callback,mode=mode) == 1: if self.load_database(filename,callback,mode=mode) == 1:
if filename[-1] == '/': if filename[-1] == '/':
filename = filename[:-1] filename = filename[:-1]
name = os.path.basename(filename) name = os.path.basename(filename)
if self.db.readonly:
self.topWindow.set_title("%s (%s) - GRAMPS" % (name,_('Read Only')))
else:
self.topWindow.set_title("%s - GRAMPS" % name) self.topWindow.set_title("%s - GRAMPS" % name)
else: else:
GrampsKeys.save_last_file("") GrampsKeys.save_last_file("")
ErrorDialog(_('Cannot open database'), ErrorDialog(_('Cannot open database'),
_('The database file specified could not be opened.')) _('The database file specified could not be opened.'))
return 0 return 0
except db.DBAccessError, msg:
ErrorDialog(_('Cannot open database'),
_('%s could not be opened.' % filename) + '\n' + msg[1])
return 0
self.topWindow.set_resizable(gtk.TRUE) self.topWindow.set_resizable(gtk.TRUE)
#self.people_view.apply_filter() self.gtop.get_widget('import1').set_sensitive(not self.db.readonly)
self.gtop.get_widget('abandon').set_sensitive(not self.db.readonly)
self.gtop.get_widget('undolabel').set_sensitive(not self.db.readonly)
self.gtop.get_widget('redolabel').set_sensitive(not self.db.readonly)
self.gtop.get_widget('add_item').set_sensitive(not self.db.readonly)
self.gtop.get_widget('remove_item').set_sensitive(not self.db.readonly)
self.gtop.get_widget('merge').set_sensitive(not self.db.readonly)
self.gtop.get_widget('default_person1').set_sensitive(not self.db.readonly)
self.gtop.get_widget('edit_bookmarks').set_sensitive(not self.db.readonly)
self.gtop.get_widget('tools_menu').set_sensitive(not self.db.readonly)
self.gtop.get_widget('tools').set_sensitive(not self.db.readonly)
self.goto_active_person() self.goto_active_person()
return 1 return 1