Some basic media object editing

svn: r456
This commit is contained in:
Don Allingham 2001-10-11 22:56:48 +00:00
parent d5b51fe57b
commit 1415d94503
10 changed files with 1951 additions and 136 deletions

View File

@ -22,7 +22,7 @@
<last_modification_time>Fri, 03 Aug 2001 01:42:42 GMT</last_modification_time> <last_modification_time>Fri, 03 Aug 2001 01:42:42 GMT</last_modification_time>
</signal> </signal>
<title>Gramps - Edit Person</title> <title>Gramps - Edit Person</title>
<type>GTK_WINDOW_TOPLEVEL</type> <type>GTK_WINDOW_DIALOG</type>
<position>GTK_WIN_POS_NONE</position> <position>GTK_WIN_POS_NONE</position>
<modal>False</modal> <modal>False</modal>
<allow_shrink>False</allow_shrink> <allow_shrink>False</allow_shrink>
@ -3567,10 +3567,10 @@
<class>GtkHButtonBox</class> <class>GtkHButtonBox</class>
<name>hbuttonbox13</name> <name>hbuttonbox13</name>
<layout_style>GTK_BUTTONBOX_SPREAD</layout_style> <layout_style>GTK_BUTTONBOX_SPREAD</layout_style>
<spacing>30</spacing> <spacing>15</spacing>
<child_min_width>85</child_min_width> <child_min_width>85</child_min_width>
<child_min_height>27</child_min_height> <child_min_height>27</child_min_height>
<child_ipad_x>7</child_ipad_x> <child_ipad_x>3</child_ipad_x>
<child_ipad_y>0</child_ipad_y> <child_ipad_y>0</child_ipad_y>
<child> <child>
<padding>0</padding> <padding>0</padding>
@ -3589,7 +3589,7 @@
<object>editPerson</object> <object>editPerson</object>
<last_modification_time>Sat, 09 Dec 2000 22:09:54 GMT</last_modification_time> <last_modification_time>Sat, 09 Dec 2000 22:09:54 GMT</last_modification_time>
</signal> </signal>
<label>Add Object</label> <label>Add Media Object</label>
<relief>GTK_RELIEF_NORMAL</relief> <relief>GTK_RELIEF_NORMAL</relief>
</widget> </widget>
@ -3604,7 +3604,7 @@
<object>editPerson</object> <object>editPerson</object>
<last_modification_time>Sun, 10 Dec 2000 03:48:08 GMT</last_modification_time> <last_modification_time>Sun, 10 Dec 2000 03:48:08 GMT</last_modification_time>
</signal> </signal>
<label>Delete Object</label> <label>Delete Media Object</label>
<relief>GTK_RELIEF_NORMAL</relief> <relief>GTK_RELIEF_NORMAL</relief>
</widget> </widget>
@ -3619,7 +3619,22 @@
<object>editPerson</object> <object>editPerson</object>
<last_modification_time>Sun, 10 Dec 2000 15:10:41 GMT</last_modification_time> <last_modification_time>Sun, 10 Dec 2000 15:10:41 GMT</last_modification_time>
</signal> </signal>
<label>Make Primary</label> <label>Make Primary Object</label>
<relief>GTK_RELIEF_NORMAL</relief>
</widget>
<widget>
<class>GtkButton</class>
<name>button127</name>
<can_default>True</can_default>
<can_focus>True</can_focus>
<signal>
<name>clicked</name>
<handler>on_edit_properties_clicked</handler>
<object>editPerson</object>
<last_modification_time>Thu, 11 Oct 2001 22:22:08 GMT</last_modification_time>
</signal>
<label>Edit Properties</label>
<relief>GTK_RELIEF_NORMAL</relief> <relief>GTK_RELIEF_NORMAL</relief>
</widget> </widget>
</widget> </widget>

View File

