-
Notifications
You must be signed in to change notification settings - Fork 2
Expand file tree
/
Copy pathMainWindow.xaml.cs
More file actions
63 lines (58 loc) · 2.6 KB
/
MainWindow.xaml.cs
File metadata and controls
63 lines (58 loc) · 2.6 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
57
58
59
60
61
62
63
using System.Windows;
using XPOIssues.Issues;
using System;
using System.Linq.Expressions;
using DevExpress.Data.Filtering;
using DevExpress.Xpf.Data;
using System.Linq;
using System.Threading.Tasks;
using DevExpress.Xpo;
using DevExpress.Xpf.Grid;
namespace XPOIssues {
public partial class MainWindow : Window {
public MainWindow() {
InitializeComponent();
using(var session = new Session()) {
var classInfo = session.GetClassInfo<Issue>();
var properties = classInfo.Members
.Where(member => member.IsPublic && member.IsPersistent)
.Select(member => member.Name)
.ToArray();
_DetachedObjectsHelper = DetachedObjectsHelper<Issue>.Create(classInfo.KeyProperty.Name, properties);
}
var source = new InfiniteAsyncSource {
CustomProperties = _DetachedObjectsHelper.Properties,
KeyProperty = nameof(Issue.Oid)
};
source.FetchRows += OnFetchRows;
source.GetTotalSummaries += OnGetTotalSummaries;
grid.ItemsSource = source;
LoadLookupData();
}
Expression<Func<Issue, bool>> MakeFilterExpression(CriteriaOperator filter) {
var converter = new GridFilterCriteriaToExpressionConverter<Issue>();
return converter.Convert(filter);
}
DetachedObjectsHelper<Issue> _DetachedObjectsHelper;
void OnFetchRows(object sender, FetchRowsAsyncEventArgs e) {
e.Result = Task.Run<FetchRowsResult>(() => {
using(var session = new Session()) {
var queryable = session.Query<Issue>().SortBy(e.SortOrder, defaultUniqueSortPropertyName: nameof(Issue.Oid)).Where(MakeFilterExpression(e.Filter));
var items = queryable.Skip(e.Skip).Take(e.Take ?? 100).ToArray();
return _DetachedObjectsHelper.ConvertToDetachedObjects(items);
}
});
}
void OnGetTotalSummaries(object sender, GetSummariesAsyncEventArgs e) {
e.Result = Task.Run(() => {
using(var session = new Session()) {
return session.Query<Issue>().Where(MakeFilterExpression(e.Filter)).GetSummaries(e.Summaries);
}
});
}
void LoadLookupData() {
var session = new Session();
usersLookup.ItemsSource = session.Query<User>().OrderBy(user => user.Oid).Select(user => new { Id = user.Oid, Name = user.FirstName + " " + user.LastName }).ToArray();
}
}
}