Welcome Guest Search | Active Topics | Sign In | Register

eo_RegisterDragTarget example bug + finding target treenode Options
ixthnar
Posted: Tuesday, December 28, 2010 10:37:37 AM
Rank: Advanced Member
Groups: Member

Joined: 11/15/2008
Posts: 44
I am working with TreeView DragDropScope="Global" (using EO 8.0.44.2) with targets that include the treeview itself, another treeview, and a non-EO construct wrapped in a callback_panel. I sure would love more documentation. For example, what is "mode"?

In ~/Demos/TreeView/Programming/Drag Drop to Grid/Demo.aspx line 101 the code is
GridDragTarget.prototype.drop = function(mode, type, data)
In use, the provided parameters are
GridDragTarget.prototype.drop = function(type, mode, data)

Could you provide code EO's code that accomplishes the TreeView DragDropScope="Local" behavior for moving? While I have implemented a drop to my own, non-EO target, I still want the default behavior when the treeview is the drop target. Alternatively, could you advise on how to best identify the treenode under an x,y coordinate. Yes, I can figure out a brute force way to do this, but I am thinking that you have a better.

Thanks so much,
Chris
eo_support
Posted: Tuesday, December 28, 2010 3:45:53 PM
Rank: Administration
Groups: Administration

Joined: 5/27/2007
Posts: 24,229
Hi,

"Global" and "Local" used to control whether the TreeView to recognize an external drag target. When DragDropScope is set to "Local", drag and drop only works within the TreeView itself. When it is set to "Global", you can drag it to elsewhere. Unfortunately I do not believe you can have both at the same time because there is no public JavaScript API for you add tree node on the client side.

The argument you noticed about drop function is a bug. The correct sequence should be (mode, type, data) in order to be consistent with other methods. We will change that in our next build.

I believe "mode" is a pass through parameter. You can implement a get_DragMode method on your drag source. That method will be called to return a "mode" value, which will be passed to your drop function on your drag target object. Thus a drag source can use "mode" to indicate additional information that maybe useful for the drag target. A typical example is a drag source can return "mode" "1" if ctrl key is down to indicate the drag drop should perform a "copy" instead of a "move", and return "mode" "0" if ctrl key is not down. Usually the drag source will define what value means what, and the drag target then interprets it according to that definition. No EO controls set mode though.

There is no easy way to find out a node under an x, y coordinate. We have such function internally on the TreeView (in order to support the built-in drag drop), but it is not exposed. We will see if we can expose it.

Thanks
ixthnar
Posted: Tuesday, December 28, 2010 4:05:02 PM
Rank: Advanced Member
Groups: Member

Joined: 11/15/2008
Posts: 44
Thank you for the clear, informative response!!

I like the drop fix even though I'll have change my code. Better than the "creat" legacy from K&R C 8)

It would be great if the TreeView equivalent of Grid's findCell could be exposed. I am completing my equivalent but I'll bet EO's is better.

Thanks,
Chris

(If you folks are ever in the market for another enthusiastic software engineer, I'd love working with you folks!)
eo_support
Posted: Tuesday, December 28, 2010 4:12:15 PM
Rank: Administration
Groups: Administration

Joined: 5/27/2007
Posts: 24,229
You are very welcome. We will try to expose that function as soon as possible. Our implementation might be better because it has access to all our internal data, so it has some nature advantages. : )

We do not have any opening right now but we will keep your offering in mind!
ixthnar
Posted: Tuesday, December 28, 2010 9:52:19 PM
Rank: Advanced Member
Groups: Member

Joined: 11/15/2008
Posts: 44
Like I need more work ;)

Approach 1: The classic elementFromPoint(x,y)-like approach get's the drag image but not "below" it into the TreeView TreeNodes.

Approach 2: Traverse TreeNodes to determine whether one includes the onDragInTarget x,y. Dropped because I cannot find a way to get the coordinates of a TreeNode.

Approach 3: Beg you folks to tell me which obscured EO method can help. Working on this one 8)

Approach 4: drop the eo_RegisterDragTarget support and write yet-another-drag-drop utility but for EO TreeViews. Seems crazy wasteful.

What are my prospects for the 3rd approach?

Thanks,
Chris
eo_support
Posted: Wednesday, December 29, 2010 9:23:24 AM
Rank: Administration
Groups: Administration

Joined: 5/27/2007
Posts: 24,229
Hi,

The third approach is the best approach. We won't tell you which obscured EO method though because we DO NOT KNOW whether it will work for you. It was only intended to be used internally so it may have a number of restrictions (such as you have to call another method before calling that method, or the arguments/return values are interpreted differently than you would hoped, etc). In order for you to use it, we have to sort all those out and document them clearly. That means you will have to wait until we make it public. : )

Thanks!
ixthnar
Posted: Wednesday, December 29, 2010 9:46:05 AM
Rank: Advanced Member
Groups: Member

Joined: 11/15/2008
Posts: 44
Thanks and cool!! Any thoughts on timing? I can work on other areas in the mean time ... it takes some rigor to shift focus leaving a bit of work uncompleted.

Cheers and Happy New Year!
eo_support
Posted: Wednesday, December 29, 2010 11:29:35 AM
Rank: Administration
Groups: Administration

Joined: 5/27/2007
Posts: 24,229
We do not have an ETA yet. We will try to put it out as soon as possible but it will be after the new year for sure.
eo_support
Posted: Tuesday, January 11, 2011 4:30:50 PM
Rank: Administration
Groups: Administration

Joined: 5/27/2007
Posts: 24,229
Hi,

We have posted a new build that added findNode on the client side TreeView object. Please see your private message for the download location.

Thanks!
ixthnar
Posted: Tuesday, January 11, 2011 5:43:33 PM
Rank: Advanced Member
Groups: Member

Joined: 11/15/2008
Posts: 44
Hooray!! You folks really rock. EO forever!!


You cannot post new topics in this forum.
You cannot reply to topics in this forum.
You cannot delete your posts in this forum.
You cannot edit your posts in this forum.
You cannot create polls in this forum.
You cannot vote in polls in this forum.