Added selected_handles() to navigation views for compatibility with listviews
svn: r15766
This commit is contained in:
parent
c9f82192b1
commit
e7d365a5d7
@ -136,6 +136,24 @@ def obj2target(target):
|
|||||||
}
|
}
|
||||||
return d[target] if target in d else None
|
return d[target] if target in d else None
|
||||||
|
|
||||||
|
def model_contains(model, path, iter, data):
|
||||||
|
"""
|
||||||
|
Returns True if data is a row in model.
|
||||||
|
"""
|
||||||
|
# check type and value
|
||||||
|
# data[0] is type of drop item, data[1] is ScratchPad object
|
||||||
|
print "-----"
|
||||||
|
if data[0] == 'TEXT':
|
||||||
|
print model.get_value(iter, 0), data[0]
|
||||||
|
print model.get_value(iter, 1)._value, data[1]._value
|
||||||
|
return ((model.get_value(iter, 0) == data[0]) and
|
||||||
|
(model.get_value(iter, 1)._value == data[1]._value))
|
||||||
|
else:
|
||||||
|
print model.get_value(iter, 0), data[0]
|
||||||
|
print model.get_value(iter, 1)._handle, data[1]._handle
|
||||||
|
return ((model.get_value(iter, 0) == data[0]) and
|
||||||
|
(model.get_value(iter, 1)._handle == data[1]._handle))
|
||||||
|
|
||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
#
|
#
|
||||||
# wrapper classes to provide object specific listing in the ListView
|
# wrapper classes to provide object specific listing in the ListView
|
||||||
@ -1349,6 +1367,11 @@ class ScratchPadListView(object):
|
|||||||
o_list = o.get_objects()
|
o_list = o.get_objects()
|
||||||
else:
|
else:
|
||||||
o_list = [o]
|
o_list = [o]
|
||||||
|
data = [o.__class__.DRAG_TARGET.drag_type, o, o.tooltip,
|
||||||
|
o._type, o._value]
|
||||||
|
import pdb; pdb.set_trace()
|
||||||
|
contains = model.foreach(model_contains, data)
|
||||||
|
if not contains:
|
||||||
for o in o_list:
|
for o in o_list:
|
||||||
drop_info = widget.get_dest_row_at_pos(x, y)
|
drop_info = widget.get_dest_row_at_pos(x, y)
|
||||||
if drop_info:
|
if drop_info:
|
||||||
@ -1356,17 +1379,16 @@ class ScratchPadListView(object):
|
|||||||
node = model.get_iter(path)
|
node = model.get_iter(path)
|
||||||
if (position == gtk.TREE_VIEW_DROP_BEFORE
|
if (position == gtk.TREE_VIEW_DROP_BEFORE
|
||||||
or position == gtk.TREE_VIEW_DROP_INTO_OR_BEFORE):
|
or position == gtk.TREE_VIEW_DROP_INTO_OR_BEFORE):
|
||||||
model.insert_before(node,[o.__class__.DRAG_TARGET.drag_type,
|
model.insert_before(node, data)
|
||||||
o, o.tooltip, o._type, o._value])
|
|
||||||
else:
|
else:
|
||||||
model.insert_after(node,[o.__class__.DRAG_TARGET.drag_type,
|
model.insert_after(node, data)
|
||||||
o, o.tooltip, o._type, o._value])
|
|
||||||
else:
|
else:
|
||||||
model.append([o.__class__.DRAG_TARGET.drag_type, o, o.tooltip,
|
model.append(data)
|
||||||
o._type, o._value])
|
|
||||||
|
|
||||||
if context.action == ACTION_MOVE:
|
if context.action == ACTION_MOVE:
|
||||||
context.finish(True, True, time)
|
context.finish(True, True, time)
|
||||||
|
elif context.action == ACTION_MOVE:
|
||||||
|
context.finish(True, True, time)
|
||||||
|
|
||||||
# remember time for double drop workaround.
|
# remember time for double drop workaround.
|
||||||
self._previous_drop_time = realTime
|
self._previous_drop_time = realTime
|
||||||
|
Loading…
Reference in New Issue
Block a user