-
Notifications
You must be signed in to change notification settings - Fork 2
Expand file tree
/
Copy pathMainWindow.xaml.cs
More file actions
56 lines (51 loc) · 2.14 KB
/
MainWindow.xaml.cs
File metadata and controls
56 lines (51 loc) · 2.14 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
using System.Windows;
using EntityFrameworkIssues.Issues;
using System;
using System.Linq.Expressions;
using DevExpress.Data.Filtering;
using DevExpress.Xpf.Data;
using System.Linq;
using System.Threading.Tasks;
using System.Data.Entity;
using DevExpress.Xpf.Grid;
namespace EntityFrameworkIssues {
public partial class MainWindow : Window {
public MainWindow() {
InitializeComponent();
var source = new PagedAsyncSource {
ElementType = typeof(Issue),
KeyProperty = nameof(Issue.Id),
PageNavigationMode = PageNavigationMode.ArbitraryWithTotalPageCount
};
source.FetchPage += OnFetchPage;
source.GetTotalSummaries += OnGetTotalSummaries;
grid.ItemsSource = source;
LoadLookupData();
}
Expression<Func<Issue, bool>> MakeFilterExpression(CriteriaOperator filter) {
var converter = new GridFilterCriteriaToExpressionConverter<Issue>();
return converter.Convert(filter);
}
void OnFetchPage(object sender, FetchPageAsyncEventArgs e) {
const int pageTakeCount = 5;
e.Result = Task.Run<FetchRowsResult>(() => {
var context = new IssuesContext();
var queryable = context.Issues.AsNoTracking()
.SortBy(e.SortOrder, defaultUniqueSortPropertyName: nameof(Issue.Id))
.Where(MakeFilterExpression(e.Filter));
return queryable.Skip(e.Skip).Take(e.Take * pageTakeCount).ToArray();
});
}
void OnGetTotalSummaries(object sender, GetSummariesAsyncEventArgs e) {
e.Result = Task.Run(() => {
var context = new IssuesContext();
var queryable = context.Issues.Where(MakeFilterExpression(e.Filter));
return queryable.GetSummaries(e.Summaries);
});
}
void LoadLookupData() {
var context = new IssuesContext();
usersLookup.ItemsSource = context.Users.Select(user => new { Id = user.Id, Name = user.FirstName + " " + user.LastName }).ToArray();
}
}
}