Image thumbnails, source bug fixes
svn: r71
This commit is contained in:
@ -27,7 +27,7 @@ import const
|
|||||||
import string
|
import string
|
||||||
|
|
||||||
try:
|
try:
|
||||||
import PIL
|
import Image
|
||||||
no_pil = 0
|
no_pil = 0
|
||||||
except:
|
except:
|
||||||
no_pil = 1
|
no_pil = 1
|
||||||
@ -79,10 +79,10 @@ class AbiWordDoc(TextDoc):
|
|||||||
tag = string.replace(base,'.','_')
|
tag = string.replace(base,'.','_')
|
||||||
|
|
||||||
if no_pil:
|
if no_pil:
|
||||||
cmd = "%s -size %dx%d %s %s" % (const.convert,width,height,file,base)
|
cmd = "%s -geometry %dx%d '%s' '%s'" % (const.convert,width,height,file,base)
|
||||||
os.system(cmd)
|
os.system(cmd)
|
||||||
else:
|
else:
|
||||||
im = PIL.Image.open(file)
|
im = Image.open(file)
|
||||||
im.thumbnail((width,height))
|
im.thumbnail((width,height))
|
||||||
im.save(base,"PNG")
|
im.save(base,"PNG")
|
||||||
|
|
||||||
|
@ -2569,11 +2569,6 @@
|
|||||||
<object>editPerson</object>
|
<object>editPerson</object>
|
||||||
<last_modification_time>Sun, 10 Dec 2000 03:48:37 GMT</last_modification_time>
|
<last_modification_time>Sun, 10 Dec 2000 03:48:37 GMT</last_modification_time>
|
||||||
</signal>
|
</signal>
|
||||||
<signal>
|
|
||||||
<name>text_changed</name>
|
|
||||||
<handler>on_photolist_text_changed</handler>
|
|
||||||
<last_modification_time>Sun, 10 Dec 2000 15:12:13 GMT</last_modification_time>
|
|
||||||
</signal>
|
|
||||||
<signal>
|
<signal>
|
||||||
<name>button_press_event</name>
|
<name>button_press_event</name>
|
||||||
<handler>on_photolist_button_press_event</handler>
|
<handler>on_photolist_button_press_event</handler>
|
||||||
|
@ -79,6 +79,7 @@ class EditPerson:
|
|||||||
self.surname_list = surname_list
|
self.surname_list = surname_list
|
||||||
self.callback = callback
|
self.callback = callback
|
||||||
self.path = db.getSavePath()
|
self.path = db.getSavePath()
|
||||||
|
self.not_loaded = 1
|
||||||
|
|
||||||
self.top_window = libglade.GladeXML(const.editPersonFile, "editPerson")
|
self.top_window = libglade.GladeXML(const.editPersonFile, "editPerson")
|
||||||
|
|
||||||
@ -123,7 +124,6 @@ class EditPerson:
|
|||||||
self.is_female = self.get_widget("genderFemale")
|
self.is_female = self.get_widget("genderFemale")
|
||||||
|
|
||||||
self.selectedIcon = -1
|
self.selectedIcon = -1
|
||||||
self.currentImages = []
|
|
||||||
|
|
||||||
self.top_window.signal_autoconnect({
|
self.top_window.signal_autoconnect({
|
||||||
"on_eventAddBtn_clicked" : on_event_add_clicked,
|
"on_eventAddBtn_clicked" : on_event_add_clicked,
|
||||||
@ -210,7 +210,10 @@ class EditPerson:
|
|||||||
# load photos into the photo window
|
# load photos into the photo window
|
||||||
photo_list = person.getPhotoList()
|
photo_list = person.getPhotoList()
|
||||||
if len(photo_list) != 0:
|
if len(photo_list) != 0:
|
||||||
self.load_photo(photo_list[0].getPath())
|
thumb = self.db.getSavePath() + os.sep + ".thumb" + \
|
||||||
|
os.sep + "i%d.jpg" % self.person.getId()
|
||||||
|
RelImage.check_thumb(photo_list[0].getPath(),thumb,const.picWidth)
|
||||||
|
self.load_photo(thumb)
|
||||||
|
|
||||||
# set notes data
|
# set notes data
|
||||||
self.notes_field.set_point(0)
|
self.notes_field.set_point(0)
|
||||||
@ -386,33 +389,27 @@ class EditPerson:
|
|||||||
|
|
||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
#
|
#
|
||||||
# add_thumbnail - Scale the image and add it to the IconList. Currently,
|
# add_thumbnail - Scale the image and add it to the IconList.
|
||||||
# there seems to be a problem with either GdkImlib. A reference has to be
|
|
||||||
# kept to the image, or it gets lost. This is supposed to be a known
|
|
||||||
# imlib problem
|
|
||||||
#
|
#
|
||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
def add_thumbnail(self,photo):
|
def add_thumbnail(self,photo):
|
||||||
|
src = photo.getPath()
|
||||||
|
thumb = self.db.getSavePath() + os.sep + ".thumb" + os.sep + \
|
||||||
|
os.path.basename(src)
|
||||||
|
|
||||||
image2 = RelImage.scale_image(photo.getPath(),const.thumbScale)
|
RelImage.check_thumb(src,thumb,const.thumbScale)
|
||||||
|
|
||||||
self.currentImages.append(image2)
|
self.photo_list.append(thumb,photo.getDescription())
|
||||||
self.photo_list.append_imlib(image2,photo.getDescription())
|
|
||||||
|
|
||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
#
|
#
|
||||||
# load_images - clears the currentImages list to free up any cached
|
# load_images - add each photo in the person's list of photos to the
|
||||||
# Imlibs. Then add each photo in the person's list of photos to the
|
|
||||||
# photolist window.
|
# photolist window.
|
||||||
#
|
#
|
||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
def load_images(self):
|
def load_images(self):
|
||||||
|
|
||||||
if len(self.person.getPhotoList()) == 0:
|
if len(self.person.getPhotoList()) == 0:
|
||||||
return
|
return
|
||||||
|
|
||||||
self.currentImages = []
|
|
||||||
|
|
||||||
self.photo_list.freeze()
|
self.photo_list.freeze()
|
||||||
self.photo_list.clear()
|
self.photo_list.clear()
|
||||||
for photo in self.person.getPhotoList():
|
for photo in self.person.getPhotoList():
|
||||||
@ -427,8 +424,7 @@ class EditPerson:
|
|||||||
#
|
#
|
||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
def load_photo(self,photo):
|
def load_photo(self,photo):
|
||||||
image2 = RelImage.scale_image(photo,const.picWidth)
|
self.get_widget("personPix").load_file(photo)
|
||||||
self.get_widget("personPix").load_imlib(image2)
|
|
||||||
|
|
||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
#
|
#
|
||||||
@ -840,8 +836,10 @@ def on_event_select_row(obj,row,b,c):
|
|||||||
#
|
#
|
||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
def on_switch_page(obj,a,page):
|
def on_switch_page(obj,a,page):
|
||||||
if page == 6:
|
edit_obj = obj.get_data(EDITPERSON)
|
||||||
obj.get_data(EDITPERSON).load_images()
|
if page == 6 and edit_obj.not_loaded:
|
||||||
|
edit_obj.not_loaded = 0
|
||||||
|
edit_obj.load_images()
|
||||||
|
|
||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
#
|
#
|
||||||
@ -884,7 +882,12 @@ def on_primary_photo_clicked(obj):
|
|||||||
photolist[selectedIcon-i] = photolist[selectedIcon-i-1]
|
photolist[selectedIcon-i] = photolist[selectedIcon-i-1]
|
||||||
photolist[0] = savePhoto
|
photolist[0] = savePhoto
|
||||||
edit_person_obj.load_images()
|
edit_person_obj.load_images()
|
||||||
edit_person_obj.load_photo(savePhoto)
|
|
||||||
|
thumb = edit_person_obj.db.getSavePath() + os.sep + ".thumb" + os.sep + \
|
||||||
|
"i%d" % edit_person_obj.person.getId()
|
||||||
|
|
||||||
|
mk_thumb(savePhoto,thumb,const.picWidth)
|
||||||
|
edit_person_obj.load_photo(thumb)
|
||||||
utils.modified()
|
utils.modified()
|
||||||
|
|
||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
|
@ -53,18 +53,29 @@ import RelImage
|
|||||||
|
|
||||||
_ = intl.gettext
|
_ = intl.gettext
|
||||||
|
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
#
|
||||||
|
# Constants
|
||||||
|
#
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
INDEX = "i"
|
||||||
|
SOURCE = "s"
|
||||||
|
|
||||||
class EditSource:
|
class EditSource:
|
||||||
|
|
||||||
def __init__(self,source,db,func):
|
def __init__(self,source,db,func):
|
||||||
self.source = source
|
self.source = source
|
||||||
self.db = db
|
self.db = db
|
||||||
self.callback = func
|
self.callback = func
|
||||||
|
self.path = db.getSavePath()
|
||||||
|
self.not_loaded = 1
|
||||||
|
|
||||||
|
self.selectedIcon = -1
|
||||||
|
self.currentImages = []
|
||||||
self.top_window = libglade.GladeXML(const.gladeFile,"sourceEditor")
|
self.top_window = libglade.GladeXML(const.gladeFile,"sourceEditor")
|
||||||
self.title = self.top_window.get_widget("source_title")
|
self.title = self.top_window.get_widget("source_title")
|
||||||
self.author = self.top_window.get_widget("author")
|
self.author = self.top_window.get_widget("author")
|
||||||
self.pubinfo = self.top_window.get_widget("pubinfo")
|
self.pubinfo = self.top_window.get_widget("pubinfo")
|
||||||
self.pubinfo = self.top_window.get_widget("pubinfo")
|
|
||||||
self.note = self.top_window.get_widget("source_note")
|
self.note = self.top_window.get_widget("source_note")
|
||||||
|
|
||||||
self.title.set_text(source.getTitle())
|
self.title.set_text(source.getTitle())
|
||||||
@ -75,17 +86,63 @@ class EditSource:
|
|||||||
self.note.insert_defaults(source.getNote())
|
self.note.insert_defaults(source.getNote())
|
||||||
self.note.set_word_wrap(1)
|
self.note.set_word_wrap(1)
|
||||||
|
|
||||||
|
self.photo_list = self.top_window.get_widget("photolist")
|
||||||
|
|
||||||
self.top_window.signal_autoconnect({
|
self.top_window.signal_autoconnect({
|
||||||
"destroy_passed_object" : utils.destroy_passed_object,
|
"destroy_passed_object" : utils.destroy_passed_object,
|
||||||
|
"on_photolist_select_icon" : on_photo_select_icon,
|
||||||
|
"on_photolist_button_press_event" : on_photolist_button_press_event,
|
||||||
|
"on_switch_page" : on_switch_page,
|
||||||
|
"on_addphoto_clicked" : on_add_photo_clicked,
|
||||||
|
"on_deletephoto_clicked" : on_delete_photo_clicked,
|
||||||
"on_sourceapply_clicked" : on_source_apply_clicked
|
"on_sourceapply_clicked" : on_source_apply_clicked
|
||||||
})
|
})
|
||||||
|
|
||||||
self.top = self.top_window.get_widget("sourceEditor")
|
self.top = self.top_window.get_widget("sourceEditor")
|
||||||
self.top.set_data("o",self)
|
self.top.set_data(SOURCE,self)
|
||||||
|
|
||||||
|
if self.source.getId() == -1:
|
||||||
|
self.top_window.get_widget("add_photo").set_sensitive(0)
|
||||||
|
self.top_window.get_widget("delete_photo").set_sensitive(0)
|
||||||
|
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
#
|
||||||
|
# add_thumbnail - Scale the image and add it to the IconList.
|
||||||
|
#
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
def add_thumbnail(self,photo):
|
||||||
|
src = photo.getPath()
|
||||||
|
thumb = self.db.getSavePath() + os.sep + ".thumb" + os.sep + \
|
||||||
|
os.path.basename(src)
|
||||||
|
|
||||||
|
RelImage.check_thumb(src,thumb,const.thumbScale)
|
||||||
|
|
||||||
|
self.photo_list.append(thumb,photo.getDescription())
|
||||||
|
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
#
|
||||||
|
# load_images - clears the currentImages list to free up any cached
|
||||||
|
# Imlibs. Then add each photo in the source's list of photos to the
|
||||||
|
# photolist window.
|
||||||
|
#
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
def load_images(self):
|
||||||
|
if len(self.source.getPhotoList()) == 0:
|
||||||
|
return
|
||||||
|
self.photo_list.freeze()
|
||||||
|
self.photo_list.clear()
|
||||||
|
for photo in self.source.getPhotoList():
|
||||||
|
self.add_thumbnail(photo)
|
||||||
|
self.photo_list.thaw()
|
||||||
|
|
||||||
|
#-----------------------------------------------------------------------------
|
||||||
|
#
|
||||||
|
#
|
||||||
|
#
|
||||||
|
#-----------------------------------------------------------------------------
|
||||||
def on_source_apply_clicked(obj):
|
def on_source_apply_clicked(obj):
|
||||||
|
|
||||||
edit = obj.get_data("o")
|
edit = obj.get_data(SOURCE)
|
||||||
title = edit.title.get_text()
|
title = edit.title.get_text()
|
||||||
author = edit.author.get_text()
|
author = edit.author.get_text()
|
||||||
pubinfo = edit.pubinfo.get_text()
|
pubinfo = edit.pubinfo.get_text()
|
||||||
@ -100,7 +157,7 @@ def on_source_apply_clicked(obj):
|
|||||||
utils.modified()
|
utils.modified()
|
||||||
|
|
||||||
if pubinfo != edit.source.getPubInfo():
|
if pubinfo != edit.source.getPubInfo():
|
||||||
edit.source.sePubInfo(pubinfo)
|
edit.source.setPubInfo(pubinfo)
|
||||||
utils.modified()
|
utils.modified()
|
||||||
|
|
||||||
if note != edit.source.getNote():
|
if note != edit.source.getNote():
|
||||||
@ -110,4 +167,222 @@ def on_source_apply_clicked(obj):
|
|||||||
utils.destroy_passed_object(edit.top)
|
utils.destroy_passed_object(edit.top)
|
||||||
edit.callback(edit.source)
|
edit.callback(edit.source)
|
||||||
|
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
#
|
||||||
|
#
|
||||||
|
#
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
def on_switch_page(obj,a,page):
|
||||||
|
src = obj.get_data(SOURCE)
|
||||||
|
if page == 2 and src.not_loaded:
|
||||||
|
src.not_loaded = 0
|
||||||
|
src.load_images()
|
||||||
|
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
#
|
||||||
|
#
|
||||||
|
#
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
def on_photo_select_icon(obj,iconNumber,event):
|
||||||
|
obj.get_data(SOURCE).selectedIcon = iconNumber
|
||||||
|
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
#
|
||||||
|
#
|
||||||
|
#
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
def on_delete_photo_clicked(obj):
|
||||||
|
edit_source_obj = obj.get_data(SOURCE)
|
||||||
|
icon = edit_source_obj.selectedIcon
|
||||||
|
|
||||||
|
if icon == -1:
|
||||||
|
return
|
||||||
|
|
||||||
|
photolist = edit_source_obj.source.getPhotoList()
|
||||||
|
edit_source_obj.photo_list.remove(icon)
|
||||||
|
del photolist[edit_source_obj.selectedIcon]
|
||||||
|
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
#
|
||||||
|
#
|
||||||
|
#
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
def on_add_photo_clicked(obj):
|
||||||
|
|
||||||
|
edit_source = obj.get_data(SOURCE)
|
||||||
|
|
||||||
|
image_select = libglade.GladeXML(const.imageselFile,"imageSelect")
|
||||||
|
|
||||||
|
edit_source.isel = image_select
|
||||||
|
|
||||||
|
image_select.signal_autoconnect({
|
||||||
|
"on_savephoto_clicked" : on_savephoto_clicked,
|
||||||
|
"on_name_changed" : on_name_changed,
|
||||||
|
"destroy_passed_object" : utils.destroy_passed_object
|
||||||
|
})
|
||||||
|
|
||||||
|
edit_source.fname = image_select.get_widget("fname")
|
||||||
|
edit_source.add_image = image_select.get_widget("image")
|
||||||
|
edit_source.external = image_select.get_widget("private")
|
||||||
|
image_select.get_widget("imageSelect").set_data(SOURCE,edit_source)
|
||||||
|
image_select.get_widget("imageSelect").show()
|
||||||
|
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
#
|
||||||
|
#
|
||||||
|
#
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
def on_savephoto_clicked(obj):
|
||||||
|
edit_source_obj = obj.get_data(SOURCE)
|
||||||
|
image_select = edit_source_obj.isel
|
||||||
|
|
||||||
|
filename = image_select.get_widget("photosel").get_full_path(0)
|
||||||
|
description = image_select.get_widget("photoDescription").get_text()
|
||||||
|
|
||||||
|
if os.path.exists(filename) == 0:
|
||||||
|
return
|
||||||
|
|
||||||
|
prefix = "s" + str(edit_source_obj.source.getId())
|
||||||
|
if edit_source_obj.external.get_active() == 1:
|
||||||
|
if os.path.isfile(filename):
|
||||||
|
name = filename
|
||||||
|
else:
|
||||||
|
return
|
||||||
|
else:
|
||||||
|
name = RelImage.import_photo(filename,edit_source_obj.path,prefix)
|
||||||
|
if name == None:
|
||||||
|
return
|
||||||
|
|
||||||
|
photo = Photo()
|
||||||
|
photo.setPath(name)
|
||||||
|
photo.setDescription(description)
|
||||||
|
|
||||||
|
edit_source_obj.source.addPhoto(photo)
|
||||||
|
edit_source_obj.add_thumbnail(photo)
|
||||||
|
|
||||||
|
utils.modified()
|
||||||
|
utils.destroy_passed_object(obj)
|
||||||
|
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
#
|
||||||
|
#
|
||||||
|
#
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
def on_photolist_button_press_event(obj,event):
|
||||||
|
|
||||||
|
myobj = obj.get_data(SOURCE)
|
||||||
|
icon = myobj.selectedIcon
|
||||||
|
if icon == -1:
|
||||||
|
return
|
||||||
|
|
||||||
|
if event.button == 3:
|
||||||
|
photo = myobj.source.getPhotoList()[icon]
|
||||||
|
menu = GtkMenu()
|
||||||
|
item = GtkTearoffMenuItem()
|
||||||
|
item.show()
|
||||||
|
view = GtkMenuItem(_("View Photo"))
|
||||||
|
view.set_data("m",myobj)
|
||||||
|
view.connect("activate",on_view_photo)
|
||||||
|
view.show()
|
||||||
|
edit = GtkMenuItem(_("Edit Photo"))
|
||||||
|
edit.set_data("m",myobj)
|
||||||
|
edit.connect("activate",on_edit_photo)
|
||||||
|
edit.show()
|
||||||
|
change = GtkMenuItem(_("Edit Description"))
|
||||||
|
change.set_data("m",myobj)
|
||||||
|
change.connect("activate",on_change_description)
|
||||||
|
change.show()
|
||||||
|
menu.append(item)
|
||||||
|
menu.append(view)
|
||||||
|
menu.append(edit)
|
||||||
|
menu.append(change)
|
||||||
|
if photo.getPrivate() == 0:
|
||||||
|
private = GtkMenuItem(_("Convert to private copy"))
|
||||||
|
private.set_data("m",myobj)
|
||||||
|
private.connect("activate",on_convert_to_private)
|
||||||
|
private.show()
|
||||||
|
menu.append(private)
|
||||||
|
menu.popup(None,None,None,0,0)
|
||||||
|
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
#
|
||||||
|
#
|
||||||
|
#
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
def on_convert_to_private(obj):
|
||||||
|
edit_source_obj = obj.get_data("m")
|
||||||
|
photo = edit_source_obj.source.getPhotoList()[edit_source_obj.selectedIcon]
|
||||||
|
|
||||||
|
prefix = "i" + str(edit_source_obj.source.getId())
|
||||||
|
name = RelImage.import_photo(photo.getPath(),edit_source_obj.path,prefix)
|
||||||
|
|
||||||
|
photo.setPath(name)
|
||||||
|
photo.setPrivate(1)
|
||||||
|
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
#
|
||||||
|
#
|
||||||
|
#
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
def on_view_photo(obj):
|
||||||
|
myobj = obj.get_data("m")
|
||||||
|
photo = myobj.source.getPhotoList()[myobj.selectedIcon]
|
||||||
|
type = gnome.mime.type(photo.getPath())
|
||||||
|
|
||||||
|
prog = string.split(gnome.mime.get_value(type,'view'))
|
||||||
|
args = []
|
||||||
|
for val in prog:
|
||||||
|
if val == "%f":
|
||||||
|
args.append(photo.getPath())
|
||||||
|
else:
|
||||||
|
args.append(val)
|
||||||
|
|
||||||
|
if os.fork() == 0:
|
||||||
|
os.execvp(args[0],args)
|
||||||
|
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
#
|
||||||
|
#
|
||||||
|
#
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
def on_edit_photo(obj):
|
||||||
|
myobj = obj.get_data("m")
|
||||||
|
photo = myobj.source.getPhotoList()[myobj.selectedIcon]
|
||||||
|
if os.fork() == 0:
|
||||||
|
os.execvp(const.editor,[const.editor, photo.getPath()])
|
||||||
|
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
#
|
||||||
|
#
|
||||||
|
#
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
def on_change_description(obj):
|
||||||
|
myobj = obj.get_data("m")
|
||||||
|
photo = myobj.source.getPhotoList()[myobj.selectedIcon]
|
||||||
|
window = libglade.GladeXML(const.imageselFile,"dialog1")
|
||||||
|
|
||||||
|
text = window.get_widget("text")
|
||||||
|
text.set_text(photo.getDescription())
|
||||||
|
|
||||||
|
image2 = RelImage.scale_image(photo.getPath(),200.0)
|
||||||
|
window.get_widget("photo").load_imlib(image2)
|
||||||
|
window.get_widget("dialog1").set_data("p",photo)
|
||||||
|
window.get_widget("dialog1").set_data("t",text)
|
||||||
|
window.get_widget("dialog1").set_data("m",obj.get_data("m"))
|
||||||
|
window.signal_autoconnect({
|
||||||
|
"on_cancel_clicked" : utils.destroy_passed_object,
|
||||||
|
"on_ok_clicked" : on_ok_clicked,
|
||||||
|
"on_apply_clicked" : on_apply_clicked
|
||||||
|
})
|
||||||
|
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
#
|
||||||
|
#
|
||||||
|
#
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
def on_name_changed(obj):
|
||||||
|
edit_person = obj.get_data(SOURCE)
|
||||||
|
file = edit_person.fname.get_text()
|
||||||
|
if os.path.isfile(file):
|
||||||
|
image = RelImage.scale_image(file,const.thumbScale)
|
||||||
|
edit_person.add_image.load_imlib(image)
|
||||||
|
@ -69,6 +69,7 @@ class GrampsParser(handler.ContentHandler):
|
|||||||
self.scomments_list = []
|
self.scomments_list = []
|
||||||
self.note_list = []
|
self.note_list = []
|
||||||
|
|
||||||
|
self.use_p = 0
|
||||||
self.in_note = 0
|
self.in_note = 0
|
||||||
self.in_attribute = 0
|
self.in_attribute = 0
|
||||||
self.in_old_attr = 0
|
self.in_old_attr = 0
|
||||||
@ -398,6 +399,8 @@ class GrampsParser(handler.ContentHandler):
|
|||||||
photo.setPrivate(0)
|
photo.setPrivate(0)
|
||||||
if self.in_family == 1:
|
if self.in_family == 1:
|
||||||
self.family.addPhoto(photo)
|
self.family.addPhoto(photo)
|
||||||
|
if self.in_source == 1:
|
||||||
|
self.source.addPhoto(photo)
|
||||||
else:
|
else:
|
||||||
self.person.addPhoto(photo)
|
self.person.addPhoto(photo)
|
||||||
|
|
||||||
@ -609,7 +612,12 @@ class GrampsParser(handler.ContentHandler):
|
|||||||
#
|
#
|
||||||
#---------------------------------------------------------------------
|
#---------------------------------------------------------------------
|
||||||
def stop_stext(self,tag):
|
def stop_stext(self,tag):
|
||||||
self.source_ref.setText(fix_spaces(tag))
|
if self.use_p:
|
||||||
|
self.use_p = 0
|
||||||
|
note = fix_spaces(self.stext_list)
|
||||||
|
else:
|
||||||
|
note = tag
|
||||||
|
self.source_ref.setText(note)
|
||||||
|
|
||||||
#---------------------------------------------------------------------
|
#---------------------------------------------------------------------
|
||||||
#
|
#
|
||||||
@ -617,7 +625,12 @@ class GrampsParser(handler.ContentHandler):
|
|||||||
#
|
#
|
||||||
#---------------------------------------------------------------------
|
#---------------------------------------------------------------------
|
||||||
def stop_scomments(self,tag):
|
def stop_scomments(self,tag):
|
||||||
self.source_ref.setComments(fix_spaces(self.scomments_list))
|
if self.use_p:
|
||||||
|
self.use_p = 0
|
||||||
|
note = fix_spaces(self.scomments_list)
|
||||||
|
else:
|
||||||
|
note = tag
|
||||||
|
self.source_ref.setComments(note)
|
||||||
|
|
||||||
#---------------------------------------------------------------------
|
#---------------------------------------------------------------------
|
||||||
#
|
#
|
||||||
@ -658,16 +671,23 @@ class GrampsParser(handler.ContentHandler):
|
|||||||
#---------------------------------------------------------------------
|
#---------------------------------------------------------------------
|
||||||
def stop_note(self,tag):
|
def stop_note(self,tag):
|
||||||
self.in_note = 0
|
self.in_note = 0
|
||||||
|
if self.use_p:
|
||||||
|
self.use_p = 0
|
||||||
|
note = fix_spaces(self.note_list)
|
||||||
|
else:
|
||||||
|
note = tag
|
||||||
if self.in_address == 1:
|
if self.in_address == 1:
|
||||||
self.address.setNote(fix_spaces(self.note_list))
|
self.address.setNote(note)
|
||||||
elif self.in_source_ref == 1:
|
if self.in_attribute == 1:
|
||||||
self.source_ref.setNote(fix_spaces(self.note_list))
|
self.attribute.setNote(note)
|
||||||
|
elif self.in_source == 1:
|
||||||
|
self.source.setNote(note)
|
||||||
elif self.in_event == 1:
|
elif self.in_event == 1:
|
||||||
self.event.setNote(fix_spaces(self.note_list))
|
self.event.setNote(note)
|
||||||
elif self.in_people == 1:
|
elif self.in_people == 1:
|
||||||
self.person.setNote(fix_spaces(self.note_list))
|
self.person.setNote(note)
|
||||||
elif self.in_family == 1:
|
elif self.in_family == 1:
|
||||||
self.family.setNote(fix_spaces(self.note_list))
|
self.family.setNote(note)
|
||||||
self.note_list = []
|
self.note_list = []
|
||||||
|
|
||||||
#---------------------------------------------------------------------
|
#---------------------------------------------------------------------
|
||||||
@ -749,6 +769,7 @@ class GrampsParser(handler.ContentHandler):
|
|||||||
#
|
#
|
||||||
#---------------------------------------------------------------------
|
#---------------------------------------------------------------------
|
||||||
def stop_ptag(self,tag):
|
def stop_ptag(self,tag):
|
||||||
|
self.use_p = 1
|
||||||
if self.in_note:
|
if self.in_note:
|
||||||
self.note_list.append(tag)
|
self.note_list.append(tag)
|
||||||
elif self.in_stext:
|
elif self.in_stext:
|
||||||
|
@ -70,7 +70,6 @@ class Marriage:
|
|||||||
self.path = db.getSavePath()
|
self.path = db.getSavePath()
|
||||||
|
|
||||||
self.selectedIcon = 0
|
self.selectedIcon = 0
|
||||||
self.currentImages = []
|
|
||||||
|
|
||||||
self.top = libglade.GladeXML(const.marriageFile,"marriageEditor")
|
self.top = libglade.GladeXML(const.marriageFile,"marriageEditor")
|
||||||
self.top.signal_autoconnect({
|
self.top.signal_autoconnect({
|
||||||
@ -149,10 +148,13 @@ class Marriage:
|
|||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
def add_thumbnail(self,photo):
|
def add_thumbnail(self,photo):
|
||||||
|
|
||||||
image2 = RelImage.scale_image(photo.getPath(),const.thumbScale)
|
src = photo.getPath()
|
||||||
|
thumb = self.db.getSavePath() + os.sep + ".thumb" + os.sep + \
|
||||||
|
os.path.basename(src)
|
||||||
|
|
||||||
self.currentImages.append(image2)
|
RelImage.check_thumb(src,thumb,const.thumbScale)
|
||||||
self.photo_list.append_imlib(image2,photo.getDescription())
|
|
||||||
|
self.photo_list.append(thumb,photo.getDescription())
|
||||||
|
|
||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
#
|
#
|
||||||
@ -165,9 +167,6 @@ class Marriage:
|
|||||||
|
|
||||||
if len(self.family.getPhotoList()) == 0:
|
if len(self.family.getPhotoList()) == 0:
|
||||||
return
|
return
|
||||||
|
|
||||||
self.currentImages = []
|
|
||||||
|
|
||||||
self.photo_list.freeze()
|
self.photo_list.freeze()
|
||||||
self.photo_list.clear()
|
self.photo_list.clear()
|
||||||
for photo in self.family.getPhotoList():
|
for photo in self.family.getPhotoList():
|
||||||
|
@ -27,7 +27,7 @@ from latin_utf8 import latin_to_utf8
|
|||||||
import const
|
import const
|
||||||
|
|
||||||
try:
|
try:
|
||||||
import PIL
|
import Image
|
||||||
no_pil = 0
|
no_pil = 0
|
||||||
except:
|
except:
|
||||||
no_pil = 1
|
no_pil = 1
|
||||||
@ -425,10 +425,10 @@ class OpenOfficeDoc(TextDoc):
|
|||||||
base = os.path.basename(file)
|
base = os.path.basename(file)
|
||||||
image_name = self.tempdir + os.sep + "Pictures" + os.sep + base
|
image_name = self.tempdir + os.sep + "Pictures" + os.sep + base
|
||||||
if no_pil:
|
if no_pil:
|
||||||
cmd = "%s -size %dx%d '%s' '%s'" % (const.convert,width,height,file,image_name)
|
cmd = "%s -geometry %dx%d '%s' '%s'" % (const.convert,width,height,file,image_name)
|
||||||
os.system(cmd)
|
os.system(cmd)
|
||||||
else:
|
else:
|
||||||
im = PIL.Image.open(file)
|
im = Image.open(file)
|
||||||
im.thumbnail((width,height))
|
im.thumbnail((width,height))
|
||||||
im.save(name,"JPEG")
|
im.save(name,"JPEG")
|
||||||
|
|
||||||
|
@ -30,7 +30,7 @@ import reportlab.lib.styles
|
|||||||
from latin_utf8 import latin_to_utf8
|
from latin_utf8 import latin_to_utf8
|
||||||
|
|
||||||
try:
|
try:
|
||||||
import PIL.Image
|
import Image
|
||||||
no_pil = 0
|
no_pil = 0
|
||||||
except:
|
except:
|
||||||
no_pil = 1
|
no_pil = 1
|
||||||
@ -215,7 +215,7 @@ class PdfDoc(TextDoc):
|
|||||||
|
|
||||||
def add_photo(self,name,x,y):
|
def add_photo(self,name,x,y):
|
||||||
if no_pil == 0:
|
if no_pil == 0:
|
||||||
im = PIL.Image.open(name)
|
im = Image.open(name)
|
||||||
|
|
||||||
nx,ny = im.size
|
nx,ny = im.size
|
||||||
scale = float(y)/float(nx)
|
scale = float(y)/float(nx)
|
||||||
|
@ -31,7 +31,7 @@ from gnome.ui import *
|
|||||||
_ = intl.gettext
|
_ = intl.gettext
|
||||||
|
|
||||||
try:
|
try:
|
||||||
import PIL.Image
|
import Image
|
||||||
no_pil = 0
|
no_pil = 0
|
||||||
except:
|
except:
|
||||||
no_pil = 1
|
no_pil = 1
|
||||||
@ -56,7 +56,15 @@ def import_photo(filename,path,prefix):
|
|||||||
if os.path.exists(name) == 0:
|
if os.path.exists(name) == 0:
|
||||||
break
|
break
|
||||||
|
|
||||||
|
thumb = path+os.sep+".thumb"
|
||||||
|
if not os.path.exists(thumb):
|
||||||
|
os.mkdir(thumb)
|
||||||
|
|
||||||
try:
|
try:
|
||||||
|
path = thumb + os.sep + base
|
||||||
|
|
||||||
|
mk_thumb(filename,path,const.thumbScale)
|
||||||
|
|
||||||
if type == "image/jpeg":
|
if type == "image/jpeg":
|
||||||
shutil.copy(filename,name)
|
shutil.copy(filename,name)
|
||||||
else:
|
else:
|
||||||
@ -64,7 +72,7 @@ def import_photo(filename,path,prefix):
|
|||||||
cmd = "%s '%s' '%s'" % (const.convert,filename,name)
|
cmd = "%s '%s' '%s'" % (const.convert,filename,name)
|
||||||
os.system(cmd)
|
os.system(cmd)
|
||||||
else:
|
else:
|
||||||
PIL.Image.open(filename).save(name)
|
Image.open(filename).save(name)
|
||||||
except:
|
except:
|
||||||
return None
|
return None
|
||||||
|
|
||||||
@ -91,4 +99,38 @@ def scale_image(path,size):
|
|||||||
image2 = image1.clone_scaled_image(int(scale*width), int(scale*height))
|
image2 = image1.clone_scaled_image(int(scale*width), int(scale*height))
|
||||||
return image2
|
return image2
|
||||||
|
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
#
|
||||||
|
# scale_image
|
||||||
|
#
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
def mk_thumb(source,dest,size):
|
||||||
|
|
||||||
|
dir = os.path.dirname(dest)
|
||||||
|
if not os.path.exists(dir):
|
||||||
|
os.mkdir(dir)
|
||||||
|
|
||||||
|
if no_pil:
|
||||||
|
cmd = "%s -geometry %dx%d '%s' '%s'" % (const.convert,size,size,source,dest)
|
||||||
|
print cmd
|
||||||
|
os.system(cmd)
|
||||||
|
else:
|
||||||
|
im = Image.open(source)
|
||||||
|
im.thumbnail((size,size))
|
||||||
|
im.save(dest,"JPEG")
|
||||||
|
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
#
|
||||||
|
# scale_image
|
||||||
|
#
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
def check_thumb(source,dest,size):
|
||||||
|
if not os.path.isfile(source):
|
||||||
|
return
|
||||||
|
if not os.path.isfile(dest):
|
||||||
|
mk_thumb(source,dest,size)
|
||||||
|
elif os.path.getmtime(source) > os.path.getmtime(dest):
|
||||||
|
mk_thumb(source,dest,size)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -620,6 +620,8 @@ class Source:
|
|||||||
self.pubinfo = ""
|
self.pubinfo = ""
|
||||||
self.callno = ""
|
self.callno = ""
|
||||||
self.note = Note()
|
self.note = Note()
|
||||||
|
self.photoList = []
|
||||||
|
self.id = -1
|
||||||
|
|
||||||
def setId(self,newId):
|
def setId(self,newId):
|
||||||
self.id = newId
|
self.id = newId
|
||||||
@ -627,6 +629,12 @@ class Source:
|
|||||||
def getId(self):
|
def getId(self):
|
||||||
return self.id
|
return self.id
|
||||||
|
|
||||||
|
def addPhoto(self,photo):
|
||||||
|
self.photoList.append(photo)
|
||||||
|
|
||||||
|
def getPhotoList(self):
|
||||||
|
return self.photoList
|
||||||
|
|
||||||
def setTitle(self,title):
|
def setTitle(self,title):
|
||||||
self.title = title
|
self.title = title
|
||||||
|
|
||||||
|
@ -106,7 +106,11 @@ class SourceEditor:
|
|||||||
typeMenu.append(menuitem)
|
typeMenu.append(menuitem)
|
||||||
index = 1
|
index = 1
|
||||||
save = 0
|
save = 0
|
||||||
|
if self.source_ref:
|
||||||
self.base = self.source_ref.getBase()
|
self.base = self.source_ref.getBase()
|
||||||
|
else:
|
||||||
|
self.base = None
|
||||||
|
|
||||||
for src in self.db.getSourceMap().values():
|
for src in self.db.getSourceMap().values():
|
||||||
if src == self.base:
|
if src == self.base:
|
||||||
save = index
|
save = index
|
||||||
@ -155,6 +159,10 @@ def on_sourceok_clicked(obj):
|
|||||||
src_edit = obj.get_data(SOURCEDISP)
|
src_edit = obj.get_data(SOURCEDISP)
|
||||||
|
|
||||||
current_source_ref = src_edit.active_entry.getSourceRef()
|
current_source_ref = src_edit.active_entry.getSourceRef()
|
||||||
|
if current_source_ref == None:
|
||||||
|
current_source_ref = SourceRef()
|
||||||
|
src_edit.active_entry.setSourceRef(current_source_ref)
|
||||||
|
|
||||||
if src_edit.active_source != current_source_ref.getBase():
|
if src_edit.active_source != current_source_ref.getBase():
|
||||||
src_edit.active_entry.getSourceRef().setBase(src_edit.active_source)
|
src_edit.active_entry.getSourceRef().setBase(src_edit.active_source)
|
||||||
utils.modified()
|
utils.modified()
|
||||||
|
@ -62,11 +62,8 @@ def fix(line):
|
|||||||
def writeNote(g,val,note):
|
def writeNote(g,val,note):
|
||||||
if not note:
|
if not note:
|
||||||
return
|
return
|
||||||
g.write("<" + val + ">\n")
|
g.write("<" + val + ">")
|
||||||
textlines = string.split(note[:-1],'\n')
|
g.write(fix(note))
|
||||||
|
|
||||||
for line in textlines:
|
|
||||||
g.write("<p>" + fix(line) + "</p>\n")
|
|
||||||
g.write("</" + val + ">\n")
|
g.write("</" + val + ">\n")
|
||||||
|
|
||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
@ -90,7 +87,7 @@ def dump_my_event(g,name,event):
|
|||||||
date = event.getSaveDate()
|
date = event.getSaveDate()
|
||||||
place = event.getPlace()
|
place = event.getPlace()
|
||||||
description = event.getDescription()
|
description = event.getDescription()
|
||||||
if not date and not place and not description:
|
if not name and not date and not place and not description:
|
||||||
return
|
return
|
||||||
|
|
||||||
g.write("<event type=\"" + fix(name) + "\">\n")
|
g.write("<event type=\"" + fix(name) + "\">\n")
|
||||||
@ -123,7 +120,7 @@ def dump_source_ref(g,source_ref):
|
|||||||
write_line(g,"spage",p)
|
write_line(g,"spage",p)
|
||||||
writeNote(g,"scomments",c)
|
writeNote(g,"scomments",c)
|
||||||
writeNote(g,"stext",t)
|
writeNote(g,"stext",t)
|
||||||
write_line(g,"sdate",c)
|
write_line(g,"sdate",d)
|
||||||
g.write("</sourceref>\n")
|
g.write("</sourceref>\n")
|
||||||
|
|
||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
@ -283,7 +280,7 @@ def exportData(database, filename, callback):
|
|||||||
g.write("<attributes>\n")
|
g.write("<attributes>\n")
|
||||||
for attr in person.getAttributeList():
|
for attr in person.getAttributeList():
|
||||||
if attr.getSourceRef() or attr.getNote():
|
if attr.getSourceRef() or attr.getNote():
|
||||||
g.write('<attribute>')
|
g.write('<attribute>\n')
|
||||||
write_line(g,"attr_type",attr.getType())
|
write_line(g,"attr_type",attr.getType())
|
||||||
write_line(g,"attr_value",attr.getValue())
|
write_line(g,"attr_value",attr.getValue())
|
||||||
dump_source_ref(g,attr.getSourceRef())
|
dump_source_ref(g,attr.getSourceRef())
|
||||||
@ -358,6 +355,12 @@ def exportData(database, filename, callback):
|
|||||||
write_line(g,"scallno",source.getCallNumber())
|
write_line(g,"scallno",source.getCallNumber())
|
||||||
if source.getNote() != "":
|
if source.getNote() != "":
|
||||||
writeNote(g,"note",source.getNote())
|
writeNote(g,"note",source.getNote())
|
||||||
|
for photo in source.getPhotoList():
|
||||||
|
path = photo.getPath()
|
||||||
|
if os.path.dirname(path) == fileroot:
|
||||||
|
path = os.path.basename(path)
|
||||||
|
g.write("<img src=\"" + fix(path) + "\"")
|
||||||
|
g.write(" descrip=\"" + fix(photo.getDescription()) + "\"/>\n")
|
||||||
g.write("</source>\n")
|
g.write("</source>\n")
|
||||||
g.write("</sources>\n")
|
g.write("</sources>\n")
|
||||||
|
|
||||||
|
@ -2373,6 +2373,11 @@
|
|||||||
<handler>on_source_list_select_row</handler>
|
<handler>on_source_list_select_row</handler>
|
||||||
<last_modification_time>Tue, 29 May 2001 21:23:02 GMT</last_modification_time>
|
<last_modification_time>Tue, 29 May 2001 21:23:02 GMT</last_modification_time>
|
||||||
</signal>
|
</signal>
|
||||||
|
<signal>
|
||||||
|
<name>button_press_event</name>
|
||||||
|
<handler>on_source_list_button_press_event</handler>
|
||||||
|
<last_modification_time>Thu, 31 May 2001 17:22:45 GMT</last_modification_time>
|
||||||
|
</signal>
|
||||||
<columns>2</columns>
|
<columns>2</columns>
|
||||||
<column_widths>300,80</column_widths>
|
<column_widths>300,80</column_widths>
|
||||||
<selection_mode>GTK_SELECTION_SINGLE</selection_mode>
|
<selection_mode>GTK_SELECTION_SINGLE</selection_mode>
|
||||||
@ -3407,7 +3412,7 @@ Other
|
|||||||
<title>Gramps - Source Editor</title>
|
<title>Gramps - Source Editor</title>
|
||||||
<type>GTK_WINDOW_TOPLEVEL</type>
|
<type>GTK_WINDOW_TOPLEVEL</type>
|
||||||
<position>GTK_WIN_POS_CENTER</position>
|
<position>GTK_WIN_POS_CENTER</position>
|
||||||
<modal>True</modal>
|
<modal>False</modal>
|
||||||
<allow_shrink>False</allow_shrink>
|
<allow_shrink>False</allow_shrink>
|
||||||
<allow_grow>False</allow_grow>
|
<allow_grow>False</allow_grow>
|
||||||
<auto_shrink>False</auto_shrink>
|
<auto_shrink>False</auto_shrink>
|
||||||
@ -3519,8 +3524,14 @@ Other
|
|||||||
<class>GtkNotebook</class>
|
<class>GtkNotebook</class>
|
||||||
<name>notebook2</name>
|
<name>notebook2</name>
|
||||||
<width>450</width>
|
<width>450</width>
|
||||||
<height>250</height>
|
<height>350</height>
|
||||||
<can_focus>True</can_focus>
|
<can_focus>True</can_focus>
|
||||||
|
<signal>
|
||||||
|
<name>switch_page</name>
|
||||||
|
<handler>on_switch_page</handler>
|
||||||
|
<object>sourceEditor</object>
|
||||||
|
<last_modification_time>Thu, 31 May 2001 15:04:55 GMT</last_modification_time>
|
||||||
|
</signal>
|
||||||
<show_tabs>True</show_tabs>
|
<show_tabs>True</show_tabs>
|
||||||
<show_border>True</show_border>
|
<show_border>True</show_border>
|
||||||
<tab_pos>GTK_POS_TOP</tab_pos>
|
<tab_pos>GTK_POS_TOP</tab_pos>
|
||||||
@ -3711,7 +3722,7 @@ Other
|
|||||||
<class>GtkScrolledWindow</class>
|
<class>GtkScrolledWindow</class>
|
||||||
<name>scrolledwindow23</name>
|
<name>scrolledwindow23</name>
|
||||||
<hscrollbar_policy>GTK_POLICY_NEVER</hscrollbar_policy>
|
<hscrollbar_policy>GTK_POLICY_NEVER</hscrollbar_policy>
|
||||||
<vscrollbar_policy>GTK_POLICY_ALWAYS</vscrollbar_policy>
|
<vscrollbar_policy>GTK_POLICY_AUTOMATIC</vscrollbar_policy>
|
||||||
<hupdate_policy>GTK_UPDATE_CONTINUOUS</hupdate_policy>
|
<hupdate_policy>GTK_UPDATE_CONTINUOUS</hupdate_policy>
|
||||||
<vupdate_policy>GTK_UPDATE_CONTINUOUS</vupdate_policy>
|
<vupdate_policy>GTK_UPDATE_CONTINUOUS</vupdate_policy>
|
||||||
|
|
||||||
@ -3738,7 +3749,101 @@ Other
|
|||||||
</widget>
|
</widget>
|
||||||
|
|
||||||
<widget>
|
<widget>
|
||||||
<class>Placeholder</class>
|
<class>GtkScrolledWindow</class>
|
||||||
|
<name>scrolledwindow25</name>
|
||||||
|
<hscrollbar_policy>GTK_POLICY_NEVER</hscrollbar_policy>
|
||||||
|
<vscrollbar_policy>GTK_POLICY_AUTOMATIC</vscrollbar_policy>
|
||||||
|
<hupdate_policy>GTK_UPDATE_CONTINUOUS</hupdate_policy>
|
||||||
|
<vupdate_policy>GTK_UPDATE_CONTINUOUS</vupdate_policy>
|
||||||
|
|
||||||
|
<widget>
|
||||||
|
<class>GtkViewport</class>
|
||||||
|
<name>viewport1</name>
|
||||||
|
<shadow_type>GTK_SHADOW_IN</shadow_type>
|
||||||
|
|
||||||
|
<widget>
|
||||||
|
<class>GtkVBox</class>
|
||||||
|
<name>vbox34</name>
|
||||||
|
<homogeneous>False</homogeneous>
|
||||||
|
<spacing>0</spacing>
|
||||||
|
|
||||||
|
<widget>
|
||||||
|
<class>GnomeIconList</class>
|
||||||
|
<name>photolist</name>
|
||||||
|
<can_focus>True</can_focus>
|
||||||
|
<signal>
|
||||||
|
<name>select_icon</name>
|
||||||
|
<handler>on_photolist_select_icon</handler>
|
||||||
|
<object>sourceEditor</object>
|
||||||
|
<last_modification_time>Thu, 31 May 2001 14:39:53 GMT</last_modification_time>
|
||||||
|
</signal>
|
||||||
|
<signal>
|
||||||
|
<name>button_press_event</name>
|
||||||
|
<handler>on_photolist_button_press_event</handler>
|
||||||
|
<object>sourceEditor</object>
|
||||||
|
<last_modification_time>Thu, 31 May 2001 14:40:04 GMT</last_modification_time>
|
||||||
|
</signal>
|
||||||
|
<selection_mode>GTK_SELECTION_SINGLE</selection_mode>
|
||||||
|
<icon_width>100</icon_width>
|
||||||
|
<row_spacing>20</row_spacing>
|
||||||
|
<column_spacing>10</column_spacing>
|
||||||
|
<text_spacing>5</text_spacing>
|
||||||
|
<text_editable>False</text_editable>
|
||||||
|
<text_static>True</text_static>
|
||||||
|
<child>
|
||||||
|
<padding>0</padding>
|
||||||
|
<expand>True</expand>
|
||||||
|
<fill>True</fill>
|
||||||
|
</child>
|
||||||
|
</widget>
|
||||||
|
|
||||||
|
<widget>
|
||||||
|
<class>GtkHButtonBox</class>
|
||||||
|
<name>hbuttonbox21</name>
|
||||||
|
<layout_style>GTK_BUTTONBOX_SPREAD</layout_style>
|
||||||
|
<spacing>30</spacing>
|
||||||
|
<child_min_width>85</child_min_width>
|
||||||
|
<child_min_height>27</child_min_height>
|
||||||
|
<child_ipad_x>7</child_ipad_x>
|
||||||
|
<child_ipad_y>0</child_ipad_y>
|
||||||
|
<child>
|
||||||
|
<padding>0</padding>
|
||||||
|
<expand>False</expand>
|
||||||
|
<fill>True</fill>
|
||||||
|
</child>
|
||||||
|
|
||||||
|
<widget>
|
||||||
|
<class>GtkButton</class>
|
||||||
|
<name>add_photo</name>
|
||||||
|
<can_default>True</can_default>
|
||||||
|
<can_focus>True</can_focus>
|
||||||
|
<signal>
|
||||||
|
<name>clicked</name>
|
||||||
|
<handler>on_addphoto_clicked</handler>
|
||||||
|
<object>sourceEditor</object>
|
||||||
|
<last_modification_time>Thu, 31 May 2001 14:39:32 GMT</last_modification_time>
|
||||||
|
</signal>
|
||||||
|
<label>Add Photo</label>
|
||||||
|
<relief>GTK_RELIEF_NORMAL</relief>
|
||||||
|
</widget>
|
||||||
|
|
||||||
|
<widget>
|
||||||
|
<class>GtkButton</class>
|
||||||
|
<name>delete_photo</name>
|
||||||
|
<can_default>True</can_default>
|
||||||
|
<can_focus>True</can_focus>
|
||||||
|
<signal>
|
||||||
|
<name>clicked</name>
|
||||||
|
<handler>on_deletephoto_clicked</handler>
|
||||||
|
<object>sourceEditor</object>
|
||||||
|
<last_modification_time>Thu, 31 May 2001 14:39:16 GMT</last_modification_time>
|
||||||
|
</signal>
|
||||||
|
<label>Delete Photo</label>
|
||||||
|
<relief>GTK_RELIEF_NORMAL</relief>
|
||||||
|
</widget>
|
||||||
|
</widget>
|
||||||
|
</widget>
|
||||||
|
</widget>
|
||||||
</widget>
|
</widget>
|
||||||
|
|
||||||
<widget>
|
<widget>
|
||||||
|
@ -65,7 +65,9 @@ import utils
|
|||||||
import Bookmarks
|
import Bookmarks
|
||||||
import ListColors
|
import ListColors
|
||||||
import Config
|
import Config
|
||||||
|
import EditSource
|
||||||
|
import EditPerson
|
||||||
|
import Marriage
|
||||||
|
|
||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
#
|
#
|
||||||
@ -579,8 +581,6 @@ def new_database_response(val):
|
|||||||
#
|
#
|
||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
def marriage_edit(family):
|
def marriage_edit(family):
|
||||||
import Marriage
|
|
||||||
|
|
||||||
Marriage.Marriage(family,database)
|
Marriage.Marriage(family,database)
|
||||||
|
|
||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
@ -669,8 +669,6 @@ def on_source_list_select_row(obj,a,b,c):
|
|||||||
#
|
#
|
||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
def on_add_source_clicked(obj):
|
def on_add_source_clicked(obj):
|
||||||
import EditSource
|
|
||||||
|
|
||||||
EditSource.EditSource(Source(),database,new_source_after_edit)
|
EditSource.EditSource(Source(),database,new_source_after_edit)
|
||||||
|
|
||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
@ -687,8 +685,6 @@ def on_delete_source_clicked(obj):
|
|||||||
#
|
#
|
||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
def on_edit_source_clicked(obj):
|
def on_edit_source_clicked(obj):
|
||||||
import EditSource
|
|
||||||
|
|
||||||
index = obj.get_data("i")
|
index = obj.get_data("i")
|
||||||
if index == -1:
|
if index == -1:
|
||||||
return
|
return
|
||||||
@ -1603,8 +1599,6 @@ def update_after_edit(person):
|
|||||||
#
|
#
|
||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
def load_person(person):
|
def load_person(person):
|
||||||
import EditPerson
|
|
||||||
|
|
||||||
if person == None:
|
if person == None:
|
||||||
EditPerson.EditPerson(Person(),database,surnameList,\
|
EditPerson.EditPerson(Person(),database,surnameList,\
|
||||||
new_after_edit)
|
new_after_edit)
|
||||||
|
Reference in New Issue
Block a user