20426f36e3
* Editors/_EditRepository.py * Editors/_EditFamily.py * DisplayTabs/_SourceEmbedList.py * DisplayTabs/_PersonRefEmbedList.py * DisplayTabs/_RepoEmbedList.py * DisplayTabs/_AddrEmbedList.py * DisplayTabs/_WebEmbedList.py * DisplayTabs/_NameEmbedList.py * DisplayTabs/_EventEmbedList.py * DisplayTabs/_EmbeddedList.py * DisplayTabs/_NoteTab.py * DisplayTabs/_LocationEmbedList.py * DisplayTabs/_ButtonTab.py * DisplayTabs/_DataEmbedList.py * DisplayTabs/_AttrEmbedList.py * DisplayTabs/_LdsEmbedList.py * DisplayTabs/_GrampsTab.py add Up and Down buttons to the tabs. Added individual tooltips for buttons 0001807: Missing buttons MoveUp, MoveDown on a Events list in a person... svn: r10108
196 lines
6.3 KiB
Python
196 lines
6.3 KiB
Python
#
|
|
# Gramps - a GTK+/GNOME based genealogy program
|
|
#
|
|
# Copyright (C) 2000-2007 Donald N. Allingham
|
|
#
|
|
# This program is free software; you can redistribute it and/or modify
|
|
# it under the terms of the GNU General Public License as published by
|
|
# the Free Software Foundation; either version 2 of the License, or
|
|
# (at your option) any later version.
|
|
#
|
|
# This program is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
# GNU General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU General Public License
|
|
# along with this program; if not, write to the Free Software
|
|
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
#
|
|
|
|
# $Id$
|
|
|
|
#-------------------------------------------------------------------------
|
|
#
|
|
# Python classes
|
|
#
|
|
#-------------------------------------------------------------------------
|
|
from gettext import gettext as _
|
|
|
|
#-------------------------------------------------------------------------
|
|
#
|
|
# GTK/Gnome modules
|
|
#
|
|
#-------------------------------------------------------------------------
|
|
|
|
#-------------------------------------------------------------------------
|
|
#
|
|
# GRAMPS classes
|
|
#
|
|
#-------------------------------------------------------------------------
|
|
import Errors
|
|
import gen.lib
|
|
from _NoteModel import NoteModel
|
|
from _EmbeddedList import EmbeddedList
|
|
from DdTargets import DdTargets
|
|
|
|
#-------------------------------------------------------------------------
|
|
#
|
|
# NoteTab
|
|
#
|
|
#-------------------------------------------------------------------------
|
|
class NoteTab(EmbeddedList):
|
|
"""
|
|
Note List display tab for edit dialogs.
|
|
|
|
Derives from the EmbeddedList class.
|
|
"""
|
|
|
|
_HANDLE_COL = 2
|
|
_DND_TYPE = DdTargets.NOTE_LINK
|
|
|
|
_MSG = {
|
|
'add' : _('Create and add a new note'),
|
|
'del' : _('Remove the existing note'),
|
|
'edit' : _('Edit the selected note'),
|
|
'share' : _('Add an existing note'),
|
|
'up' : _('Move the selected note upwards'),
|
|
'down' : _('Move the selected note downwards'),
|
|
}
|
|
|
|
_column_names = [
|
|
(_('Type'), 0, 100),
|
|
(_('Preview'), 1, 200),
|
|
]
|
|
|
|
def __init__(self, dbstate, uistate, track, data, callertitle=None,
|
|
notetype=None):
|
|
self.data = data
|
|
self.callertitle = callertitle
|
|
self.notetype = notetype
|
|
EmbeddedList.__init__(self, dbstate, uistate, track,
|
|
_("_Notes"), NoteModel, share_button=True,
|
|
move_buttons=True)
|
|
|
|
def connect_db_signals(self):
|
|
#connect external remove/change of object to rebuild of grampstab
|
|
self._add_db_signal('note-delete', self.note_delete)
|
|
self._add_db_signal('note-rebuild', self.rebuild)
|
|
self._add_db_signal('note-update',self.note_update)
|
|
|
|
def get_editor(self):
|
|
pass
|
|
|
|
def get_user_values(self):
|
|
return []
|
|
|
|
def get_data(self):
|
|
"""
|
|
Return the data associated with display tab
|
|
"""
|
|
return self.data
|
|
|
|
def column_order(self):
|
|
"""
|
|
Return the column order of the columns in the display tab.
|
|
"""
|
|
return ((1, 0), (1, 1))
|
|
|
|
def add_button_clicked(self, obj):
|
|
"""
|
|
Create a new Note instance and call the EditNote editor with the new
|
|
note.
|
|
|
|
Called when the Add button is clicked.
|
|
If the window already exists (Errors.WindowActiveError), we ignore it.
|
|
This prevents the dialog from coming up twice on the same object.
|
|
"""
|
|
note = gen.lib.Note()
|
|
if self.notetype :
|
|
note.set_type(self.notetype)
|
|
try:
|
|
from Editors import EditNote
|
|
EditNote(self.dbstate, self.uistate, self.track,
|
|
note, self.add_callback,
|
|
self.callertitle, extratype = [self.notetype])
|
|
except Errors.WindowActiveError:
|
|
pass
|
|
|
|
def add_callback(self, name):
|
|
"""
|
|
Called to update the screen when a new note is added
|
|
"""
|
|
self.get_data().append(name)
|
|
self.changed = True
|
|
self.rebuild()
|
|
|
|
def edit_button_clicked(self, obj):
|
|
"""
|
|
Get the selected Note instance and call the EditNote editor with the
|
|
note.
|
|
|
|
Called when the Edit button is clicked.
|
|
If the window already exists (Errors.WindowActiveError), we ignore it.
|
|
This prevents the dialog from coming up twice on the same object.
|
|
"""
|
|
handle = self.get_selected()
|
|
if handle:
|
|
note = self.dbstate.db.get_note_from_handle(handle)
|
|
try:
|
|
from Editors import EditNote
|
|
EditNote(self.dbstate, self.uistate, self.track, note,
|
|
callertitle = self.callertitle,
|
|
extratype = [self.notetype] )
|
|
except Errors.WindowActiveError:
|
|
pass
|
|
|
|
def share_button_clicked(self, obj):
|
|
from Selectors import selector_factory
|
|
SelectNote = selector_factory('Note')
|
|
|
|
sel = SelectNote(self.dbstate,self.uistate,self.track)
|
|
note = sel.run()
|
|
if note:
|
|
self.add_callback(note.handle)
|
|
|
|
def get_icon_name(self):
|
|
"""
|
|
Return the stock-id icon name associated with the display tab
|
|
"""
|
|
return 'gramps-notes'
|
|
|
|
def note_delete(self, del_note_handle_list):
|
|
"""
|
|
Outside of this tab note objects have been deleted. Check if tab
|
|
and object must be changed.
|
|
Note: delete of object will cause reference on database to be removed,
|
|
so this method need not do this
|
|
"""
|
|
rebuild = False
|
|
for handle in del_note_handle_list :
|
|
while self.data.count(handle) > 0:
|
|
self.data.remove(handle)
|
|
rebuild = True
|
|
if rebuild:
|
|
self.rebuild()
|
|
|
|
def note_update(self, upd_note_handle_list):
|
|
"""
|
|
Outside of this tab note objects have been updated. Check if tab
|
|
and object must be updated.
|
|
"""
|
|
for handle in upd_note_handle_list :
|
|
if handle in self.data:
|
|
self.rebuild()
|
|
break
|