SyncDataHandlers.cs
1.88 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
64
65
66
67
using System;
using System.Collections.Generic;
using System.Linq;
using Sungero.Core;
using Sungero.CoreEntities;
using DirRX.Storage.SyncData;
namespace DirRX.Storage
{
partial class SyncDataFilteringServerHandler<T>
{
public override IQueryable<T> Filtering(IQueryable<T> query, Sungero.Domain.FilteringEventArgs e)
{
var filter = _filter;
if (filter == null)
return query;
query = base.Filtering(query, e);
// Фильтр по системе-источнику.
if (filter.SourceSystem != null)
query = query.Where(f => f.ExternalSystem == filter.SourceSystem);
// Фильтр по состоянию.
var stages = new List<Sungero.Core.Enumeration>();
if (filter.InQueue)
stages.Add(CurrentState.InQueue);
if (filter.InProcess)
stages.Add(CurrentState.InProcess);
if (filter.Completed)
stages.Add(CurrentState.Complete);
if (filter.Error)
stages.Add(CurrentState.Error);
query = query.Where(x => stages.Contains(x.CurrentState.Value));
// Фильтр по подтверждению.
if (filter.Confirmed && !filter.NotConfirmed)
query = query.Where(x => x.Accepted.HasValue);
else if (!filter.Confirmed && filter.NotConfirmed)
query = query.Where(x => !x.Accepted.HasValue);
// Фильтр по диапазону лет.
if (filter.DateRangeTo != null)
query = query.Where(f => f.Created <= filter.DateRangeTo.Value);
if (filter.DateRangeFrom != null)
query = query.Where(f => f.Created >= filter.DateRangeFrom.Value);
return query;
}
}
partial class SyncDataServerHandlers
{
public override void Saving(Sungero.Domain.SavingEventArgs e)
{
_obj.Name = "Пакет " + _obj.Created.Value.ToString();
}
}
}