@ -197,6 +197,7 @@ class EditPerson:
"on_delete_event" : on_delete_event, "on_delete_event" : on_delete_event,
"on_delete_url_clicked" : on_delete_url_clicked, "on_delete_url_clicked" : on_delete_url_clicked,
"on_deletephoto_clicked" : self.gallery.on_delete_photo_clicked, "on_deletephoto_clicked" : self.gallery.on_delete_photo_clicked,
"on_edit_properties_clicked": self.gallery.popup_change_description,
"on_editperson_switch_page" : on_switch_page, "on_editperson_switch_page" : on_switch_page,
"on_event_add_clicked" : on_event_add_clicked, "on_event_add_clicked" : on_event_add_clicked,
"on_event_delete_clicked" : on_event_delete_clicked, "on_event_delete_clicked" : on_event_delete_clicked,
@ -263,6 +264,7 @@ class EditPerson:
if len(photo_list) != 0: if len(photo_list) != 0:
ph = photo_list[0] ph = photo_list[0]
object = ph.getReference() object = ph.getReference()
if object.getMimeType()[0:5] == "image":
self.load_photo(object.getPath()) self.load_photo(object.getPath())
# set notes data # set notes data
@ -408,11 +410,12 @@ class PersonGallery(ImageSelect.Gallery):
photolist[selected_icon-i] = photolist[selected_icon-i-1] photolist[selected_icon-i] = photolist[selected_icon-i-1]
photolist[0] = savePhoto photolist[0] = savePhoto
ref = savePhoto.getReference()
if ref.getMimeType() == "image":
self.epo.load_photo(savePhoto.getReference().getPath()) self.epo.load_photo(savePhoto.getReference().getPath())
self.load_images() self.load_images()
utils.modified() utils.modified()
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
# #
# #

View File

@ -505,7 +505,7 @@ class GrampsParser(handler.ContentHandler):
a.setType(key) a.setType(key)
a.setValue(u2l(attrs[key])) a.setValue(u2l(attrs[key]))
self.photo.addAttribute(a) self.photo.addAttribute(a)
self.photo.setMimeType(gnome.mime.type_or_default(self.photo.getPath(),"unknown")) self.photo.setMimeType(utils.get_mime_type(self.photo.getPath()))
self.db.addObject(self.photo) self.db.addObject(self.photo)
if self.family: if self.family:
self.family.addPhoto(self.pref) self.family.addPhoto(self.pref)

View File

