NAME

Gtk2::Ex::TreeModelFilter::DragDest -- drag destination mix-in for TreeModelFilter subclasses

SYNOPSIS

package MyNewFilterModel;
use Gtk2;
use base 'Gtk2::Ex::TreeModelFilter::DragDest';

use Glib::Object::Subclass
  Gtk2::TreeModelFilter::,
  interfaces => [ 'Gtk2::TreeDragDest' ];

DESCRIPTION

Gtk2::Ex::TreeModelFilter::DragDest provides the following two functions to implement the Gtk2::TreeDragDest interface in a sub-class of Gtk2::TreeModelFilter.

ROW_DROP_POSSIBLE
DRAG_DATA_RECEIVED

They're designed as a multiple-inheritance mix-in, so you put Gtk2::Ex::TreeModelFilter::DragDest in your @ISA, then add Gtk2::TreeDragDest to the interfaces in your use Glib::Object::Subclass (or register_object).

For simple filter draggability you'll probably find Gtk2::Ex::TreeModelFilter::Draggable enough, but DragDest lets you add draggability to sub-sub-classes of TreeModelFilter.

Drop

The drop strategy is simply to delegate to the filter's child-model. If it's not a TreeDragDest, but is another Gtk2::TreeModelFilter, then its child-model is tried, and so downwards to the first TreeDragDest capable child. The destination path position is converted as necessary.

If the drag source is the filter itself (which is usual for say dragging in a Gtk2::TreeView) then the source row ends up being from the first non-filter child model. The above drop strategy ends up on that same child, which is important for instance for a Gtk2::ListStore since it only allows drags within itself.

OTHER NOTES

There's probably no reason GtkTreeModelFilter itself couldn't do this sort of drop, but as of Gtk 2.12 it doesn't. Perhaps by the time you read this it will, and you won't need this code.

If your filter's "visible" function decides a newly dropped row shouldn't appear then the drop still works, but it'll look to the user like the source just disappeared. That might be confusing; or if the destination is some designated "hidden track" then it be what you want.

SEE ALSO

Gtk2::TreeModelFilter, Gtk2::TreeModel

HOME PAGE

http://user42.tuxfamily.org/gtk2-ex-treemodelfilter-dragdest/

COPYRIGHT

Copyright 2008, 2009, 2010 Kevin Ryde

Gtk2-Ex-TreeModelFilter-DragDest is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 3, or (at your option) any later version.

Gtk2-Ex-TreeModelFilter-DragDest is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.

You should have received a copy of the GNU General Public License along with Gtk2-Ex-TreeModelFilter-DragDest. If not, see http://www.gnu.org/licenses/.