Fix place selecton on LDS ords

svn: r6273
This commit is contained in:
Don Allingham 2006-04-05 21:30:27 +00:00
parent a817cb4a3d
commit ac9501eed4
4 changed files with 213 additions and 195 deletions

View File

@ -1,4 +1,7 @@
2006-04-05 Don Allingham <don@gramps-project.org>
* src/Editors/_EditLdsOrd.py: save place information
* src/GrampsWidgets.py: select default value in menu
* src/BaseDoc.py: pylint
* src/DisplayTabs.py: handle temple not set for LdsOrd
* src/RelLib/_LdsOrd.py: unserialize returns self
* src/RelLib/_LdsOrdBase.py: variable name change

View File

@ -91,9 +91,9 @@ log = logging.getLogger(".BaseDoc")
#
#-------------------------------------------------------------------------
try:
from xml.sax import make_parser,handler,SAXParseException
from xml.sax import make_parser, handler, SAXParseException
except:
from _xmlplus.sax import make_parser,handler,SAXParseException
from _xmlplus.sax import make_parser, handler, SAXParseException
#-------------------------------------------------------------------------
#
@ -140,10 +140,10 @@ def cnv2color(text):
converts a hex value in the form of #XXXXXX into a tuple of integers
representing the RGB values
"""
c0 = int(text[1:3],16)
c1 = int(text[3:5],16)
c2 = int(text[5:7],16)
return (c0,c1,c2)
c0 = int(text[1:3], 16)
c1 = int(text[3:5], 16)
c2 = int(text[5:7], 16)
return (c0, c1, c2)
#------------------------------------------------------------------------
#
@ -155,7 +155,7 @@ class PaperStyle:
Defines the dimensions of a sheet of paper. All dimensions are in
centimeters.
"""
def __init__(self,name,height,width):
def __init__(self, name, height, width):
"""
Creates a new paper style with.
@ -176,7 +176,7 @@ class PaperStyle:
"Returns the page orientation (PAPER_PORTRAIT or PAPER_LANDSCAPE)"
return self.orientation
def set_orientation(self,val):
def set_orientation(self, val):
"""
Sets the page orientation.
@ -189,7 +189,7 @@ class PaperStyle:
"Returns the page height in cm"
return self.height
def set_height(self,height):
def set_height(self, height):
"Sets the page height in cm"
self.height = height
@ -197,7 +197,7 @@ class PaperStyle:
"Returns the page width in cm"
return self.width
def set_width(self,width):
def set_width(self, width):
"Sets the page width in cm"
self.width = width
@ -245,10 +245,11 @@ class FontStyle:
self.size = 12
self.italic = 0
self.bold = 0
self.color = (0,0,0)
self.color = (0, 0, 0)
self.under = 0
def set(self,face=None,size=None,italic=None,bold=None,underline=None,color=None):
def set(self, face=None, size=None, italic=None, bold=None,
underline=None, color=None):
"""
Sets font characteristics.
@ -274,7 +275,7 @@ class FontStyle:
if color != None:
self.set_color(color)
def set_italic(self,val):
def set_italic(self, val):
"0 disables italics, 1 enables italics"
self.italic = val
@ -282,7 +283,7 @@ class FontStyle:
"1 indicates use italics"
return self.italic
def set_bold(self,val):
def set_bold(self, val):
"0 disables bold face, 1 enables bold face"
self.bold = val
@ -290,7 +291,7 @@ class FontStyle:
"1 indicates use bold face"
return self.bold
def set_color(self,val):
def set_color(self, val):
"sets the color using an RGB color tuple"
self.color = val
@ -298,7 +299,7 @@ class FontStyle:
"Returns an RGB color tuple"
return self.color
def set_size(self,val):
def set_size(self, val):
"sets font size in points"
self.size = val
@ -306,7 +307,7 @@ class FontStyle:
"returns font size in points"
return self.size
def set_type_face(self,val):
def set_type_face(self, val):
"sets the font face type"
self.face = val
@ -314,7 +315,7 @@ class FontStyle:
"returns the font face type"
return self.face
def set_underline(self,val):
def set_underline(self, val):
"1 enables underlining"
self.under = val
@ -334,7 +335,7 @@ class TableStyle:
number of columns, and the width of each column as a percentage of the
width of the table.
"""
def __init__(self,obj=None):
def __init__(self, obj=None):
"""
Creates a new TableStyle object, with the values initialized to
empty, with allocating space for up to 100 columns.
@ -351,7 +352,7 @@ class TableStyle:
self.columns = 0
self.colwid = [ 0 ] * 100
def set_width(self,width):
def set_width(self, width):
"""
Sets the width of the table in terms of percent of the available
width
@ -364,7 +365,7 @@ class TableStyle:
"""
return self.width
def set_columns(self,columns):
def set_columns(self, columns):
"""
Sets the number of columns.
@ -378,16 +379,16 @@ class TableStyle:
"""
return self.columns
def set_column_widths(self, list):
def set_column_widths(self, clist):
"""
Sets the width of all the columns at once, taking the percentages
from the passed list.
"""
self.columns = len(list)
self.columns = len(clist)
for i in range(self.columns):
self.colwid[i] = list[i]
self.colwid[i] = clist[i]
def set_column_width(self,index,width):
def set_column_width(self, index, width):
"""
Sets the width of a specified column to the specified width.
@ -396,7 +397,7 @@ class TableStyle:
"""
self.colwid[index] = width
def get_column_width(self,index):
def get_column_width(self, index):
"""
Returns the column width of the specified column as a percentage of
the entire table width.
@ -415,7 +416,7 @@ class TableCellStyle:
Defines the style of a particular table cell. Characteristics are:
right border, left border, top border, bottom border, and padding.
"""
def __init__(self,obj=None):
def __init__(self, obj=None):
"""
Creates a new TableCellStyle instance.
@ -437,11 +438,11 @@ class TableCellStyle:
self.padding = 0
self.longlist = 0
def set_padding(self,val):
def set_padding(self, val):
"Returns the cell padding in centimeters"
self.padding = val
def set_right_border(self,val):
def set_right_border(self, val):
"""
Defines if a right border in used
@ -449,7 +450,7 @@ class TableCellStyle:
"""
self.rborder = val
def set_left_border(self,val):
def set_left_border(self, val):
"""
Defines if a left border in used
@ -457,7 +458,7 @@ class TableCellStyle:
"""
self.lborder = val
def set_top_border(self,val):
def set_top_border(self, val):
"""
Defines if a top border in used
@ -465,7 +466,7 @@ class TableCellStyle:
"""
self.tborder = val
def set_bottom_border(self,val):
def set_bottom_border(self, val):
"""
Defines if a bottom border in used
@ -473,7 +474,7 @@ class TableCellStyle:
"""
self.bborder = val
def set_longlist(self,val):
def set_longlist(self, val):
self.longlist = val
def get_padding(self):
@ -512,7 +513,7 @@ class ParagraphStyle:
right border, left border, padding, and background color.
"""
def __init__(self,source=None):
def __init__(self, source=None):
"""
@param source: if not None, then the ParagraphStyle is created
using the values of the source instead of the default values.
@ -550,16 +551,16 @@ class ParagraphStyle:
self.bgcolor = (255,255,255)
self.description = ""
def set_description(self,text):
def set_description(self, text):
self.description = text
def get_description(self):
return self.description
def set(self,rmargin=None,lmargin=None,first_indent=None,
tmargin=None,bmargin=None,align=None,
tborder=None,bborder=None,rborder=None,lborder=None,pad=None,
bgcolor=None,font=None):
def set(self, rmargin=None, lmargin=None, first_indent=None,
tmargin=None, bmargin=None, align=None,
tborder=None, bborder=None, rborder=None, lborder=None,
pad=None, bgcolor=None, font=None):
"""
Allows the values of the object to be set.
@ -604,7 +605,7 @@ class ParagraphStyle:
if bmargin != None:
self.set_bottom_margin(bmargin)
def set_header_level(self,level):
def set_header_level(self, level):
"""
Sets the header level for the paragraph. This is useful for
numbered paragraphs. A value of 1 indicates a header level
@ -617,7 +618,7 @@ class ParagraphStyle:
"Returns the header level of the paragraph"
return self.level
def set_font(self,font):
def set_font(self, font):
"""
Sets the font style of the paragraph.
@ -629,7 +630,7 @@ class ParagraphStyle:
"Returns the FontStyle of the paragraph"
return self.font
def set_padding(self,val):
def set_padding(self, val):
"""
Sets the paragraph padding in centimeters
@ -641,7 +642,7 @@ class ParagraphStyle:
"""Returns a the padding of the paragraph"""
return self.pad
def set_top_border(self,val):
def set_top_border(self, val):
"""
Sets the presence or absence of top border.
@ -654,7 +655,7 @@ class ParagraphStyle:
"Returns 1 if a top border is specified"
return self.top_border
def set_bottom_border(self,val):
def set_bottom_border(self, val):
"""
Sets the presence or absence of bottom border.
@ -667,7 +668,7 @@ class ParagraphStyle:
"Returns 1 if a bottom border is specified"
return self.bottom_border
def set_left_border(self,val):
def set_left_border(self, val):
"""
Sets the presence or absence of left border.
@ -680,7 +681,7 @@ class ParagraphStyle:
"Returns 1 if a left border is specified"
return self.left_border
def set_right_border(self,val):
def set_right_border(self ,val):
"""
Sets the presence or absence of rigth border.
@ -700,7 +701,7 @@ class ParagraphStyle:
"""
return self.bgcolor
def set_background_color(self,color):
def set_background_color(self, color):
"""
Sets the background color of the paragraph.
@ -709,7 +710,7 @@ class ParagraphStyle:
"""
self.bgcolor = color
def set_alignment(self,align):
def set_alignment(self, align):
"""
Sets the paragraph alignment.
@ -737,23 +738,23 @@ class ParagraphStyle:
return "justify"
return "unknown"
def set_left_margin(self,value):
def set_left_margin(self, value):
"sets the left indent in centimeters"
self.lmargin = value
def set_right_margin(self,value):
def set_right_margin(self, value):
"sets the right indent in centimeters"
self.rmargin = value
def set_first_indent(self,value):
def set_first_indent(self, value):
"sets the first line indent in centimeters"
self.first_indent = value
def set_top_margin(self,value):
def set_top_margin(self, value):
"sets the space above paragraph in centimeters"
self.tmargin = value
def set_bottom_margin(self,value):
def set_bottom_margin(self, value):
"sets the space below paragraph in centimeters"
self.bmargin = value
@ -789,7 +790,7 @@ class StyleSheetList:
styles are loaded from a specified XML file if it exists.
"""
def __init__(self,file,defstyle):
def __init__(self, filename, defstyle):
"""
Creates a new StyleSheetList from the specified default style and
any other styles that may be defined in the specified file.
@ -799,10 +800,10 @@ class StyleSheetList:
"""
defstyle.set_name('default')
self.map = { "default" : defstyle }
self.file = os.path.join(const.home_dir,file)
self.file = os.path.join(const.home_dir,filename)
self.parse()
def delete_style_sheet(self,name):
def delete_style_sheet(self, name):
"""
Removes a style from the list. Since each style must have a
unique name, the name is used to delete the stylesheet.
@ -817,7 +818,7 @@ class StyleSheetList:
"""
return self.map
def get_style_sheet(self,name):
def get_style_sheet(self, name):
"""
Returns the StyleSheet associated with the name
@ -829,7 +830,7 @@ class StyleSheetList:
"Returns a list of all the style names in the StyleSheetList"
return self.map.keys()
def set_style_sheet(self,name,style):
def set_style_sheet(self, name, style):
"""
Adds or replaces a StyleSheet in the StyleSheetList. The
default style may not be replaced.
@ -924,7 +925,7 @@ class StyleSheet:
style = obj.style_list[style_name]
self.style_list[style_name] = ParagraphStyle(style)
def set_name(self,name):
def set_name(self, name):
self.name = name
def get_name(self):
@ -934,7 +935,7 @@ class StyleSheet:
"Removes all paragraph styles from the StyleSheet"
self.style_list = {}
def add_style(self,name,style):
def add_style(self, name, style):
"""
Adds a paragraph style to the style sheet.
@ -951,7 +952,7 @@ class StyleSheet:
"Returns the paragraph name/ParagraphStyle map"
return self.style_list
def get_style(self,name):
def get_style(self, name):
"""
Returns the ParagraphStyle associated with the name
@ -969,7 +970,7 @@ class SheetParser(handler.ContentHandler):
SAX parsing class for the StyleSheetList XML file.
"""
def __init__(self,sheetlist):
def __init__(self, sheetlist):
"""
Creates a SheetParser class that populates the passed StyleSheetList
class.
@ -984,7 +985,7 @@ class SheetParser(handler.ContentHandler):
self.sname = None
self.pname = None
def startElement(self,tag,attrs):
def startElement(self, tag, attrs):
"""
Overridden class that handles the start of a XML element
"""
@ -1022,7 +1023,7 @@ class SheetParser(handler.ContentHandler):
self.p = ParagraphStyle()
self.pname = attrs['name']
def endElement(self,tag):
def endElement(self, tag):
"Overridden class that handles the start of a XML element"
if tag == "style":
self.p.set_font(self.f)
@ -1036,7 +1037,7 @@ class SheetParser(handler.ContentHandler):
#
#------------------------------------------------------------------------
class GraphicsStyle:
def __init__(self,obj=None):
def __init__(self, obj=None):
if obj:
self.height = obj.height
self.width = obj.width
@ -1058,7 +1059,7 @@ class GraphicsStyle:
self.fill_color = (255,255,255)
self.lstyle = SOLID
def set_line_width(self,val):
def set_line_width(self, val):
self.lwidth = val
def get_line_width(self):
@ -1067,29 +1068,29 @@ class GraphicsStyle:
def get_line_style(self):
return self.lstyle
def set_line_style(self,val):
def set_line_style(self, val):
self.lstyle = val
def set_height(self,val):
def set_height(self, val):
self.height = val
def set_width(self,val):
def set_width(self, val):
self.width = val
def set_paragraph_style(self,val):
def set_paragraph_style(self, val):
self.para_name = val
def set_shadow(self,val,space=0.2):
def set_shadow(self, val, space=0.2):
self.shadow = val
self.shadow_space = space
def get_shadow_space(self):
return self.shadow_space
def set_color(self,val):
def set_color(self, val):
self.color = val
def set_fill_color(self,val):
def set_fill_color(self, val):
self.fill_color = val
def get_height(self):
@ -1121,7 +1122,8 @@ class BaseDoc:
such as OpenOffice, AbiWord, and LaTeX are derived from this base
class, providing a common interface to all document generators.
"""
def __init__(self,styles,paper_type,template,orientation=PAPER_PORTRAIT):
def __init__(self, styles, paper_type ,template,
orientation=PAPER_PORTRAIT):
"""
Creates a BaseDoc instance, which provides a document generation
interface. This class should never be instantiated directly, but
@ -1175,7 +1177,7 @@ class BaseDoc:
def end_page(self):
pass
def print_requested (self):
def print_requested(self):
self.print_req = 1
def set_owner(self,owner):
@ -1186,7 +1188,7 @@ class BaseDoc:
"""
self.owner = owner
def add_media_object(self,name,align,w_cm,h_cm):
def add_media_object(self, name, align, w_cm, h_cm):
"""
Adds a photo of the specified width (in centimeters)
@ -1228,7 +1230,7 @@ class BaseDoc:
"Returns the owner name"
self.name = name
def set_title(self,name):
def set_title(self, name):
"""
Sets the title of the document.
@ -1236,16 +1238,16 @@ class BaseDoc:
"""
self.title = name
def add_draw_style(self,name,style):
def add_draw_style(self, name, style):
self.draw_styles[name] = GraphicsStyle(style)
def get_draw_style(self,name):
def get_draw_style(self, name):
return self.draw_styles[name]
def get_style(self,name):
def get_style(self, name):
return self.style_list[name]
def add_table_style(self,name,style):
def add_table_style(self, name, style):
"""
Adds the TableStyle with the specfied name.
@ -1254,7 +1256,7 @@ class BaseDoc:
"""
self.table_styles[name] = TableStyle(style)
def add_cell_style(self,name,style):
def add_cell_style(self, name, style):
"""
Adds the TableCellStyle with the specfied name.
@ -1263,7 +1265,7 @@ class BaseDoc:
"""
self.cell_styles[name] = TableCellStyle(style)
def open(self,filename):
def open(self, filename):
"""
Opens the document.
@ -1275,7 +1277,7 @@ class BaseDoc:
"Closes the document"
pass
def string_width(self,fontstyle,text):
def string_width(self, fontstyle, text):
"Determine the width need for text in given font"
return FontScale.string_width(fontstyle,text)
@ -1299,7 +1301,7 @@ class BaseDoc:
def end_superscript(self):
pass
def start_listing(self,style_name):
def start_listing(self, style_name):
"""
Starts a new listing block, using the specified style name.
@ -1310,7 +1312,7 @@ class BaseDoc:
def end_listing(self):
pass
def start_paragraph(self,style_name,leader=None):
def start_paragraph(self, style_name, leader=None):
"""
Starts a new paragraph, using the specified style name.
@ -1325,7 +1327,7 @@ class BaseDoc:
"Ends the current parsgraph"
pass
def start_table(self,name,style_name):
def start_table(self, name, style_name):
"""
Starts a new table.
@ -1346,7 +1348,7 @@ class BaseDoc:
"Ends the current row on the current table"
pass
def start_cell(self,style_name,span=1):
def start_cell(self, style_name, span=1):
"""
Starts a new table cell, using the paragraph style specified.
@ -1363,7 +1365,7 @@ class BaseDoc:
"Creates a horizontal line"
pass
def write_note(self,text,format,style_name):
def write_note(self, text, format, style_name):
"""
Writes the note's text and take care of paragraphs,
depending on the format.
@ -1374,7 +1376,7 @@ class BaseDoc:
"""
pass
def write_text(self,text):
def write_text(self, text):
"""
Writes the text in the current paragraph. Should only be used after a
start_paragraph and before an end_paragraph.
@ -1383,7 +1385,7 @@ class BaseDoc:
"""
pass
def write_cmdstr(self,text):
def write_cmdstr(self, text):
"""
Writes the text in the current paragraph. Should only be used after a
start_paragraph and before an end_paragraph.
@ -1392,35 +1394,35 @@ class BaseDoc:
"""
pass
def draw_arc(self,style,x1,y1,x2,y2,angle,extent):
def draw_arc(self, style, x1, y1, x2, y2, angle, extent):
pass
def draw_path(self,style,path):
def draw_path(self, style, path):
pass
def draw_box(self,style,text,x,y):
def draw_box(self, style, text, x, y):
pass
def write_at(self,style,text,x,y):
def write_at(self, style, text, x, y):
pass
def draw_bar(self,style,x1,y1,x2,y2):
def draw_bar(self, style, x1, y1, x2, y2):
pass
def draw_text(self,style,text,x1,y1):
def draw_text(self, style, text, x1, y1):
pass
def center_text(self,style,text,x1,y1):
def center_text(self, style, text, x1, y1):
pass
def rotate_text(self,style,text,x,y,angle):
def rotate_text(self, style, text, x, y, angle):
pass
def draw_line(self,style,x1,y1,x2,y2):
def draw_line(self, style, x1, y1, x2, y2):
pass
def draw_wedge(self, style, centerx, centery, radius, start_angle,
end_angle, short_radius=0):
def draw_wedge(self, style, centerx, centery, radius, start_angle,
end_angle, short_radius=0):
assert(self.init_called)
while end_angle < start_angle:
@ -1437,7 +1439,7 @@ class BaseDoc:
angle = sangle
if short_radius == 0:
p.append((centerx,centery))
p.append((centerx, centery))
else:
origx = (centerx + cos(angle)*short_radius)
origy = (centery + sin(angle)*short_radius)
@ -1446,24 +1448,24 @@ class BaseDoc:
while angle<eangle:
x = centerx + cos(angle)*radius
y = centery + sin(angle)*radius
p.append((x,y))
p.append((x, y))
angle = angle+radiansdelta
x = centerx + cos(eangle)*radius
y = centery + sin(eangle)*radius
p.append((x,y))
p.append((x, y))
if short_radius:
x = centerx + cos(eangle)*short_radius
y = centery + sin(eangle)*short_radius
p.append((x,y))
p.append((x, y))
angle = eangle
while angle>=sangle:
x = centerx + cos(angle)*short_radius
y = centery + sin(angle)*short_radius
p.append((x,y))
p.append((x, y))
angle = angle-radiansdelta
self.draw_path(style,p)
self.draw_path(style, p)
delta = (eangle - sangle)/2.0
rad = short_radius + (radius-short_radius)/2.0
@ -1471,13 +1473,13 @@ class BaseDoc:
return ( (centerx + cos(sangle+delta) * rad),
(centery + sin(sangle+delta) * rad))
def start_path(self,style,x,y):
def start_path(self, style, x, y):
pass
def line_to(self,x,y):
def line_to(self, x, y):
pass
def arc_to(self,x,y,angle,extent):
def arc_to(self, x, y, angle, extent):
pass
def end_path(self):

