2002-10-20 19:55:16 +05:30
|
|
|
#
|
|
|
|
# Gramps - a GTK+/GNOME based genealogy program
|
|
|
|
#
|
2007-06-28 11:11:40 +05:30
|
|
|
# Copyright (C) 2000-2007 Donald N. Allingham
|
2002-10-20 19:55:16 +05:30
|
|
|
#
|
|
|
|
# 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
|
|
|
|
#
|
|
|
|
|
2003-11-13 00:15:07 +05:30
|
|
|
# $Id$
|
|
|
|
|
2005-02-25 22:36:04 +05:30
|
|
|
#-------------------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# Standard python modules
|
|
|
|
#
|
|
|
|
#-------------------------------------------------------------------------
|
2006-04-07 03:32:46 +05:30
|
|
|
from gettext import gettext as _
|
2005-02-25 22:36:04 +05:30
|
|
|
|
2002-10-20 19:55:16 +05:30
|
|
|
#-------------------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# GTK/Gnome modules
|
|
|
|
#
|
|
|
|
#-------------------------------------------------------------------------
|
2008-02-19 05:18:35 +05:30
|
|
|
import gtk
|
2008-02-19 01:37:09 +05:30
|
|
|
from gtk import glade
|
2002-10-20 19:55:16 +05:30
|
|
|
|
|
|
|
#-------------------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# gramps modules
|
|
|
|
#
|
|
|
|
#-------------------------------------------------------------------------
|
|
|
|
import const
|
2006-11-26 10:09:34 +05:30
|
|
|
import Config
|
2007-06-28 11:11:40 +05:30
|
|
|
from BasicUtils import name_displayer
|
2006-03-04 12:04:48 +05:30
|
|
|
from _EditSecondary import EditSecondary
|
2007-10-08 22:11:39 +05:30
|
|
|
from gen.lib import NoteType
|
2007-12-20 19:19:41 +05:30
|
|
|
from DisplayTabs import GrampsTab,SourceEmbedList,NoteTab
|
2008-02-19 01:37:09 +05:30
|
|
|
from GrampsWidgets import (MonitoredEntry, MonitoredMenu, MonitoredDate,
|
|
|
|
MonitoredDataType, PrivacyButton)
|
2002-10-20 19:55:16 +05:30
|
|
|
|
2007-12-20 19:19:41 +05:30
|
|
|
|
|
|
|
#-------------------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# Classes
|
|
|
|
#
|
|
|
|
#-------------------------------------------------------------------------
|
|
|
|
|
|
|
|
class GeneralNameTab(GrampsTab):
|
|
|
|
"""
|
|
|
|
This class provides the tabpage of the general name tab
|
|
|
|
"""
|
|
|
|
|
|
|
|
def __init__(self, dbstate, uistate, track, name, widget):
|
|
|
|
"""
|
|
|
|
@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
|
|
|
|
@param widget: widget to be shown in the tab
|
|
|
|
@type widge: gtk widget
|
|
|
|
"""
|
|
|
|
GrampsTab.__init__(self, dbstate, uistate, track, name)
|
|
|
|
eventbox = gtk.EventBox()
|
|
|
|
eventbox.add(widget)
|
|
|
|
self.pack_start(eventbox)
|
|
|
|
self._set_label(show_image=False)
|
|
|
|
widget.connect('key_press_event', self.key_pressed)
|
|
|
|
self.show_all()
|
|
|
|
|
|
|
|
def is_empty(self):
|
|
|
|
"""
|
|
|
|
Override base class
|
|
|
|
"""
|
|
|
|
return False
|
|
|
|
|
2002-10-20 19:55:16 +05:30
|
|
|
#-------------------------------------------------------------------------
|
|
|
|
#
|
2006-03-04 09:56:08 +05:30
|
|
|
# EditName class
|
2002-10-20 19:55:16 +05:30
|
|
|
#
|
|
|
|
#-------------------------------------------------------------------------
|
2006-03-04 12:04:48 +05:30
|
|
|
class EditName(EditSecondary):
|
2002-10-20 19:55:16 +05:30
|
|
|
|
2006-11-26 10:09:34 +05:30
|
|
|
WIDTH_KEY = Config.NAME_WIDTH
|
|
|
|
HEIGHT_KEY = Config.NAME_HEIGHT
|
|
|
|
|
2005-12-23 11:05:32 +05:30
|
|
|
def __init__(self, dbstate, uistate, track, name, callback):
|
2005-12-23 05:13:32 +05:30
|
|
|
|
2006-03-04 12:04:48 +05:30
|
|
|
EditSecondary.__init__(self, dbstate, uistate,
|
|
|
|
track, name, callback)
|
2006-02-22 05:42:52 +05:30
|
|
|
|
2006-03-02 10:02:37 +05:30
|
|
|
def _local_init(self):
|
|
|
|
|
2008-02-19 01:37:09 +05:30
|
|
|
self.top = glade.XML(const.GLADE_FILE, "name_edit","gramps")
|
2006-04-24 03:48:01 +05:30
|
|
|
self.set_window(self.top.get_widget("name_edit"),
|
|
|
|
self.top.get_widget("title"),
|
|
|
|
_("Name Editor"))
|
2004-08-05 09:44:21 +05:30
|
|
|
|
2007-12-20 19:19:41 +05:30
|
|
|
tblgnam = self.top.get_widget('table23')
|
|
|
|
notebook = self.top.get_widget('notebook')
|
|
|
|
#recreate start page as GrampsTab
|
|
|
|
notebook.remove_page(0)
|
|
|
|
self.gennam = GeneralNameTab(self.dbstate, self.uistate, self.track,
|
2008-02-16 04:08:47 +05:30
|
|
|
_('_General'), tblgnam)
|
2007-12-20 19:19:41 +05:30
|
|
|
|
2006-03-02 10:02:37 +05:30
|
|
|
self.original_group_as = self.obj.get_group_as()
|
2007-10-09 18:35:56 +05:30
|
|
|
self.original_group_set = not (self.original_group_as == '')
|
|
|
|
srn = self.obj.get_surname()
|
|
|
|
self._get_global_grouping(srn)
|
|
|
|
|
2004-09-29 07:36:46 +05:30
|
|
|
self.group_over = self.top.get_widget('group_over')
|
2006-02-22 05:42:52 +05:30
|
|
|
self.group_over.connect('toggled',self.on_group_over_toggled)
|
2005-12-06 12:08:09 +05:30
|
|
|
self.group_over.set_sensitive(not self.db.readonly)
|
2007-10-09 18:35:56 +05:30
|
|
|
|
|
|
|
self.toggle_dirty = False
|
2002-10-20 19:55:16 +05:30
|
|
|
|
2006-03-02 10:02:37 +05:30
|
|
|
def _post_init(self):
|
2007-10-09 18:35:56 +05:30
|
|
|
"""if there is override, set the override toggle active
|
|
|
|
"""
|
|
|
|
if self.original_group_set or self.global_group_set :
|
2006-02-22 05:42:52 +05:30
|
|
|
self.group_over.set_active(True)
|
2005-12-23 05:13:32 +05:30
|
|
|
|
2006-02-22 05:42:52 +05:30
|
|
|
def _connect_signals(self):
|
2006-03-02 10:02:37 +05:30
|
|
|
self.define_cancel_button(self.top.get_widget('button119'))
|
2008-04-05 19:47:15 +05:30
|
|
|
self.define_help_button(self.top.get_widget('button131'))
|
2006-03-02 10:02:37 +05:30
|
|
|
self.define_ok_button(self.top.get_widget('button118'),self.save)
|
2006-02-22 05:42:52 +05:30
|
|
|
|
|
|
|
def _setup_fields(self):
|
|
|
|
self.group_as = MonitoredEntry(
|
2006-04-05 03:25:35 +05:30
|
|
|
self.top.get_widget("group_as"),
|
|
|
|
self.obj.set_group_as,
|
|
|
|
self.obj.get_group_as,
|
|
|
|
self.db.readonly)
|
2006-02-22 05:42:52 +05:30
|
|
|
|
2007-10-09 18:35:56 +05:30
|
|
|
if not self.original_group_set:
|
|
|
|
if self.global_group_set :
|
|
|
|
self.group_as.force_value(self.global_group_as)
|
|
|
|
else :
|
|
|
|
self.group_as.force_value(self.obj.get_surname())
|
2006-02-22 05:42:52 +05:30
|
|
|
|
2008-02-24 19:25:55 +05:30
|
|
|
format_list = [(name, number) for (number, name,fmt_str,act)
|
2007-06-28 11:11:40 +05:30
|
|
|
in name_displayer.get_name_format(also_default=True)]
|
2006-07-06 23:16:46 +05:30
|
|
|
|
2006-02-22 05:42:52 +05:30
|
|
|
self.sort_as = MonitoredMenu(
|
2006-04-05 03:25:35 +05:30
|
|
|
self.top.get_widget('sort_as'),
|
|
|
|
self.obj.set_sort_as,
|
2006-03-02 10:02:37 +05:30
|
|
|
self.obj.get_sort_as,
|
2006-07-06 23:16:46 +05:30
|
|
|
format_list,
|
2006-02-22 05:42:52 +05:30
|
|
|
self.db.readonly)
|
|
|
|
|
|
|
|
self.display_as = MonitoredMenu(
|
|
|
|
self.top.get_widget('display_as'),
|
2006-04-05 03:25:35 +05:30
|
|
|
self.obj.set_display_as,
|
|
|
|
self.obj.get_display_as,
|
2006-07-06 23:16:46 +05:30
|
|
|
format_list,
|
2006-02-22 05:42:52 +05:30
|
|
|
self.db.readonly)
|
|
|
|
|
|
|
|
self.given_field = MonitoredEntry(
|
2006-05-06 02:46:24 +05:30
|
|
|
self.top.get_widget("alt_given"),
|
|
|
|
self.obj.set_first_name,
|
|
|
|
self.obj.get_first_name,
|
|
|
|
self.db.readonly)
|
|
|
|
|
|
|
|
self.call_field = MonitoredEntry(
|
|
|
|
self.top.get_widget("call"),
|
|
|
|
self.obj.set_call_name,
|
|
|
|
self.obj.get_call_name,
|
|
|
|
self.db.readonly)
|
2006-02-22 05:42:52 +05:30
|
|
|
|
|
|
|
self.title_field = MonitoredEntry(
|
2006-05-06 02:46:24 +05:30
|
|
|
self.top.get_widget("alt_title"),
|
|
|
|
self.obj.set_title,
|
|
|
|
self.obj.get_title,
|
|
|
|
self.db.readonly)
|
2006-02-22 05:42:52 +05:30
|
|
|
|
|
|
|
self.suffix_field = MonitoredEntry(
|
2006-05-06 02:46:24 +05:30
|
|
|
self.top.get_widget("alt_suffix"),
|
|
|
|
self.obj.set_suffix,
|
|
|
|
self.obj.get_suffix,
|
|
|
|
self.db.readonly)
|
2006-02-22 05:42:52 +05:30
|
|
|
|
|
|
|
self.patronymic_field = MonitoredEntry(
|
2006-05-06 02:46:24 +05:30
|
|
|
self.top.get_widget("patronymic"),
|
|
|
|
self.obj.set_patronymic,
|
|
|
|
self.obj.get_patronymic,
|
|
|
|
self.db.readonly)
|
2006-02-22 05:42:52 +05:30
|
|
|
|
|
|
|
self.surname_field = MonitoredEntry(
|
2006-04-05 03:25:35 +05:30
|
|
|
self.top.get_widget("alt_surname"),
|
|
|
|
self.obj.set_surname,
|
|
|
|
self.obj.get_surname,
|
|
|
|
self.db.readonly,
|
2006-11-21 08:13:24 +05:30
|
|
|
autolist=self.db.get_surname_list(),
|
2006-04-05 03:25:35 +05:30
|
|
|
changed=self.update_group_as)
|
2006-02-22 05:42:52 +05:30
|
|
|
|
|
|
|
self.prefix_field = MonitoredEntry(
|
2006-05-06 02:46:24 +05:30
|
|
|
self.top.get_widget("alt_prefix"),
|
|
|
|
self.obj.set_surname_prefix,
|
|
|
|
self.obj.get_surname_prefix,
|
|
|
|
self.db.readonly)
|
2007-01-07 04:05:29 +05:30
|
|
|
|
2006-04-19 09:27:10 +05:30
|
|
|
self.date = MonitoredDate(
|
2007-03-24 06:00:14 +05:30
|
|
|
self.top.get_widget("date_entry"),
|
2006-04-19 09:27:10 +05:30
|
|
|
self.top.get_widget("date_stat"),
|
|
|
|
self.obj.get_date_object(),
|
2006-05-06 08:44:13 +05:30
|
|
|
self.uistate,
|
|
|
|
self.track,
|
|
|
|
self.db.readonly)
|
2006-02-22 05:42:52 +05:30
|
|
|
|
2006-04-14 10:06:25 +05:30
|
|
|
self.obj_combo = MonitoredDataType(
|
|
|
|
self.top.get_widget("name_type"),
|
|
|
|
self.obj.set_type,
|
2006-04-19 09:27:10 +05:30
|
|
|
self.obj.get_type,
|
2006-05-21 09:54:56 +05:30
|
|
|
self.db.readonly,
|
|
|
|
self.db.get_name_types(),
|
2006-04-19 09:27:10 +05:30
|
|
|
)
|
2006-02-22 05:42:52 +05:30
|
|
|
|
|
|
|
self.privacy = PrivacyButton(
|
2006-12-14 21:02:33 +05:30
|
|
|
self.top.get_widget("priv"), self.obj,
|
|
|
|
self.db.readonly)
|
2006-02-22 05:42:52 +05:30
|
|
|
|
|
|
|
def _create_tabbed_pages(self):
|
2006-03-02 10:02:37 +05:30
|
|
|
|
|
|
|
notebook = self.top.get_widget("notebook")
|
|
|
|
|
2007-12-20 19:19:41 +05:30
|
|
|
self._add_tab(notebook, self.gennam)
|
|
|
|
|
2006-03-02 10:02:37 +05:30
|
|
|
self.srcref_list = self._add_tab(
|
|
|
|
notebook,
|
2006-10-09 08:15:26 +05:30
|
|
|
SourceEmbedList(self.dbstate,self.uistate,self.track,self.obj))
|
2006-03-02 10:02:37 +05:30
|
|
|
|
|
|
|
self.note_tab = self._add_tab(
|
|
|
|
notebook,
|
|
|
|
NoteTab(self.dbstate, self.uistate, self.track,
|
2007-05-08 02:11:16 +05:30
|
|
|
self.obj.get_note_list(),
|
|
|
|
notetype=NoteType.PERSONNAME))
|
2006-02-04 10:22:16 +05:30
|
|
|
|
2007-01-16 12:42:10 +05:30
|
|
|
self._setup_notebook_tabs( notebook)
|
2007-10-09 18:35:56 +05:30
|
|
|
|
|
|
|
def _get_global_grouping(self, srn):
|
|
|
|
""" we need info on the global grouping of the surname on init,
|
|
|
|
and on change of surname
|
|
|
|
"""
|
|
|
|
self.global_group_as = self.db.get_name_group_mapping(srn)
|
|
|
|
if srn == self.global_group_as:
|
|
|
|
self.global_group_as = None
|
|
|
|
self.global_group_set = False
|
|
|
|
else:
|
|
|
|
self.global_group_set = True
|
|
|
|
|
2007-01-16 12:42:10 +05:30
|
|
|
|
2008-02-24 19:25:55 +05:30
|
|
|
def build_menu_names(self, name):
|
2005-12-23 05:13:32 +05:30
|
|
|
if name:
|
2007-06-28 11:11:40 +05:30
|
|
|
ntext = name_displayer.display_name(name)
|
2008-02-24 19:25:55 +05:30
|
|
|
submenu_label = '%s: %s' % (_('Name'), ntext)
|
2005-12-23 05:13:32 +05:30
|
|
|
else:
|
|
|
|
submenu_label = _('New Name')
|
|
|
|
menu_label = _('Name Editor')
|
|
|
|
return (menu_label,submenu_label)
|
|
|
|
|
2008-02-24 19:25:55 +05:30
|
|
|
def update_group_as(self, obj):
|
2007-10-09 18:35:56 +05:30
|
|
|
"""Callback if surname changes on GUI
|
|
|
|
If overwrite is not set, we change the group name too
|
|
|
|
"""
|
|
|
|
name = self.obj.get_surname()
|
2004-10-01 00:02:56 +05:30
|
|
|
if not self.group_over.get_active():
|
2007-10-09 18:35:56 +05:30
|
|
|
self.group_as.force_value(name)
|
|
|
|
#new surname, so perhaps now a different grouping?
|
|
|
|
self._get_global_grouping(name)
|
|
|
|
if not self.group_over.get_active() and self.global_group_set :
|
|
|
|
self.group_over.set_active(True)
|
|
|
|
self.group_as.enable(True)
|
|
|
|
self.toggle_dirty = True
|
|
|
|
self.group_as.force_value(self.global_group_as)
|
|
|
|
elif self.group_over.get_active() and self.toggle_dirty:
|
|
|
|
#changing surname caused active group_over in past, change
|
|
|
|
# group_over as we type
|
|
|
|
if self.global_group_set :
|
|
|
|
self.group_as.force_value(self.global_group_as)
|
2004-10-01 00:02:56 +05:30
|
|
|
else:
|
2007-10-09 18:35:56 +05:30
|
|
|
self.toggle_dirty = False
|
|
|
|
self.group_as.force_value(name)
|
|
|
|
self.group_over.set_active(False)
|
|
|
|
self.group_as.enable(False)
|
2004-10-01 00:02:56 +05:30
|
|
|
|
2008-02-24 19:25:55 +05:30
|
|
|
def on_group_over_toggled(self, obj):
|
2007-10-09 18:35:56 +05:30
|
|
|
""" group over changes, if activated, enable edit,
|
|
|
|
if unactivated, go back to surname.
|
|
|
|
"""
|
|
|
|
self.toggle_dirty = False
|
|
|
|
#enable group as box
|
2006-02-22 05:42:52 +05:30
|
|
|
self.group_as.enable(obj.get_active())
|
|
|
|
|
|
|
|
if not obj.get_active():
|
2007-10-09 18:35:56 +05:30
|
|
|
surname = self.obj.get_surname()
|
|
|
|
self.group_as.set_text(surname)
|
2004-09-29 07:36:46 +05:30
|
|
|
|
2006-03-02 10:02:37 +05:30
|
|
|
def save(self,*obj):
|
2007-10-09 18:35:56 +05:30
|
|
|
"""Save the name setting. All is ok, except grouping. We need to
|
|
|
|
consider:
|
|
|
|
1/ global set, not local set --> unset (ask if global unset)
|
|
|
|
2/ global set, local set --> unset (only local unset!)
|
|
|
|
3/ not global set, local set
|
|
|
|
or not global set, not local set --> unset
|
|
|
|
4/ not local set, not global set
|
|
|
|
or not local set, global set --> set val (ask global or local)
|
|
|
|
5/ local set, not global set --> set (change local)
|
|
|
|
6/ local set, global set --> set (set to global if possible)
|
|
|
|
"""
|
|
|
|
closeit = True
|
|
|
|
surname = self.obj.get_surname()
|
|
|
|
group_as= self.obj.get_group_as()
|
|
|
|
grouping_active = self.group_over.get_active()
|
|
|
|
|
|
|
|
if not grouping_active :
|
|
|
|
#user wants to group with surname
|
|
|
|
if self.global_group_set and not self.original_group_set :
|
|
|
|
#warn that group will revert to surname
|
2004-10-01 00:02:56 +05:30
|
|
|
from QuestionDialog import QuestionDialog2
|
2005-02-27 11:21:59 +05:30
|
|
|
q = QuestionDialog2(
|
2007-10-09 18:35:56 +05:30
|
|
|
_("Break global name grouping?"),
|
|
|
|
_("All people with the name of %(surname)s will no longer "
|
|
|
|
"be grouped with the name of %(group_name)s."
|
|
|
|
) % { 'surname' : surname,
|
|
|
|
'group_name':group_as},
|
|
|
|
_("Continue"),
|
|
|
|
_("Return to Name Editor"))
|
|
|
|
val = q.run()
|
|
|
|
if val:
|
|
|
|
#delete the grouping link on database
|
|
|
|
self.db.set_name_group_mapping(surname, None)
|
|
|
|
self.obj.set_group_as("")
|
|
|
|
else :
|
|
|
|
closeit = False
|
|
|
|
elif self.global_group_set and self.original_group_set:
|
|
|
|
#we change it only back to surname locally, so store group_as
|
|
|
|
# Note: if all surnames are locally changed to surname, we
|
|
|
|
# should actually unsed the global group here ....
|
|
|
|
pass
|
|
|
|
else :
|
|
|
|
#global group not set, don't set local group too:
|
|
|
|
self.obj.set_group_as("")
|
|
|
|
else:
|
|
|
|
#user wants to override surname, see what he wants
|
|
|
|
if not self.original_group_set :
|
|
|
|
#if changed, ask if this has to happen for the entire group,
|
|
|
|
#this might be creation of group link, or change of group link
|
|
|
|
if self.global_group_as != group_as:
|
|
|
|
from QuestionDialog import QuestionDialog2
|
|
|
|
|
|
|
|
q = QuestionDialog2(
|
2005-02-27 11:21:59 +05:30
|
|
|
_("Group all people with the same name?"),
|
|
|
|
_("You have the choice of grouping all people with the "
|
|
|
|
"name of %(surname)s with the name of %(group_name)s, or "
|
2007-10-09 18:35:56 +05:30
|
|
|
"just mapping this particular name."
|
|
|
|
) % { 'surname' : surname,
|
|
|
|
'group_name':group_as},
|
2005-02-27 11:21:59 +05:30
|
|
|
_("Group all"),
|
|
|
|
_("Group this name only"))
|
2007-10-09 18:35:56 +05:30
|
|
|
val = q.run()
|
|
|
|
if val:
|
|
|
|
if group_as == surname :
|
|
|
|
self.db.set_name_group_mapping(surname, None)
|
|
|
|
else:
|
|
|
|
self.db.set_name_group_mapping(surname, group_as)
|
|
|
|
self.obj.set_group_as("")
|
|
|
|
else:
|
|
|
|
if self.global_group_set :
|
|
|
|
#allow smith to Dummy, but one person still Smith
|
|
|
|
self.obj.set_group_as(group_as)
|
|
|
|
elif group_as == surname :
|
|
|
|
self.obj.set_group_as("")
|
|
|
|
else:
|
|
|
|
self.obj.set_group_as(group_as)
|
|
|
|
else:
|
|
|
|
#keep original value, no original group
|
|
|
|
self.obj.set_group_as("")
|
|
|
|
elif not self.global_group_set :
|
|
|
|
#don't ask user, group was set locally before,
|
|
|
|
#change it locally only
|
|
|
|
if group_as == surname :
|
|
|
|
#remove grouping
|
2006-03-02 10:02:37 +05:30
|
|
|
self.obj.set_group_as("")
|
2004-10-01 00:02:56 +05:30
|
|
|
else:
|
2007-10-09 18:35:56 +05:30
|
|
|
pass
|
|
|
|
|
|
|
|
else:
|
|
|
|
#locally set group and global group set
|
|
|
|
if group_as == self.global_group_as :
|
|
|
|
#unset local group, go with global one
|
|
|
|
self.obj.set_group_as("")
|
|
|
|
else :
|
|
|
|
#local set is different from global, keep it like that
|
|
|
|
pass
|
|
|
|
|
|
|
|
if closeit:
|
|
|
|
if self.callback:
|
|
|
|
self.callback(self.obj)
|
|
|
|
self.close()
|