From 644d0ac5405d57340b3a87325600879050ddd478 Mon Sep 17 00:00:00 2001 From: Benny Malengier Date: Sun, 28 Feb 2010 14:03:52 +0000 Subject: [PATCH] Fix drag/drop bug: allow multiple drop on gallery svn: r14516 --- src/gui/editors/displaytabs/gallerytab.py | 48 ++++++++++++----------- src/plugins/view/mediaview.py | 7 +++- 2 files changed, 30 insertions(+), 25 deletions(-) diff --git a/src/gui/editors/displaytabs/gallerytab.py b/src/gui/editors/displaytabs/gallerytab.py index b32fdd43c..a048b1519 100644 --- a/src/gui/editors/displaytabs/gallerytab.py +++ b/src/gui/editors/displaytabs/gallerytab.py @@ -456,29 +456,31 @@ class GalleryTab(ButtonTab, DbGUIElement): elif self._DND_EXTRA and mytype == self._DND_EXTRA.drag_type: self.handle_extra_type(mytype, obj) except pickle.UnpicklingError: - d = Utils.fix_encoding(sel_data.data.replace('\0',' ').strip()) - protocol, site, mfile, j, k, l = urlparse.urlparse(d) - if protocol == "file": - name = Utils.fix_encoding(mfile) - name = unicode(urllib.url2pathname(name.encode(sys.getfilesystemencoding()))) - mime = gen.mime.get_type(name) - if not gen.mime.is_valid_type(mime): - return - photo = gen.lib.MediaObject() - photo.set_path(name) - photo.set_mime_type(mime) - basename = os.path.basename(name) - (root, ext) = os.path.splitext(basename) - photo.set_description(root) - trans = self.dbstate.db.transaction_begin() - self.dbstate.db.add_object(photo, trans) - oref = gen.lib.MediaRef() - oref.set_reference_handle(photo.get_handle()) - self.get_data().append(oref) - self.changed = True -# self.dataobj.add_media_reference(oref) - self.dbstate.db.transaction_commit(trans, - _("Drag Media Object")) + #We assume this is for URI_LIST + for file in sel_data.get_uris(): + d = Utils.fix_encoding(file.replace('\0',' ').strip()) + protocol, site, mfile, j, k, l = urlparse.urlparse(d) + if protocol == "file": + name = Utils.fix_encoding(mfile) + name = unicode(urllib.url2pathname( + name.encode(sys.getfilesystemencoding()))) + mime = gen.mime.get_type(name) + if not gen.mime.is_valid_type(mime): + return + photo = gen.lib.MediaObject() + photo.set_path(name) + photo.set_mime_type(mime) + basename = os.path.basename(name) + (root, ext) = os.path.splitext(basename) + photo.set_description(root) + trans = self.dbstate.db.transaction_begin() + self.dbstate.db.add_object(photo, trans) + oref = gen.lib.MediaRef() + oref.set_reference_handle(photo.get_handle()) + self.get_data().append(oref) + self.changed = True + self.dbstate.db.transaction_commit(trans, + _("Drag Media Object")) self.rebuild() def handle_extra_type(self, objtype, obj): diff --git a/src/plugins/view/mediaview.py b/src/plugins/view/mediaview.py index ea729fd56..5d4081ac8 100644 --- a/src/plugins/view/mediaview.py +++ b/src/plugins/view/mediaview.py @@ -148,11 +148,12 @@ class MediaView(ListView): dnd_types = [ self._DND_TYPE.target() ] self.list.drag_dest_set(gtk.DEST_DEFAULT_ALL, dnd_types, - gtk.gdk.ACTION_COPY) + gtk.gdk.ACTION_PRIVATE) self.list.drag_source_set(gtk.gdk.BUTTON1_MASK, [self._DND_TYPE.target()], gtk.gdk.ACTION_COPY) - self.list.connect('drag_data_get', self.drag_data_get) + #connected in listview already + #self.list.connect('drag_data_get', self.drag_data_get) self.list.connect('drag_data_received', self.drag_data_received) def drag_data_get(self, widget, context, sel_data, info, time): @@ -194,6 +195,8 @@ class MediaView(ListView): If the selection data is define, extract the value from sel_data.data, and decide if this is a move or a reorder. + The only data we accept on mediaview is dropping a file, so URI_LIST. + We assume this is what we obtain """ if sel_data and sel_data.data: cleaned_string = sel_data.data.replace('\0', ' ')