Reorder Items in Grouped ListView
This help topic will provide an overview on how you could enable reordering feature of RadListView control when its items are grouped.
Before proceeding, please check the Reorder Items topic which describes in details reordering functionality of the ListView.
When the items of RadListView are grouped by a certain criteria and the end user drags/starts reordering an item, the dragged item could be added to a different group. Since this depends on the items' relation, in order to handle the scenario, you would need to subscribe to the ListView Reorder Command and manually update the dragged item details. Below you could find a sample implementation.
First, let's create a sample business object, for example Event:
public class Event : NotifyPropertyChangedBase
{
public string _content;
public string _day;
public string Content
{
get { return this._content; }
set
{
if(this._content != value)
{
this._content = value;
OnPropertyChanged();
}
}
}
public string Day
{
get { return this._day; }
set
{
if(this._day != value)
{
this._day = value;
OnPropertyChanged();
}
}
}
}
Then, create a ViewModel class containing a collection of Event objects as well as a Reorder command implementation considering the Events will be grouped according to Day property. Inside the Reorder command you will have access to some useful details through ReorderEndedCommandContext such as:
- Item: Refers to the data item that is being interacted with.
- DestinationItem: Refers to the data item that corresponds to the location where the dragged item has been released.
- Group: Gets the group containing the data item that is being interacted with.
- DestinationGroup: Refers to the group that corresponds to the location where the dragged item has been released.
- Placement (of type ItemReorderPlacement): Indicates whether the dragged item should be placed before or after the destination item.
public class ViewModel
{
public ViewModel()
{
this.Events = new ObservableCollection<Event>()
{
new Event() { Content = "Meeting with John", Day = "Tommorow" },
new Event() { Content = "This also happens today", Day = "Yesterday" },
new Event() { Content = "More events today", Day = "Today" },
new Event() { Content = "Go shopping after 19:00", Day = "Yesterday" },
new Event() { Content = "Lunch with Sara", Day = "Today" },
new Event() { Content = "Planning for tommorow", Day = "Today"},
new Event() { Content = "Free lunch time", Day = "Yesterday" },
new Event() { Content = "Kids Party", Day = "Tommorow" },
new Event() { Content = "Party", Day = "Tommorow" }
};
this.ReorderCommand = new Command<ReorderEndedCommandContext>(this.Reorder);
}
public ObservableCollection<Event> Events { get; set; }
public Command<ReorderEndedCommandContext> ReorderCommand { get; }
private void Reorder(ReorderEndedCommandContext context)
{
var sourceItem = (Event)context.Item;
this.Events.Remove(sourceItem);
var destinationItem = (Event)context.DestinationItem;
var destinationGroup = context.DestinationGroup;
var destinationIndex = this.Events.IndexOf(destinationItem);
if (context.Placement == ItemReorderPlacement.After)
{
destinationIndex++;
}
sourceItem.Day = (string)destinationGroup.Key;
this.Events.Insert(destinationIndex, sourceItem);
}
}
And here is the RadListView definition with PropertyGroupDescriptor and Reorder command applied:
<telerikDataControls:RadListView x:Name="listView"
ItemsSource="{Binding Events}"
IsItemsReorderEnabled="True">
<telerikDataControls:RadListView.ItemTemplate>
<DataTemplate>
<telerikListView:ListViewTemplateCell>
<telerikListView:ListViewTemplateCell.View>
<StackLayout Orientation="Horizontal" Padding="16, 0, 0, 0">
<Label Margin="0,2,0,0" Text="" FontFamily="{StaticResource IconsFontFamily}" />
<Label Text="{Binding Content}" TextColor="#6F6F70" FontSize="Small" />
</StackLayout>
</telerikListView:ListViewTemplateCell.View>
</telerikListView:ListViewTemplateCell>
</DataTemplate>
</telerikDataControls:RadListView.ItemTemplate>
<telerikDataControls:RadListView.GroupDescriptors>
<telerikListView:PropertyGroupDescriptor PropertyName="Day"/>
</telerikDataControls:RadListView.GroupDescriptors>
<telerikDataControls:RadListView.Commands>
<telerikListViewCommands:ListViewUserCommand Id="ReorderEnded"
Command="{Binding ReorderCommand}" />
</telerikDataControls:RadListView.Commands>
</telerikDataControls:RadListView>
Lastly, set the ViewModel as a BindingContext:
this.BindingContext = new ViewModel();
You could check the result on the image below: