0001782: Further refinements to Relationship View: added sibling collapse arrows; compressed data vertically; config theme; frame around selected sibling
svn: r10602
This commit is contained in:
parent
d34c010422
commit
bfdb86069b
@ -172,6 +172,7 @@ NO_RECORD_TEXT = ('preferences', 'no-record-text', 2)
|
|||||||
PRIVATE_SURNAME_TEXT = ('preferences', 'private-surname-text', 2)
|
PRIVATE_SURNAME_TEXT = ('preferences', 'private-surname-text', 2)
|
||||||
PRIVATE_GIVEN_TEXT = ('preferences', 'private-given-text', 2)
|
PRIVATE_GIVEN_TEXT = ('preferences', 'private-given-text', 2)
|
||||||
PRIVATE_RECORD_TEXT = ('preferences', 'private-record-text', 2)
|
PRIVATE_RECORD_TEXT = ('preferences', 'private-record-text', 2)
|
||||||
|
RELATION_DISPLAY_THEME= ('preferences', 'relation-display-theme', 2)
|
||||||
|
|
||||||
default_value = {
|
default_value = {
|
||||||
DEFAULT_SOURCE : False,
|
DEFAULT_SOURCE : False,
|
||||||
@ -278,8 +279,8 @@ default_value = {
|
|||||||
OWNER_WARN : False,
|
OWNER_WARN : False,
|
||||||
EXPORT_NO_PRIVATE : True,
|
EXPORT_NO_PRIVATE : True,
|
||||||
EXPORT_RESTRICT : True,
|
EXPORT_RESTRICT : True,
|
||||||
DATE_BEFORE_RANGE : 9999,
|
DATE_BEFORE_RANGE : 10,
|
||||||
DATE_AFTER_RANGE : 9999,
|
DATE_AFTER_RANGE : 10,
|
||||||
DATE_ABOUT_RANGE : 10,
|
DATE_ABOUT_RANGE : 10,
|
||||||
MAX_AGE_PROB_ALIVE : 110,
|
MAX_AGE_PROB_ALIVE : 110,
|
||||||
MAX_SIB_AGE_DIFF : 20,
|
MAX_SIB_AGE_DIFF : 20,
|
||||||
@ -297,4 +298,5 @@ default_value = {
|
|||||||
PRIVATE_SURNAME_TEXT : "[%s]" % _("Living"),
|
PRIVATE_SURNAME_TEXT : "[%s]" % _("Living"),
|
||||||
PRIVATE_GIVEN_TEXT : "[%s]" % _("Living"),
|
PRIVATE_GIVEN_TEXT : "[%s]" % _("Living"),
|
||||||
PRIVATE_RECORD_TEXT : "[%s]" % _("Private Record"),
|
PRIVATE_RECORD_TEXT : "[%s]" % _("Private Record"),
|
||||||
|
RELATION_DISPLAY_THEME: "CLASSIC",
|
||||||
}
|
}
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
# Gramps - a GTK+/GNOME based genealogy program
|
|
||||||
#
|
#
|
||||||
# Copyright (C) 2001-2007 Donald N. Allingham
|
# Copyright (C) 2001-2007 Donald N. Allingham
|
||||||
#
|
#
|
||||||
@ -486,7 +486,7 @@ class RelationshipView(PageView.PersonNavView):
|
|||||||
self.child = gtk.Table(self.attach.max_y, cols)
|
self.child = gtk.Table(self.attach.max_y, cols)
|
||||||
self.child.set_border_width(12)
|
self.child.set_border_width(12)
|
||||||
self.child.set_col_spacings(12)
|
self.child.set_col_spacings(12)
|
||||||
self.child.set_row_spacings(9)
|
self.child.set_row_spacings(0)
|
||||||
|
|
||||||
for d in self.attach.list:
|
for d in self.attach.list:
|
||||||
x0 = d[1]
|
x0 = d[1]
|
||||||
@ -515,13 +515,14 @@ class RelationshipView(PageView.PersonNavView):
|
|||||||
|
|
||||||
table = gtk.Table(2, 3)
|
table = gtk.Table(2, 3)
|
||||||
table.set_col_spacings(12)
|
table.set_col_spacings(12)
|
||||||
table.set_row_spacings(6)
|
table.set_row_spacings(0)
|
||||||
|
|
||||||
# name and edit button
|
# name and edit button
|
||||||
name = name_displayer.display(person)
|
name = name_displayer.display(person)
|
||||||
fmt = '<span size="larger" weight="bold">%s</span>'
|
fmt = '<span size="larger" weight="bold">%s</span>'
|
||||||
text = fmt % cgi.escape(name)
|
text = fmt % cgi.escape(name)
|
||||||
label = GrampsWidgets.DualMarkupLabel(text, _GenderCode[person.gender])
|
label = GrampsWidgets.DualMarkupLabel(text, _GenderCode[person.gender],
|
||||||
|
x_align=1, y_align=0)
|
||||||
if Config.get(Config.RELEDITBTN):
|
if Config.get(Config.RELEDITBTN):
|
||||||
button = GrampsWidgets.IconButton(self.edit_button_press,
|
button = GrampsWidgets.IconButton(self.edit_button_press,
|
||||||
person.handle)
|
person.handle)
|
||||||
@ -538,7 +539,7 @@ class RelationshipView(PageView.PersonNavView):
|
|||||||
table.attach(eventbox, 1, 2, 1, 2)
|
table.attach(eventbox, 1, 2, 1, 2)
|
||||||
subtbl = gtk.Table(3, 3)
|
subtbl = gtk.Table(3, 3)
|
||||||
subtbl.set_col_spacings(12)
|
subtbl.set_col_spacings(12)
|
||||||
subtbl.set_row_spacings(6)
|
subtbl.set_row_spacings(0)
|
||||||
eventbox.add(subtbl)
|
eventbox.add(subtbl)
|
||||||
|
|
||||||
# GRAMPS ID
|
# GRAMPS ID
|
||||||
@ -659,10 +660,10 @@ class RelationshipView(PageView.PersonNavView):
|
|||||||
def write_label(self, title, family, is_parent, person = None):
|
def write_label(self, title, family, is_parent, person = None):
|
||||||
msg = '<span style="italic" weight="heavy">%s</span>' % cgi.escape(title)
|
msg = '<span style="italic" weight="heavy">%s</span>' % cgi.escape(title)
|
||||||
hbox = gtk.HBox()
|
hbox = gtk.HBox()
|
||||||
label = GrampsWidgets.MarkupLabel(msg)
|
label = GrampsWidgets.MarkupLabel(msg, x_align=1)
|
||||||
# Draw the collapse/expand button:
|
# Draw the collapse/expand button:
|
||||||
if family != None:
|
if family != None:
|
||||||
if self.check_collapsed(person, family.handle):
|
if self.check_collapsed(person.handle, family.handle):
|
||||||
arrow = GrampsWidgets.ExpandCollapseArrow(True,
|
arrow = GrampsWidgets.ExpandCollapseArrow(True,
|
||||||
self.expand_collapse_press,
|
self.expand_collapse_press,
|
||||||
(person, family.handle))
|
(person, family.handle))
|
||||||
@ -673,8 +674,7 @@ class RelationshipView(PageView.PersonNavView):
|
|||||||
else :
|
else :
|
||||||
arrow = gtk.Arrow(gtk.ARROW_RIGHT, gtk.SHADOW_OUT)
|
arrow = gtk.Arrow(gtk.ARROW_RIGHT, gtk.SHADOW_OUT)
|
||||||
hbox.pack_start(arrow, False)
|
hbox.pack_start(arrow, False)
|
||||||
|
hbox.pack_start(label, True)
|
||||||
hbox.pack_start(label, False)
|
|
||||||
self.attach.attach(hbox,
|
self.attach.attach(hbox,
|
||||||
_LABEL_START, _LABEL_STOP,
|
_LABEL_START, _LABEL_STOP,
|
||||||
self.row, self.row+1, gtk.SHRINK|gtk.FILL)
|
self.row, self.row+1, gtk.SHRINK|gtk.FILL)
|
||||||
@ -687,7 +687,7 @@ class RelationshipView(PageView.PersonNavView):
|
|||||||
_DATA_START, _DATA_STOP,
|
_DATA_START, _DATA_STOP,
|
||||||
self.row, self.row+1, gtk.SHRINK|gtk.FILL)
|
self.row, self.row+1, gtk.SHRINK|gtk.FILL)
|
||||||
|
|
||||||
if family and self.check_collapsed(person, family.handle):
|
if family and self.check_collapsed(person.handle, family.handle):
|
||||||
# show family names later
|
# show family names later
|
||||||
pass
|
pass
|
||||||
else:
|
else:
|
||||||
@ -746,7 +746,7 @@ class RelationshipView(PageView.PersonNavView):
|
|||||||
family = self.dbstate.db.get_family_from_handle(family_handle)
|
family = self.dbstate.db.get_family_from_handle(family_handle)
|
||||||
if not family:
|
if not family:
|
||||||
return
|
return
|
||||||
if person and self.check_collapsed(person, family_handle):
|
if person and self.check_collapsed(person.handle, family_handle):
|
||||||
# don't show rest
|
# don't show rest
|
||||||
self.write_label("%s:" % _('Parents'), family, True, person)
|
self.write_label("%s:" % _('Parents'), family, True, person)
|
||||||
self.row -= 1 # back up one row for summary names
|
self.row -= 1 # back up one row for summary names
|
||||||
@ -788,16 +788,54 @@ class RelationshipView(PageView.PersonNavView):
|
|||||||
|
|
||||||
if self.show_siblings:
|
if self.show_siblings:
|
||||||
active = self.dbstate.active.handle
|
active = self.dbstate.active.handle
|
||||||
|
hbox = gtk.HBox()
|
||||||
child_list = [ref.ref for ref in family.get_child_ref_list()]
|
if self.check_collapsed(person.handle, "SIBLINGS"):
|
||||||
|
arrow = GrampsWidgets.ExpandCollapseArrow(True,
|
||||||
|
self.expand_collapse_press,
|
||||||
|
(person, "SIBLINGS"))
|
||||||
|
else:
|
||||||
|
arrow = GrampsWidgets.ExpandCollapseArrow(False,
|
||||||
|
self.expand_collapse_press,
|
||||||
|
(person, "SIBLINGS"))
|
||||||
|
hbox.pack_start(arrow, False)
|
||||||
label_cell = self.build_label_cell(_('Siblings'))
|
label_cell = self.build_label_cell(_('Siblings'))
|
||||||
label_cell.set_alignment(0, 0)
|
hbox.pack_start(label_cell, True)
|
||||||
self.attach.attach(
|
self.attach.attach(
|
||||||
label_cell, _CLABEL_START-1, _CLABEL_STOP-1, self.row,
|
hbox, _CLABEL_START-1, _CLABEL_STOP-1, self.row,
|
||||||
self.row+1, xoptions=gtk.FILL|gtk.SHRINK,
|
self.row+1, xoptions=gtk.FILL|gtk.SHRINK,
|
||||||
yoptions=gtk.FILL)
|
yoptions=gtk.FILL)
|
||||||
|
|
||||||
|
if self.check_collapsed(person.handle, "SIBLINGS"):
|
||||||
|
hbox = gtk.HBox()
|
||||||
|
child_list = [ref.ref for ref in family.get_child_ref_list()
|
||||||
|
if ref.ref != active]
|
||||||
|
if child_list:
|
||||||
|
count = len(child_list)
|
||||||
|
else:
|
||||||
|
count = 0
|
||||||
|
if count > 1 :
|
||||||
|
childmsg = _(" (%d siblings)") % count
|
||||||
|
elif count == 1 :
|
||||||
|
gender = self.dbstate.db.get_person_from_handle(\
|
||||||
|
child_list[0]).gender
|
||||||
|
if gender == gen.lib.Person.MALE :
|
||||||
|
childmsg = _(" (1 brother)")
|
||||||
|
elif gender == gen.lib.Person.FEMALE :
|
||||||
|
childmsg = _(" (1 sister)")
|
||||||
|
else :
|
||||||
|
childmsg = _(" (1 sibling)")
|
||||||
|
else :
|
||||||
|
childmsg = _(" (only child)")
|
||||||
|
box = self.get_people_box(post_msg=childmsg)
|
||||||
|
eventbox = gtk.EventBox()
|
||||||
|
if self.use_shade:
|
||||||
|
eventbox.modify_bg(gtk.STATE_NORMAL, self.color)
|
||||||
|
eventbox.add(box)
|
||||||
|
self.attach.attach(
|
||||||
|
eventbox, _PDATA_START, _PDATA_STOP,
|
||||||
|
self.row, self.row+1)
|
||||||
|
self.row += 1 # now advance it
|
||||||
|
else:
|
||||||
hbox = gtk.HBox()
|
hbox = gtk.HBox()
|
||||||
addchild = GrampsWidgets.IconButton(
|
addchild = GrampsWidgets.IconButton(
|
||||||
self.add_child_to_fam,
|
self.add_child_to_fam,
|
||||||
@ -822,6 +860,7 @@ class RelationshipView(PageView.PersonNavView):
|
|||||||
self.row += 1
|
self.row += 1
|
||||||
vbox = gtk.VBox()
|
vbox = gtk.VBox()
|
||||||
i = 1
|
i = 1
|
||||||
|
child_list = [ref.ref for ref in family.get_child_ref_list()]
|
||||||
for child_handle in child_list:
|
for child_handle in child_list:
|
||||||
child_should_be_linked = (child_handle != active)
|
child_should_be_linked = (child_handle != active)
|
||||||
self.write_child(vbox, child_handle, i, child_should_be_linked)
|
self.write_child(vbox, child_handle, i, child_should_be_linked)
|
||||||
@ -875,8 +914,8 @@ class RelationshipView(PageView.PersonNavView):
|
|||||||
else:
|
else:
|
||||||
format = "%s"
|
format = "%s"
|
||||||
|
|
||||||
label = GrampsWidgets.MarkupLabel(format % cgi.escape(title))
|
label = GrampsWidgets.MarkupLabel(format % cgi.escape(title),
|
||||||
label.set_alignment(0, 0)
|
x_align=1, y_align=0)
|
||||||
if Config.get(Config.RELEDITBTN):
|
if Config.get(Config.RELEDITBTN):
|
||||||
label.set_padding(0, 5)
|
label.set_padding(0, 5)
|
||||||
self.attach.attach(label, _PLABEL_START, _PLABEL_STOP, self.row,
|
self.attach.attach(label, _PLABEL_START, _PLABEL_STOP, self.row,
|
||||||
@ -924,22 +963,42 @@ class RelationshipView(PageView.PersonNavView):
|
|||||||
else:
|
else:
|
||||||
format = "%s"
|
format = "%s"
|
||||||
|
|
||||||
lbl = GrampsWidgets.MarkupLabel(format % cgi.escape(title))
|
lbl = GrampsWidgets.MarkupLabel(format % cgi.escape(title),
|
||||||
|
x_align=1, y_align=.5)
|
||||||
if Config.get(Config.RELEDITBTN):
|
if Config.get(Config.RELEDITBTN):
|
||||||
lbl.set_padding(0, 5)
|
lbl.set_padding(0, 5)
|
||||||
return lbl
|
return lbl
|
||||||
|
|
||||||
def write_child(self, vbox, handle, index, child_should_be_linked):
|
def write_child(self, vbox, handle, index, child_should_be_linked):
|
||||||
|
if not child_should_be_linked:
|
||||||
|
original_vbox = vbox
|
||||||
|
vbox = gtk.VBox()
|
||||||
|
frame = gtk.Frame()
|
||||||
|
frame.set_shadow_type(gtk.SHADOW_ETCHED_IN)
|
||||||
|
frame.add(vbox)
|
||||||
|
original_vbox.add(frame)
|
||||||
|
|
||||||
parent = has_children(self.dbstate.db,
|
parent = has_children(self.dbstate.db,
|
||||||
self.dbstate.db.get_person_from_handle(handle))
|
self.dbstate.db.get_person_from_handle(handle))
|
||||||
|
|
||||||
format = ''
|
format = ''
|
||||||
|
relation_display_theme = Config.get(Config.RELATION_DISPLAY_THEME)
|
||||||
if child_should_be_linked and parent:
|
if child_should_be_linked and parent:
|
||||||
|
if relation_display_theme == "CLASSIC":
|
||||||
format = 'underline="single" weight="heavy" style="italic"'
|
format = 'underline="single" weight="heavy" style="italic"'
|
||||||
|
elif relation_display_theme == "WEBPAGE":
|
||||||
|
format = 'foreground="blue" weight="heavy"'
|
||||||
|
else:
|
||||||
|
raise AttributeError("invalid relation-display-theme: '%s'" % relation_display_theme)
|
||||||
elif child_should_be_linked and not parent:
|
elif child_should_be_linked and not parent:
|
||||||
|
if relation_display_theme == "CLASSIC":
|
||||||
format = 'underline="single"'
|
format = 'underline="single"'
|
||||||
|
elif relation_display_theme == "WEBPAGE":
|
||||||
|
format = 'foreground="blue"'
|
||||||
|
else:
|
||||||
|
raise AttributeError("invalid relation-display-theme: '%s'" % relation_display_theme)
|
||||||
elif parent and not child_should_be_linked:
|
elif parent and not child_should_be_linked:
|
||||||
format = 'weight="heavy" style="italic"'
|
format = 'weight="heavy"'
|
||||||
|
|
||||||
if child_should_be_linked:
|
if child_should_be_linked:
|
||||||
link_func = self._button_press
|
link_func = self._button_press
|
||||||
@ -959,11 +1018,8 @@ class RelationshipView(PageView.PersonNavView):
|
|||||||
button = None
|
button = None
|
||||||
|
|
||||||
hbox = gtk.HBox()
|
hbox = gtk.HBox()
|
||||||
if child_should_be_linked:
|
|
||||||
l = GrampsWidgets.BasicLabel("%d." % index)
|
l = GrampsWidgets.BasicLabel("%d." % index)
|
||||||
else:
|
l.set_width_chars(3)
|
||||||
l = GrampsWidgets.BasicLabel("> %d." % index)
|
|
||||||
l.set_width_chars(5)
|
|
||||||
l.set_alignment(1.0, 0.5)
|
l.set_alignment(1.0, 0.5)
|
||||||
hbox.pack_start(l, False, False, 0)
|
hbox.pack_start(l, False, False, 0)
|
||||||
hbox.pack_start(GrampsWidgets.LinkBox(link_label, button),
|
hbox.pack_start(GrampsWidgets.LinkBox(link_label, button),
|
||||||
@ -1024,9 +1080,9 @@ class RelationshipView(PageView.PersonNavView):
|
|||||||
value = ""
|
value = ""
|
||||||
return value
|
return value
|
||||||
|
|
||||||
def check_collapsed(self, person, handle):
|
def check_collapsed(self, person_handle, handle):
|
||||||
""" Return true if collapsed. """
|
""" Return true if collapsed. """
|
||||||
return (handle in self.collapsed_items.get(person.handle, []))
|
return (handle in self.collapsed_items.get(person_handle, []))
|
||||||
|
|
||||||
def expand_collapse_press(self, obj, event, pair):
|
def expand_collapse_press(self, obj, event, pair):
|
||||||
""" Calback function for ExpandCollapseArrow, user param is pair,
|
""" Calback function for ExpandCollapseArrow, user param is pair,
|
||||||
@ -1151,7 +1207,7 @@ class RelationshipView(PageView.PersonNavView):
|
|||||||
handle = father_handle
|
handle = father_handle
|
||||||
|
|
||||||
# collapse button
|
# collapse button
|
||||||
if self.check_collapsed(person, family_handle):
|
if self.check_collapsed(person.handle, family_handle):
|
||||||
# show "> Family: ..." and nothing else
|
# show "> Family: ..." and nothing else
|
||||||
self.write_label("%s:" % _('Family'), family, False, person)
|
self.write_label("%s:" % _('Family'), family, False, person)
|
||||||
self.row -= 1 # back up
|
self.row -= 1 # back up
|
||||||
@ -1184,15 +1240,46 @@ class RelationshipView(PageView.PersonNavView):
|
|||||||
if not self.write_marriage(box, family):
|
if not self.write_marriage(box, family):
|
||||||
self.write_relationship(box, family)
|
self.write_relationship(box, family)
|
||||||
|
|
||||||
child_list = family.get_child_ref_list()
|
hbox = gtk.HBox()
|
||||||
|
if self.check_collapsed(person.handle, "CHILDREN"):
|
||||||
|
arrow = GrampsWidgets.ExpandCollapseArrow(True,
|
||||||
|
self.expand_collapse_press,
|
||||||
|
(person, "CHILDREN"))
|
||||||
|
else:
|
||||||
|
arrow = GrampsWidgets.ExpandCollapseArrow(False,
|
||||||
|
self.expand_collapse_press,
|
||||||
|
(person, "CHILDREN"))
|
||||||
|
hbox.pack_start(arrow, True)
|
||||||
label_cell = self.build_label_cell(_('Children'))
|
label_cell = self.build_label_cell(_('Children'))
|
||||||
label_cell.set_alignment(0, 0)
|
hbox.pack_start(label_cell, True)
|
||||||
self.attach.attach(
|
self.attach.attach(
|
||||||
label_cell, _CLABEL_START-1, _CLABEL_STOP-1, self.row,
|
hbox, _CLABEL_START-1, _CLABEL_STOP-1, self.row,
|
||||||
self.row+1, xoptions=gtk.FILL|gtk.SHRINK,
|
self.row+1, xoptions=gtk.FILL|gtk.SHRINK,
|
||||||
yoptions=gtk.FILL)
|
yoptions=gtk.FILL)
|
||||||
|
|
||||||
|
if self.check_collapsed(person.handle, "CHILDREN"):
|
||||||
|
hbox = gtk.HBox()
|
||||||
|
child_list = family.get_child_ref_list()
|
||||||
|
if child_list:
|
||||||
|
count = len(child_list)
|
||||||
|
else:
|
||||||
|
count = 0
|
||||||
|
if count > 1 :
|
||||||
|
childmsg = _(" (%d children)") % count
|
||||||
|
elif count == 1 :
|
||||||
|
childmsg = _(" (1 child)")
|
||||||
|
else :
|
||||||
|
childmsg = _(" (no children)")
|
||||||
|
box = self.get_people_box(post_msg=childmsg)
|
||||||
|
eventbox = gtk.EventBox()
|
||||||
|
if self.use_shade:
|
||||||
|
eventbox.modify_bg(gtk.STATE_NORMAL, self.color)
|
||||||
|
eventbox.add(box)
|
||||||
|
self.attach.attach(
|
||||||
|
eventbox, _PDATA_START, _PDATA_STOP,
|
||||||
|
self.row, self.row+1)
|
||||||
|
self.row += 1 # now advance it
|
||||||
|
else:
|
||||||
hbox = gtk.HBox()
|
hbox = gtk.HBox()
|
||||||
addchild = GrampsWidgets.IconButton(
|
addchild = GrampsWidgets.IconButton(
|
||||||
self.add_child_to_fam,
|
self.add_child_to_fam,
|
||||||
@ -1215,6 +1302,7 @@ class RelationshipView(PageView.PersonNavView):
|
|||||||
|
|
||||||
vbox = gtk.VBox()
|
vbox = gtk.VBox()
|
||||||
i = 1
|
i = 1
|
||||||
|
child_list = family.get_child_ref_list()
|
||||||
for child_ref in child_list:
|
for child_ref in child_list:
|
||||||
self.write_child(vbox, child_ref.ref, i, True)
|
self.write_child(vbox, child_ref.ref, i, True)
|
||||||
i += 1
|
i += 1
|
||||||
@ -1322,7 +1410,7 @@ class RelationshipView(PageView.PersonNavView):
|
|||||||
self.dbstate.db.commit_family(family, trans)
|
self.dbstate.db.commit_family(family, trans)
|
||||||
self.dbstate.db.transaction_commit(trans, _("Add Child to Family"))
|
self.dbstate.db.transaction_commit(trans, _("Add Child to Family"))
|
||||||
|
|
||||||
def sel_child_to_fam(self, obj, event, handle):
|
def sel_child_to_fam(self, obj, event, handle, surname=None):
|
||||||
from Selectors import selector_factory
|
from Selectors import selector_factory
|
||||||
if button_activated(event, _LEFT_BUTTON):
|
if button_activated(event, _LEFT_BUTTON):
|
||||||
SelectPerson = selector_factory('Person')
|
SelectPerson = selector_factory('Person')
|
||||||
|
@ -114,14 +114,22 @@ class ExpandCollapseArrow(gtk.EventBox):
|
|||||||
else:
|
else:
|
||||||
self.arrow = gtk.Arrow(gtk.ARROW_DOWN, gtk.SHADOW_OUT)
|
self.arrow = gtk.Arrow(gtk.ARROW_DOWN, gtk.SHADOW_OUT)
|
||||||
self.tooltips.set_tip(self, _("Collapse this section"))
|
self.tooltips.set_tip(self, _("Collapse this section"))
|
||||||
|
|
||||||
self.add(self.arrow)
|
self.add(self.arrow)
|
||||||
self.connect('button-press-event', onbuttonpress, pair)
|
self.connect('button-press-event', onbuttonpress, pair)
|
||||||
self.connect('realize', realize_cb)
|
self.connect('realize', realize_cb)
|
||||||
|
|
||||||
class LinkLabel(gtk.EventBox):
|
class LinkLabel(gtk.EventBox):
|
||||||
|
|
||||||
def __init__(self, label, func, handle, decoration='underline="single"'):
|
def __init__(self, label, func, handle, decoration=None):
|
||||||
|
if decoration == None:
|
||||||
|
relation_display_theme = Config.get(Config.RELATION_DISPLAY_THEME)
|
||||||
|
if relation_display_theme == "CLASSIC":
|
||||||
|
decoration = 'underline="single"'
|
||||||
|
elif relation_display_theme == "WEBPAGE":
|
||||||
|
decoration = 'foreground="blue"'
|
||||||
|
else:
|
||||||
|
raise AttributeError("invalid relation-display-theme: '%s'" % relation_display_theme)
|
||||||
|
|
||||||
gtk.EventBox.__init__(self)
|
gtk.EventBox.__init__(self)
|
||||||
self.orig_text = cgi.escape(label[0])
|
self.orig_text = cgi.escape(label[0])
|
||||||
self.gender = label[1]
|
self.gender = label[1]
|
||||||
@ -158,7 +166,13 @@ class LinkLabel(gtk.EventBox):
|
|||||||
self.label.set_padding(x, y)
|
self.label.set_padding(x, y)
|
||||||
|
|
||||||
def enter_text(self, obj, event, handle):
|
def enter_text(self, obj, event, handle):
|
||||||
|
relation_display_theme = Config.get(Config.RELATION_DISPLAY_THEME)
|
||||||
|
if relation_display_theme == "CLASSIC":
|
||||||
text = '<span foreground="blue" %s>%s</span>' % (self.decoration, self.orig_text)
|
text = '<span foreground="blue" %s>%s</span>' % (self.decoration, self.orig_text)
|
||||||
|
elif relation_display_theme == "WEBPAGE":
|
||||||
|
text = '<span underline="single" %s>%s</span>' % (self.decoration, self.orig_text)
|
||||||
|
else:
|
||||||
|
raise AttributeError("invalid relation-display-theme: '%s'" % relation_display_theme)
|
||||||
self.label.set_text(text)
|
self.label.set_text(text)
|
||||||
self.label.set_use_markup(True)
|
self.label.set_use_markup(True)
|
||||||
|
|
||||||
@ -253,18 +267,18 @@ class GenderLabel(gtk.Label):
|
|||||||
|
|
||||||
class MarkupLabel(gtk.Label):
|
class MarkupLabel(gtk.Label):
|
||||||
|
|
||||||
def __init__(self, text):
|
def __init__(self, text, x_align=0, y_align=0.5):
|
||||||
gtk.Label.__init__(self, text)
|
gtk.Label.__init__(self, text)
|
||||||
self.set_alignment(0, 0.5)
|
self.set_alignment(x_align, y_align)
|
||||||
self.set_use_markup(True)
|
self.set_use_markup(True)
|
||||||
self.show_all()
|
self.show_all()
|
||||||
|
|
||||||
class DualMarkupLabel(gtk.HBox):
|
class DualMarkupLabel(gtk.HBox):
|
||||||
|
|
||||||
def __init__(self, text, alt):
|
def __init__(self, text, alt, x_align=0, y_align=0.5):
|
||||||
gtk.HBox.__init__(self)
|
gtk.HBox.__init__(self)
|
||||||
label = gtk.Label(text)
|
label = gtk.Label(text)
|
||||||
label.set_alignment(0, 0.5)
|
label.set_alignment(x_align, y_align)
|
||||||
label.set_use_markup(True)
|
label.set_use_markup(True)
|
||||||
|
|
||||||
self.pack_start(label, False, False, 0)
|
self.pack_start(label, False, False, 0)
|
||||||
|
Loading…
Reference in New Issue
Block a user