В настоящее время я разрабатываю приложение, в котором даты сгруппированы по годам и месяцам (внутренние группы).
Я погуглил несколько примеров группирования в TreeView
и нашел такое решение: я использую простой список дат как Source
для CollectionViewSource
, определяю группы и сортировки, пишу шаблон для моего TreeView
и так далее.
Рабочие примеры (но только для вложенности одной группы) включают такой код:
<TreeView ItemsSource={Binding Source={StaticResource CVS}, Path=Groups} />
.
Поскольку я использую шаблон MVVM, я определяю CollectionViewSource
как свойство модели представления (не как ресурс).
Может быть, я встал не с той ноги, но я не смог перенести код выше, я пытался сделать это:
<TreeView ItemsSource={Binding Path=CVS.Groups} />
и так:
<TreeView ItemsSource={Binding Path=CVS.View} />
но это не работает. CollectionViewSource
не имеет свойства Group
.
Что я делаю не так?
UPDATE:
Полный исходный код:
В DayWorkInfoViewModel.cs:
internal sealed class DayWorkInfoViewModel : ViewModelBase
{
#region properties
private DateTime _date;
public DateTime Date
{
get
{
return _date;
}
set
{
if (_date != value)
{
_date = value;
OnPropertyChanged("Date");
OnPropertyChanged("Year");
OnPropertyChanged("Month");
OnPropertyChanged("MonthName");
OnPropertyChanged("Day");
}
}
}
public int Year
{
get
{
return Date.Year;
}
}
public int Month
{
get
{
return Date.Month;
}
}
public string MonthName
{
get
{
return CultureInfo.CurrentCulture.DateTimeFormat.GetMonthName(Date.Month);
}
}
public int Day
{
get
{
return Date.Day;
}
}
#endregion properties
}
В DayWorkViewModel.cs:
internal sealed class WorkViewModel : PageBaseViewModel
{
#region fields
private readonly IWorkService _workService;
#endregion fields
#region properties
private readonly ObservableCollection<DayWorkInfoViewModel> _dayWorkInfos = new ObservableCollection<DayWorkInfoViewModel>();
public CollectionViewSource DayWorkInfos { get; set; }
private DayWorkInfoViewModel _selectedDayWorkInfo;
public DayWorkInfoViewModel SelectedDayWorkInfo
{
get
{
return _selectedDayWorkInfo;
}
set
{
if (_selectedDayWorkInfo != value)
{
_selectedDayWorkInfo = value;
OnPropertyChanged("SelectedDayWorkInfo");
}
}
}
#endregion properties
#region command properties
#endregion command properties
#region ctors
public WorkViewModel()
{
if (IsInDesign)
{
_workService = new SimpleWorkService();
}
else
{
_workService = new WorkService();
}
DayWorkInfos = new CollectionViewSource { Source = _dayWorkInfos };
DayWorkInfos.GroupDescriptions.Add(new PropertyGroupDescription("Year"));
DayWorkInfos.GroupDescriptions.Add(new PropertyGroupDescription("MonthName"));
DayWorkInfos.SortDescriptions.Add(new SortDescription("Year", ListSortDirection.Ascending));
DayWorkInfos.SortDescriptions.Add(new SortDescription("Month", ListSortDirection.Ascending));
DoAsync<IEnumerable<DateTime>>(
() =>
{
return _workService.GetDayWorkInfos();
},
(result) =>
{
_dayWorkInfos.Clear();
foreach (var dt in result)
{
_dayWorkInfos.Add(new DayWorkInfoViewModel { Date = dt });
}
//DayWorkInfos.View.Refresh();
},
(exc) =>
{
ShowError("Couldn't load work dates...");
},
"Loading work dates...");
}
#endregion ctors
}
В WorkView.xaml:
<controls:PageBase.Resources>
<DataTemplate x:Key="DayTemplate">
<TextBlock Text="{Binding Path=Day}" />
</DataTemplate>
<HierarchicalDataTemplate x:Key="MonthTemplate"
ItemsSource="{Binding Path=Items}"
ItemTemplate="{StaticResource DayTemplate}">
<TextBlock Text="{Binding Path=Date}" />
</HierarchicalDataTemplate>
<HierarchicalDataTemplate x:Key="YearTemplate"
ItemsSource="{Binding Path=Items}"
ItemTemplate="{StaticResource MonthTemplate}">
<TextBlock Text="{Binding Path=Year}" />
</HierarchicalDataTemplate>
</controls:PageBase.Resources>
<Grid>
<telerik:RadTreeView Margin="10"
BorderBrush="Red"
BorderThickness="3"
ItemsSource="{Binding DayWorkInfo.Groups}"
ItemTemplate="{StaticResource YearTemplate}" />
</Grid>
В WorkView.xaml.cs:
public partial class WorkView : PageBase
{
#region ctors
public WorkView()
{
InitializeComponent();
DataContext = new WorkViewModel();
}
#endregion ctors
}