diff --git a/gramps2/ChangeLog b/gramps2/ChangeLog index 7eb7a3042..9f82e2137 100644 --- a/gramps2/ChangeLog +++ b/gramps2/ChangeLog @@ -1,3 +1,7 @@ +2006-05-04 Alex Roitman + * src/DisplayTabs.py: remove file. + * src/DisplayTabs: Add package. + 2006-05-04 Don Allingham * src/DataViews/_PersonView.py: start of filter sidebar diff --git a/gramps2/configure.in b/gramps2/configure.in index 8367d0841..1b39eeeed 100644 --- a/gramps2/configure.in +++ b/gramps2/configure.in @@ -194,6 +194,7 @@ src/Makefile src/RelLib/Makefile src/Config/Makefile src/Mime/Makefile +src/DisplayTabs/Makefile src/ObjectSelector/Makefile src/GrampsLogger/Makefile src/TreeViews/Makefile diff --git a/gramps2/po/ChangeLog b/gramps2/po/ChangeLog index 52d503b24..90664c0f7 100644 --- a/gramps2/po/ChangeLog +++ b/gramps2/po/ChangeLog @@ -1,3 +1,6 @@ +2006-05-04 Alex Roitman + * POTFILES.in: Add new files. + 2006-05-02 Alex Roitman * POTFILES.in: Add new files. diff --git a/gramps2/po/POTFILES.in b/gramps2/po/POTFILES.in index afc6a5daf..709f9fdf1 100644 --- a/gramps2/po/POTFILES.in +++ b/gramps2/po/POTFILES.in @@ -98,6 +98,44 @@ src/docgen/PSDrawDoc.py src/docgen/RTFDoc.py src/docgen/SpreadSheetDoc.py src/docgen/SvgDrawDoc.py +src/DisplayTabs/_AddrEmbedList.py +src/DisplayTabs/_AddressModel.py +src/DisplayTabs/_AttrEmbedList.py +src/DisplayTabs/_AttrModel.py +src/DisplayTabs/_BackRefList.py +src/DisplayTabs/_BackRefModel.py +src/DisplayTabs/_ButtonTab.py +src/DisplayTabs/_ChildModel.py +src/DisplayTabs/_DataEmbedList.py +src/DisplayTabs/_DataModel.py +src/DisplayTabs/_EmbeddedList.py +src/DisplayTabs/_EventBackRefList.py +src/DisplayTabs/_EventEmbedList.py +src/DisplayTabs/_EventRefModel.py +src/DisplayTabs/_FamilyAttrEmbedList.py +src/DisplayTabs/_FamilyLdsEmbedList.py +src/DisplayTabs/_GalleryTab.py +src/DisplayTabs/_GrampsTab.py +src/DisplayTabs/_LdsEmbedList.py +src/DisplayTabs/_LdsModel.py +src/DisplayTabs/_LocationEmbedList.py +src/DisplayTabs/_LocationModel.py +src/DisplayTabs/_MediaBackRefList.py +src/DisplayTabs/_NameEmbedList.py +src/DisplayTabs/_NameModel.py +src/DisplayTabs/_NoteTab.py +src/DisplayTabs/_PersonEventEmbedList.py +src/DisplayTabs/_PersonRefEmbedList.py +src/DisplayTabs/_PersonRefModel.py +src/DisplayTabs/_PlaceBackRefList.py +src/DisplayTabs/_RepoEmbedList.py +src/DisplayTabs/_RepoRefModel.py +src/DisplayTabs/_SourceBackRefList.py +src/DisplayTabs/_SourceEmbedList.py +src/DisplayTabs/_SourceRefModel.py +src/DisplayTabs/_WebEmbedList.py +src/DisplayTabs/_WebModel.py +src/DisplayTabs/__init__.py src/Editors/_EditAddress.py src/Editors/_EditAttribute.py src/Editors/_EditEvent.py diff --git a/gramps2/src/DisplayTabs.py b/gramps2/src/DisplayTabs.py deleted file mode 100644 index 1b0d1692a..000000000 --- a/gramps2/src/DisplayTabs.py +++ /dev/null @@ -1,2294 +0,0 @@ -# -# Gramps - a GTK+/GNOME based genealogy program -# -# Copyright (C) 2000-2006 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 -# - -#------------------------------------------------------------------------- -# -# GTK libraries -# -#------------------------------------------------------------------------- -import gtk -import gobject -import pango -from gtk.gdk import ACTION_COPY, BUTTON1_MASK - -#------------------------------------------------------------------------- -# -# python -# -#------------------------------------------------------------------------- - -from gettext import gettext as _ -import pickle - -try: - set() -except: - from sets import Set as set - -#------------------------------------------------------------------------- -# -# set up logging -# -#------------------------------------------------------------------------- -import logging -log = logging.getLogger(".DisplayTabs") - -#------------------------------------------------------------------------- -# -# GRAMPS libraries -# -#------------------------------------------------------------------------- -import DateHandler -import NameDisplay -import RelLib -import Utils -import ImgManip -import Spell -import Errors -import Mime - -from DdTargets import DdTargets -from GrampsWidgets import SimpleButton - -#------------------------------------------------------------------------- -# -# constants -# -#------------------------------------------------------------------------- - -#------------------------------------------------------------------------- -# -# Classes -# -#------------------------------------------------------------------------- - -class GrampsTab(gtk.HBox): - """ - This class provides the base level class for 'tabs', which are used to - fill in notebook tabs for GRAMPS edit dialogs. Each tab returns a - gtk container widget which can be inserted into a gtk.Notebook by the - instantiating object. - - All tab classes should inherit from GrampsTab - """ - - def __init__(self, dbstate, uistate, track, name): - """ - @param dbstate: The database state. Contains a reference to - the database, along with other state information. The GrampsTab - uses this to access the database and to pass to and created - child windows (such as edit dialogs). - @type dbstate: DbState - @param uistate: The UI state. Used primarily to pass to any created - subwindows. - @type uistate: DisplayState - @param track: The window tracking mechanism used to manage windows. - This is only used to pass to generted child windows. - @type track: list - @param name: Notebook label name - @type name: str/unicode - """ - gtk.HBox.__init__(self) - - # store information to pass to child windows - self.dbstate = dbstate - self.uistate = uistate - self.track = track - self.changed = False - - # save name used for notebook label, and build the widget used - # for the label - - self.tab_name = name - self.label_container = self.build_label_widget() - - # build the interface - self.share_btn = None - self.build_interface() - - def get_selected(self): - return None - - def is_empty(self): - """ - Indicates if the tab contains any data. This is used to determine - how the label should be displayed. - """ - return True - - def build_label_widget(self): - """ - Standard routine to build a widget. Does not need to be overridden - by the derrived class. Creates an container that has the label and - the icon in it. - @returns: widget to be used for the notebook label. - @rtype: gtk.HBox - """ - hbox = gtk.HBox() - self.tab_image = gtk.image_new_from_stock(self.get_icon_name(), - gtk.ICON_SIZE_MENU) - self.label = gtk.Label(self.tab_name) - hbox.pack_start(self.tab_image) - hbox.set_spacing(6) - hbox.add(self.label) - hbox.show_all() - return hbox - - def get_icon_name(self): - """ - Provides the name of the registered stock icon to be used as the - icon in the label. This is typically overridden by the derrived - class to provide the new name. - @returns: stock icon name - @rtype: str - """ - return gtk.STOCK_NEW - - def get_tab_widget(self): - """ - Provides the widget to be used for the notebook tab label. A - container class is provided, and the object may manipulate the - child widgets contained in the container. - @returns: gtk widget - @rtype: gtk.HBox - """ - return self.label_container - - def _set_label(self): - """ - Updates the label based of if the tab contains information. Tabs - without information will not have an icon, and the text will not - be bold. Tabs that contain data will have their icon displayed and - the label text will be in bold face. - """ - if not self.is_empty(): - self.tab_image.show() - self.label.set_text("%s" % self.tab_name) - self.label.set_use_markup(True) - else: - self.tab_image.hide() - self.label.set_text(self.tab_name) - - def build_interface(self): - """ - Builds the interface for the derived class. This function should be - overridden in the derived class. Since the classes are derrived from - gtk.HBox, the self.pack_start, self.pack_end, and self.add functions - can be used to add widgets to the interface. - """ - pass - -class ButtonTab(GrampsTab): - """ - This class derives from the base GrampsTab, yet is not a usable Tab. It - serves as another base tab for classes which need an Add/Edit/Remove button - combination. - """ - - _MSG = { - 'add' : _('Add'), - 'del' : _('Remove'), - 'edit' : _('Edit'), - 'share' : _('Share'), - } - - def __init__(self, dbstate, uistate, track, name, share_button=False): - """ - Similar to the base class, except after Build - @param dbstate: The database state. Contains a reference to - the database, along with other state information. The GrampsTab - uses this to access the database and to pass to and created - child windows (such as edit dialogs). - @type dbstate: DbState - @param uistate: The UI state. Used primarily to pass to any created - subwindows. - @type uistate: DisplayState - @param track: The window tracking mechanism used to manage windows. - This is only used to pass to generted child windows. - @type track: list - @param name: Notebook label name - @type name: str/unicode - """ - GrampsTab.__init__(self,dbstate, uistate, track, name) - self.tooltips = gtk.Tooltips() - self.create_buttons(share_button) - - def create_buttons(self, share_button=False): - """ - Creates a button box consisting of three buttons, one for Add, - one for Edit, and one for Delete. This button box is then appended - hbox (self). - """ - self.add_btn = SimpleButton(gtk.STOCK_ADD, self.add_button_clicked) - self.edit_btn = SimpleButton(gtk.STOCK_EDIT, self.edit_button_clicked) - self.del_btn = SimpleButton(gtk.STOCK_REMOVE, self.del_button_clicked) - - self.tooltips.set_tip(self.add_btn, self._MSG['add']) - self.tooltips.set_tip(self.edit_btn, self._MSG['edit']) - self.tooltips.set_tip(self.del_btn, self._MSG['del']) - - if share_button: - self.share_btn = SimpleButton(gtk.STOCK_INDEX, self.share_button_clicked) - self.tooltips.set_tip(self.share_btn, self._MSG['share']) - else: - self.share_btn = None - - vbox = gtk.VBox() - vbox.set_spacing(6) - vbox.pack_start(self.add_btn, False) - if share_button: - vbox.pack_start(self.share_btn, False) - vbox.pack_start(self.edit_btn, False) - vbox.pack_start(self.del_btn, False) - vbox.show_all() - self.pack_start(vbox, False) - - def double_click(self, obj, event): - """ - Handles the double click on list. If the double click occurs, - the Edit button handler is called - """ - if event.type == gtk.gdk._2BUTTON_PRESS and event.button == 1: - self.edit_button_clicked(obj) - - def add_button_clicked(self, obj): - """ - Function called with the Add button is clicked. This function - should be overridden by the derived class. - """ - print "Uncaught Add clicked" - - def share_button_clicked(self, obj): - """ - Function called with the Add button is clicked. This function - should be overridden by the derived class. - """ - print "Uncaught Share clicked" - - def del_button_clicked(self, obj): - """ - Function called with the Delete button is clicked. This function - should be overridden by the derived class. - """ - print "Uncaught Delete clicked" - - def edit_button_clicked(self, obj): - """ - Function called with the Edit button is clicked or the double - click is caught. This function should be overridden by the derived - class. - """ - print "Uncaught Edit clicked" - - def _selection_changed(self, obj=None): - """ - Attached to the selection's 'changed' signal. Checks - to see if anything is selected. If it is, the edit and - delete buttons are enabled, otherwise the are disabled. - """ - # Comparing to None is important, as empty strings - # and 0 can be returned - if self.get_selected() != None: - self.edit_btn.set_sensitive(True) - self.del_btn.set_sensitive(True) - else: - self.edit_btn.set_sensitive(False) - self.del_btn.set_sensitive(False) - -class EmbeddedList(ButtonTab): - """ - This class provides the base class for all the list tabs. It - maintains a gtk.TreeView, including the selection and button - sensitivity. - """ - - _HANDLE_COL = -1 - _DND_TYPE = None - _DND_EXTRA = None - - def __init__(self, dbstate, uistate, track, name, build_model, - share=False): - """ - Creates a new list, using the passed build_model to - populate the list. - """ - ButtonTab.__init__(self, dbstate, uistate, track, name, share) - - - self.changed = False - self.build_model = build_model - - # handle the selection - self.selection = self.tree.get_selection() - self.selection.connect('changed', self._selection_changed) - - # build the columns - self.columns = [] - self.build_columns() - - if self._DND_TYPE: - self._set_dnd() - - # set up right click option - self.tree.connect('button-press-event', self._on_button_press) - - # build the initial data - self.rebuild() - self.show_all() - - def _on_button_press(self, obj, event): - if event.type == gtk.gdk.BUTTON_PRESS and event.button == 3: - ref = self.get_selected() - if ref: - self.right_click(obj, event) - - def right_click(self, obj, event): - - if self.share_btn: - itemlist = [ - (True, gtk.STOCK_ADD, self.add_button_clicked), - (False, _('Share'), self.edit_button_clicked), - (True, gtk.STOCK_EDIT, self.edit_button_clicked), - (True, gtk.STOCK_REMOVE, self.del_button_clicked), - ] - else: - itemlist = [ - (True, gtk.STOCK_ADD, self.add_button_clicked), - (True, gtk.STOCK_EDIT, self.edit_button_clicked), - (True, gtk.STOCK_REMOVE, self.del_button_clicked), - ] - - menu = gtk.Menu() - for (image, title, func) in itemlist: - if image: - item = gtk.ImageMenuItem(stock_id=title) - else: - item = gtk.MenuItem(title) - item.connect('activate', func) - item.show() - menu.append(item) - menu.popup(None, None, None, event.button, event.time) - - def find_index(self, obj): - """ - returns the index of the object within the associated data - """ - return self.get_data().index(obj) - - def _set_dnd(self): - """ - Sets up drag-n-drop. The source and destionation are set by calling .target() - on the _DND_TYPE. Obviously, this means that there must be a _DND_TYPE - variable defined that points to an entry in DdTargets. - """ - - if self._DND_EXTRA: - dnd_types = [ self._DND_TYPE.target(), self._DND_EXTRA.target() ] - else: - dnd_types = [ self._DND_TYPE.target() ] - - self.tree.drag_dest_set(gtk.DEST_DEFAULT_ALL, dnd_types, ACTION_COPY) - self.tree.drag_source_set(BUTTON1_MASK, [self._DND_TYPE.target()], ACTION_COPY) - self.tree.connect('drag_data_get', self.drag_data_get) - self.tree.connect('drag_data_received', self.drag_data_received) - - def drag_data_get(self, widget, context, sel_data, info, time): - """ - Provide the drag_data_get function, which passes a tuple consisting of: - - 1) Drag type defined by the .drag_type field specfied by the value - assigned to _DND_TYPE - 2) The id value of this object, used for the purpose of determining - the source of the object. If the source of the object is the same - as the object, we are doing a reorder instead of a normal drag - and drop - 3) Pickled data. The pickled version of the selected object - 4) Source row. Used for a reorder to determine the original position - of the object - """ - - # get the selected object, returning if not is defined - obj = self.get_selected() - if not obj: - return - - # pickle the data, and build the tuple to be passed - value = (self._DND_TYPE.drag_type, id(self), obj,self.find_index(obj)) - data = pickle.dumps(value) - - # pass as a string (8 bits) - sel_data.set(sel_data.target, 8, data) - - def drag_data_received(self, widget, context, x, y, sel_data, info, time): - """ - Handle the standard gtk interface for drag_data_received. - - If the selection data is define, extract the value from sel_data.data, - and decide if this is a move or a reorder. - """ - if sel_data and sel_data.data: - (mytype, selfid, obj, row_from) = pickle.loads(sel_data.data) - - # make sure this is the correct DND type for this object - if mytype == self._DND_TYPE.drag_type: - - # determine the destination row - row = self._find_row(x, y) - - # if the is same object, we have a move, otherwise, - # it is a standard drag-n-drop - - if id(self) == selfid: - self._move(row_from, row, obj) - else: - self._handle_drag(row, obj) - self.rebuild() - elif self._DND_EXTRA and mytype == self._DND_EXTRA.drag_type: - self.handle_extra_type(mytype, obj) - - def handle_extra_type(self, objtype, obj): - pass - - def _find_row(self, x, y): - row = self.tree.get_path_at_pos(x, y) - if row == None: - return len(self.get_data()) - else: - return row[0][0] - - def _handle_drag(self, row, obj): - self.get_data().insert(row, obj) - self.changed = True - self.rebuild() - - def _move(self, row_from, row_to, obj): - dlist = self.get_data() - if row_from < row_to: - dlist.insert(row_to, obj) - del dlist[row_from] - else: - del dlist[row_from] - dlist.insert(row_to-1, obj) - self.changed = True - self.rebuild() - - def get_icon_name(self): - """ - Specifies the basic icon used for a generic list. Typically, - a derived class will override this. The icon chose is the - STOCK_JUSTIFY_FILL icon, which in the default GTK style - looks kind of like a list. - """ - return gtk.STOCK_JUSTIFY_FILL - - def del_button_clicked(self, obj): - ref = self.get_selected() - if ref: - ref_list = self.get_data() - ref_list.remove(ref) - self.changed = True - self.rebuild() - - def build_interface(self): - """ - Builds the interface, instantiating a gtk.TreeView in a - gtk.ScrolledWindow. - """ - - # create the tree, turn on rule hinting and connect the - # button press to the double click function. - - self.tree = gtk.TreeView() - self.tree.set_reorderable(True) - self.tree.set_rules_hint(True) - self.tree.connect('button_press_event', self.double_click) - - # create the scrolled window, and attach the treeview - scroll = gtk.ScrolledWindow() - scroll.set_shadow_type(gtk.SHADOW_IN) - scroll.set_policy(gtk.POLICY_AUTOMATIC, gtk.POLICY_AUTOMATIC) - scroll.add(self.tree) - self.pack_start(scroll, True) - - def get_selected(self): - """ - returns the value associated with selected row in the model, - based of the _HANDLE_COL value. Each model must define this - to indicate what the returned value should be. If no selection - has been made, None is returned. - """ - (model, node) = self.selection.get_selected() - if node: - return model.get_value(node, self._HANDLE_COL) - return None - - def is_empty(self): - """ - Returns True if the get_data returns a length greater than - 0. Typically, get_data returns the list of associated data. - """ - return len(self.get_data()) == 0 - - def get_data(self): - """ - Returns the data associated with the list. This is typically - a list of objects. - - This should be overridden in the derrived classes. - """ - return [] - - def column_order(self): - """ - Specifies the column order for the columns. This should be - in the format of a list of tuples, in the format of (int,int), - where the first in indicates if the column is visible, and the - second column indicates the index into the model. - - This should be overridden in the derrived classes. - """ - return [] - - def build_columns(self): - """ - Builds the columns and inserts them into the TreeView. Any - previous columns exist, they will be in the self.columns array, - and removed. - """ - - # remove any existing columns, which would be stored in - # self.columns - - for column in self.columns: - self.tree.remove_column(column) - self.columns = [] - - # loop through the values returned by column_order - - for pair in self.column_order(): - - # if the first value isn't 1, then we skip the values - if not pair[0]: - continue - - # extract the name from the _column_names variable, and - # assign it to the column name. The text value is extracted - # from the model column specified in pair[1] - name = self._column_names[pair[1]][0] - renderer = gtk.CellRendererText() - renderer.set_property('ellipsize', pango.ELLIPSIZE_END) - column = gtk.TreeViewColumn(name, renderer, text=pair[1]) - - # insert the colum into the tree - column.set_resizable(True) - column.set_min_width(self._column_names[pair[1]][2]) - column.set_sort_column_id(self._column_names[pair[1]][1]) - self.columns.append(column) - self.tree.append_column(column) - - def rebuild(self): - """ - Rebuilds the data in the database by creating a new model, - using the build_model function passed at creation time. - """ - self.model = self.build_model(self.get_data(), self.dbstate.db) - self.tree.set_model(self.model) - self._set_label() - self._selection_changed() - -#------------------------------------------------------------------------- -# -# EventEmbedList -# -#------------------------------------------------------------------------- -class EventEmbedList(EmbeddedList): - - _HANDLE_COL = 6 - _DND_TYPE = DdTargets.EVENTREF - _DND_EXTRA = DdTargets.EVENT - - _MSG = { - 'add' : _('Add a new event'), - 'del' : _('Remove the selected event'), - 'edit' : _('Edit the selected event'), - 'share' : _('Share an exisiting event'), - } - - _column_names = [ - (_('Type'), 0, 100), - (_('Description'), 1, 175), - (_('ID'), 2, 60), - (_('Date'), 3, 150), - (_('Place'), 4, 140), - (_('Role'), 5, 80), - ] - - def __init__(self, dbstate, uistate, track, obj): - self.obj = obj - EmbeddedList.__init__(self, dbstate, uistate, track, - _('Events'), EventRefModel, True) - - def get_ref_editor(self): - from Editors import EditFamilyEventRef - return EditFamilyEventRef - - def get_icon_name(self): - return 'gramps-event' - - def get_data(self): - return self.obj.get_event_ref_list() - - def column_order(self): - return ((1, 0), (1, 1), (1, 2), (1, 3), (1, 4), (1, 5)) - - def handle_extra_type(self, objtype, obj): - try: - ref = RelLib.EventRef() - event = self.dbstate.db.get_event_from_handle(obj) - event.set_type(self.default_type()) - ref.set_role(self.default_role()) - self.get_ref_editor()( - self.dbstate, self.uistate, self.track, - event, ref, self.event_added) - except Errors.WindowActiveError: - pass - - def default_type(self): - return RelLib.EventType(RelLib.EventType.MARRIAGE) - - def default_role(self): - return RelLib.EventRoleType(RelLib.EventRoleType.FAMILY) - - def add_button_clicked(self, obj): - try: - ref = RelLib.EventRef() - event = RelLib.Event() - ref.set_role(self.default_role()) - event.set_type(self.default_type()) - self.get_ref_editor()( - self.dbstate, self.uistate, self.track, - event, ref, self.event_added) - except Errors.WindowActiveError: - pass - - def share_button_clicked(self, obj): - import SelectEvent - - sel = SelectEvent.SelectEvent(self.dbstate,self.uistate,self.track, - _("Select event")) - event = sel.run() - if event: - try: - ref = RelLib.EventRef() - ref.set_role(self.default_role()) - self.get_ref_editor()( - self.dbstate, self.uistate, self.track, - event, ref, self.event_added) - except Errors.WindowActiveError: - pass - - def edit_button_clicked(self, obj): - ref = self.get_selected() - if ref: - event = self.dbstate.db.get_event_from_handle(ref.ref) - try: - self.get_ref_editor()( - self.dbstate, self.uistate, self.track, - event, ref, self.event_updated) - except Errors.WindowActiveError: - pass - - def event_updated(self, ref, event): - self.changed = True - self.rebuild() - - def event_added(self, ref, event): - ref.ref = event.handle - self.get_data().append(ref) - self.changed = True - self.rebuild() - -class PersonEventEmbedList(EventEmbedList): - - def __init__(self, dbstate, uistate, track, obj): - self.orig_data = [ data for data in [ obj.get_birth_ref(), \ - obj.get_death_ref()] + \ - obj.get_event_ref_list() \ - if data ] - EventEmbedList.__init__(self, dbstate, uistate, track, obj) - - def get_data(self): - return self.orig_data - - def default_role(self): - return RelLib.EventRoleType(RelLib.EventRoleType.PRIMARY) - - def default_type(self): - type_list = [] - ref_list = [ e for e in [self.obj.get_birth_ref(), self.obj.get_death_ref()] + \ - self.obj.get_event_ref_list() if e ] - - event = None - for event_ref in ref_list: - event = self.dbstate.db.get_event_from_handle(event_ref.ref) - type_list.append(int(event.get_type())) - - if event: - etype = event.get_type() - for etype in [RelLib.EventType.BIRTH, RelLib.EventType.DEATH]: - if etype not in type_list: - return RelLib.EventType(etype) - return RelLib.EventType(RelLib.EventType.BIRTH) - - def get_ref_editor(self): - from Editors import EditEventRef - return EditEventRef - - def return_info(self): - new_list = [] - birth_ref = None - death_ref = None - - for ref in self.orig_data: - event = self.dbstate.db.get_event_from_handle(ref.ref) - if birth_ref == None and event.get_type() == RelLib.EventType.BIRTH: - birth_ref = ref - elif death_ref == None and event.get_type() == RelLib.EventType.DEATH: - death_ref = ref - else: - new_list.append(ref) - return (birth_ref, death_ref, new_list) - -#------------------------------------------------------------------------- -# -# BackRefList -# -#------------------------------------------------------------------------- -class BackRefList(EmbeddedList): - - _HANDLE_COL = 3 - - _column_names = [ - (_('Type'), 0, 100), - (_('ID'), 1, 75), - (_('Name'), 2, 250), - ] - - def __init__(self, dbstate, uistate, track, obj, refmodel, callback=None): - self.obj = obj - EmbeddedList.__init__(self, dbstate, uistate, track, - _('References'), refmodel) - self._callback = callback - self.model.connect('row-inserted', self.update_label) - - def update_label(self, *obj): - if self.model.count > 0: - self._set_label() - if self._callback and self.model.count > 1: - self._callback() - - def close(self): - self.model.close() - - def is_empty(self): - return self.model.count == 0 - - def create_buttons(self, share=False): - self.edit_btn = SimpleButton(gtk.STOCK_EDIT, self.edit_button_clicked) - - vbox = gtk.VBox() - vbox.set_spacing(6) - vbox.pack_start(self.edit_btn, False) - vbox.show_all() - self.pack_start(vbox, False) - - def _selection_changed(self, obj=None): - if self.get_selected(): - self.edit_btn.set_sensitive(True) - else: - self.edit_btn.set_sensitive(False) - - def get_data(self): - return self.obj - - def column_order(self): - return ((1, 0), (1, 1), (1, 2)) - - def find_node(self): - (model, node) = self.selection.get_selected() - try: - return (model.get_value(node, 0), model.get_value(node, 3)) - except: - return (None, None) - - def edit_button_clicked(self, obj): - (reftype, ref) = self.find_node() - if reftype == 'Person': - try: - from Editors import EditPerson - - person = self.dbstate.db.get_person_from_handle(ref) - EditPerson(self.dbstate, self.uistate, [], person) - except Errors.WindowActiveError: - pass - elif reftype == 'Family': - try: - from Editors import EditFamily - - family = self.dbstate.db.get_family_from_handle(ref) - EditFamily(self.dbstate, self.uistate, [], family) - except Errors.WindowActiveError: - pass - elif reftype == 'Source': - try: - from Editors import EditSource - - source = self.dbstate.db.get_source_from_handle(ref) - EditSource(self.dbstate, self.uistate, [], source) - except Errors.WindowActiveError: - pass - elif reftype == 'Place': - try: - from Editors import EditPlace - - place = self.dbstate.db.get_place_from_handle(ref) - EditPlace(self.dbstate, self.uistate, [], place) - except Errors.WindowActiveError: - pass - elif reftype == 'Media': - try: - from Editors import EditMedia - - obj = self.dbstate.db.get_object_from_handle(ref) - EditMedia(self.dbstate, self.uistate, [], obj) - except Errors.WindowActiveError: - pass - -class SourceBackRefList(BackRefList): - - def __init__(self, dbstate, uistate, track, obj, callback=None): - BackRefList.__init__(self, dbstate, uistate, track, obj, - BackRefModel, callback=callback) - - def get_icon_name(self): - return 'gramps-source' - -class EventBackRefList(BackRefList): - - def __init__(self, dbstate, uistate, track, obj, callback=None): - BackRefList.__init__(self, dbstate, uistate, track, obj, - BackRefModel, callback) - - def get_icon_name(self): - return 'gramps-event' - -class MediaBackRefList(BackRefList): - - def __init__(self, dbstate, uistate, track, obj, callback=None): - BackRefList.__init__(self, dbstate, uistate, track, obj, - BackRefModel, callback=callback) - - def get_icon_name(self): - return 'gramps-media' - -class PlaceBackRefList(BackRefList): - - def __init__(self, dbstate, uistate, track, obj, callback=None): - BackRefList.__init__(self, dbstate, uistate, track, obj, - BackRefModel, callback=callback) - - def get_icon_name(self): - return 'gramps-place' - - -#------------------------------------------------------------------------- -# -# DataEmbedList -# -#------------------------------------------------------------------------- -class DataEmbedList(EmbeddedList): - - _HANDLE_COL = 0 - _DND_TYPE = DdTargets.DATA - _column_names = [ - (_('Key'), 0, 150), - (_('Value'), 1, 250), - ] - - def __init__(self, dbstate, uistate, track, obj): - self.obj = obj - - EmbeddedList.__init__(self, dbstate, uistate, track, - _('Data'), DataModel) - - def build_columns(self): - EmbeddedList.build_columns(self) - - # Need to add attributes to renderers - # and connect renderers to the 'edited' signal - for colno in range(len(self.columns)): - for renderer in self.columns[colno].get_cell_renderers(): - renderer.set_property('editable',True) - renderer.connect('edited',self.edit_inline,colno) - - def get_data(self): - return self.obj.get_data_map() - - def is_empty(self): - return len(self.model)==0 - - def _get_map_from_model(self): - new_map = {} - for idx in range(len(self.model)): - node = self.model.get_iter(idx) - key = unicode(self.model.get_value(node,0)) - value = unicode(self.model.get_value(node,1)) - if key.strip(): - new_map[key] = value - return new_map - - def update(self): - new_map = self._get_map_from_model() - self.obj.set_data_map(new_map) - self._set_label() - - def column_order(self): - return ((1, 0), (1, 1)) - - def add_button_clicked(self, obj): - node = self.model.append(row=['','']) - self.selection.select_iter(node) - path = self.model.get_path(node) - self.tree.set_cursor_on_cell(path, - focus_column=self.columns[0], - focus_cell=None, - start_editing=True) - - def del_button_clicked(self, obj): - (model,node) = self.selection.get_selected() - if node: - self.model.remove(node) - self.update() - - def edit_inline(self, cell, path, new_text, data): - node = self.model.get_iter(path) - self.model.set_value(node,data,new_text) - self.update() - - def edit_button_clicked(self, obj): - (model,node) = self.selection.get_selected() - if node: - path = self.model.get_path(node) - self.tree.set_cursor_on_cell(path, - focus_column=self.columns[0], - focus_cell=None, - start_editing=True) - -#------------------------------------------------------------------------- -# -# -# -#------------------------------------------------------------------------- -class AttrEmbedList(EmbeddedList): - - _HANDLE_COL = 2 - _DND_TYPE = DdTargets.ATTRIBUTE - - _column_names = [ - (_('Type'), 0, 250), - (_('Value'), 1, 200), - ] - - def __init__(self, dbstate, uistate, track, data): - self.data = data - EmbeddedList.__init__(self, dbstate, uistate, track, - _('Attributes'), AttrModel) - - def get_editor(self): - from Editors import EditAttribute - return EditAttribute - - def get_user_values(self): - return self.dbstate.db.get_person_attribute_types() - - def get_data(self): - return self.data - - def column_order(self): - return ((1, 0), (1, 1)) - - def add_button_clicked(self, obj): - pname = '' - attr = RelLib.Attribute() - try: - self.get_editor()( - self.dbstate, self.uistate, self.track, attr, - pname, self.get_user_values(), self.add_callback) - except Errors.WindowActiveError: - pass - - def add_callback(self, name): - self.get_data().append(name) - self.changed = True - self.rebuild() - - def edit_button_clicked(self, obj): - attr = self.get_selected() - if attr: - pname = '' - try: - self.get_editor()( - self.dbstate, self.uistate, self.track, attr, - pname, self.get_user_values(), self.edit_callback) - except Errors.WindowActiveError: - pass - - def edit_callback(self, name): - self.changed = True - self.rebuild() - -#------------------------------------------------------------------------- -# -# -# -#------------------------------------------------------------------------- -class FamilyAttrEmbedList(AttrEmbedList): - - def __init__(self, dbstate, uistate, track, data): - AttrEmbedList.__init__(self, dbstate, uistate, track, data) - - def get_editor(self): - from Editors import EditFamilyAttribute - return EditFamilyAttribute - - def get_user_values(self): - return self.dbstate.db.get_family_attribute_types() - -#------------------------------------------------------------------------- -# -# -# -#------------------------------------------------------------------------- -class WebEmbedList(EmbeddedList): - - _HANDLE_COL = 3 - _DND_TYPE = DdTargets.URL - - _column_names = [ - (_('Type') , 0, 100), - (_('Path') , 1, 200), - (_('Description'), 2, 150), - ] - - def __init__(self, dbstate, uistate, track, data): - self.data = data - EmbeddedList.__init__(self, dbstate, uistate, track, - _('Internet'), WebModel) - - def get_data(self): - return self.data - - def column_order(self): - return ((1, 0), (1, 1), (1, 2)) - - def add_button_clicked(self, obj): - url = RelLib.Url() - try: - from Editors import EditUrl - - EditUrl(self.dbstate, self.uistate, self.track, - '', url, self.add_callback) - except Errors.WindowActiveError: - pass - - def add_callback(self, url): - self.get_data().append(url) - self.rebuild() - - def edit_button_clicked(self, obj): - url = self.get_selected() - if url: - try: - from Editors import EditUrl - - EditUrl(self.dbstate, self.uistate, self.track, - '', url, self.edit_callback) - except Errors.WindowActiveError: - pass - - def edit_callback(self, url): - self.rebuild() - -#------------------------------------------------------------------------- -# -# -# -#------------------------------------------------------------------------- -class NameEmbedList(EmbeddedList): - - _HANDLE_COL = 2 - _DND_TYPE = DdTargets.NAME - - _column_names = [ - (_('Name'), 0, 250), - (_('Type'), 1, 100), - ] - - def __init__(self, dbstate, uistate, track, data): - self.data = data - EmbeddedList.__init__(self, dbstate, uistate, track, - _('Names'), NameModel) - - def get_data(self): - return self.data - - def column_order(self): - return ((1, 0), (1, 1)) - - def add_button_clicked(self, obj): - name = RelLib.Name() - try: - from Editors import EditName - - EditName(self.dbstate, self.uistate, self.track, - name, self.add_callback) - except Errors.WindowActiveError: - pass - - def add_callback(self, name): - self.get_data().append(name) - self.rebuild() - - def edit_button_clicked(self, obj): - name = self.get_selected() - if name: - try: - from Editors import EditName - - EditName(self.dbstate, self.uistate, self.track, - name, self.edit_callback) - except Errors.WindowActiveError: - pass - - def edit_callback(self, name): - self.rebuild() - -#------------------------------------------------------------------------- -# -# -# -#------------------------------------------------------------------------- -class AddrEmbedList(EmbeddedList): - - _HANDLE_COL = 5 - _DND_TYPE = DdTargets.ADDRESS - - _column_names = [ - (_('Date'), 0, 150), - (_('Street'), 1, 225), - (_('State'), 2, 100), - (_('City'), 3, 100), - (_('Country'), 4, 75), - ] - - def __init__(self, dbstate, uistate, track, data): - self.data = data - EmbeddedList.__init__(self, dbstate, uistate, track, - _('Addresses'), AddressModel) - - def get_data(self): - return self.data - - def column_order(self): - return ((1, 0), (1, 1), (1, 2), (1, 3), (1, 4)) - - def add_button_clicked(self, obj): - addr = RelLib.Address() - try: - from Editors import EditAddress - - EditAddress(self.dbstate, self.uistate, self.track, - addr, self.add_callback) - except Errors.WindowActiveError: - pass - - def add_callback(self, name): - self.get_data().append(name) - self.rebuild() - - def edit_button_clicked(self, obj): - addr = self.get_selected() - if addr: - try: - from Editors import EditAddress - - EditAddress(self.dbstate, self.uistate, self.track, - addr, self.edit_callback) - except Errors.WindowActiveError: - pass - - def edit_callback(self, name): - self.rebuild() - -#------------------------------------------------------------------------- -# -# -# -#------------------------------------------------------------------------- -class PersonRefEmbedList(EmbeddedList): - - _HANDLE_COL = 3 - _DND_TYPE = DdTargets.ADDRESS - - _column_names = [ - (_('Name'), 0, 250), - (_('ID'), 1, 100), - (_('Relationship'), 2, 100), - ] - - def __init__(self, dbstate, uistate, track, data): - self.data = data - EmbeddedList.__init__(self, dbstate, uistate, track, - _('Relationships'), PersonRefModel) - - def get_data(self): - return self.data - - def column_order(self): - return ((1, 0), (1, 1), (1, 2)) - - def add_button_clicked(self, obj): - from Editors import EditPersonRef - - try: - ref = RelLib.PersonRef() - ref.rel = _('Godfather') - EditPersonRef( - self.dbstate, self.uistate, self.track, - ref, self.add_callback) - except Errors.WindowActiveError: - pass - - def add_callback(self, obj): - self.get_data().append(obj) - self.rebuild() - - def edit_button_clicked(self, obj): - ref = self.get_selected() - if ref: - try: - from Editors import EditPersonRef - EditPersonRef( - self.dbstate, self.uistate, self.track, - ref, self.edit_callback) - except Errors.WindowActiveError: - pass - - def edit_callback(self, obj): - self.rebuild() - -#------------------------------------------------------------------------- -# -# -# -#------------------------------------------------------------------------- -class LdsEmbedList(EmbeddedList): - - _HANDLE_COL = 5 -# _DND_TYPE = DdTargets.ADDRESS - - _column_names = [ - (_('Type'), 0, 150), - (_('Date'), 1, 150), - (_('Status'), 3, 75), - (_('Temple'), 2, 200), - (_('Place'), 3, 100), - ] - - def __init__(self, dbstate, uistate, track, data): - self.data = data - EmbeddedList.__init__(self, dbstate, uistate, track, - _('LDS'), LdsModel) - - def get_editor(self): - from Editors import EditLdsOrd - return EditLdsOrd - - def new_data(self): - return RelLib.LdsOrd() - - def get_data(self): - return self.data - - def column_order(self): - return ((1, 0), (1, 1), (1, 2), (1, 3), (1, 4)) - - def add_button_clicked(self, obj): - try: - self.get_editor()(self.dbstate, self.uistate, self.track, - self.new_data(), self.add_callback) - except Errors.WindowActiveError: - pass - - def add_callback(self, name): - self.get_data().append(name) - self.rebuild() - - def edit_button_clicked(self, obj): - lds = self.get_selected() - if lds: - try: - self.get_editor()(self.dbstate, self.uistate, self.track, - lds, self.edit_callback) - except Errors.WindowActiveError: - pass - - def edit_callback(self, name): - self.rebuild() - - -#------------------------------------------------------------------------- -# -# -# -#------------------------------------------------------------------------- -class FamilyLdsEmbedList(LdsEmbedList): - - _HANDLE_COL = 5 -# _DND_TYPE = DdTargets.ADDRESS - - _column_names = [ - (_('Type'), 0, 150), - (_('Date'), 1, 150), - (_('Status'), 3, 75), - (_('Temple'), 2, 200), - (_('Place'), 3, 100), - ] - - def __init__(self, dbstate, uistate, track, data): - LdsEmbedList.__init__(self, dbstate, uistate, track, data) - - def get_editor(self): - from Editors import EditFamilyLdsOrd - return EditFamilyLdsOrd - - def new_data(self): - lds = RelLib.LdsOrd() - lds.set_type(RelLib.LdsOrd.SEAL_TO_SPOUSE) - return lds - -#------------------------------------------------------------------------- -# -# -# -#------------------------------------------------------------------------- -class LocationEmbedList(EmbeddedList): - - _HANDLE_COL = 5 - _DND_TYPE = DdTargets.LOCATION - - _column_names = [ - (_('City'), 0, 150), - (_('County'), 1, 100), - (_('Church Parish'), 2, 100), - (_('State/Province'), 3, 100), - (_('Country'), 4, 75), - ] - - def __init__(self, dbstate, uistate, track, data): - self.data = data - EmbeddedList.__init__(self, dbstate, uistate, track, - _('Alternate Locations'), LocationModel) - - def get_data(self): - return self.data - - def column_order(self): - return ((1, 0), (1, 1), (1, 2), (1, 3), (1, 4)) - - def add_button_clicked(self, obj): - loc = RelLib.Location() - try: - from Editors import EditLocation - - EditLocation(self.dbstate, self.uistate, self.track, - loc, self.add_callback) - except Errors.WindowActiveError: - pass - - def add_callback(self, name): - self.get_data().append(name) - self.rebuild() - - def edit_button_clicked(self, obj): - loc = self.get_selected() - if loc: - try: - from Editors import EditLocation - - EditLocation(self.dbstate, self.uistate, self.track, - loc, self.edit_callback) - except Errors.WindowActiveError: - pass - - def edit_callback(self, name): - self.rebuild() - -#------------------------------------------------------------------------- -# -# NoteTab -# -#------------------------------------------------------------------------- -class NoteTab(GrampsTab): - - def __init__(self, dbstate, uistate, track, note_obj, title=_('Note')): - self.note_obj = note_obj - GrampsTab.__init__(self, dbstate, uistate, track, title) - self.show_all() - - def _update_label(self, *obj): - cc = self.buf.get_char_count() - if cc == 0 and not self.empty: - self.empty = True - self._set_label() - elif cc != 0 and self.empty: - self.empty = False - self._set_label() - - def is_empty(self): - """ - Indicates if the tab contains any data. This is used to determine - how the label should be displayed. - """ - return self.buf.get_char_count() == 0 - - def build_interface(self): - vbox = gtk.VBox() - - self.text = gtk.TextView() - self.flowed = gtk.RadioButton(None, _('Flowed')) - self.format = gtk.RadioButton(self.flowed, _('Formatted')) - - if self.note_obj and self.note_obj.get_format(): - self.format.set_active(True) - self.text.set_wrap_mode(gtk.WRAP_NONE) - else: - self.flowed.set_active(True) - self.text.set_wrap_mode(gtk.WRAP_WORD) - self.spellcheck = Spell.Spell(self.text) - - self.flowed.connect('toggled', self.flow_changed) - - scroll = gtk.ScrolledWindow() - scroll.set_policy(gtk.POLICY_AUTOMATIC, gtk.POLICY_AUTOMATIC) - scroll.add_with_viewport(self.text) - scroll.connect('focus-out-event', self.update) - - vbox.pack_start(scroll, True) - vbox.set_spacing(6) - vbox.set_border_width(6) - - hbox = gtk.HBox() - hbox.set_spacing(12) - hbox.set_border_width(6) - hbox.pack_start(self.flowed, False) - hbox.pack_start(self.format, False) - - vbox.pack_start(hbox, False) - - self.pack_start(vbox, True) - self.buf = self.text.get_buffer() - if self.note_obj: - self.empty = False - self.buf.insert_at_cursor(self.note_obj.get()) - else: - self.empty = True - - self.buf.connect('changed', self.update) - self.rebuild() - - def update(self, obj): - if self.note_obj: - start = self.buf.get_start_iter() - stop = self.buf.get_end_iter() - text = self.buf.get_text(start, stop) - self.note_obj.set(text) - else: - print "NOTE OBJ DOES NOT EXIST" - self._update_label(obj) - return False - - def flow_changed(self, obj): - if obj.get_active(): - self.text.set_wrap_mode(gtk.WRAP_WORD) - else: - self.text.set_wrap_mode(gtk.WRAP_NONE) - - def rebuild(self): - self._set_label() - -#------------------------------------------------------------------------- -# -# GalleryTab -# -#------------------------------------------------------------------------- -class GalleryTab(ButtonTab): - - def __init__(self, dbstate, uistate, track, media_list, update=None): - ButtonTab.__init__(self, dbstate, uistate, track, _('Gallery'), True) - self.media_list = media_list - self.update = update - self.rebuild() - self.show_all() - - def double_click(self, obj, event): - """ - Handles the double click on list. If the double click occurs, - the Edit button handler is called - """ - if event.type == gtk.gdk._2BUTTON_PRESS and event.button == 1: - self.edit_button_clicked(obj) - elif event.type == gtk.gdk.BUTTON_PRESS and event.button == 3: - reflist = self.iconlist.get_selected_items() - if len(reflist) == 1: - ref = self.media_list[reflist[0][0]] - self.right_click(ref, event) - - def right_click(self, obj, event): - itemlist = [ - (True, gtk.STOCK_ADD, self.add_button_clicked), - (False, _('Share'), self.edit_button_clicked), - (True, gtk.STOCK_EDIT, self.edit_button_clicked), - (True, gtk.STOCK_REMOVE, self.del_button_clicked), - ] - - menu = gtk.Menu() - - ref_obj = self.dbstate.db.get_object_from_handle(obj.ref) - mime_type = ref_obj.get_mime_type() - if mime_type: - app = Mime.get_application(mime_type) - if app: - item = gtk.MenuItem(_('Open with %s') % app[1]) - item.connect('activate', make_launcher(app[0], - ref_obj.get_path())) - item.show() - menu.append(item) - item = gtk.SeparatorMenuItem() - item.show() - menu.append(item) - - for (image, title, func) in itemlist: - if image: - item = gtk.ImageMenuItem(stock_id=title) - else: - item = gtk.MenuItem(title) - item.connect('activate', func) - item.show() - menu.append(item) - menu.popup(None, None, None, event.button, event.time) - - def get_icon_name(self): - return 'gramps-media' - - def is_empty(self): - return len(self.media_list)==0 - - def _build_icon_model(self): - self.iconmodel= gtk.ListStore(gtk.gdk.Pixbuf, str, object) - - def _connect_icon_model(self): - self.iconlist.set_model(self.iconmodel) - self.iconmodel.connect_after('row-inserted', self._update_internal_list) - self.iconmodel.connect_after('row-deleted', self._update_internal_list) - - def build_interface(self): - - self._build_icon_model() - # build the icon view - self.iconlist = gtk.IconView() - self.iconlist.set_pixbuf_column(0) - self.iconlist.set_text_column(1) - self.iconlist.set_margin(12) - self.iconlist.set_reorderable(True) - self.iconlist.set_item_width(125) - self.iconlist.set_spacing(24) - self.iconlist.set_selection_mode(gtk.SELECTION_SINGLE) - self.iconlist.connect('selection-changed', self._selection_changed) - self.iconlist.connect('button_press_event', self.double_click) - self._connect_icon_model() - - scroll = gtk.ScrolledWindow() - scroll.set_policy(gtk.POLICY_AUTOMATIC, gtk.POLICY_AUTOMATIC) - scroll.add_with_viewport(self.iconlist) - self.pack_start(scroll, True) - - def _update_internal_list(self, *obj): - newlist = [] - node = self.iconmodel.get_iter_first() - while node != None: - newlist.append(self.iconmodel.get_value(node, 2)) - node = self.iconmodel.iter_next(node) - for i in xrange(len(self.media_list)): - self.media_list.pop() - for i in newlist: - if i: - self.media_list.append(i) - - if self.update: - self.update() - self.changed = True - - def get_data(self): - return self.media_list - - def rebuild(self): - self._build_icon_model() - for ref in self.media_list: - handle = ref.get_reference_handle() - obj = self.dbstate.db.get_object_from_handle(handle) - pixbuf = ImgManip.get_thumbnail_image(obj.get_path(), - obj.get_mime_type()) - self.iconmodel.append(row=[pixbuf, obj.get_description(), ref]) - self._connect_icon_model() - self._set_label() - self._selection_changed() - if self.update: - self.update() - - def get_selected(self): - node = self.iconlist.get_selected_items() - if len(node) > 0: - return self.media_list[node[0][0]] - return None - - def add_button_clicked(self, obj): - import AddMedia - - am = AddMedia.AddMediaObject(self.dbstate, self.uistate, self.track) - am.run() - src = am.object - - if src: - sref = RelLib.MediaRef() - try: - from Editors import EditMediaRef - - EditMediaRef(self.dbstate, self.uistate, self.track, - src, sref, self.add_callback) - except Errors.WindowActiveError: - pass - - def add_callback(self, media_ref, media): - media_ref.ref = media.handle - self.get_data().append(media_ref) - self.changed = True - self.rebuild() - - def share_button_clicked(self, obj): - """ - Function called with the Add button is clicked. This function - should be overridden by the derived class. - """ - import SelectObject - - sel = SelectObject.SelectObject(self.dbstate,self.uistate,self.track, - _("Select media")) - src = sel.run() - if src: - sref = RelLib.MediaRef() - try: - from Editors import EditMediaRef - - EditMediaRef(self.dbstate, self.uistate, self.track, - src, sref, self.add_callback) - except Errors.WindowActiveError: - pass - - def del_button_clicked(self, obj): - ref = self.get_selected() - if ref: - self.media_list.remove(ref) - self.rebuild() - - def edit_button_clicked(self, obj): - ref = self.get_selected() - if ref: - obj = self.dbstate.db.get_object_from_handle(ref.get_reference_handle()) - try: - from Editors import EditMediaRef - - EditMediaRef(self.dbstate, self.uistate, self.track, - obj, ref, self.edit_callback) - except Errors.WindowActiveError: - pass - - def edit_callback(self, media_ref, ref): - self.changed = True - self.rebuild() - -#------------------------------------------------------------------------- -# -# SourceEmbedList -# -#------------------------------------------------------------------------- -class SourceEmbedList(EmbeddedList): - - _HANDLE_COL = 4 - _DND_TYPE = DdTargets.SOURCEREF - _DND_EXTRA = DdTargets.SOURCE_LINK - - _MSG = { - 'add' : _('Create and add a new source'), - 'del' : _('Remove the existing source'), - 'edit' : _('Edit the selected source'), - 'share' : _('Add an existing source'), - } - - _column_names = [ - (_('ID'), 0, 75), - (_('Title'), 1, 200), - (_('Author'), 2, 125), - (_('Page'), 3, 100), - ] - - def __init__(self, dbstate, uistate, track, obj): - self.obj = obj - EmbeddedList.__init__(self, dbstate, uistate, track, - _('Sources'), SourceRefModel, True) - - def get_icon_name(self): - return 'gramps-event' - - def get_data(self): - return self.obj - - def column_order(self): - return ((1, 0), (1, 1), (1, 2), (1, 3)) - - def add_button_clicked(self, obj): - sref = RelLib.SourceRef() - src = RelLib.Source() - try: - from Editors import EditSourceRef - - EditSourceRef(self.dbstate, self.uistate, self.track, - src, sref, self.add_callback) - except Errors.WindowActiveError: - pass - - def share_button_clicked(self, obj): - import SelectSource - - sel = SelectSource.SelectSource(self.dbstate,self.uistate,self.track, - _("Select source")) - src = sel.run() - if src: - try: - from Editors import EditSourceRef - - ref = RelLib.SourceRef() - EditSourceRef(self.dbstate, self.uistate, self.track, - src, ref, self.add_callback) - except Errors.WindowActiveError: - pass - - def add_callback(self, reference, primary): - reference.ref = primary.handle - self.get_data().append(reference) - self.changed = True - self.rebuild() - - def edit_button_clicked(self, obj): - sref = self.get_selected() - src = self.dbstate.db.get_source_from_handle(sref.ref) - if sref: - try: - from Editors import EditSourceRef - - EditSourceRef(self.dbstate, self.uistate, self.track, - src, sref, self.edit_callback) - except Errors.WindowActiveError: - pass - - def edit_callback(self, refererence, primary): - self.changed = True - self.rebuild() - - def handle_extra_type(self, objtype, obj): - sref = RelLib.SourceRef() - src = self.dbstate.db.get_source_from_handle(obj) - try: - from Editors import EditSourceRef - - EditSourceRef(self.dbstate, self.uistate, self.track, - src, sref, self.add_callback) - except Errors.WindowActiveError: - pass - - -#------------------------------------------------------------------------- -# -# RepoEmbedList -# -#------------------------------------------------------------------------- -class RepoEmbedList(EmbeddedList): - - _HANDLE_COL = 4 - _DND_TYPE = DdTargets.REPOREF - _DND_EXTRA = DdTargets.REPO_LINK - - _column_names = [ - (_('ID'), 0, 75), - (_('Title'), 1, 200), - (_('Call Number'), 2, 125), - (_('Type'), 3, 100), - ] - - def __init__(self, dbstate, uistate, track, obj): - self.obj = obj - EmbeddedList.__init__(self, dbstate, uistate, track, - _('Repositories'), RepoRefModel) - - def get_icon_name(self): - return 'gramps-repository' - - def get_data(self): - return self.obj - - def column_order(self): - return ((1, 0), (1, 1), (1, 2), (1, 3)) - - def handle_extra_type(self, objtype, obj): - try: - from Editors import EditRepoRef - - ref = RelLib.RepoRef() - repo = self.dbstate.db.get_repository_from_handle(obj) - EditRepoRef( - self.dbstate, self.uistate, self.track, - repo, ref, self.add_callback) - except Errors.WindowActiveError: - pass - - def add_button_clicked(self, obj): - ref = RelLib.RepoRef() - repo = RelLib.Repository() - try: - from Editors import EditRepoRef - - EditRepoRef( - self.dbstate, self.uistate, self.track, - repo, ref, self.add_callback) - except Errors.WindowActiveError: - pass - - def add_callback(self, value): - value[0].ref = value[1].handle - self.get_data().append(value[0]) - self.changed = True - self.rebuild() - - def edit_button_clicked(self, obj): - ref = self.get_selected() - if ref: - repo = self.dbstate.db.get_repository_from_handle(ref.ref) - try: - from Editors import EditRepoRef - - EditRepoRef( - self.dbstate, self.uistate, self.track, repo, - ref, self.edit_callback) - except Errors.WindowActiveError: - pass - - def edit_callback(self, name): - self.changed = True - self.rebuild() - -#------------------------------------------------------------------------- -# -# ChildModel -# -#------------------------------------------------------------------------- -class ChildModel(gtk.ListStore): - - _HANDLE_COL = -8 - - def __init__(self, family, db): - self.family = family - gtk.ListStore.__init__(self, int, str, str, str, str, str, - str, str, str, str, str, str, int, int) - self.db = db - index = 1 - for child_ref in self.get_data(): - child = db.get_person_from_handle(child_ref.ref) - self.append(row=[ - index, - child.get_gramps_id(), - NameDisplay.displayer.display(child), - Utils.gender[child.get_gender()], - str(child_ref.get_father_relation()), - str(child_ref.get_mother_relation()), - self.column_birth_day(child), - self.column_death_day(child), - self.column_birth_place(child), - self.column_death_place(child), - child.get_handle(), - NameDisplay.displayer.sort_string(child.primary_name), - self.column_birth_sort(child), - self.column_death_sort(child), - ]) - index += 1 - - def get_data(self): - return self.family.get_child_ref_list() - - def column_birth_day(self, data): - event_ref = data.get_birth_ref() - if event_ref and event_ref.ref: - event = self.db.get_event_from_handle(event_ref.ref) - return DateHandler.get_date(event) - else: - return u"" - - def column_birth_sort(self, data): - event_ref = data.get_birth_ref() - if event_ref and event_ref.ref: - event = self.db.get_event_from_handle(event_ref.ref) - return event.get_date_object().get_sort_value() - else: - return 0 - - def column_death_day(self, data): - event_ref = data.get_death_ref() - if event_ref and event_ref.ref: - event = self.db.get_event_from_handle(event_ref.ref) - return DateHandler.get_date(event) - else: - return u"" - - def column_death_sort(self, data): - event_ref = data.get_death_ref() - if event_ref and event_ref.ref: - event = self.db.get_event_from_handle(event_ref.ref) - return event.get_date_object().get_sort_value() - else: - return 0 - - def column_birth_place(self, data): - event_ref = data.get_birth_ref() - if event_ref and event_ref.ref: - event = self.db.get_event_from_handle(event_ref.ref) - if event: - place_handle = event.get_place_handle() - if place_handle: - return self.db.get_place_from_handle(place_handle).get_title() - return u"" - - def column_death_place(self, data): - event_ref = data.get_death_ref() - if event_ref and event_ref.ref: - event = self.db.get_event_from_handle(event_ref.ref) - if event: - place_handle = event.get_place_handle() - if place_handle: - return self.db.get_place_from_handle(place_handle).get_title() - return u"" - -#------------------------------------------------------------------------- -# -# EventRefModel -# -#------------------------------------------------------------------------- -class EventRefModel(gtk.ListStore): - - def __init__(self, event_list, db): - gtk.ListStore.__init__(self, str, str, str, str, str, str, object) - self.db = db - for event_ref in event_list: - event = db.get_event_from_handle(event_ref.ref) - self.append(row=[ - str(event.get_type()), - event.get_description(), - event.get_gramps_id(), - self.column_date(event_ref), - self.column_place(event_ref), - self.column_role(event_ref), - event_ref - ]) - - def column_role(self, event_ref): - return str(event_ref.get_role()) - - def column_date(self, event_ref): - event = self.db.get_event_from_handle(event_ref.ref) - return DateHandler.get_date(event) - - def column_place(self, event_ref): - if event_ref and event_ref.ref: - event = self.db.get_event_from_handle(event_ref.ref) - if event: - place_handle = event.get_place_handle() - if place_handle: - return self.db.get_place_from_handle(place_handle).get_title() - return u"" - -#------------------------------------------------------------------------- -# -# AttrModel -# -#------------------------------------------------------------------------- -class AttrModel(gtk.ListStore): - - def __init__(self, attr_list, db): - gtk.ListStore.__init__(self, str, str, object) - self.db = db - for attr in attr_list: - self.append(row=[ - str(attr.get_type()), - attr.get_value(), - attr, - ]) - -#------------------------------------------------------------------------- -# -# LdsModel -# -#------------------------------------------------------------------------- -class LdsModel(gtk.ListStore): - - _HANDLE_COL = 5 - - def __init__(self, lds_list, db): - gtk.ListStore.__init__(self, str, str, str, str, str, object) - - import lds - - self.db = db - for lds_ord in lds_list: - self.append(row=[ - lds.ord_type[lds_ord.get_type()], - DateHandler.get_date(lds_ord), - lds.ord_status[lds_ord.get_status()], - lds.temple_to_abrev.get(lds_ord.get_temple(), _("unknown")), - self.column_place(lds_ord), - lds_ord, - ]) - - def column_place(self, lds_ord): - if lds_ord: - place_handle = lds_ord.get_place_handle() - if place_handle: - return self.db.get_place_from_handle(place_handle).get_title() - return u"" - -#------------------------------------------------------------------------- -# -# NameModel -# -#------------------------------------------------------------------------- -class NameModel(gtk.ListStore): - - def __init__(self, obj_list, db): - gtk.ListStore.__init__(self, str, str, object) - self.db = db - for obj in obj_list: - self.append(row=[ - NameDisplay.displayer.display_name(obj), - str(obj.get_type()), - obj, - ]) - -#------------------------------------------------------------------------- -# -# AddressModel -# -#------------------------------------------------------------------------- -class AddressModel(gtk.ListStore): - - def __init__(self, obj_list, db): - gtk.ListStore.__init__(self, str, str, str, str, str, object) - self.db = db - for obj in obj_list: - self.append(row=[ - DateHandler.get_date(obj), - obj.street, - obj.city, - obj.state, - obj.country, - obj, - ]) - -#------------------------------------------------------------------------- -# -# PersonRefModel -# -#------------------------------------------------------------------------- -class PersonRefModel(gtk.ListStore): - - def __init__(self, obj_list, db): - gtk.ListStore.__init__(self, str, str, str, object) - self.db = db - for obj in obj_list: - p = self.db.get_person_from_handle(obj.ref) - if p: - data = [NameDisplay.displayer.display(p), p.gramps_id, obj.rel, obj] - else: - data = ['unknown','unknown',obj.rel,obj] - self.append(row=data) - -#------------------------------------------------------------------------- -# -# LocationModel -# -#------------------------------------------------------------------------- -class LocationModel(gtk.ListStore): - - def __init__(self, obj_list, db): - gtk.ListStore.__init__(self, str, str, str, str, str, object) - self.db = db - for obj in obj_list: - self.append(row=[obj.city, obj.county, obj.parish, - obj.state, obj.country, obj, ]) - -#------------------------------------------------------------------------- -# -# AddressModel -# -#------------------------------------------------------------------------- -class WebModel(gtk.ListStore): - - def __init__(self, obj_list, db): - gtk.ListStore.__init__(self, str, str, str, object) - self.db = db - for obj in obj_list: - self.append(row=[str(obj.type), obj.path, obj.desc, obj]) - -#------------------------------------------------------------------------- -# -# DataModel -# -#------------------------------------------------------------------------- -class DataModel(gtk.ListStore): - - def __init__(self, attr_list, db): - gtk.ListStore.__init__(self, str, str) - self.db = db - - for key,value in attr_list.items(): - self.append(row=[key,value]) - -#------------------------------------------------------------------------- -# -# SourceRefModel -# -#------------------------------------------------------------------------- -class SourceRefModel(gtk.ListStore): - - def __init__(self, sref_list, db): - gtk.ListStore.__init__(self, str, str, str, str, object) - self.db = db - for sref in sref_list: - src = self.db.get_source_from_handle(sref.ref) - self.append(row=[src.gramps_id, src.title, src.author, - sref.page, sref, ]) - -#------------------------------------------------------------------------- -# -# RepoRefModel -# -#------------------------------------------------------------------------- -class RepoRefModel(gtk.ListStore): - - def __init__(self, ref_list, db): - gtk.ListStore.__init__(self, str, str, str, str, object) - self.db = db - for ref in ref_list: - repo = self.db.get_repository_from_handle(ref.ref) - self.append(row=[ - repo.gramps_id, - repo.name, - ref.call_number, - str(repo.get_type()), - ref, ]) - -#------------------------------------------------------------------------- -# -# BackRefModel -# -#------------------------------------------------------------------------- -class BackRefModel(gtk.ListStore): - - def __init__(self, sref_list, db): - gtk.ListStore.__init__(self, str, str, str, str) - self.db = db - self.sref_list = sref_list - self.idle = 0 - self.count = 0 - self.idle = gobject.idle_add(self.load_model().next) - - def close(self): - gobject.source_remove(self.idle) - - def load_model(self): - self.count = 0 - for ref in self.sref_list: - self.count += 1 - dtype = ref[0] - if dtype == 'Person': - p = self.db.get_person_from_handle(ref[1]) - gid = p.gramps_id - handle = p.handle - name = NameDisplay.displayer.display(p) - elif dtype == 'Family': - p = self.db.get_family_from_handle(ref[1]) - gid = p.gramps_id - handle = p.handle - name = Utils.family_name(p, self.db) - elif dtype == 'Source': - p = self.db.get_source_from_handle(ref[1]) - gid = p.gramps_id - handle = p.handle - name = p.get_title() - elif dtype == 'Event': - p = self.db.get_event_from_handle(ref[1]) - gid = p.gramps_id - name = p.get_description() - handle = p.handle - if not name: - name = str(p.get_type()) - elif dtype == 'Place': - p = self.db.get_place_from_handle(ref[1]) - name = p.get_title() - gid = p.gramps_id - handle = p.handle - else: - p = self.db.get_object_from_handle(ref[1]) - name = p.get_description() - gid = p.gramps_id - handle = p.handle - - self.append(row=[dtype, gid, name, handle]) - yield True - yield False - -def make_launcher(prog, path): - return lambda x: Utils.launch(prog, path) diff --git a/gramps2/src/DisplayTabs/Makefile.am b/gramps2/src/DisplayTabs/Makefile.am new file mode 100644 index 000000000..e7688fc05 --- /dev/null +++ b/gramps2/src/DisplayTabs/Makefile.am @@ -0,0 +1,55 @@ +# This is the src/DisplayTabs level Makefile for Gramps + +pkgdatadir = $(datadir)/@PACKAGE@/DisplayTabs + +pkgdata_PYTHON = \ + _AddrEmbedList.py \ + _AddressModel.py \ + _AttrEmbedList.py \ + _AttrModel.py \ + _BackRefList.py \ + _BackRefModel.py \ + _ButtonTab.py \ + _ChildModel.py \ + _DataEmbedList.py \ + _DataModel.py \ + _EmbeddedList.py \ + _EventBackRefList.py \ + _EventEmbedList.py \ + _EventRefModel.py \ + _FamilyAttrEmbedList.py \ + _FamilyLdsEmbedList.py \ + _GalleryTab.py \ + _GrampsTab.py \ + _LdsEmbedList.py \ + _LdsModel.py \ + _LocationEmbedList.py \ + _LocationModel.py \ + _MediaBackRefList.py \ + _NameEmbedList.py \ + _NameModel.py \ + _NoteTab.py \ + _PersonEventEmbedList.py \ + _PersonRefEmbedList.py \ + _PersonRefModel.py \ + _PlaceBackRefList.py \ + _RepoEmbedList.py \ + _RepoRefModel.py \ + _SourceBackRefList.py \ + _SourceEmbedList.py \ + _SourceRefModel.py \ + _WebEmbedList.py \ + _WebModel.py \ + __init__.py + +pkgpyexecdir = @pkgpyexecdir@/DisplayTabs +pkgpythondir = @pkgpythondir@/DisplayTabs + +# Clean up all the byte-compiled files +MOSTLYCLEANFILES = *pyc *pyo + +GRAMPS_PY_MODPATH = "../" + +pycheck: + (export PYTHONPATH=$(GRAMPS_PY_MODPATH); \ + pychecker $(pkgdata_PYTHON)); diff --git a/gramps2/src/DisplayTabs/_AddrEmbedList.py b/gramps2/src/DisplayTabs/_AddrEmbedList.py new file mode 100644 index 000000000..8b7e648c1 --- /dev/null +++ b/gramps2/src/DisplayTabs/_AddrEmbedList.py @@ -0,0 +1,96 @@ +# +# Gramps - a GTK+/GNOME based genealogy program +# +# Copyright (C) 2000-2006 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 _ + +#------------------------------------------------------------------------- +# +# GRAMPS classes +# +#------------------------------------------------------------------------- +import RelLib +import Errors +from DdTargets import DdTargets +from _AddressModel import AddressModel +from _EmbeddedList import EmbeddedList + +#------------------------------------------------------------------------- +# +# +# +#------------------------------------------------------------------------- +class AddrEmbedList(EmbeddedList): + + _HANDLE_COL = 5 + _DND_TYPE = DdTargets.ADDRESS + + _column_names = [ + (_('Date'), 0, 150), + (_('Street'), 1, 225), + (_('State'), 2, 100), + (_('City'), 3, 100), + (_('Country'), 4, 75), + ] + + def __init__(self, dbstate, uistate, track, data): + self.data = data + EmbeddedList.__init__(self, dbstate, uistate, track, + _('Addresses'), AddressModel) + + def get_data(self): + return self.data + + def column_order(self): + return ((1, 0), (1, 1), (1, 2), (1, 3), (1, 4)) + + def add_button_clicked(self, obj): + addr = RelLib.Address() + try: + from Editors import EditAddress + + EditAddress(self.dbstate, self.uistate, self.track, + addr, self.add_callback) + except Errors.WindowActiveError: + pass + + def add_callback(self, name): + self.get_data().append(name) + self.rebuild() + + def edit_button_clicked(self, obj): + addr = self.get_selected() + if addr: + try: + from Editors import EditAddress + + EditAddress(self.dbstate, self.uistate, self.track, + addr, self.edit_callback) + except Errors.WindowActiveError: + pass + + def edit_callback(self, name): + self.rebuild() diff --git a/gramps2/src/DisplayTabs/_AddressModel.py b/gramps2/src/DisplayTabs/_AddressModel.py new file mode 100644 index 000000000..1e52ca795 --- /dev/null +++ b/gramps2/src/DisplayTabs/_AddressModel.py @@ -0,0 +1,55 @@ +# +# Gramps - a GTK+/GNOME based genealogy program +# +# Copyright (C) 2000-2006 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$ + +#------------------------------------------------------------------------- +# +# GTK libraries +# +#------------------------------------------------------------------------- +import gtk + +#------------------------------------------------------------------------- +# +# GRAMPS classes +# +#------------------------------------------------------------------------- +import DateHandler + +#------------------------------------------------------------------------- +# +# AddressModel +# +#------------------------------------------------------------------------- +class AddressModel(gtk.ListStore): + + def __init__(self, obj_list, db): + gtk.ListStore.__init__(self, str, str, str, str, str, object) + self.db = db + for obj in obj_list: + self.append(row=[ + DateHandler.get_date(obj), + obj.street, + obj.city, + obj.state, + obj.country, + obj, + ]) diff --git a/gramps2/src/DisplayTabs/_AttrEmbedList.py b/gramps2/src/DisplayTabs/_AttrEmbedList.py new file mode 100644 index 000000000..c06835f39 --- /dev/null +++ b/gramps2/src/DisplayTabs/_AttrEmbedList.py @@ -0,0 +1,102 @@ +# +# Gramps - a GTK+/GNOME based genealogy program +# +# Copyright (C) 2000-2006 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 _ + +#------------------------------------------------------------------------- +# +# GRAMPS classes +# +#------------------------------------------------------------------------- +import RelLib +import Errors +from DdTargets import DdTargets +from _AttrModel import AttrModel +from _EmbeddedList import EmbeddedList + +#------------------------------------------------------------------------- +# +# +# +#------------------------------------------------------------------------- +class AttrEmbedList(EmbeddedList): + + _HANDLE_COL = 2 + _DND_TYPE = DdTargets.ATTRIBUTE + + _column_names = [ + (_('Type'), 0, 250), + (_('Value'), 1, 200), + ] + + def __init__(self, dbstate, uistate, track, data): + self.data = data + EmbeddedList.__init__(self, dbstate, uistate, track, + _('Attributes'), AttrModel) + + def get_editor(self): + from Editors import EditAttribute + return EditAttribute + + def get_user_values(self): + return self.dbstate.db.get_person_attribute_types() + + def get_data(self): + return self.data + + def column_order(self): + return ((1, 0), (1, 1)) + + def add_button_clicked(self, obj): + pname = '' + attr = RelLib.Attribute() + try: + self.get_editor()( + self.dbstate, self.uistate, self.track, attr, + pname, self.get_user_values(), self.add_callback) + except Errors.WindowActiveError: + pass + + def add_callback(self, name): + self.get_data().append(name) + self.changed = True + self.rebuild() + + def edit_button_clicked(self, obj): + attr = self.get_selected() + if attr: + pname = '' + try: + self.get_editor()( + self.dbstate, self.uistate, self.track, attr, + pname, self.get_user_values(), self.edit_callback) + except Errors.WindowActiveError: + pass + + def edit_callback(self, name): + self.changed = True + self.rebuild() diff --git a/gramps2/src/DisplayTabs/_AttrModel.py b/gramps2/src/DisplayTabs/_AttrModel.py new file mode 100644 index 000000000..452aea300 --- /dev/null +++ b/gramps2/src/DisplayTabs/_AttrModel.py @@ -0,0 +1,52 @@ +# +# Gramps - a GTK+/GNOME based genealogy program +# +# Copyright (C) 2000-2006 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$ + +#------------------------------------------------------------------------- +# +# GTK libraries +# +#------------------------------------------------------------------------- +import gtk + +#------------------------------------------------------------------------- +# +# GRAMPS classes +# +#------------------------------------------------------------------------- + + +#------------------------------------------------------------------------- +# +# AttrModel +# +#------------------------------------------------------------------------- +class AttrModel(gtk.ListStore): + + def __init__(self, attr_list, db): + gtk.ListStore.__init__(self, str, str, object) + self.db = db + for attr in attr_list: + self.append(row=[ + str(attr.get_type()), + attr.get_value(), + attr, + ]) diff --git a/gramps2/src/DisplayTabs/_BackRefList.py b/gramps2/src/DisplayTabs/_BackRefList.py new file mode 100644 index 000000000..23f705565 --- /dev/null +++ b/gramps2/src/DisplayTabs/_BackRefList.py @@ -0,0 +1,149 @@ +# +# Gramps - a GTK+/GNOME based genealogy program +# +# Copyright (C) 2000-2006 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 libraries +# +#------------------------------------------------------------------------- +import gtk + +#------------------------------------------------------------------------- +# +# GRAMPS classes +# +#------------------------------------------------------------------------- +import Errors +from GrampsWidgets import SimpleButton +from _EmbeddedList import EmbeddedList + +#------------------------------------------------------------------------- +# +# BackRefList +# +#------------------------------------------------------------------------- +class BackRefList(EmbeddedList): + + _HANDLE_COL = 3 + + _column_names = [ + (_('Type'), 0, 100), + (_('ID'), 1, 75), + (_('Name'), 2, 250), + ] + + def __init__(self, dbstate, uistate, track, obj, refmodel, callback=None): + self.obj = obj + EmbeddedList.__init__(self, dbstate, uistate, track, + _('References'), refmodel) + self._callback = callback + self.model.connect('row-inserted', self.update_label) + + def update_label(self, *obj): + if self.model.count > 0: + self._set_label() + if self._callback and self.model.count > 1: + self._callback() + + def close(self): + self.model.close() + + def is_empty(self): + return self.model.count == 0 + + def create_buttons(self, share=False): + self.edit_btn = SimpleButton(gtk.STOCK_EDIT, self.edit_button_clicked) + + vbox = gtk.VBox() + vbox.set_spacing(6) + vbox.pack_start(self.edit_btn, False) + vbox.show_all() + self.pack_start(vbox, False) + + def _selection_changed(self, obj=None): + if self.get_selected(): + self.edit_btn.set_sensitive(True) + else: + self.edit_btn.set_sensitive(False) + + def get_data(self): + return self.obj + + def column_order(self): + return ((1, 0), (1, 1), (1, 2)) + + def find_node(self): + (model, node) = self.selection.get_selected() + try: + return (model.get_value(node, 0), model.get_value(node, 3)) + except: + return (None, None) + + def edit_button_clicked(self, obj): + (reftype, ref) = self.find_node() + if reftype == 'Person': + try: + from Editors import EditPerson + + person = self.dbstate.db.get_person_from_handle(ref) + EditPerson(self.dbstate, self.uistate, [], person) + except Errors.WindowActiveError: + pass + elif reftype == 'Family': + try: + from Editors import EditFamily + + family = self.dbstate.db.get_family_from_handle(ref) + EditFamily(self.dbstate, self.uistate, [], family) + except Errors.WindowActiveError: + pass + elif reftype == 'Source': + try: + from Editors import EditSource + + source = self.dbstate.db.get_source_from_handle(ref) + EditSource(self.dbstate, self.uistate, [], source) + except Errors.WindowActiveError: + pass + elif reftype == 'Place': + try: + from Editors import EditPlace + + place = self.dbstate.db.get_place_from_handle(ref) + EditPlace(self.dbstate, self.uistate, [], place) + except Errors.WindowActiveError: + pass + elif reftype == 'Media': + try: + from Editors import EditMedia + + obj = self.dbstate.db.get_object_from_handle(ref) + EditMedia(self.dbstate, self.uistate, [], obj) + except Errors.WindowActiveError: + pass diff --git a/gramps2/src/DisplayTabs/_BackRefModel.py b/gramps2/src/DisplayTabs/_BackRefModel.py new file mode 100644 index 000000000..bc80d2e13 --- /dev/null +++ b/gramps2/src/DisplayTabs/_BackRefModel.py @@ -0,0 +1,97 @@ +# +# Gramps - a GTK+/GNOME based genealogy program +# +# Copyright (C) 2000-2006 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$ + +#------------------------------------------------------------------------- +# +# GTK libraries +# +#------------------------------------------------------------------------- +import gobject +import gtk + +#------------------------------------------------------------------------- +# +# GRAMPS classes +# +#------------------------------------------------------------------------- +import NameDisplay +import Utils + +#------------------------------------------------------------------------- +# +# BackRefModel +# +#------------------------------------------------------------------------- +class BackRefModel(gtk.ListStore): + + def __init__(self, sref_list, db): + gtk.ListStore.__init__(self, str, str, str, str) + self.db = db + self.sref_list = sref_list + self.idle = 0 + self.count = 0 + self.idle = gobject.idle_add(self.load_model().next) + + def close(self): + gobject.source_remove(self.idle) + + def load_model(self): + self.count = 0 + for ref in self.sref_list: + self.count += 1 + dtype = ref[0] + if dtype == 'Person': + p = self.db.get_person_from_handle(ref[1]) + gid = p.gramps_id + handle = p.handle + name = NameDisplay.displayer.display(p) + elif dtype == 'Family': + p = self.db.get_family_from_handle(ref[1]) + gid = p.gramps_id + handle = p.handle + name = Utils.family_name(p, self.db) + elif dtype == 'Source': + p = self.db.get_source_from_handle(ref[1]) + gid = p.gramps_id + handle = p.handle + name = p.get_title() + elif dtype == 'Event': + p = self.db.get_event_from_handle(ref[1]) + gid = p.gramps_id + name = p.get_description() + handle = p.handle + if not name: + name = str(p.get_type()) + elif dtype == 'Place': + p = self.db.get_place_from_handle(ref[1]) + name = p.get_title() + gid = p.gramps_id + handle = p.handle + else: + p = self.db.get_object_from_handle(ref[1]) + name = p.get_description() + gid = p.gramps_id + handle = p.handle + + self.append(row=[dtype, gid, name, handle]) + yield True + yield False diff --git a/gramps2/src/DisplayTabs/_ButtonTab.py b/gramps2/src/DisplayTabs/_ButtonTab.py new file mode 100644 index 000000000..2cdbbd735 --- /dev/null +++ b/gramps2/src/DisplayTabs/_ButtonTab.py @@ -0,0 +1,165 @@ +# +# Gramps - a GTK+/GNOME based genealogy program +# +# Copyright (C) 2000-2006 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 libraries +# +#------------------------------------------------------------------------- +import gtk + +#------------------------------------------------------------------------- +# +# GRAMPS classes +# +#------------------------------------------------------------------------- +from GrampsWidgets import SimpleButton +from _GrampsTab import GrampsTab + +#------------------------------------------------------------------------- +# +# Classes +# +#------------------------------------------------------------------------- +class ButtonTab(GrampsTab): + """ + This class derives from the base GrampsTab, yet is not a usable Tab. It + serves as another base tab for classes which need an Add/Edit/Remove button + combination. + """ + + _MSG = { + 'add' : _('Add'), + 'del' : _('Remove'), + 'edit' : _('Edit'), + 'share' : _('Share'), + } + + def __init__(self, dbstate, uistate, track, name, share_button=False): + """ + Similar to the base class, except after Build + @param dbstate: The database state. Contains a reference to + the database, along with other state information. The GrampsTab + uses this to access the database and to pass to and created + child windows (such as edit dialogs). + @type dbstate: DbState + @param uistate: The UI state. Used primarily to pass to any created + subwindows. + @type uistate: DisplayState + @param track: The window tracking mechanism used to manage windows. + This is only used to pass to generted child windows. + @type track: list + @param name: Notebook label name + @type name: str/unicode + """ + GrampsTab.__init__(self,dbstate, uistate, track, name) + self.tooltips = gtk.Tooltips() + self.create_buttons(share_button) + + def create_buttons(self, share_button=False): + """ + Creates a button box consisting of three buttons, one for Add, + one for Edit, and one for Delete. This button box is then appended + hbox (self). + """ + self.add_btn = SimpleButton(gtk.STOCK_ADD, self.add_button_clicked) + self.edit_btn = SimpleButton(gtk.STOCK_EDIT, self.edit_button_clicked) + self.del_btn = SimpleButton(gtk.STOCK_REMOVE, self.del_button_clicked) + + self.tooltips.set_tip(self.add_btn, self._MSG['add']) + self.tooltips.set_tip(self.edit_btn, self._MSG['edit']) + self.tooltips.set_tip(self.del_btn, self._MSG['del']) + + if share_button: + self.share_btn = SimpleButton(gtk.STOCK_INDEX, self.share_button_clicked) + self.tooltips.set_tip(self.share_btn, self._MSG['share']) + else: + self.share_btn = None + + vbox = gtk.VBox() + vbox.set_spacing(6) + vbox.pack_start(self.add_btn, False) + if share_button: + vbox.pack_start(self.share_btn, False) + vbox.pack_start(self.edit_btn, False) + vbox.pack_start(self.del_btn, False) + vbox.show_all() + self.pack_start(vbox, False) + + def double_click(self, obj, event): + """ + Handles the double click on list. If the double click occurs, + the Edit button handler is called + """ + if event.type == gtk.gdk._2BUTTON_PRESS and event.button == 1: + self.edit_button_clicked(obj) + + def add_button_clicked(self, obj): + """ + Function called with the Add button is clicked. This function + should be overridden by the derived class. + """ + print "Uncaught Add clicked" + + def share_button_clicked(self, obj): + """ + Function called with the Add button is clicked. This function + should be overridden by the derived class. + """ + print "Uncaught Share clicked" + + def del_button_clicked(self, obj): + """ + Function called with the Delete button is clicked. This function + should be overridden by the derived class. + """ + print "Uncaught Delete clicked" + + def edit_button_clicked(self, obj): + """ + Function called with the Edit button is clicked or the double + click is caught. This function should be overridden by the derived + class. + """ + print "Uncaught Edit clicked" + + def _selection_changed(self, obj=None): + """ + Attached to the selection's 'changed' signal. Checks + to see if anything is selected. If it is, the edit and + delete buttons are enabled, otherwise the are disabled. + """ + # Comparing to None is important, as empty strings + # and 0 can be returned + if self.get_selected() != None: + self.edit_btn.set_sensitive(True) + self.del_btn.set_sensitive(True) + else: + self.edit_btn.set_sensitive(False) + self.del_btn.set_sensitive(False) diff --git a/gramps2/src/DisplayTabs/_ChildModel.py b/gramps2/src/DisplayTabs/_ChildModel.py new file mode 100644 index 000000000..e46d5cd43 --- /dev/null +++ b/gramps2/src/DisplayTabs/_ChildModel.py @@ -0,0 +1,127 @@ +# +# Gramps - a GTK+/GNOME based genealogy program +# +# Copyright (C) 2000-2006 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$ + +#------------------------------------------------------------------------- +# +# GTK libraries +# +#------------------------------------------------------------------------- +import gtk + +#------------------------------------------------------------------------- +# +# GRAMPS classes +# +#------------------------------------------------------------------------- +import DateHandler +import NameDisplay +import Utils + +#------------------------------------------------------------------------- +# +# ChildModel +# +#------------------------------------------------------------------------- +class ChildModel(gtk.ListStore): + + _HANDLE_COL = -8 + + def __init__(self, family, db): + self.family = family + gtk.ListStore.__init__(self, int, str, str, str, str, str, + str, str, str, str, str, str, int, int) + self.db = db + index = 1 + for child_ref in self.get_data(): + child = db.get_person_from_handle(child_ref.ref) + self.append(row=[ + index, + child.get_gramps_id(), + NameDisplay.displayer.display(child), + Utils.gender[child.get_gender()], + str(child_ref.get_father_relation()), + str(child_ref.get_mother_relation()), + self.column_birth_day(child), + self.column_death_day(child), + self.column_birth_place(child), + self.column_death_place(child), + child.get_handle(), + NameDisplay.displayer.sort_string(child.primary_name), + self.column_birth_sort(child), + self.column_death_sort(child), + ]) + index += 1 + + def get_data(self): + return self.family.get_child_ref_list() + + def column_birth_day(self, data): + event_ref = data.get_birth_ref() + if event_ref and event_ref.ref: + event = self.db.get_event_from_handle(event_ref.ref) + return DateHandler.get_date(event) + else: + return u"" + + def column_birth_sort(self, data): + event_ref = data.get_birth_ref() + if event_ref and event_ref.ref: + event = self.db.get_event_from_handle(event_ref.ref) + return event.get_date_object().get_sort_value() + else: + return 0 + + def column_death_day(self, data): + event_ref = data.get_death_ref() + if event_ref and event_ref.ref: + event = self.db.get_event_from_handle(event_ref.ref) + return DateHandler.get_date(event) + else: + return u"" + + def column_death_sort(self, data): + event_ref = data.get_death_ref() + if event_ref and event_ref.ref: + event = self.db.get_event_from_handle(event_ref.ref) + return event.get_date_object().get_sort_value() + else: + return 0 + + def column_birth_place(self, data): + event_ref = data.get_birth_ref() + if event_ref and event_ref.ref: + event = self.db.get_event_from_handle(event_ref.ref) + if event: + place_handle = event.get_place_handle() + if place_handle: + return self.db.get_place_from_handle(place_handle).get_title() + return u"" + + def column_death_place(self, data): + event_ref = data.get_death_ref() + if event_ref and event_ref.ref: + event = self.db.get_event_from_handle(event_ref.ref) + if event: + place_handle = event.get_place_handle() + if place_handle: + return self.db.get_place_from_handle(place_handle).get_title() + return u"" diff --git a/gramps2/src/DisplayTabs/_DataEmbedList.py b/gramps2/src/DisplayTabs/_DataEmbedList.py new file mode 100644 index 000000000..06bb151f6 --- /dev/null +++ b/gramps2/src/DisplayTabs/_DataEmbedList.py @@ -0,0 +1,120 @@ +# +# Gramps - a GTK+/GNOME based genealogy program +# +# Copyright (C) 2000-2006 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 _ + +#------------------------------------------------------------------------- +# +# GRAMPS classes +# +#------------------------------------------------------------------------- +from DdTargets import DdTargets +from _DataModel import DataModel +from _EmbeddedList import EmbeddedList + +#------------------------------------------------------------------------- +# +# DataEmbedList +# +#------------------------------------------------------------------------- +class DataEmbedList(EmbeddedList): + + _HANDLE_COL = 0 + _DND_TYPE = DdTargets.DATA + _column_names = [ + (_('Key'), 0, 150), + (_('Value'), 1, 250), + ] + + def __init__(self, dbstate, uistate, track, obj): + self.obj = obj + + EmbeddedList.__init__(self, dbstate, uistate, track, + _('Data'), DataModel) + + def build_columns(self): + EmbeddedList.build_columns(self) + + # Need to add attributes to renderers + # and connect renderers to the 'edited' signal + for colno in range(len(self.columns)): + for renderer in self.columns[colno].get_cell_renderers(): + renderer.set_property('editable',True) + renderer.connect('edited',self.edit_inline,colno) + + def get_data(self): + return self.obj.get_data_map() + + def is_empty(self): + return len(self.model)==0 + + def _get_map_from_model(self): + new_map = {} + for idx in range(len(self.model)): + node = self.model.get_iter(idx) + key = unicode(self.model.get_value(node,0)) + value = unicode(self.model.get_value(node,1)) + if key.strip(): + new_map[key] = value + return new_map + + def update(self): + new_map = self._get_map_from_model() + self.obj.set_data_map(new_map) + self._set_label() + + def column_order(self): + return ((1, 0), (1, 1)) + + def add_button_clicked(self, obj): + node = self.model.append(row=['','']) + self.selection.select_iter(node) + path = self.model.get_path(node) + self.tree.set_cursor_on_cell(path, + focus_column=self.columns[0], + focus_cell=None, + start_editing=True) + + def del_button_clicked(self, obj): + (model,node) = self.selection.get_selected() + if node: + self.model.remove(node) + self.update() + + def edit_inline(self, cell, path, new_text, data): + node = self.model.get_iter(path) + self.model.set_value(node,data,new_text) + self.update() + + def edit_button_clicked(self, obj): + (model,node) = self.selection.get_selected() + if node: + path = self.model.get_path(node) + self.tree.set_cursor_on_cell(path, + focus_column=self.columns[0], + focus_cell=None, + start_editing=True) diff --git a/gramps2/src/DisplayTabs/_DataModel.py b/gramps2/src/DisplayTabs/_DataModel.py new file mode 100644 index 000000000..76bee57e8 --- /dev/null +++ b/gramps2/src/DisplayTabs/_DataModel.py @@ -0,0 +1,49 @@ +# +# Gramps - a GTK+/GNOME based genealogy program +# +# Copyright (C) 2000-2006 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$ + +#------------------------------------------------------------------------- +# +# GTK libraries +# +#------------------------------------------------------------------------- +import gtk + +#------------------------------------------------------------------------- +# +# GRAMPS classes +# +#------------------------------------------------------------------------- + + +#------------------------------------------------------------------------- +# +# DataModel +# +#------------------------------------------------------------------------- +class DataModel(gtk.ListStore): + + def __init__(self, attr_list, db): + gtk.ListStore.__init__(self, str, str) + self.db = db + + for key,value in attr_list.items(): + self.append(row=[key,value]) diff --git a/gramps2/src/DisplayTabs/_EmbeddedList.py b/gramps2/src/DisplayTabs/_EmbeddedList.py new file mode 100644 index 000000000..a39328447 --- /dev/null +++ b/gramps2/src/DisplayTabs/_EmbeddedList.py @@ -0,0 +1,353 @@ +# +# Gramps - a GTK+/GNOME based genealogy program +# +# Copyright (C) 2000-2006 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 +# +#------------------------------------------------------------------------- +from gettext import gettext as _ +import pickle + +#------------------------------------------------------------------------- +# +# GTK libraries +# +#------------------------------------------------------------------------- +import gtk +import pango + +#------------------------------------------------------------------------- +# +# GRAMPS classes +# +#------------------------------------------------------------------------- +from _ButtonTab import ButtonTab + +#------------------------------------------------------------------------- +# +# Classes +# +#------------------------------------------------------------------------- +class EmbeddedList(ButtonTab): + """ + This class provides the base class for all the list tabs. It + maintains a gtk.TreeView, including the selection and button + sensitivity. + """ + + _HANDLE_COL = -1 + _DND_TYPE = None + _DND_EXTRA = None + + def __init__(self, dbstate, uistate, track, name, build_model, + share=False): + """ + Creates a new list, using the passed build_model to + populate the list. + """ + ButtonTab.__init__(self, dbstate, uistate, track, name, share) + + + self.changed = False + self.build_model = build_model + + # handle the selection + self.selection = self.tree.get_selection() + self.selection.connect('changed', self._selection_changed) + + # build the columns + self.columns = [] + self.build_columns() + + if self._DND_TYPE: + self._set_dnd() + + # set up right click option + self.tree.connect('button-press-event', self._on_button_press) + + # build the initial data + self.rebuild() + self.show_all() + + def _on_button_press(self, obj, event): + if event.type == gtk.gdk.BUTTON_PRESS and event.button == 3: + ref = self.get_selected() + if ref: + self.right_click(obj, event) + + def right_click(self, obj, event): + + if self.share_btn: + itemlist = [ + (True, gtk.STOCK_ADD, self.add_button_clicked), + (False, _('Share'), self.edit_button_clicked), + (True, gtk.STOCK_EDIT, self.edit_button_clicked), + (True, gtk.STOCK_REMOVE, self.del_button_clicked), + ] + else: + itemlist = [ + (True, gtk.STOCK_ADD, self.add_button_clicked), + (True, gtk.STOCK_EDIT, self.edit_button_clicked), + (True, gtk.STOCK_REMOVE, self.del_button_clicked), + ] + + menu = gtk.Menu() + for (image, title, func) in itemlist: + if image: + item = gtk.ImageMenuItem(stock_id=title) + else: + item = gtk.MenuItem(title) + item.connect('activate', func) + item.show() + menu.append(item) + menu.popup(None, None, None, event.button, event.time) + + def find_index(self, obj): + """ + returns the index of the object within the associated data + """ + return self.get_data().index(obj) + + def _set_dnd(self): + """ + Sets up drag-n-drop. The source and destionation are set by calling .target() + on the _DND_TYPE. Obviously, this means that there must be a _DND_TYPE + variable defined that points to an entry in DdTargets. + """ + + if self._DND_EXTRA: + dnd_types = [ self._DND_TYPE.target(), self._DND_EXTRA.target() ] + else: + dnd_types = [ self._DND_TYPE.target() ] + + self.tree.drag_dest_set(gtk.DEST_DEFAULT_ALL, dnd_types, + gtk.gdk.ACTION_COPY) + self.tree.drag_source_set(gtk.gdk.BUTTON1_MASK, + [self._DND_TYPE.target()], + gtk.gdk.ACTION_COPY) + self.tree.connect('drag_data_get', self.drag_data_get) + self.tree.connect('drag_data_received', self.drag_data_received) + + def drag_data_get(self, widget, context, sel_data, info, time): + """ + Provide the drag_data_get function, which passes a tuple consisting of: + + 1) Drag type defined by the .drag_type field specfied by the value + assigned to _DND_TYPE + 2) The id value of this object, used for the purpose of determining + the source of the object. If the source of the object is the same + as the object, we are doing a reorder instead of a normal drag + and drop + 3) Pickled data. The pickled version of the selected object + 4) Source row. Used for a reorder to determine the original position + of the object + """ + + # get the selected object, returning if not is defined + obj = self.get_selected() + if not obj: + return + + # pickle the data, and build the tuple to be passed + value = (self._DND_TYPE.drag_type, id(self), obj,self.find_index(obj)) + data = pickle.dumps(value) + + # pass as a string (8 bits) + sel_data.set(sel_data.target, 8, data) + + def drag_data_received(self, widget, context, x, y, sel_data, info, time): + """ + Handle the standard gtk interface for drag_data_received. + + If the selection data is define, extract the value from sel_data.data, + and decide if this is a move or a reorder. + """ + if sel_data and sel_data.data: + (mytype, selfid, obj, row_from) = pickle.loads(sel_data.data) + + # make sure this is the correct DND type for this object + if mytype == self._DND_TYPE.drag_type: + + # determine the destination row + row = self._find_row(x, y) + + # if the is same object, we have a move, otherwise, + # it is a standard drag-n-drop + + if id(self) == selfid: + self._move(row_from, row, obj) + else: + self._handle_drag(row, obj) + self.rebuild() + elif self._DND_EXTRA and mytype == self._DND_EXTRA.drag_type: + self.handle_extra_type(mytype, obj) + + def handle_extra_type(self, objtype, obj): + pass + + def _find_row(self, x, y): + row = self.tree.get_path_at_pos(x, y) + if row == None: + return len(self.get_data()) + else: + return row[0][0] + + def _handle_drag(self, row, obj): + self.get_data().insert(row, obj) + self.changed = True + self.rebuild() + + def _move(self, row_from, row_to, obj): + dlist = self.get_data() + if row_from < row_to: + dlist.insert(row_to, obj) + del dlist[row_from] + else: + del dlist[row_from] + dlist.insert(row_to-1, obj) + self.changed = True + self.rebuild() + + def get_icon_name(self): + """ + Specifies the basic icon used for a generic list. Typically, + a derived class will override this. The icon chose is the + STOCK_JUSTIFY_FILL icon, which in the default GTK style + looks kind of like a list. + """ + return gtk.STOCK_JUSTIFY_FILL + + def del_button_clicked(self, obj): + ref = self.get_selected() + if ref: + ref_list = self.get_data() + ref_list.remove(ref) + self.changed = True + self.rebuild() + + def build_interface(self): + """ + Builds the interface, instantiating a gtk.TreeView in a + gtk.ScrolledWindow. + """ + + # create the tree, turn on rule hinting and connect the + # button press to the double click function. + + self.tree = gtk.TreeView() + self.tree.set_reorderable(True) + self.tree.set_rules_hint(True) + self.tree.connect('button_press_event', self.double_click) + + # create the scrolled window, and attach the treeview + scroll = gtk.ScrolledWindow() + scroll.set_shadow_type(gtk.SHADOW_IN) + scroll.set_policy(gtk.POLICY_AUTOMATIC, gtk.POLICY_AUTOMATIC) + scroll.add(self.tree) + self.pack_start(scroll, True) + + def get_selected(self): + """ + returns the value associated with selected row in the model, + based of the _HANDLE_COL value. Each model must define this + to indicate what the returned value should be. If no selection + has been made, None is returned. + """ + (model, node) = self.selection.get_selected() + if node: + return model.get_value(node, self._HANDLE_COL) + return None + + def is_empty(self): + """ + Returns True if the get_data returns a length greater than + 0. Typically, get_data returns the list of associated data. + """ + return len(self.get_data()) == 0 + + def get_data(self): + """ + Returns the data associated with the list. This is typically + a list of objects. + + This should be overridden in the derrived classes. + """ + return [] + + def column_order(self): + """ + Specifies the column order for the columns. This should be + in the format of a list of tuples, in the format of (int,int), + where the first in indicates if the column is visible, and the + second column indicates the index into the model. + + This should be overridden in the derrived classes. + """ + return [] + + def build_columns(self): + """ + Builds the columns and inserts them into the TreeView. Any + previous columns exist, they will be in the self.columns array, + and removed. + """ + + # remove any existing columns, which would be stored in + # self.columns + + for column in self.columns: + self.tree.remove_column(column) + self.columns = [] + + # loop through the values returned by column_order + + for pair in self.column_order(): + + # if the first value isn't 1, then we skip the values + if not pair[0]: + continue + + # extract the name from the _column_names variable, and + # assign it to the column name. The text value is extracted + # from the model column specified in pair[1] + name = self._column_names[pair[1]][0] + renderer = gtk.CellRendererText() + renderer.set_property('ellipsize', pango.ELLIPSIZE_END) + column = gtk.TreeViewColumn(name, renderer, text=pair[1]) + + # insert the colum into the tree + column.set_resizable(True) + column.set_min_width(self._column_names[pair[1]][2]) + column.set_sort_column_id(self._column_names[pair[1]][1]) + self.columns.append(column) + self.tree.append_column(column) + + def rebuild(self): + """ + Rebuilds the data in the database by creating a new model, + using the build_model function passed at creation time. + """ + self.model = self.build_model(self.get_data(), self.dbstate.db) + self.tree.set_model(self.model) + self._set_label() + self._selection_changed() diff --git a/gramps2/src/DisplayTabs/_EventBackRefList.py b/gramps2/src/DisplayTabs/_EventBackRefList.py new file mode 100644 index 000000000..ecdedb21a --- /dev/null +++ b/gramps2/src/DisplayTabs/_EventBackRefList.py @@ -0,0 +1,45 @@ +# +# Gramps - a GTK+/GNOME based genealogy program +# +# Copyright (C) 2000-2006 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 _ + +#------------------------------------------------------------------------- +# +# GRAMPS classes +# +#------------------------------------------------------------------------- +from _BackRefModel import BackRefModel +from _BackRefList import BackRefList + +class EventBackRefList(BackRefList): + + def __init__(self, dbstate, uistate, track, obj, callback=None): + BackRefList.__init__(self, dbstate, uistate, track, obj, + BackRefModel, callback) + + def get_icon_name(self): + return 'gramps-event' diff --git a/gramps2/src/DisplayTabs/_EventEmbedList.py b/gramps2/src/DisplayTabs/_EventEmbedList.py new file mode 100644 index 000000000..74aab0ed3 --- /dev/null +++ b/gramps2/src/DisplayTabs/_EventEmbedList.py @@ -0,0 +1,151 @@ +# +# Gramps - a GTK+/GNOME based genealogy program +# +# Copyright (C) 2000-2006 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 _ + +#------------------------------------------------------------------------- +# +# GRAMPS classes +# +#------------------------------------------------------------------------- +import RelLib +import Errors +from DdTargets import DdTargets +from _EmbeddedList import EmbeddedList +from _EventRefModel import EventRefModel + +#------------------------------------------------------------------------- +# +# EventEmbedList +# +#------------------------------------------------------------------------- +class EventEmbedList(EmbeddedList): + + _HANDLE_COL = 6 + _DND_TYPE = DdTargets.EVENTREF + _DND_EXTRA = DdTargets.EVENT + + _MSG = { + 'add' : _('Add a new event'), + 'del' : _('Remove the selected event'), + 'edit' : _('Edit the selected event'), + 'share' : _('Share an exisiting event'), + } + + _column_names = [ + (_('Type'), 0, 100), + (_('Description'), 1, 175), + (_('ID'), 2, 60), + (_('Date'), 3, 150), + (_('Place'), 4, 140), + (_('Role'), 5, 80), + ] + + def __init__(self, dbstate, uistate, track, obj): + self.obj = obj + EmbeddedList.__init__(self, dbstate, uistate, track, + _('Events'), EventRefModel, True) + + def get_ref_editor(self): + from Editors import EditFamilyEventRef + return EditFamilyEventRef + + def get_icon_name(self): + return 'gramps-event' + + def get_data(self): + return self.obj.get_event_ref_list() + + def column_order(self): + return ((1, 0), (1, 1), (1, 2), (1, 3), (1, 4), (1, 5)) + + def handle_extra_type(self, objtype, obj): + try: + ref = RelLib.EventRef() + event = self.dbstate.db.get_event_from_handle(obj) + event.set_type(self.default_type()) + ref.set_role(self.default_role()) + self.get_ref_editor()( + self.dbstate, self.uistate, self.track, + event, ref, self.event_added) + except Errors.WindowActiveError: + pass + + def default_type(self): + return RelLib.EventType(RelLib.EventType.MARRIAGE) + + def default_role(self): + return RelLib.EventRoleType(RelLib.EventRoleType.FAMILY) + + def add_button_clicked(self, obj): + try: + ref = RelLib.EventRef() + event = RelLib.Event() + ref.set_role(self.default_role()) + event.set_type(self.default_type()) + self.get_ref_editor()( + self.dbstate, self.uistate, self.track, + event, ref, self.event_added) + except Errors.WindowActiveError: + pass + + def share_button_clicked(self, obj): + import SelectEvent + + sel = SelectEvent.SelectEvent(self.dbstate,self.uistate,self.track, + _("Select event")) + event = sel.run() + if event: + try: + ref = RelLib.EventRef() + ref.set_role(self.default_role()) + self.get_ref_editor()( + self.dbstate, self.uistate, self.track, + event, ref, self.event_added) + except Errors.WindowActiveError: + pass + + def edit_button_clicked(self, obj): + ref = self.get_selected() + if ref: + event = self.dbstate.db.get_event_from_handle(ref.ref) + try: + self.get_ref_editor()( + self.dbstate, self.uistate, self.track, + event, ref, self.event_updated) + except Errors.WindowActiveError: + pass + + def event_updated(self, ref, event): + self.changed = True + self.rebuild() + + def event_added(self, ref, event): + ref.ref = event.handle + self.get_data().append(ref) + self.changed = True + self.rebuild() diff --git a/gramps2/src/DisplayTabs/_EventRefModel.py b/gramps2/src/DisplayTabs/_EventRefModel.py new file mode 100644 index 000000000..ad6f72b9e --- /dev/null +++ b/gramps2/src/DisplayTabs/_EventRefModel.py @@ -0,0 +1,73 @@ +# +# Gramps - a GTK+/GNOME based genealogy program +# +# Copyright (C) 2000-2006 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$ + +#------------------------------------------------------------------------- +# +# GTK libraries +# +#------------------------------------------------------------------------- +import gtk + +#------------------------------------------------------------------------- +# +# GRAMPS classes +# +#------------------------------------------------------------------------- +import DateHandler + +#------------------------------------------------------------------------- +# +# EventRefModel +# +#------------------------------------------------------------------------- +class EventRefModel(gtk.ListStore): + + def __init__(self, event_list, db): + gtk.ListStore.__init__(self, str, str, str, str, str, str, object) + self.db = db + for event_ref in event_list: + event = db.get_event_from_handle(event_ref.ref) + self.append(row=[ + str(event.get_type()), + event.get_description(), + event.get_gramps_id(), + self.column_date(event_ref), + self.column_place(event_ref), + self.column_role(event_ref), + event_ref + ]) + + def column_role(self, event_ref): + return str(event_ref.get_role()) + + def column_date(self, event_ref): + event = self.db.get_event_from_handle(event_ref.ref) + return DateHandler.get_date(event) + + def column_place(self, event_ref): + if event_ref and event_ref.ref: + event = self.db.get_event_from_handle(event_ref.ref) + if event: + place_handle = event.get_place_handle() + if place_handle: + return self.db.get_place_from_handle(place_handle).get_title() + return u"" diff --git a/gramps2/src/DisplayTabs/_FamilyAttrEmbedList.py b/gramps2/src/DisplayTabs/_FamilyAttrEmbedList.py new file mode 100644 index 000000000..983501074 --- /dev/null +++ b/gramps2/src/DisplayTabs/_FamilyAttrEmbedList.py @@ -0,0 +1,52 @@ +# +# Gramps - a GTK+/GNOME based genealogy program +# +# Copyright (C) 2000-2006 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 _ + +#------------------------------------------------------------------------- +# +# GRAMPS classes +# +#------------------------------------------------------------------------- +from _AttrEmbedList import AttrEmbedList + +#------------------------------------------------------------------------- +# +# +# +#------------------------------------------------------------------------- +class FamilyAttrEmbedList(AttrEmbedList): + + def __init__(self, dbstate, uistate, track, data): + AttrEmbedList.__init__(self, dbstate, uistate, track, data) + + def get_editor(self): + from Editors import EditFamilyAttribute + return EditFamilyAttribute + + def get_user_values(self): + return self.dbstate.db.get_family_attribute_types() diff --git a/gramps2/src/DisplayTabs/_FamilyLdsEmbedList.py b/gramps2/src/DisplayTabs/_FamilyLdsEmbedList.py new file mode 100644 index 000000000..2b33ec627 --- /dev/null +++ b/gramps2/src/DisplayTabs/_FamilyLdsEmbedList.py @@ -0,0 +1,65 @@ +# +# Gramps - a GTK+/GNOME based genealogy program +# +# Copyright (C) 2000-2006 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 _ + +#------------------------------------------------------------------------- +# +# GRAMPS classes +# +#------------------------------------------------------------------------- +from _LdsEmbedList import LdsEmbedList + +#------------------------------------------------------------------------- +# +# +# +#------------------------------------------------------------------------- +class FamilyLdsEmbedList(LdsEmbedList): + + _HANDLE_COL = 5 +# _DND_TYPE = DdTargets.ADDRESS + + _column_names = [ + (_('Type'), 0, 150), + (_('Date'), 1, 150), + (_('Status'), 3, 75), + (_('Temple'), 2, 200), + (_('Place'), 3, 100), + ] + + def __init__(self, dbstate, uistate, track, data): + LdsEmbedList.__init__(self, dbstate, uistate, track, data) + + def get_editor(self): + from Editors import EditFamilyLdsOrd + return EditFamilyLdsOrd + + def new_data(self): + lds = RelLib.LdsOrd() + lds.set_type(RelLib.LdsOrd.SEAL_TO_SPOUSE) + return lds diff --git a/gramps2/src/DisplayTabs/_GalleryTab.py b/gramps2/src/DisplayTabs/_GalleryTab.py new file mode 100644 index 000000000..c1e1df39b --- /dev/null +++ b/gramps2/src/DisplayTabs/_GalleryTab.py @@ -0,0 +1,255 @@ +# +# Gramps - a GTK+/GNOME based genealogy program +# +# Copyright (C) 2000-2006 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 libraries +# +#------------------------------------------------------------------------- +import gtk + +#------------------------------------------------------------------------- +# +# GRAMPS classes +# +#------------------------------------------------------------------------- +import RelLib +import Utils +import ImgManip +import Mime +import Errors +from _ButtonTab import ButtonTab + +#------------------------------------------------------------------------- +# +# +# +#------------------------------------------------------------------------- +def make_launcher(prog, path): + return lambda x: Utils.launch(prog, path) + +#------------------------------------------------------------------------- +# +# GalleryTab +# +#------------------------------------------------------------------------- +class GalleryTab(ButtonTab): + + def __init__(self, dbstate, uistate, track, media_list, update=None): + ButtonTab.__init__(self, dbstate, uistate, track, _('Gallery'), True) + self.media_list = media_list + self.update = update + self.rebuild() + self.show_all() + + def double_click(self, obj, event): + """ + Handles the double click on list. If the double click occurs, + the Edit button handler is called + """ + if event.type == gtk.gdk._2BUTTON_PRESS and event.button == 1: + self.edit_button_clicked(obj) + elif event.type == gtk.gdk.BUTTON_PRESS and event.button == 3: + reflist = self.iconlist.get_selected_items() + if len(reflist) == 1: + ref = self.media_list[reflist[0][0]] + self.right_click(ref, event) + + def right_click(self, obj, event): + itemlist = [ + (True, gtk.STOCK_ADD, self.add_button_clicked), + (False, _('Share'), self.edit_button_clicked), + (True, gtk.STOCK_EDIT, self.edit_button_clicked), + (True, gtk.STOCK_REMOVE, self.del_button_clicked), + ] + + menu = gtk.Menu() + + ref_obj = self.dbstate.db.get_object_from_handle(obj.ref) + mime_type = ref_obj.get_mime_type() + if mime_type: + app = Mime.get_application(mime_type) + if app: + item = gtk.MenuItem(_('Open with %s') % app[1]) + item.connect('activate', make_launcher(app[0], + ref_obj.get_path())) + item.show() + menu.append(item) + item = gtk.SeparatorMenuItem() + item.show() + menu.append(item) + + for (image, title, func) in itemlist: + if image: + item = gtk.ImageMenuItem(stock_id=title) + else: + item = gtk.MenuItem(title) + item.connect('activate', func) + item.show() + menu.append(item) + menu.popup(None, None, None, event.button, event.time) + + def get_icon_name(self): + return 'gramps-media' + + def is_empty(self): + return len(self.media_list)==0 + + def _build_icon_model(self): + self.iconmodel= gtk.ListStore(gtk.gdk.Pixbuf, str, object) + + def _connect_icon_model(self): + self.iconlist.set_model(self.iconmodel) + self.iconmodel.connect_after('row-inserted', self._update_internal_list) + self.iconmodel.connect_after('row-deleted', self._update_internal_list) + + def build_interface(self): + + self._build_icon_model() + # build the icon view + self.iconlist = gtk.IconView() + self.iconlist.set_pixbuf_column(0) + self.iconlist.set_text_column(1) + self.iconlist.set_margin(12) + self.iconlist.set_reorderable(True) + self.iconlist.set_item_width(125) + self.iconlist.set_spacing(24) + self.iconlist.set_selection_mode(gtk.SELECTION_SINGLE) + self.iconlist.connect('selection-changed', self._selection_changed) + self.iconlist.connect('button_press_event', self.double_click) + self._connect_icon_model() + + scroll = gtk.ScrolledWindow() + scroll.set_policy(gtk.POLICY_AUTOMATIC, gtk.POLICY_AUTOMATIC) + scroll.add_with_viewport(self.iconlist) + self.pack_start(scroll, True) + + def _update_internal_list(self, *obj): + newlist = [] + node = self.iconmodel.get_iter_first() + while node != None: + newlist.append(self.iconmodel.get_value(node, 2)) + node = self.iconmodel.iter_next(node) + for i in xrange(len(self.media_list)): + self.media_list.pop() + for i in newlist: + if i: + self.media_list.append(i) + + if self.update: + self.update() + self.changed = True + + def get_data(self): + return self.media_list + + def rebuild(self): + self._build_icon_model() + for ref in self.media_list: + handle = ref.get_reference_handle() + obj = self.dbstate.db.get_object_from_handle(handle) + pixbuf = ImgManip.get_thumbnail_image(obj.get_path(), + obj.get_mime_type()) + self.iconmodel.append(row=[pixbuf, obj.get_description(), ref]) + self._connect_icon_model() + self._set_label() + self._selection_changed() + if self.update: + self.update() + + def get_selected(self): + node = self.iconlist.get_selected_items() + if len(node) > 0: + return self.media_list[node[0][0]] + return None + + def add_button_clicked(self, obj): + import AddMedia + + am = AddMedia.AddMediaObject(self.dbstate, self.uistate, self.track) + am.run() + src = am.object + + if src: + sref = RelLib.MediaRef() + try: + from Editors import EditMediaRef + + EditMediaRef(self.dbstate, self.uistate, self.track, + src, sref, self.add_callback) + except Errors.WindowActiveError: + pass + + def add_callback(self, media_ref, media): + media_ref.ref = media.handle + self.get_data().append(media_ref) + self.changed = True + self.rebuild() + + def share_button_clicked(self, obj): + """ + Function called with the Add button is clicked. This function + should be overridden by the derived class. + """ + import SelectObject + + sel = SelectObject.SelectObject(self.dbstate,self.uistate,self.track, + _("Select media")) + src = sel.run() + if src: + sref = RelLib.MediaRef() + try: + from Editors import EditMediaRef + + EditMediaRef(self.dbstate, self.uistate, self.track, + src, sref, self.add_callback) + except Errors.WindowActiveError: + pass + + def del_button_clicked(self, obj): + ref = self.get_selected() + if ref: + self.media_list.remove(ref) + self.rebuild() + + def edit_button_clicked(self, obj): + ref = self.get_selected() + if ref: + obj = self.dbstate.db.get_object_from_handle(ref.get_reference_handle()) + try: + from Editors import EditMediaRef + + EditMediaRef(self.dbstate, self.uistate, self.track, + obj, ref, self.edit_callback) + except Errors.WindowActiveError: + pass + + def edit_callback(self, media_ref, ref): + self.changed = True + self.rebuild() diff --git a/gramps2/src/DisplayTabs/_GrampsTab.py b/gramps2/src/DisplayTabs/_GrampsTab.py new file mode 100644 index 000000000..3718829e0 --- /dev/null +++ b/gramps2/src/DisplayTabs/_GrampsTab.py @@ -0,0 +1,149 @@ +# +# Gramps - a GTK+/GNOME based genealogy program +# +# Copyright (C) 2000-2006 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$ + +#------------------------------------------------------------------------- +# +# GTK libraries +# +#------------------------------------------------------------------------- +import gtk + +#------------------------------------------------------------------------- +# +# Classes +# +#------------------------------------------------------------------------- +class GrampsTab(gtk.HBox): + """ + This class provides the base level class for 'tabs', which are used to + fill in notebook tabs for GRAMPS edit dialogs. Each tab returns a + gtk container widget which can be inserted into a gtk.Notebook by the + instantiating object. + + All tab classes should inherit from GrampsTab + """ + + def __init__(self, dbstate, uistate, track, name): + """ + @param dbstate: The database state. Contains a reference to + the database, along with other state information. The GrampsTab + uses this to access the database and to pass to and created + child windows (such as edit dialogs). + @type dbstate: DbState + @param uistate: The UI state. Used primarily to pass to any created + subwindows. + @type uistate: DisplayState + @param track: The window tracking mechanism used to manage windows. + This is only used to pass to generted child windows. + @type track: list + @param name: Notebook label name + @type name: str/unicode + """ + gtk.HBox.__init__(self) + + # store information to pass to child windows + self.dbstate = dbstate + self.uistate = uistate + self.track = track + self.changed = False + + # save name used for notebook label, and build the widget used + # for the label + + self.tab_name = name + self.label_container = self.build_label_widget() + + # build the interface + self.share_btn = None + self.build_interface() + + def get_selected(self): + return None + + def is_empty(self): + """ + Indicates if the tab contains any data. This is used to determine + how the label should be displayed. + """ + return True + + def build_label_widget(self): + """ + Standard routine to build a widget. Does not need to be overridden + by the derrived class. Creates an container that has the label and + the icon in it. + @returns: widget to be used for the notebook label. + @rtype: gtk.HBox + """ + hbox = gtk.HBox() + self.tab_image = gtk.image_new_from_stock(self.get_icon_name(), + gtk.ICON_SIZE_MENU) + self.label = gtk.Label(self.tab_name) + hbox.pack_start(self.tab_image) + hbox.set_spacing(6) + hbox.add(self.label) + hbox.show_all() + return hbox + + def get_icon_name(self): + """ + Provides the name of the registered stock icon to be used as the + icon in the label. This is typically overridden by the derrived + class to provide the new name. + @returns: stock icon name + @rtype: str + """ + return gtk.STOCK_NEW + + def get_tab_widget(self): + """ + Provides the widget to be used for the notebook tab label. A + container class is provided, and the object may manipulate the + child widgets contained in the container. + @returns: gtk widget + @rtype: gtk.HBox + """ + return self.label_container + + def _set_label(self): + """ + Updates the label based of if the tab contains information. Tabs + without information will not have an icon, and the text will not + be bold. Tabs that contain data will have their icon displayed and + the label text will be in bold face. + """ + if not self.is_empty(): + self.tab_image.show() + self.label.set_text("%s" % self.tab_name) + self.label.set_use_markup(True) + else: + self.tab_image.hide() + self.label.set_text(self.tab_name) + + def build_interface(self): + """ + Builds the interface for the derived class. This function should be + overridden in the derived class. Since the classes are derrived from + gtk.HBox, the self.pack_start, self.pack_end, and self.add functions + can be used to add widgets to the interface. + """ + pass diff --git a/gramps2/src/DisplayTabs/_LdsEmbedList.py b/gramps2/src/DisplayTabs/_LdsEmbedList.py new file mode 100644 index 000000000..b9f488a28 --- /dev/null +++ b/gramps2/src/DisplayTabs/_LdsEmbedList.py @@ -0,0 +1,97 @@ +# +# Gramps - a GTK+/GNOME based genealogy program +# +# Copyright (C) 2000-2006 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 _ + +#------------------------------------------------------------------------- +# +# GRAMPS classes +# +#------------------------------------------------------------------------- +import RelLib +import Errors +from _LdsModel import LdsModel +from _EmbeddedList import EmbeddedList + +#------------------------------------------------------------------------- +# +# +# +#------------------------------------------------------------------------- +class LdsEmbedList(EmbeddedList): + + _HANDLE_COL = 5 +# _DND_TYPE = DdTargets.ADDRESS + + _column_names = [ + (_('Type'), 0, 150), + (_('Date'), 1, 150), + (_('Status'), 3, 75), + (_('Temple'), 2, 200), + (_('Place'), 3, 100), + ] + + def __init__(self, dbstate, uistate, track, data): + self.data = data + EmbeddedList.__init__(self, dbstate, uistate, track, + _('LDS'), LdsModel) + + def get_editor(self): + from Editors import EditLdsOrd + return EditLdsOrd + + def new_data(self): + return RelLib.LdsOrd() + + def get_data(self): + return self.data + + def column_order(self): + return ((1, 0), (1, 1), (1, 2), (1, 3), (1, 4)) + + def add_button_clicked(self, obj): + try: + self.get_editor()(self.dbstate, self.uistate, self.track, + self.new_data(), self.add_callback) + except Errors.WindowActiveError: + pass + + def add_callback(self, name): + self.get_data().append(name) + self.rebuild() + + def edit_button_clicked(self, obj): + lds = self.get_selected() + if lds: + try: + self.get_editor()(self.dbstate, self.uistate, self.track, + lds, self.edit_callback) + except Errors.WindowActiveError: + pass + + def edit_callback(self, name): + self.rebuild() diff --git a/gramps2/src/DisplayTabs/_LdsModel.py b/gramps2/src/DisplayTabs/_LdsModel.py new file mode 100644 index 000000000..630302b0a --- /dev/null +++ b/gramps2/src/DisplayTabs/_LdsModel.py @@ -0,0 +1,67 @@ +# +# Gramps - a GTK+/GNOME based genealogy program +# +# Copyright (C) 2000-2006 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$ + +#------------------------------------------------------------------------- +# +# GTK libraries +# +#------------------------------------------------------------------------- +import gtk + +#------------------------------------------------------------------------- +# +# GRAMPS classes +# +#------------------------------------------------------------------------- +import DateHandler + +#------------------------------------------------------------------------- +# +# LdsModel +# +#------------------------------------------------------------------------- +class LdsModel(gtk.ListStore): + + _HANDLE_COL = 5 + + def __init__(self, lds_list, db): + gtk.ListStore.__init__(self, str, str, str, str, str, object) + + import lds + + self.db = db + for lds_ord in lds_list: + self.append(row=[ + lds.ord_type[lds_ord.get_type()], + DateHandler.get_date(lds_ord), + lds.ord_status[lds_ord.get_status()], + lds.temple_to_abrev.get(lds_ord.get_temple(), _("unknown")), + self.column_place(lds_ord), + lds_ord, + ]) + + def column_place(self, lds_ord): + if lds_ord: + place_handle = lds_ord.get_place_handle() + if place_handle: + return self.db.get_place_from_handle(place_handle).get_title() + return u"" diff --git a/gramps2/src/DisplayTabs/_LocationEmbedList.py b/gramps2/src/DisplayTabs/_LocationEmbedList.py new file mode 100644 index 000000000..24e723a7d --- /dev/null +++ b/gramps2/src/DisplayTabs/_LocationEmbedList.py @@ -0,0 +1,96 @@ +# +# Gramps - a GTK+/GNOME based genealogy program +# +# Copyright (C) 2000-2006 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 _ + +#------------------------------------------------------------------------- +# +# GRAMPS classes +# +#------------------------------------------------------------------------- +import RelLib +import Errors +from DdTargets import DdTargets +from _LocationModel import LocationModel +from _EmbeddedList import EmbeddedList + +#------------------------------------------------------------------------- +# +# +# +#------------------------------------------------------------------------- +class LocationEmbedList(EmbeddedList): + + _HANDLE_COL = 5 + _DND_TYPE = DdTargets.LOCATION + + _column_names = [ + (_('City'), 0, 150), + (_('County'), 1, 100), + (_('Church Parish'), 2, 100), + (_('State/Province'), 3, 100), + (_('Country'), 4, 75), + ] + + def __init__(self, dbstate, uistate, track, data): + self.data = data + EmbeddedList.__init__(self, dbstate, uistate, track, + _('Alternate Locations'), LocationModel) + + def get_data(self): + return self.data + + def column_order(self): + return ((1, 0), (1, 1), (1, 2), (1, 3), (1, 4)) + + def add_button_clicked(self, obj): + loc = RelLib.Location() + try: + from Editors import EditLocation + + EditLocation(self.dbstate, self.uistate, self.track, + loc, self.add_callback) + except Errors.WindowActiveError: + pass + + def add_callback(self, name): + self.get_data().append(name) + self.rebuild() + + def edit_button_clicked(self, obj): + loc = self.get_selected() + if loc: + try: + from Editors import EditLocation + + EditLocation(self.dbstate, self.uistate, self.track, + loc, self.edit_callback) + except Errors.WindowActiveError: + pass + + def edit_callback(self, name): + self.rebuild() diff --git a/gramps2/src/DisplayTabs/_LocationModel.py b/gramps2/src/DisplayTabs/_LocationModel.py new file mode 100644 index 000000000..df7132083 --- /dev/null +++ b/gramps2/src/DisplayTabs/_LocationModel.py @@ -0,0 +1,49 @@ +# +# Gramps - a GTK+/GNOME based genealogy program +# +# Copyright (C) 2000-2006 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$ + +#------------------------------------------------------------------------- +# +# GTK libraries +# +#------------------------------------------------------------------------- +import gtk + +#------------------------------------------------------------------------- +# +# GRAMPS classes +# +#------------------------------------------------------------------------- + + +#------------------------------------------------------------------------- +# +# LocationModel +# +#------------------------------------------------------------------------- +class LocationModel(gtk.ListStore): + + def __init__(self, obj_list, db): + gtk.ListStore.__init__(self, str, str, str, str, str, object) + self.db = db + for obj in obj_list: + self.append(row=[obj.city, obj.county, obj.parish, + obj.state, obj.country, obj, ]) diff --git a/gramps2/src/DisplayTabs/_MediaBackRefList.py b/gramps2/src/DisplayTabs/_MediaBackRefList.py new file mode 100644 index 000000000..0dad42288 --- /dev/null +++ b/gramps2/src/DisplayTabs/_MediaBackRefList.py @@ -0,0 +1,44 @@ +# +# Gramps - a GTK+/GNOME based genealogy program +# +# Copyright (C) 2000-2006 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 _ + +#------------------------------------------------------------------------- +# +# GRAMPS classes +# +#------------------------------------------------------------------------- +from _BackRefList import BackRefList + +class MediaBackRefList(BackRefList): + + def __init__(self, dbstate, uistate, track, obj, callback=None): + BackRefList.__init__(self, dbstate, uistate, track, obj, + BackRefModel, callback=callback) + + def get_icon_name(self): + return 'gramps-media' diff --git a/gramps2/src/DisplayTabs/_NameEmbedList.py b/gramps2/src/DisplayTabs/_NameEmbedList.py new file mode 100644 index 000000000..0de7ab0ea --- /dev/null +++ b/gramps2/src/DisplayTabs/_NameEmbedList.py @@ -0,0 +1,93 @@ +# +# Gramps - a GTK+/GNOME based genealogy program +# +# Copyright (C) 2000-2006 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 _ + +#------------------------------------------------------------------------- +# +# GRAMPS classes +# +#------------------------------------------------------------------------- +import RelLib +import Errors +from DdTargets import DdTargets +from _NameModel import NameModel +from _EmbeddedList import EmbeddedList + +#------------------------------------------------------------------------- +# +# +# +#------------------------------------------------------------------------- +class NameEmbedList(EmbeddedList): + + _HANDLE_COL = 2 + _DND_TYPE = DdTargets.NAME + + _column_names = [ + (_('Name'), 0, 250), + (_('Type'), 1, 100), + ] + + def __init__(self, dbstate, uistate, track, data): + self.data = data + EmbeddedList.__init__(self, dbstate, uistate, track, + _('Names'), NameModel) + + def get_data(self): + return self.data + + def column_order(self): + return ((1, 0), (1, 1)) + + def add_button_clicked(self, obj): + name = RelLib.Name() + try: + from Editors import EditName + + EditName(self.dbstate, self.uistate, self.track, + name, self.add_callback) + except Errors.WindowActiveError: + pass + + def add_callback(self, name): + self.get_data().append(name) + self.rebuild() + + def edit_button_clicked(self, obj): + name = self.get_selected() + if name: + try: + from Editors import EditName + + EditName(self.dbstate, self.uistate, self.track, + name, self.edit_callback) + except Errors.WindowActiveError: + pass + + def edit_callback(self, name): + self.rebuild() diff --git a/gramps2/src/DisplayTabs/_NameModel.py b/gramps2/src/DisplayTabs/_NameModel.py new file mode 100644 index 000000000..ce2256e41 --- /dev/null +++ b/gramps2/src/DisplayTabs/_NameModel.py @@ -0,0 +1,52 @@ +# +# Gramps - a GTK+/GNOME based genealogy program +# +# Copyright (C) 2000-2006 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$ + +#------------------------------------------------------------------------- +# +# GTK libraries +# +#------------------------------------------------------------------------- +import gtk + +#------------------------------------------------------------------------- +# +# GRAMPS classes +# +#------------------------------------------------------------------------- +import NameDisplay + +#------------------------------------------------------------------------- +# +# NameModel +# +#------------------------------------------------------------------------- +class NameModel(gtk.ListStore): + + def __init__(self, obj_list, db): + gtk.ListStore.__init__(self, str, str, object) + self.db = db + for obj in obj_list: + self.append(row=[ + NameDisplay.displayer.display_name(obj), + str(obj.get_type()), + obj, + ]) diff --git a/gramps2/src/DisplayTabs/_NoteTab.py b/gramps2/src/DisplayTabs/_NoteTab.py new file mode 100644 index 000000000..43fbba436 --- /dev/null +++ b/gramps2/src/DisplayTabs/_NoteTab.py @@ -0,0 +1,136 @@ +# +# Gramps - a GTK+/GNOME based genealogy program +# +# Copyright (C) 2000-2006 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 libraries +# +#------------------------------------------------------------------------- +import gtk + +#------------------------------------------------------------------------- +# +# GRAMPS classes +# +#------------------------------------------------------------------------- +import Spell +from _GrampsTab import GrampsTab + +#------------------------------------------------------------------------- +# +# NoteTab +# +#------------------------------------------------------------------------- +class NoteTab(GrampsTab): + + def __init__(self, dbstate, uistate, track, note_obj, title=_('Note')): + self.note_obj = note_obj + GrampsTab.__init__(self, dbstate, uistate, track, title) + self.show_all() + + def _update_label(self, *obj): + cc = self.buf.get_char_count() + if cc == 0 and not self.empty: + self.empty = True + self._set_label() + elif cc != 0 and self.empty: + self.empty = False + self._set_label() + + def is_empty(self): + """ + Indicates if the tab contains any data. This is used to determine + how the label should be displayed. + """ + return self.buf.get_char_count() == 0 + + def build_interface(self): + vbox = gtk.VBox() + + self.text = gtk.TextView() + self.flowed = gtk.RadioButton(None, _('Flowed')) + self.format = gtk.RadioButton(self.flowed, _('Formatted')) + + if self.note_obj and self.note_obj.get_format(): + self.format.set_active(True) + self.text.set_wrap_mode(gtk.WRAP_NONE) + else: + self.flowed.set_active(True) + self.text.set_wrap_mode(gtk.WRAP_WORD) + self.spellcheck = Spell.Spell(self.text) + + self.flowed.connect('toggled', self.flow_changed) + + scroll = gtk.ScrolledWindow() + scroll.set_policy(gtk.POLICY_AUTOMATIC, gtk.POLICY_AUTOMATIC) + scroll.add_with_viewport(self.text) + scroll.connect('focus-out-event', self.update) + + vbox.pack_start(scroll, True) + vbox.set_spacing(6) + vbox.set_border_width(6) + + hbox = gtk.HBox() + hbox.set_spacing(12) + hbox.set_border_width(6) + hbox.pack_start(self.flowed, False) + hbox.pack_start(self.format, False) + + vbox.pack_start(hbox, False) + + self.pack_start(vbox, True) + self.buf = self.text.get_buffer() + if self.note_obj: + self.empty = False + self.buf.insert_at_cursor(self.note_obj.get()) + else: + self.empty = True + + self.buf.connect('changed', self.update) + self.rebuild() + + def update(self, obj): + if self.note_obj: + start = self.buf.get_start_iter() + stop = self.buf.get_end_iter() + text = self.buf.get_text(start, stop) + self.note_obj.set(text) + else: + print "NOTE OBJ DOES NOT EXIST" + self._update_label(obj) + return False + + def flow_changed(self, obj): + if obj.get_active(): + self.text.set_wrap_mode(gtk.WRAP_WORD) + else: + self.text.set_wrap_mode(gtk.WRAP_NONE) + + def rebuild(self): + self._set_label() diff --git a/gramps2/src/DisplayTabs/_PersonEventEmbedList.py b/gramps2/src/DisplayTabs/_PersonEventEmbedList.py new file mode 100644 index 000000000..65c25fe55 --- /dev/null +++ b/gramps2/src/DisplayTabs/_PersonEventEmbedList.py @@ -0,0 +1,93 @@ +# +# Gramps - a GTK+/GNOME based genealogy program +# +# Copyright (C) 2000-2006 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 _ + +#------------------------------------------------------------------------- +# +# GRAMPS classes +# +#------------------------------------------------------------------------- +import RelLib +from DdTargets import DdTargets +from _EventEmbedList import EventEmbedList + +#------------------------------------------------------------------------- +# +# PersonEventEmbedList +# +#------------------------------------------------------------------------- +class PersonEventEmbedList(EventEmbedList): + + def __init__(self, dbstate, uistate, track, obj): + self.orig_data = [ data for data in [ obj.get_birth_ref(), \ + obj.get_death_ref()] + \ + obj.get_event_ref_list() \ + if data ] + EventEmbedList.__init__(self, dbstate, uistate, track, obj) + + def get_data(self): + return self.orig_data + + def default_role(self): + return RelLib.EventRoleType(RelLib.EventRoleType.PRIMARY) + + def default_type(self): + type_list = [] + ref_list = [ e for e in [self.obj.get_birth_ref(), self.obj.get_death_ref()] + \ + self.obj.get_event_ref_list() if e ] + + event = None + for event_ref in ref_list: + event = self.dbstate.db.get_event_from_handle(event_ref.ref) + type_list.append(int(event.get_type())) + + if event: + etype = event.get_type() + for etype in [RelLib.EventType.BIRTH, RelLib.EventType.DEATH]: + if etype not in type_list: + return RelLib.EventType(etype) + return RelLib.EventType(RelLib.EventType.BIRTH) + + def get_ref_editor(self): + from Editors import EditEventRef + return EditEventRef + + def return_info(self): + new_list = [] + birth_ref = None + death_ref = None + + for ref in self.orig_data: + event = self.dbstate.db.get_event_from_handle(ref.ref) + if birth_ref == None and event.get_type() == RelLib.EventType.BIRTH: + birth_ref = ref + elif death_ref == None and event.get_type() == RelLib.EventType.DEATH: + death_ref = ref + else: + new_list.append(ref) + return (birth_ref, death_ref, new_list) diff --git a/gramps2/src/DisplayTabs/_PersonRefEmbedList.py b/gramps2/src/DisplayTabs/_PersonRefEmbedList.py new file mode 100644 index 000000000..d6372a617 --- /dev/null +++ b/gramps2/src/DisplayTabs/_PersonRefEmbedList.py @@ -0,0 +1,96 @@ +# +# Gramps - a GTK+/GNOME based genealogy program +# +# Copyright (C) 2000-2006 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 _ + +#------------------------------------------------------------------------- +# +# GRAMPS classes +# +#------------------------------------------------------------------------- +import RelLib +import Errors +from DdTargets import DdTargets +from _PersonRefModel import PersonRefModel +from _EmbeddedList import EmbeddedList + +#------------------------------------------------------------------------- +# +# +# +#------------------------------------------------------------------------- +class PersonRefEmbedList(EmbeddedList): + + _HANDLE_COL = 3 + _DND_TYPE = DdTargets.ADDRESS + + _column_names = [ + (_('Name'), 0, 250), + (_('ID'), 1, 100), + (_('Relationship'), 2, 100), + ] + + def __init__(self, dbstate, uistate, track, data): + self.data = data + EmbeddedList.__init__(self, dbstate, uistate, track, + _('Relationships'), PersonRefModel) + + def get_data(self): + return self.data + + def column_order(self): + return ((1, 0), (1, 1), (1, 2)) + + def add_button_clicked(self, obj): + from Editors import EditPersonRef + + try: + ref = RelLib.PersonRef() + ref.rel = _('Godfather') + EditPersonRef( + self.dbstate, self.uistate, self.track, + ref, self.add_callback) + except Errors.WindowActiveError: + pass + + def add_callback(self, obj): + self.get_data().append(obj) + self.rebuild() + + def edit_button_clicked(self, obj): + ref = self.get_selected() + if ref: + try: + from Editors import EditPersonRef + EditPersonRef( + self.dbstate, self.uistate, self.track, + ref, self.edit_callback) + except Errors.WindowActiveError: + pass + + def edit_callback(self, obj): + self.rebuild() diff --git a/gramps2/src/DisplayTabs/_PersonRefModel.py b/gramps2/src/DisplayTabs/_PersonRefModel.py new file mode 100644 index 000000000..a127994d2 --- /dev/null +++ b/gramps2/src/DisplayTabs/_PersonRefModel.py @@ -0,0 +1,53 @@ +# +# Gramps - a GTK+/GNOME based genealogy program +# +# Copyright (C) 2000-2006 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$ + +#------------------------------------------------------------------------- +# +# GTK libraries +# +#------------------------------------------------------------------------- +import gtk + +#------------------------------------------------------------------------- +# +# GRAMPS classes +# +#------------------------------------------------------------------------- +import NameDisplay + +#------------------------------------------------------------------------- +# +# PersonRefModel +# +#------------------------------------------------------------------------- +class PersonRefModel(gtk.ListStore): + + def __init__(self, obj_list, db): + gtk.ListStore.__init__(self, str, str, str, object) + self.db = db + for obj in obj_list: + p = self.db.get_person_from_handle(obj.ref) + if p: + data = [NameDisplay.displayer.display(p), p.gramps_id, obj.rel, obj] + else: + data = ['unknown','unknown',obj.rel,obj] + self.append(row=data) diff --git a/gramps2/src/DisplayTabs/_PlaceBackRefList.py b/gramps2/src/DisplayTabs/_PlaceBackRefList.py new file mode 100644 index 000000000..788b45dee --- /dev/null +++ b/gramps2/src/DisplayTabs/_PlaceBackRefList.py @@ -0,0 +1,45 @@ +# +# Gramps - a GTK+/GNOME based genealogy program +# +# Copyright (C) 2000-2006 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 _ + +#------------------------------------------------------------------------- +# +# GRAMPS classes +# +#------------------------------------------------------------------------- +from _BackRefModel import BackRefModel +from _BackRefList import BackRefList + +class PlaceBackRefList(BackRefList): + + def __init__(self, dbstate, uistate, track, obj, callback=None): + BackRefList.__init__(self, dbstate, uistate, track, obj, + BackRefModel, callback=callback) + + def get_icon_name(self): + return 'gramps-place' diff --git a/gramps2/src/DisplayTabs/_RepoEmbedList.py b/gramps2/src/DisplayTabs/_RepoEmbedList.py new file mode 100644 index 000000000..f2632b4e8 --- /dev/null +++ b/gramps2/src/DisplayTabs/_RepoEmbedList.py @@ -0,0 +1,118 @@ +# +# Gramps - a GTK+/GNOME based genealogy program +# +# Copyright (C) 2000-2006 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 _ + +#------------------------------------------------------------------------- +# +# GRAMPS classes +# +#------------------------------------------------------------------------- +import RelLib +import Errors +from DdTargets import DdTargets +from _RepoRefModel import RepoRefModel +from _EmbeddedList import EmbeddedList + +#------------------------------------------------------------------------- +# +# RepoEmbedList +# +#------------------------------------------------------------------------- +class RepoEmbedList(EmbeddedList): + + _HANDLE_COL = 4 + _DND_TYPE = DdTargets.REPOREF + _DND_EXTRA = DdTargets.REPO_LINK + + _column_names = [ + (_('ID'), 0, 75), + (_('Title'), 1, 200), + (_('Call Number'), 2, 125), + (_('Type'), 3, 100), + ] + + def __init__(self, dbstate, uistate, track, obj): + self.obj = obj + EmbeddedList.__init__(self, dbstate, uistate, track, + _('Repositories'), RepoRefModel) + + def get_icon_name(self): + return 'gramps-repository' + + def get_data(self): + return self.obj + + def column_order(self): + return ((1, 0), (1, 1), (1, 2), (1, 3)) + + def handle_extra_type(self, objtype, obj): + try: + from Editors import EditRepoRef + + ref = RelLib.RepoRef() + repo = self.dbstate.db.get_repository_from_handle(obj) + EditRepoRef( + self.dbstate, self.uistate, self.track, + repo, ref, self.add_callback) + except Errors.WindowActiveError: + pass + + def add_button_clicked(self, obj): + ref = RelLib.RepoRef() + repo = RelLib.Repository() + try: + from Editors import EditRepoRef + + EditRepoRef( + self.dbstate, self.uistate, self.track, + repo, ref, self.add_callback) + except Errors.WindowActiveError: + pass + + def add_callback(self, value): + value[0].ref = value[1].handle + self.get_data().append(value[0]) + self.changed = True + self.rebuild() + + def edit_button_clicked(self, obj): + ref = self.get_selected() + if ref: + repo = self.dbstate.db.get_repository_from_handle(ref.ref) + try: + from Editors import EditRepoRef + + EditRepoRef( + self.dbstate, self.uistate, self.track, repo, + ref, self.edit_callback) + except Errors.WindowActiveError: + pass + + def edit_callback(self, name): + self.changed = True + self.rebuild() diff --git a/gramps2/src/DisplayTabs/_RepoRefModel.py b/gramps2/src/DisplayTabs/_RepoRefModel.py new file mode 100644 index 000000000..af6de43aa --- /dev/null +++ b/gramps2/src/DisplayTabs/_RepoRefModel.py @@ -0,0 +1,54 @@ +# +# Gramps - a GTK+/GNOME based genealogy program +# +# Copyright (C) 2000-2006 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$ + +#------------------------------------------------------------------------- +# +# GTK libraries +# +#------------------------------------------------------------------------- +import gtk + +#------------------------------------------------------------------------- +# +# GRAMPS classes +# +#------------------------------------------------------------------------- + + +#------------------------------------------------------------------------- +# +# RepoRefModel +# +#------------------------------------------------------------------------- +class RepoRefModel(gtk.ListStore): + + def __init__(self, ref_list, db): + gtk.ListStore.__init__(self, str, str, str, str, object) + self.db = db + for ref in ref_list: + repo = self.db.get_repository_from_handle(ref.ref) + self.append(row=[ + repo.gramps_id, + repo.name, + ref.call_number, + str(repo.get_type()), + ref, ]) diff --git a/gramps2/src/DisplayTabs/_SourceBackRefList.py b/gramps2/src/DisplayTabs/_SourceBackRefList.py new file mode 100644 index 000000000..76326368e --- /dev/null +++ b/gramps2/src/DisplayTabs/_SourceBackRefList.py @@ -0,0 +1,45 @@ +# +# Gramps - a GTK+/GNOME based genealogy program +# +# Copyright (C) 2000-2006 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 _ + +#------------------------------------------------------------------------- +# +# GRAMPS classes +# +#------------------------------------------------------------------------- +from _BackRefModel import BackRefModel +from _BackRefList import BackRefList + +class SourceBackRefList(BackRefList): + + def __init__(self, dbstate, uistate, track, obj, callback=None): + BackRefList.__init__(self, dbstate, uistate, track, obj, + BackRefModel, callback=callback) + + def get_icon_name(self): + return 'gramps-source' diff --git a/gramps2/src/DisplayTabs/_SourceEmbedList.py b/gramps2/src/DisplayTabs/_SourceEmbedList.py new file mode 100644 index 000000000..a3abf7859 --- /dev/null +++ b/gramps2/src/DisplayTabs/_SourceEmbedList.py @@ -0,0 +1,138 @@ +# +# Gramps - a GTK+/GNOME based genealogy program +# +# Copyright (C) 2000-2006 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 _ + +#------------------------------------------------------------------------- +# +# GRAMPS classes +# +#------------------------------------------------------------------------- +import RelLib +import Errors +from DdTargets import DdTargets +from _SourceRefModel import SourceRefModel +from _EmbeddedList import EmbeddedList + +#------------------------------------------------------------------------- +# +# SourceEmbedList +# +#------------------------------------------------------------------------- +class SourceEmbedList(EmbeddedList): + + _HANDLE_COL = 4 + _DND_TYPE = DdTargets.SOURCEREF + _DND_EXTRA = DdTargets.SOURCE_LINK + + _MSG = { + 'add' : _('Create and add a new source'), + 'del' : _('Remove the existing source'), + 'edit' : _('Edit the selected source'), + 'share' : _('Add an existing source'), + } + + _column_names = [ + (_('ID'), 0, 75), + (_('Title'), 1, 200), + (_('Author'), 2, 125), + (_('Page'), 3, 100), + ] + + def __init__(self, dbstate, uistate, track, obj): + self.obj = obj + EmbeddedList.__init__(self, dbstate, uistate, track, + _('Sources'), SourceRefModel, True) + + def get_icon_name(self): + return 'gramps-event' + + def get_data(self): + return self.obj + + def column_order(self): + return ((1, 0), (1, 1), (1, 2), (1, 3)) + + def add_button_clicked(self, obj): + sref = RelLib.SourceRef() + src = RelLib.Source() + try: + from Editors import EditSourceRef + + EditSourceRef(self.dbstate, self.uistate, self.track, + src, sref, self.add_callback) + except Errors.WindowActiveError: + pass + + def share_button_clicked(self, obj): + import SelectSource + + sel = SelectSource.SelectSource(self.dbstate,self.uistate,self.track, + _("Select source")) + src = sel.run() + if src: + try: + from Editors import EditSourceRef + + ref = RelLib.SourceRef() + EditSourceRef(self.dbstate, self.uistate, self.track, + src, ref, self.add_callback) + except Errors.WindowActiveError: + pass + + def add_callback(self, reference, primary): + reference.ref = primary.handle + self.get_data().append(reference) + self.changed = True + self.rebuild() + + def edit_button_clicked(self, obj): + sref = self.get_selected() + src = self.dbstate.db.get_source_from_handle(sref.ref) + if sref: + try: + from Editors import EditSourceRef + + EditSourceRef(self.dbstate, self.uistate, self.track, + src, sref, self.edit_callback) + except Errors.WindowActiveError: + pass + + def edit_callback(self, refererence, primary): + self.changed = True + self.rebuild() + + def handle_extra_type(self, objtype, obj): + sref = RelLib.SourceRef() + src = self.dbstate.db.get_source_from_handle(obj) + try: + from Editors import EditSourceRef + + EditSourceRef(self.dbstate, self.uistate, self.track, + src, sref, self.add_callback) + except Errors.WindowActiveError: + pass diff --git a/gramps2/src/DisplayTabs/_SourceRefModel.py b/gramps2/src/DisplayTabs/_SourceRefModel.py new file mode 100644 index 000000000..93cd9ca0d --- /dev/null +++ b/gramps2/src/DisplayTabs/_SourceRefModel.py @@ -0,0 +1,50 @@ +# +# Gramps - a GTK+/GNOME based genealogy program +# +# Copyright (C) 2000-2006 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$ + +#------------------------------------------------------------------------- +# +# GTK libraries +# +#------------------------------------------------------------------------- +import gtk + +#------------------------------------------------------------------------- +# +# GRAMPS classes +# +#------------------------------------------------------------------------- + + +#------------------------------------------------------------------------- +# +# SourceRefModel +# +#------------------------------------------------------------------------- +class SourceRefModel(gtk.ListStore): + + def __init__(self, sref_list, db): + gtk.ListStore.__init__(self, str, str, str, str, object) + self.db = db + for sref in sref_list: + src = self.db.get_source_from_handle(sref.ref) + self.append(row=[src.gramps_id, src.title, src.author, + sref.page, sref, ]) diff --git a/gramps2/src/DisplayTabs/_WebEmbedList.py b/gramps2/src/DisplayTabs/_WebEmbedList.py new file mode 100644 index 000000000..fa32ba8ed --- /dev/null +++ b/gramps2/src/DisplayTabs/_WebEmbedList.py @@ -0,0 +1,94 @@ +# +# Gramps - a GTK+/GNOME based genealogy program +# +# Copyright (C) 2000-2006 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 _ + +#------------------------------------------------------------------------- +# +# GRAMPS classes +# +#------------------------------------------------------------------------- +import RelLib +import Errors +from DdTargets import DdTargets +from _WebModel import WebModel +from _EmbeddedList import EmbeddedList + +#------------------------------------------------------------------------- +# +# +# +#------------------------------------------------------------------------- +class WebEmbedList(EmbeddedList): + + _HANDLE_COL = 3 + _DND_TYPE = DdTargets.URL + + _column_names = [ + (_('Type') , 0, 100), + (_('Path') , 1, 200), + (_('Description'), 2, 150), + ] + + def __init__(self, dbstate, uistate, track, data): + self.data = data + EmbeddedList.__init__(self, dbstate, uistate, track, + _('Internet'), WebModel) + + def get_data(self): + return self.data + + def column_order(self): + return ((1, 0), (1, 1), (1, 2)) + + def add_button_clicked(self, obj): + url = RelLib.Url() + try: + from Editors import EditUrl + + EditUrl(self.dbstate, self.uistate, self.track, + '', url, self.add_callback) + except Errors.WindowActiveError: + pass + + def add_callback(self, url): + self.get_data().append(url) + self.rebuild() + + def edit_button_clicked(self, obj): + url = self.get_selected() + if url: + try: + from Editors import EditUrl + + EditUrl(self.dbstate, self.uistate, self.track, + '', url, self.edit_callback) + except Errors.WindowActiveError: + pass + + def edit_callback(self, url): + self.rebuild() diff --git a/gramps2/src/DisplayTabs/_WebModel.py b/gramps2/src/DisplayTabs/_WebModel.py new file mode 100644 index 000000000..7ab1c85bc --- /dev/null +++ b/gramps2/src/DisplayTabs/_WebModel.py @@ -0,0 +1,48 @@ +# +# Gramps - a GTK+/GNOME based genealogy program +# +# Copyright (C) 2000-2006 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$ + +#------------------------------------------------------------------------- +# +# GTK libraries +# +#------------------------------------------------------------------------- +import gtk + +#------------------------------------------------------------------------- +# +# GRAMPS classes +# +#------------------------------------------------------------------------- + + +#------------------------------------------------------------------------- +# +# WebModel +# +#------------------------------------------------------------------------- +class WebModel(gtk.ListStore): + + def __init__(self, obj_list, db): + gtk.ListStore.__init__(self, str, str, str, object) + self.db = db + for obj in obj_list: + self.append(row=[str(obj.type), obj.path, obj.desc, obj]) diff --git a/gramps2/src/DisplayTabs/__init__.py b/gramps2/src/DisplayTabs/__init__.py new file mode 100644 index 000000000..76b88c837 --- /dev/null +++ b/gramps2/src/DisplayTabs/__init__.py @@ -0,0 +1,57 @@ +# +# Gramps - a GTK+/GNOME based genealogy program +# +# Copyright (C) 2000-2006 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$ + + +#------------------------------------------------------------------------- +# +# set up logging +# +#------------------------------------------------------------------------- +import logging +log = logging.getLogger(".DisplayTabs") + +# first import models +from _ChildModel import ChildModel + +# Then import tab classes +from _EmbeddedList import EmbeddedList +from _AddrEmbedList import AddrEmbedList +from _AttrEmbedList import AttrEmbedList +from _BackRefList import BackRefList +from _DataEmbedList import DataEmbedList +from _EventBackRefList import EventBackRefList +from _EventEmbedList import EventEmbedList +from _FamilyAttrEmbedList import FamilyAttrEmbedList +from _FamilyLdsEmbedList import FamilyLdsEmbedList +from _GalleryTab import GalleryTab +from _LdsEmbedList import LdsEmbedList +from _LocationEmbedList import LocationEmbedList +from _MediaBackRefList import MediaBackRefList +from _NameEmbedList import NameEmbedList +from _NoteTab import NoteTab +from _PersonEventEmbedList import PersonEventEmbedList +from _PersonRefEmbedList import PersonRefEmbedList +from _PlaceBackRefList import PlaceBackRefList +from _RepoEmbedList import RepoEmbedList +from _SourceBackRefList import SourceBackRefList +from _SourceEmbedList import SourceEmbedList +from _WebEmbedList import WebEmbedList diff --git a/gramps2/src/Editors/_EditAddress.py b/gramps2/src/Editors/_EditAddress.py index f518ae193..8e3741411 100644 --- a/gramps2/src/Editors/_EditAddress.py +++ b/gramps2/src/Editors/_EditAddress.py @@ -47,7 +47,7 @@ import gtk.glade import const from _EditSecondary import EditSecondary -from DisplayTabs import * +from DisplayTabs import SourceEmbedList, NoteTab from GrampsWidgets import * #------------------------------------------------------------------------- diff --git a/gramps2/src/Editors/_EditAttribute.py b/gramps2/src/Editors/_EditAttribute.py index 28d1d6de6..461347cae 100644 --- a/gramps2/src/Editors/_EditAttribute.py +++ b/gramps2/src/Editors/_EditAttribute.py @@ -53,7 +53,7 @@ import RelLib import GrampsDisplay from _EditSecondary import EditSecondary -from DisplayTabs import * +from DisplayTabs import SourceEmbedList, NoteTab from GrampsWidgets import * #------------------------------------------------------------------------- diff --git a/gramps2/src/Editors/_EditChildRef.py b/gramps2/src/Editors/_EditChildRef.py index ebb32b9ef..87662fba7 100644 --- a/gramps2/src/Editors/_EditChildRef.py +++ b/gramps2/src/Editors/_EditChildRef.py @@ -48,7 +48,7 @@ import const import RelLib from _EditSecondary import EditSecondary -from DisplayTabs import * +from DisplayTabs import SourceEmbedList, NoteTab from GrampsWidgets import * #------------------------------------------------------------------------- diff --git a/gramps2/src/Editors/_EditEvent.py b/gramps2/src/Editors/_EditEvent.py index 5715cc88d..6befdc7a3 100644 --- a/gramps2/src/Editors/_EditEvent.py +++ b/gramps2/src/Editors/_EditEvent.py @@ -53,7 +53,7 @@ import GrampsDisplay from _EditPrimary import EditPrimary from QuestionDialog import WarningDialog, ErrorDialog -from DisplayTabs import * +from DisplayTabs import SourceEmbedList, NoteTab, GalleryTab, EventBackRefList from GrampsWidgets import * #------------------------------------------------------------------------- diff --git a/gramps2/src/Editors/_EditEventRef.py b/gramps2/src/Editors/_EditEventRef.py index 73006e126..d3d86378c 100644 --- a/gramps2/src/Editors/_EditEventRef.py +++ b/gramps2/src/Editors/_EditEventRef.py @@ -49,7 +49,7 @@ import const import Utils import RelLib -from DisplayTabs import * +from DisplayTabs import SourceEmbedList,NoteTab,GalleryTab,EventBackRefList from GrampsWidgets import * from _EditReference import EditReference diff --git a/gramps2/src/Editors/_EditFamily.py b/gramps2/src/Editors/_EditFamily.py index e205fa82f..603b2f429 100644 --- a/gramps2/src/Editors/_EditFamily.py +++ b/gramps2/src/Editors/_EditFamily.py @@ -74,7 +74,9 @@ import Errors from _EditPrimary import EditPrimary from PluginUtils import ReportUtils from DdTargets import DdTargets -from DisplayTabs import * +from DisplayTabs import \ + EmbeddedList,EventEmbedList,SourceEmbedList,FamilyAttrEmbedList,\ + NoteTab,GalleryTab,FamilyLdsEmbedList from GrampsWidgets import * #from ObjectSelector import PersonSelector,PersonFilterSpec diff --git a/gramps2/src/Editors/_EditLdsOrd.py b/gramps2/src/Editors/_EditLdsOrd.py index c1a4e0ab7..3f7432caa 100644 --- a/gramps2/src/Editors/_EditLdsOrd.py +++ b/gramps2/src/Editors/_EditLdsOrd.py @@ -56,7 +56,7 @@ import lds from _EditSecondary import EditSecondary -from DisplayTabs import * +from DisplayTabs import SourceEmbedList,NoteTab from GrampsWidgets import * #------------------------------------------------------------------------- diff --git a/gramps2/src/Editors/_EditMedia.py b/gramps2/src/Editors/_EditMedia.py index 71465f7c3..99175f48c 100644 --- a/gramps2/src/Editors/_EditMedia.py +++ b/gramps2/src/Editors/_EditMedia.py @@ -51,7 +51,7 @@ from _EditPrimary import EditPrimary from GrampsWidgets import * from QuestionDialog import ErrorDialog -from DisplayTabs import * +from DisplayTabs import SourceEmbedList,AttrEmbedList,NoteTab,MediaBackRefList #------------------------------------------------------------------------- # diff --git a/gramps2/src/Editors/_EditMediaRef.py b/gramps2/src/Editors/_EditMediaRef.py index 48d4fd0e9..a5f65ecdc 100644 --- a/gramps2/src/Editors/_EditMediaRef.py +++ b/gramps2/src/Editors/_EditMediaRef.py @@ -47,7 +47,8 @@ import RelLib import Mime import ImgManip -from DisplayTabs import * +from DisplayTabs import \ + SourceEmbedList,AttrEmbedList,MediaBackRefList,NoteTab from GrampsWidgets import * from _EditReference import EditReference diff --git a/gramps2/src/Editors/_EditName.py b/gramps2/src/Editors/_EditName.py index 6067eb68e..64fa0c430 100644 --- a/gramps2/src/Editors/_EditName.py +++ b/gramps2/src/Editors/_EditName.py @@ -45,7 +45,7 @@ import RelLib import NameDisplay from _EditSecondary import EditSecondary -from DisplayTabs import * +from DisplayTabs import SourceEmbedList,NoteTab from GrampsWidgets import * #------------------------------------------------------------------------- diff --git a/gramps2/src/Editors/_EditPerson.py b/gramps2/src/Editors/_EditPerson.py index edb4eca5a..519b31ca1 100644 --- a/gramps2/src/Editors/_EditPerson.py +++ b/gramps2/src/Editors/_EditPerson.py @@ -63,7 +63,10 @@ import GrampsWidgets from _EditPrimary import EditPrimary from QuestionDialog import WarningDialog, ErrorDialog, QuestionDialog2 -from DisplayTabs import * +from DisplayTabs import \ + PersonEventEmbedList,NameEmbedList,SourceEmbedList,AttrEmbedList,\ + AddrEmbedList,NoteTab,GalleryTab,WebEmbedList,PersonRefEmbedList, \ + LdsEmbedList #------------------------------------------------------------------------- # diff --git a/gramps2/src/Editors/_EditPersonRef.py b/gramps2/src/Editors/_EditPersonRef.py index 33faea8c2..a277a62cb 100644 --- a/gramps2/src/Editors/_EditPersonRef.py +++ b/gramps2/src/Editors/_EditPersonRef.py @@ -48,7 +48,7 @@ import const import NameDisplay from _EditSecondary import EditSecondary -from DisplayTabs import * +from DisplayTabs import SourceEmbedList, NoteTab from GrampsWidgets import * #------------------------------------------------------------------------- diff --git a/gramps2/src/Editors/_EditReference.py b/gramps2/src/Editors/_EditReference.py index ecc495ef7..73b048b56 100644 --- a/gramps2/src/Editors/_EditReference.py +++ b/gramps2/src/Editors/_EditReference.py @@ -50,7 +50,6 @@ import RelLib import ManagedWindow from QuestionDialog import WarningDialog, ErrorDialog -from DisplayTabs import * from GrampsWidgets import * #------------------------------------------------------------------------- diff --git a/gramps2/src/Editors/_EditRepoRef.py b/gramps2/src/Editors/_EditRepoRef.py index da55e77eb..ef1c2adc2 100644 --- a/gramps2/src/Editors/_EditRepoRef.py +++ b/gramps2/src/Editors/_EditRepoRef.py @@ -49,7 +49,7 @@ import const import Utils import RelLib -from DisplayTabs import * +from DisplayTabs import NoteTab,AddrEmbedList,WebEmbedList,SourceBackRefList from GrampsWidgets import * from _EditReference import EditReference diff --git a/gramps2/src/Editors/_EditRepository.py b/gramps2/src/Editors/_EditRepository.py index c041b1976..22c9d789b 100644 --- a/gramps2/src/Editors/_EditRepository.py +++ b/gramps2/src/Editors/_EditRepository.py @@ -45,7 +45,7 @@ import Utils import RelLib from GrampsWidgets import * -from DisplayTabs import * +from DisplayTabs import AddrEmbedList,WebEmbedList,NoteTab,SourceBackRefList from _EditPrimary import EditPrimary class EditRepository(EditPrimary): diff --git a/gramps2/src/Editors/_EditSource.py b/gramps2/src/Editors/_EditSource.py index 972064ff1..f012c2df4 100644 --- a/gramps2/src/Editors/_EditSource.py +++ b/gramps2/src/Editors/_EditSource.py @@ -51,7 +51,8 @@ import Spell import GrampsDisplay from _EditPrimary import EditPrimary -from DisplayTabs import * +from DisplayTabs import \ + NoteTab,GalleryTab,DataEmbedList,SourceBackRefList,RepoEmbedList from GrampsWidgets import * #------------------------------------------------------------------------- diff --git a/gramps2/src/Editors/_EditSourceRef.py b/gramps2/src/Editors/_EditSourceRef.py index 10acda89b..642e6d469 100644 --- a/gramps2/src/Editors/_EditSourceRef.py +++ b/gramps2/src/Editors/_EditSourceRef.py @@ -49,7 +49,7 @@ import const import Utils import RelLib -from DisplayTabs import * +from DisplayTabs import NoteTab,GalleryTab,SourceBackRefList from GrampsWidgets import * from _EditReference import EditReference