View File

@ -215,6 +215,19 @@ class EditLdsOrd(EditSecondary):
Called when the OK button is pressed. Gets data from the
form and updates the Attribute data structure.
"""
(need_new, handle) = self.place_field.get_place_info()
if need_new:
place_obj = RelLib.Place()
place_obj.set_title(handle)
trans = self.db.transaction_begin()
self.db.add_place(place_obj,trans)
self.db.transaction_commit(trans,_("Add Place"))
self.obj.set_place_handle(place_obj.get_handle())
else:
self.obj.set_place_handle(handle)
print self.obj.get_place_handle()
if self.callback:
self.callback(self.obj)
self.close_window(obj)

View File

@ -38,12 +38,12 @@ import DateHandler
import DateEdit
import const
_lock_path = os.path.join(const.image_dir,'stock_lock.png')
_lock_open_path = os.path.join(const.image_dir,'stock_lock-open.png')
_lock_path = os.path.join(const.image_dir, 'stock_lock.png')
_lock_open_path = os.path.join(const.image_dir, 'stock_lock-open.png')
class LinkLabel(gtk.EventBox):
def __init__(self,label,func,handle):
def __init__(self, label, func, handle):
gtk.EventBox.__init__(self)
self.orig_text = cgi.escape(label[0])
self.gender = label[1]
@ -53,23 +53,23 @@ class LinkLabel(gtk.EventBox):
self.label = gtk.Label(text)
self.label.set_use_markup(True)
self.label.set_alignment(0,0.5)
self.label.set_alignment(0, 0.5)
self.add(self.label)
self.set_visible_window(False)
self.connect('button-press-event',func,handle)
self.connect('enter-notify-event',self.enter_text,handle)
self.connect('leave-notify-event',self.leave_text,handle)
self.connect('button-press-event', func, handle)
self.connect('enter-notify-event', self.enter_text, handle)
self.connect('leave-notify-event', self.leave_text, handle)
def enter_text(self,obj,event,handle):
def enter_text(self, obj, event, handle):
text = '<span foreground="blue" underline="single">%s</span>' % self.orig_text
if self.gender:
text += u" %s" % self.gender
self.label.set_text(text)
self.label.set_use_markup(True)
def leave_text(self,obj,event,handle):
def leave_text(self, obj, event, handle):
text = '<span underline="single">%s</span>' % self.orig_text
if self.gender:
text += u" %s" % self.gender
@ -78,16 +78,16 @@ class LinkLabel(gtk.EventBox):
class IconButton(gtk.EventBox):
def __init__(self,func,handle,icon=gtk.STOCK_EDIT,size=gtk.ICON_SIZE_MENU):
def __init__(self, func, handle, icon=gtk.STOCK_EDIT, size=gtk.ICON_SIZE_MENU):
gtk.EventBox.__init__(self)
image = gtk.Image()
image.set_from_stock(icon,size)
image.set_from_stock(icon, size)
image.show()
self.add(image)
self.show()
if func:
self.connect('button-press-event',func,handle)
self.connect('button-press-event', func, handle)
class WarnButton(gtk.EventBox):
def __init__(self):
@ -96,9 +96,9 @@ class WarnButton(gtk.EventBox):
# Some versions of FreeBSD don't seem to have STOCK_INFO
try:
image.set_from_stock(gtk.STOCK_INFO,gtk.ICON_SIZE_MENU)
image.set_from_stock(gtk.STOCK_INFO, gtk.ICON_SIZE_MENU)
except:
image.set_from_stock(gtk.STOCK_DIALOG_INFO,gtk.ICON_SIZE_MENU)
image.set_from_stock(gtk.STOCK_DIALOG_INFO, gtk.ICON_SIZE_MENU)
image.show()
self.add(image)
@ -106,57 +106,57 @@ class WarnButton(gtk.EventBox):
self.func = None
self.hide()
def on_clicked(self,func):
self.connect('button-press-event',self._button_press)
def on_clicked(self, func):
self.connect('button-press-event', self._button_press)
self.func = func
def _button_press(self,obj,event):
def _button_press(self, obj, event):
if event.type == gtk.gdk.BUTTON_PRESS and event.button == 1:
self.func(obj)
class SimpleButton(gtk.Button):
def __init__(self,image,func):
def __init__(self, image, func):
gtk.Button.__init__(self)
self.set_relief(gtk.RELIEF_NONE)
self.add(gtk.image_new_from_stock(image,gtk.ICON_SIZE_BUTTON))
self.connect('clicked',func)
self.add(gtk.image_new_from_stock(image, gtk.ICON_SIZE_BUTTON))
self.connect('clicked', func)
self.show()
class LinkBox(gtk.HBox):
def __init__(self,link,button):
def __init__(self, link, button):
gtk.HBox.__init__(self)
self.set_spacing(6)
self.pack_start(link,False)
self.pack_start(button,False)
self.pack_start(link, False)
self.pack_start(button, False)
self.show()
class EditLabel(gtk.HBox):
def __init__(self,text):
def __init__(self, text):
gtk.HBox.__init__(self)
label = BasicLabel(text)
self.pack_start(label,False)
self.pack_start(gtk.image_new_from_stock(gtk.STOCK_EDIT,
gtk.ICON_SIZE_MENU),False)
self.pack_start(label, False)
self.pack_start(gtk.image_new_from_stock(gtk.STOCK_EDIT,
gtk.ICON_SIZE_MENU), False)
self.set_spacing(4)
# self.tooltip = gtk.Tooltips()
# self.tooltip.set_tip(label,_('Click in the cell to change the value'))
# self.tooltip.set_tip(label, _('Click in the cell to change the value'))
# self.tooltip.enable()
self.show_all()
class BasicLabel(gtk.Label):
def __init__(self,text):
gtk.Label.__init__(self,text)
self.set_alignment(0,0.5)
def __init__(self, text):
gtk.Label.__init__(self, text)
self.set_alignment(0, 0.5)
self.show()
class MarkupLabel(gtk.Label):
def __init__(self,text):
gtk.Label.__init__(self,text)
self.set_alignment(0,0.5)
def __init__(self, text):
gtk.Label.__init__(self, text)
self.set_alignment(0, 0.5)
self.set_use_markup(True)
self.show()
@ -192,73 +192,73 @@ class IntEdit(gtk.Entry):
class TypeCellRenderer(gtk.CellRendererCombo):
def __init__(self,values):
def __init__(self, values):
gtk.CellRendererCombo.__init__(self)
model = gtk.ListStore(str,int)
model = gtk.ListStore(str, int)
for key in values:
model.append(row=[values[key],key])
self.set_property('editable',True)
self.set_property('model',model)
self.set_property('text-column',0)
model.append(row=[values[key], key])
self.set_property('editable', True)
self.set_property('model', model)
self.set_property('text-column', 0)
class PrivacyButton:
def __init__(self,button,obj,readonly=False):
def __init__(self, button, obj, readonly=False):
self.button = button
self.button.connect('toggled',self._on_toggle)
self.button.connect('toggled', self._on_toggle)
self.tooltips = gtk.Tooltips()
self.obj = obj
self.set_active(obj.get_privacy())
self.button.set_sensitive(not readonly)
def set_sensitive(self,val):
def set_sensitive(self, val):
self.button.set_sensitive(val)
def set_active(self,val):
def set_active(self, val):
self.button.set_active(val)
self._on_toggle(self.button)
def get_active(self):
return self.button.get_active()
def _on_toggle(self,obj):
def _on_toggle(self, obj):
child = obj.child
if child:
obj.remove(child)
image = gtk.Image()
if obj.get_active():
# image.set_from_icon_name('stock_lock',gtk.ICON_SIZE_MENU)
# image.set_from_icon_name('stock_lock', gtk.ICON_SIZE_MENU)
image.set_from_file(_lock_path)
self.tooltips.set_tip(obj,_('Record is private'))
self.tooltips.set_tip(obj, _('Record is private'))
self.obj.set_privacy(True)
else:
# image.set_from_icon_name('stock_lock-open',gtk.ICON_SIZE_MENU)
# image.set_from_icon_name('stock_lock-open', gtk.ICON_SIZE_MENU)
image.set_from_file(_lock_open_path)
self.tooltips.set_tip(obj,_('Record is public'))
self.tooltips.set_tip(obj, _('Record is public'))
self.obj.set_privacy(False)
image.show()
obj.add(image)
class MonitoredCheckbox:
def __init__(self,obj,button,set_val,get_val,on_toggle=None):
def __init__(self, obj, button, set_val, get_val, on_toggle=None):
self.button = button
self.button.connect('toggled',self._on_toggle)
self.button.connect('toggled', self._on_toggle)
self.on_toggle = on_toggle
self.obj = obj
self.set_val = set_val
self.get_val = get_val
self.obj.set_active(get_val())
def _on_toggle(self,obj):
def _on_toggle(self, obj):
self.set_val(obj.get_active())
if self.on_toggle:
self.on_toggle(self.get_val())
class MonitoredEntry:
def __init__(self,obj,set_val,get_val,read_only=False,
def __init__(self, obj, set_val, get_val, read_only=False,
autolist=None, changed=None):
self.obj = obj
self.set_val = set_val
@ -273,21 +273,21 @@ class MonitoredEntry:
if autolist:
AutoComp.fill_entry(obj,autolist)
def connect(self,signal,callback):
self.obj.connect(signal,callback)
def connect(self, signal, callback):
self.obj.connect(signal, callback)
def _on_change(self,obj):
def _on_change(self, obj):
self.set_val(unicode(obj.get_text()))
if self.changed:
self.changed(obj)
def force_value(self,value):
def force_value(self, value):
self.obj.set_text(value)
def get_value(self,value):
def get_value(self, value):
return unicode(self.obj.get_text())
def enable(self,value):
def enable(self, value):
self.obj.set_sensitive(value)
self.obj.set_editable(value)
@ -300,7 +300,7 @@ class MonitoredEntry:
class MonitoredText:
def __init__(self,obj,set_val,get_val,read_only=False):
def __init__(self, obj, set_val, get_val, read_only=False):
self.buf = obj.get_buffer()
self.set_val = set_val
self.get_val = get_val
@ -310,13 +310,13 @@ class MonitoredText:
self.buf.connect('changed', self.on_change)
obj.set_editable(not read_only)
def on_change(self,obj):
s,e = self.buf.get_bounds()
self.set_val(unicode(self.buf.get_text(s,e,False)))
def on_change(self, obj):
s, e = self.buf.get_bounds()
self.set_val(unicode(self.buf.get_text(s, e, False)))
class MonitoredType:
def __init__(self,obj,set_val,get_val,mapping,custom,readonly=False,
def __init__(self, obj, set_val, get_val, mapping, custom, readonly=False,
custom_values=None):
self.set_val = set_val
self.get_val = get_val
@ -345,46 +345,46 @@ class MonitoredType:
class MonitoredMenu:
def __init__(self,obj,set_val,get_val,mapping,readonly=False,changed=None):
def __init__(self, obj, set_val, get_val, mapping, readonly=False, changed=None):
self.set_val = set_val
self.get_val = get_val
self.changed = changed
self.obj = obj
self.model = gtk.ListStore(str,int)
self.model = gtk.ListStore(str, int)
self.data = {}
index = 0
for t,v in mapping:
self.model.append(row=[t,v])
for t, v in mapping:
self.model.append(row=[t, v])
self.data[v] = index
index += 1
self.obj.set_model(self.model)
self.obj.set_active(self.data[get_val()])
self.obj.connect('changed',self.on_change)
self.obj.connect('changed', self.on_change)
self.obj.set_sensitive(not readonly)
def force(self,value):
def force(self, value):
self.obj.set_active(value)
def change_menu(self, mapping):
self.model = gtk.ListStore(str,int)
for t,v in mapping:
self.model.append(row=[t,v])
self.model = gtk.ListStore(str, int)
for t, v in mapping:
self.model.append(row=[t, v])
self.obj.set_model(self.model)
self.obj.set_active(0)
def on_change(self, obj):
print "ON CHANGE"
self.set_val(self.model.get_value(obj.get_active_iter(),1))
self.set_val(self.model.get_value(obj.get_active_iter(), 1))
if self.changed:
print "CALL"
self.changed()
class MonitoredStrMenu:
def __init__(self,obj,set_val,get_val,mapping,readonly=False):
def __init__(self, obj, set_val, get_val, mapping, readonly=False):
self.set_val = set_val
self.get_val = get_val
@ -401,16 +401,16 @@ class MonitoredStrMenu:
default = get_val()
active = 0
for t,v in mapping:
for t, v in mapping:
self.model.append(row=[v])
self.data.append(t)
if v == default:
active = index
index += 1
if t == default:
active = index
self.obj.set_model(self.model)
self.obj.set_active(active)
self.obj.connect('changed',self.on_change)
self.obj.connect('changed', self.on_change)
self.obj.set_sensitive(not readonly)
def on_change(self, obj):
@ -418,7 +418,7 @@ class MonitoredStrMenu:
class MonitoredDate:
def __init__(self,field,button,value,window, readonly=False):
def __init__(self, field, button, value, window, readonly=False):
self.date = value
self.date_check = DateEdit.DateEdit(
self.date, field, button, window)
@ -445,7 +445,7 @@ class PlaceEntry:
self.obj.set_editable(True)
store = gtk.ListStore(str)
foo = [ (locale.strxfrm(self.places[v]),v) \
foo = [ (locale.strxfrm(self.places[v]), v) \
for v in self.places.keys()]
foo.sort()
for val in foo:
@ -462,8 +462,8 @@ class PlaceEntry:
if text:
for key in self.places.keys():
if text == self.places[key]:
return (False,key)
return (True,text)
return (False, key)
return (True, text)
else:
return (False,u"")
return (False, u"")