@ -34,7 +34,6 @@ import string
from gtk import * from gtk import *
from gnome.ui import * from gnome.ui import *
import GDK import GDK
import gnome.mime
import libglade import libglade
import GdkImlib import GdkImlib
@ -103,8 +102,12 @@ class ImageSelect:
def on_name_changed(self, obj): def on_name_changed(self, obj):
filename = self.fname.get_text() filename = self.fname.get_text()
if os.path.isfile(filename): if os.path.isfile(filename):
type = utils.get_mime_type(filename)
if type[0:5] == "image":
image = RelImage.scale_image(filename,const.thumbScale) image = RelImage.scale_image(filename,const.thumbScale)
self.image.load_imlib(image) self.image.load_imlib(image)
else:
self.image.load_file(utils.find_icon(type))
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
# #
@ -119,24 +122,31 @@ class ImageSelect:
GnomeErrorDialog(_("That is not a valid file name.")); GnomeErrorDialog(_("That is not a valid file name."));
return return
type = utils.get_mime_type(filename)
mobj = Photo()
if description == "":
description = os.path.basename(name)
mobj.setDescription(description)
mobj.setMimeType(type)
self.savephoto(mobj)
if type[0:5] == "image":
if self.external.get_active() == 1: if self.external.get_active() == 1:
if os.path.isfile(filename): if os.path.isfile(filename):
name = filename name = filename
thumb = "%s%s.thumb%s%s" % (self.path,os.sep,os.sep,os.path.basename(filename)) thumb = "%s/.thumb/%s.jpg" % (self.path,mobj.getId())
RelImage.mk_thumb(filename,thumb,const.thumbScale) RelImage.mk_thumb(filename,thumb,const.thumbScale)
else: else:
return return
else: else:
name = RelImage.import_photo(filename,self.path,self.prefix) name = RelImage.import_media_object(filename,self.path,mobj.getId())
if name == None: else:
return if self.external.get_active() == 1:
name = filename
else:
name = RelImage.import_media_object(filename,self.path,mobj.getId())
photo = Photo() mobj.setPath(name)
photo.setPath(name)
photo.setDescription(description)
photo.setMimeType(gnome.mime.type_or_default_of_file(name,"unknown"))
self.savephoto(photo)
utils.modified() utils.modified()
utils.destroy_passed_object(obj) utils.destroy_passed_object(obj)
@ -166,11 +176,11 @@ class Gallery(ImageSelect):
('text/uri-list',0,2), ('text/uri-list',0,2),
('application/x-rootwin-drop',0,1)] ('application/x-rootwin-drop',0,1)]
icon_list.drag_dest_set(DEST_DEFAULT_ALL, t, GDK.ACTION_COPY) icon_list.drag_dest_set(DEST_DEFAULT_ALL, t, GDK.ACTION_COPY | GDK.ACTION_MOVE)
icon_list.connect("drag_data_received", self.on_photolist_drag_data_received) icon_list.connect("drag_data_received", self.on_photolist_drag_data_received)
icon_list.drag_source_set(GDK.BUTTON1_MASK|GDK.BUTTON3_MASK,t,\ icon_list.drag_source_set(GDK.BUTTON1_MASK|GDK.BUTTON3_MASK,t,\
GDK.ACTION_COPY) GDK.ACTION_COPY | GDK.ACTION_MOVE)
icon_list.connect("drag_data_get", self.on_photolist_drag_data_get) icon_list.connect("drag_data_get", self.on_photolist_drag_data_get)
@ -210,11 +220,11 @@ class Gallery(ImageSelect):
object = photo.getReference() object = photo.getReference()
path = object.getPath() path = object.getPath()
src = os.path.basename(path) src = os.path.basename(path)
if object.getLocal(): if object.getMimeType()[0:5] == "image":
thumb = "%s%s.thumb%s%s" % (self.path,os.sep,os.sep,src) thumb = "%s/.thumb/%s.jpg" % (self.path,object.getId())
else:
thumb = "%s%s.thumb%s%s.jpg" % (self.path,os.sep,os.sep,os.path.basename(src))
RelImage.check_thumb(path,thumb,const.thumbScale) RelImage.check_thumb(path,thumb,const.thumbScale)
else:
thumb = utils.find_icon(object.getMimeType())
self.icon_list.append(thumb,object.getDescription()) self.icon_list.append(thumb,object.getDescription())
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
@ -244,22 +254,25 @@ class Gallery(ImageSelect):
d = string.strip(string.replace(data.data,'\0',' ')) d = string.strip(string.replace(data.data,'\0',' '))
if d[0:5] == "file:": if d[0:5] == "file:":
name = d[5:] name = d[5:]
mime = gnome.mime.type_or_default_of_file(name,"unknown") mime = utils.get_mime_type(name)
if mime[0:5] == "image":
photo = Photo() photo = Photo()
photo.setPath(name) photo.setPath(name)
photo.setMimeType(mime) photo.setMimeType(mime)
description = os.path.basename(name)
photo.setDescription(description)
self.savephoto(photo) self.savephoto(photo)
else:
print name,mime
else: else:
if self.db.getObjectMap().has_key(data.data): if self.db.getObjectMap().has_key(data.data):
for p in self.dataobj.getPhotoList():
if data.data == p.getReference().getId():
w.drag_finish(context, TRUE, FALSE, time) w.drag_finish(context, TRUE, FALSE, time)
return
oref = ObjectRef() oref = ObjectRef()
oref.setReference(self.db.findObjectNoMap(data.data)) oref.setReference(self.db.findObjectNoMap(data.data))
self.dataobj.addPhoto(oref) self.dataobj.addPhoto(oref)
self.add_thumbnail(oref) self.add_thumbnail(oref)
utils.modified() utils.modified()
w.drag_finish(context, TRUE, FALSE, time)
else: else:
w.drag_finish(context, FALSE, FALSE, time) w.drag_finish(context, FALSE, FALSE, time)
@ -292,6 +305,11 @@ class Gallery(ImageSelect):
if icon != -1: if icon != -1:
self.icon_list.remove(icon) self.icon_list.remove(icon)
del self.dataobj.getPhotoList()[icon] del self.dataobj.getPhotoList()[icon]
if len(self.dataobj.getPhotoList()) == 0:
self.selectedIcon = -1
else:
self.selectedIcon = 0
self.icon_list.select_icon(0)
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
# #
@ -310,9 +328,9 @@ class Gallery(ImageSelect):
item = GtkTearoffMenuItem() item = GtkTearoffMenuItem()
item.show() item.show()
menu.append(item) menu.append(item)
utils.add_menuitem(menu,_("View Object"),None,self.popup_view_photo) utils.add_menuitem(menu,_("View in the default viewer"),None,self.popup_view_photo)
utils.add_menuitem(menu,_("Edit Object"),None,self.popup_edit_photo) utils.add_menuitem(menu,_("Edit in the default editor"),None,self.popup_edit_photo)
utils.add_menuitem(menu,_("Edit Description"),None, utils.add_menuitem(menu,_("Edit Object Properties"),None,
self.popup_change_description) self.popup_change_description)
object = photo.getReference() object = photo.getReference()
if object.getLocal() == 0: if object.getLocal() == 0:
@ -362,17 +380,31 @@ class Gallery(ImageSelect):
def popup_change_description(self, obj): def popup_change_description(self, obj):
photo = self.dataobj.getPhotoList()[self.selectedIcon] photo = self.dataobj.getPhotoList()[self.selectedIcon]
object = photo.getReference() object = photo.getReference()
path = object.getPath()
src = os.path.basename(path)
self.change_dialog = libglade.GladeXML(const.imageselFile,"change_description") self.change_dialog = libglade.GladeXML(const.imageselFile,"change_description")
window = self.change_dialog.get_widget("change_description") window = self.change_dialog.get_widget("change_description")
text = self.change_dialog.get_widget("text") self.change_dialog.get_widget("description").set_text(object.getDescription())
text.set_text(object.getDescription()) pixmap = self.change_dialog.get_widget("pixmap")
mtype = object.getMimeType()
if mtype[0:5] == "image":
thumb = "%s/.thumb/%s" % (self.path,object.getId())
RelImage.check_thumb(path,thumb,const.thumbScale)
pixmap.load_file(thumb)
else:
pixmap.load_file(utils.find_icon(mtype))
image2 = RelImage.scale_image(object.getPath(),200.0) self.change_dialog.get_widget("gid").set_text(object.getId())
self.change_dialog.get_widget("photo").load_imlib(image2) self.change_dialog.get_widget("description").set_text(object.getDescription())
if object.getLocal():
self.change_dialog.get_widget("path").set_text("<local>")
else:
self.change_dialog.get_widget("path").set_text(path)
self.change_dialog.get_widget("type").set_text(utils.get_mime_description(mtype))
self.change_dialog.get_widget("notes").insert_defaults(photo.getNote())
window.set_data("p",photo) window.set_data("p",photo)
window.set_data("t",text) window.set_data("t",self.change_dialog)
window.editable_enters(text)
self.change_dialog.signal_autoconnect({ self.change_dialog.signal_autoconnect({
"on_cancel_clicked" : utils.destroy_passed_object, "on_cancel_clicked" : utils.destroy_passed_object,
"on_ok_clicked" : self.new_desc_ok_clicked, "on_ok_clicked" : self.new_desc_ok_clicked,
@ -386,11 +418,11 @@ class Gallery(ImageSelect):
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
def new_desc_apply_clicked(self, obj): def new_desc_apply_clicked(self, obj):
photo = obj.get_data("p") photo = obj.get_data("p")
object = photo.getReference() top = obj.get_data('t')
text = obj.get_data("t").get_text() text = top.get_widget("notes").get_chars(0,-1)
if text != object.getDescription(): note = photo.getNote()
object.setDescription(text) if text != note:
self.load_images() photo.setNote(text)
utils.modified() utils.modified()
#------------------------------------------------------------------------- #-------------------------------------------------------------------------

View File

@ -26,6 +26,8 @@
import os import os
import const import const
import intl import intl
import string
import utils
from gnome.ui import * from gnome.ui import *
_ = intl.gettext _ = intl.gettext
@ -38,25 +40,18 @@ except:
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
# #
# import_photo # import_media_object
# #
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
def import_photo(filename,path,prefix): def import_media_object(filename,path,base):
import gnome.mime
import shutil import shutil
type = gnome.mime.type_of_file(filename) type = utils.get_mime_type(filename)
if type[0:6] != "image/": if type[0:5] == "image":
GnomeErrorDialog(_("Currently only image files are supported")) name = "%s/%s.jpg" % (path,base)
return None base = "%s.jpg" % (base)
for index in range(0,1000): thumb = "%s/.thumb" % (path)
name = "%s%s%s_%d.jpg" % (path,os.sep,prefix,index)
base = "%s_%d.jpg" % (prefix,index)
if os.path.exists(name) == 0:
break
thumb = "%s%s.thumb" % (path,os.sep)
try: try:
if not os.path.exists(thumb): if not os.path.exists(thumb):
@ -67,7 +62,7 @@ def import_photo(filename,path,prefix):
GnomeErrorDialog(_("Could not create %s") % thumb) GnomeErrorDialog(_("Could not create %s") % thumb)
try: try:
path = "%s%s%s" % (thumb,os.sep,base) path = "%s/%s" % (thumb,base)
mk_thumb(filename,path,const.thumbScale) mk_thumb(filename,path,const.thumbScale)
@ -81,6 +76,11 @@ def import_photo(filename,path,prefix):
PIL.Image.open(filename).save(name) PIL.Image.open(filename).save(name)
except: except:
return None return None
else:
bname = os.path.basename(filename)
l = string.split(bname,'.')
name = "%s/%s.%s" % (path,base,l[-1])
shutil.copy(filename,name)
return name return name

View File

@ -293,8 +293,6 @@ def write_photo_list(g,list,indent=3):
g.write(">\n") g.write(">\n")
write_attribute_list(g,proplist,indent+1) write_attribute_list(g,proplist,indent+1)
write_note(g,"note",photo.getNote(),indent+1) write_note(g,"note",photo.getNote(),indent+1)
for s in photo.getSourceRefList():
dump_source_ref(g,s,indent+1)
g.write('%s</objref>\n' % sp) g.write('%s</objref>\n' % sp)
def write_url_list(g, list): def write_url_list(g, list):

View File

@ -2879,6 +2879,11 @@
<handler>on_media_list_drag_data_get</handler> <handler>on_media_list_drag_data_get</handler>
<last_modification_time>Tue, 09 Oct 2001 21:02:46 GMT</last_modification_time> <last_modification_time>Tue, 09 Oct 2001 21:02:46 GMT</last_modification_time>
</signal> </signal>
<signal>
<name>drag_data_received</name>
<handler>on_media_list_drag_data_received</handler>
<last_modification_time>Thu, 11 Oct 2001 22:42:26 GMT</last_modification_time>
</signal>
<columns>5</columns> <columns>5</columns>
<column_widths>33,331,104,168,80</column_widths> <column_widths>33,331,104,168,80</column_widths>
<selection_mode>GTK_SELECTION_SINGLE</selection_mode> <selection_mode>GTK_SELECTION_SINGLE</selection_mode>
@ -2972,6 +2977,11 @@
<name>button142</name> <name>button142</name>
<can_default>True</can_default> <can_default>True</can_default>
<can_focus>True</can_focus> <can_focus>True</can_focus>
<signal>
<name>clicked</name>
<handler>on_add_media_clicked</handler>
<last_modification_time>Thu, 11 Oct 2001 22:36:50 GMT</last_modification_time>
</signal>
<label>Add Media Object</label> <label>Add Media Object</label>
<relief>GTK_RELIEF_NORMAL</relief> <relief>GTK_RELIEF_NORMAL</relief>
</widget> </widget>

View File

@ -42,7 +42,6 @@ _ = intl.gettext
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
from gtk import * from gtk import *
from gnome.ui import * from gnome.ui import *
import GDK import GDK
import GTK import GTK
import libglade import libglade
@ -1681,7 +1680,7 @@ def remove_from_person_list(person):
del id2col[person] del id2col[person]
del alt2col[person] del alt2col[person]
if row <= person_list.rows: if row > person_list.rows:
(active_person,alt) = person_list.get_row_data(row) (active_person,alt) = person_list.get_row_data(row)
person_list.thaw() person_list.thaw()
@ -2118,6 +2117,7 @@ def load_places():
def on_media_list_select_row(obj,row,b,c): def on_media_list_select_row(obj,row,b,c):
mobj = obj.get_row_data(row) mobj = obj.get_row_data(row)
type = mobj.getMimeType() type = mobj.getMimeType()
type_name = utils.get_mime_description(type)
path = mobj.getPath() path = mobj.getPath()
if type[0:5] == "image": if type[0:5] == "image":
dir = os.path.dirname(path) dir = os.path.dirname(path)
@ -2126,9 +2126,10 @@ def on_media_list_select_row(obj,row,b,c):
RelImage.check_thumb(path,thumb,const.thumbScale) RelImage.check_thumb(path,thumb,const.thumbScale)
preview.load_file(thumb) preview.load_file(thumb)
else: else:
pass preview.load_file(utils.find_icon(type))
mid.set_text(mobj.getId()) mid.set_text(mobj.getId())
mtype.set_text(type) mtype.set_text(type_name)
mdesc.set_text(mobj.getDescription()) mdesc.set_text(mobj.getDescription())
if path[0] == "/": if path[0] == "/":
mpath.set_text(path) mpath.set_text(path)
@ -2156,7 +2157,7 @@ def load_media():
for src in objects: for src in objects:
title = src.getDescription() title = src.getDescription()
id = src.getId() id = src.getId()
type = src.getMimeType() type = utils.get_mime_description(src.getMimeType())
if src.getLocal(): if src.getLocal():
path = "<local copy>" path = "<local copy>"
else: else:
@ -3338,8 +3339,12 @@ def main(arg):
dateArrow = gtop.get_widget("dateSort") dateArrow = gtop.get_widget("dateSort")
deathArrow = gtop.get_widget("deathSort") deathArrow = gtop.get_widget("deathSort")
t = [('STRING', 0, 0)] t = [ ('STRING', 0, 0),
('text/plain',0,0),
('text/uri-list',0,2),
('application/x-rootwin-drop',0,1)]
media_list.drag_source_set(GDK.BUTTON1_MASK|GDK.BUTTON3_MASK,t,GDK.ACTION_COPY) media_list.drag_source_set(GDK.BUTTON1_MASK|GDK.BUTTON3_MASK,t,GDK.ACTION_COPY)
media_list.drag_dest_set(DEST_DEFAULT_ALL,t,GDK.ACTION_COPY|GDK.ACTION_MOVE)
person_list.set_column_visibility(5,0) person_list.set_column_visibility(5,0)
person_list.set_column_visibility(6,0) person_list.set_column_visibility(6,0)
person_list.set_column_visibility(7,0) person_list.set_column_visibility(7,0)
@ -3406,9 +3411,11 @@ def main(arg):
"on_person_list_select_row" : on_person_list_select_row, "on_person_list_select_row" : on_person_list_select_row,
"on_place_list_button_press_event" : on_place_list_button_press_event, "on_place_list_button_press_event" : on_place_list_button_press_event,
"on_main_key_release_event" : on_main_key_release_event, "on_main_key_release_event" : on_main_key_release_event,
"on_add_media_clicked" : create_add_dialog,
"on_media_activate" : on_media_activate, "on_media_activate" : on_media_activate,
"on_media_list_select_row" : on_media_list_select_row, "on_media_list_select_row" : on_media_list_select_row,
"on_media_list_drag_data_get" : on_media_list_drag_data_get, "on_media_list_drag_data_get" : on_media_list_drag_data_get,
"on_media_list_drag_data_received" : on_media_list_drag_data_received,
"on_places_activate" : on_places_activate, "on_places_activate" : on_places_activate,
"on_preferences_activate" : on_preferences_activate, "on_preferences_activate" : on_preferences_activate,
"on_remove_child_clicked" : on_remove_child_clicked, "on_remove_child_clicked" : on_remove_child_clicked,
@ -3463,6 +3470,80 @@ def on_canvas1_event(obj,event):
load_canvas() load_canvas()
return 0 return 0
def create_add_dialog(obj):
glade = libglade.GladeXML(const.imageselFile,"imageSelect")
window = glade.get_widget("imageSelect")
fname = glade.get_widget("fname")
image = glade.get_widget("image")
description = glade.get_widget("photoDescription")
external = glade.get_widget("private")
glade.signal_autoconnect({
"on_savephoto_clicked" : on_savephoto_clicked,
"on_name_changed" : on_name_changed,
"destroy_passed_object" : utils.destroy_passed_object
})
window.editable_enters(description)
window.set_data("t",glade)
window.show()
def on_savephoto_clicked(obj):
glade = obj.get_data("t")
filename = glade.get_widget("photosel").get_full_path(0)
description = glade.get_widget("photoDescription").get_text()
external = glade.get_widget("private")
if os.path.exists(filename) == 0:
GnomeErrorDialog(_("That is not a valid file name."));
return
type = utils.get_mime_type(filename)
mobj = Photo()
if description == "":
description = os.path.basename(filename)
mobj.setDescription(description)
mobj.setMimeType(type)
database.addObject(mobj)
if external.get_active() == 0:
path = database.getSavePath()
name = RelImage.import_media_object(filename,path,mobj.getId())
mobj.setPath(name)
utils.modified()
load_media()
utils.destroy_passed_object(obj)
def on_name_changed(obj):
glade = obj.get_data('t')
filename = glade.get_widget("fname").get_text()
if os.path.isfile(filename):
type = utils.get_mime_type(filename)
if type[0:5] == "image":
image = RelImage.scale_image(filename,const.thumbScale)
glade.get_widget("image").load_imlib(image)
else:
glade.get_widget("image").load_file(utils.find_icon(type))
def on_media_list_drag_data_received(w, context, x, y, data, info, time):
if data and data.format == 8:
d = string.strip(string.replace(data.data,'\0',' '))
if d[0:5] == "file:":
name = d[5:]
mime = utils.get_mime_type(name)
photo = Photo()
photo.setPath(name)
photo.setMimeType(mime)
description = os.path.basename(name)
photo.setDescription(description)
database.addObject(photo)
utils.modified()
w.drag_finish(context, TRUE, FALSE, time)
load_media()
else:
w.drag_finish(context, FALSE, FALSE, time)
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
# #
# Start it all # Start it all

File diff suppressed because it is too large Load Diff

View File

@ -20,6 +20,7 @@
import gtk import gtk
import gnome.mime import gnome.mime
from gnome.ui import *
import string import string
import os import os
import const import const
@ -247,8 +248,27 @@ def add_menuitem(menu,msg,obj,func):
# #
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
def view_photo(photo): def view_photo(photo):
type = gnome.mime.type(photo.getPath()) type = photo.getMimeType()
prog = string.split(gnome.mime.get_value(type,'view')) prog = ""
open = ""
edit = ""
for key in gnome.mime.get_keys(type):
print key,gnome.mime.get_value(type,key)
if key == 'view':
prog = string.split(gnome.mime.get_value(type,key))
if key == 'open':
open = string.split(gnome.mime.get_value(type,key))
if key == 'edit':
edit = string.split(gnome.mime.get_value(type,key))
if prog == "" and open == "" and edit == "":
GnomeWarningDialog("Sorry, I cannot find a viewer for %s type" % type)
return
if prog == "" and open == "":
prog = edit
else:
prog = open
args = [] args = []
for val in prog: for val in prog:
if val == "%f": if val == "%f":
@ -256,6 +276,7 @@ def view_photo(photo):
else: else:
args.append(val) args.append(val)
print args
if os.fork() == 0: if os.fork() == 0:
os.execvp(args[0],args) os.execvp(args[0],args)
@ -312,3 +333,39 @@ def get_place_from_list(obj):
return None return None
else: else:
return select[0].get_data(LISTOBJ) return select[0].get_data(LISTOBJ)
def find_icon(mtype):
icon = None
nicon = None
for k in gnome.mime.get_keys(mtype):
if k == "icon-filename":
icon = gnome.mime.get_value(mtype,k)
elif k == "icon_filename":
nicon = gnome.mime.get_value(mtype,k)
if nicon:
p = "%s/%s" % (gnome.util.pixmap_file("nautilus"),nicon)
if os.path.isfile(p):
print "n",p
return p
p = "%s.png" % p
if os.path.isfile(p):
print "n",p
return p
if icon:
return icon
return ""
def get_mime_type(file):
if os.path.isfile(file) or os.path.isdir(file):
mtype = gnome.mime.type_of_file(file)
if len(string.split(mtype,"/")) != 2:
mtype = gnome.mime.type(file)
else:
mtype = gnome.mime.type(file)
return mtype
def get_mime_description(type):
for key in gnome.mime.get_keys(type):
if key == "description":
return gnome.mime.get_value(type,key)
return type