Why not, but this will not solve the issue :)
I will probably fix that in the train today (5h long trip to Bordeaux ^^)
.

The issue is that the items are sorted by default, which means that 
the list is populated with a copy of the items provided.

Maybe it should not :)
Then for the convenient methods, I am not that sure :P
But maybe it’s a good use case for traits :P

Ben

On 04 Apr 2014, at 09:19, Goubier Thierry <thierry.goub...@cea.fr> wrote:

> Hi Ben,
> 
> I think that hard-linking the collections inside the drop block isn't working 
> in that case, so you have to write that without any reference to collection1 
> and collection2 :)
> 
> But, since you're here: why don't I have an API to add or remove items from 
> the ListModel instance? If I was working in VisualWorks, I would have used 
> one of the model subclasses for collections and I would have used its API for 
> adding or removing items... Here writing code like:
> 
> list1
>       acceptDropBlock: [ :transfer :event :source :receiver :index |
>               | c1 c2 l1 l2 |
>               l1 := source model model.
>                l2 := transfer source model model.
>                transfer passenger do: [ :e |
>                               l1 insert: e first before: index.
>                       l2 remove: e first ] ].
> 
> i.e. have the ListModel instance behave as a collection for a subset of the 
> usual collection api.
> 
> Thierry
> 
> Le 04/04/2014 00:40, Benjamin Van Ryseghem a écrit :
>> here is a "hackish" solution:
>> 
>>         collection1 := #(1 2 3 4 5) asOrderedCollection.
>>         collection2 := #($a $b $c $d $e) asOrderedCollection.
>>         list1 := ListModel new.
>>         list1 items: collection1.
>>         list1 dragEnabled: true.
>>         list1 dropEnabled: true.
>>          list1
>>                 acceptDropBlock: [ :transfer :event :source :receiver
>> :index |
>>                         | c1 c2 l1 l2 |
>>                         l1 := source model model.
>>                         c1 := l1 listItems.
>>                         l2 := transfer source model model.
>>                         c2 := l2 listItems.
>>                         transfer passenger
>>                                 do: [ :e |
>>                                         c1 insert: e first before: index.
>>                                         c2 remove: e first ].
>>                         l1 items: c1.
>> collection1 removeAll; addAll: c1.
>>                         l2 items: c2.
>> collection2 removeAll; addAll: c2. ].
>>         list1 openWithSpec.
>>         list2 := ListModel new.
>>         list2 items: collection2.
>>         list2 dragEnabled: true.
>>         list2 dropEnabled: true.
>>         list2 acceptDropBlock: [ :transfer :event :source :receiver
>> :index |
>> self halt ].
>>         ^ list2 openWithSpec.
>> 
>> The problem here is that by default, the list items are sorted, setting
>> the listItems with a copy.
>> Maybe it would be better to actually do not sort until one sets a real
>> sortingBlock.
>> 
>> Ben
>> 
>> 
>> 2014-04-03 22:55 GMT+02:00 MartinW <w...@fastmail.fm 
>> <mailto:w...@fastmail.fm>>:
>> 
>>    Goubier Thierry wrote
>>     > Another approach, that I would use, is to put more complex objects
>>     > inside the lists. Thoses objects would know how to get added /
>>    removed
>>     > from their respective collections, and then I would propagate
>>    collection
>>     > changes to the ListModel instances.
>> 
>>    That sounded promising. I made a Collectible class. It's instances
>>    know how
>>    to add themselves to a collection (i'm not sure if that's a good
>>    idea, but
>>    as experiment..)
>> 
>>    The problem is, i never get to these objects in my acceptDropBlock. In
>> 
>>    list1 acceptDropBlock: [ :transfer :event :source :receiver :index |
>>        transfer passenger do: [:element | element addSelfToCollection:
>>    collection1] ].
>> 
>>    the element is only a ByteString - the name of my Collectible object. :(
>> 
>>    Are there other possibilities if i do not use Spec?
>> 
>> 
>> 
>>    --
>>    View this message in context:
>>    
>> http://forum.world.st/Drag-and-drop-items-between-list-views-tp4752285p4752625.html
>>    Sent from the Pharo Smalltalk Users mailing list archive at Nabble.com.
>> 
>> 
> 
> -- 
> Thierry Goubier
> CEA list
> Laboratoire des Fondations des Systèmes Temps Réel Embarqués
> 91191 Gif sur Yvette Cedex
> France
> Phone/Fax: +33 (0) 1 69 08 32 92 / 83 95

Reply via email to