InOutModel.cs 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  1. using System;
  2. using System.Linq;
  3. using Comal.Classes;
  4. using InABox.Core;
  5. using System.Diagnostics.CodeAnalysis;
  6. namespace comal.timesheets
  7. {
  8. public class InOutModel : ListModel<InOutModel,InOutShell,Employee>
  9. {
  10. public InOutModel(IModelHost host, Func<Filter<Employee>> filter, bool transient = false) : base(host, filter, transient)
  11. {
  12. }
  13. public InOutModel(IModelHost host, Func<Filter<Employee>> filter, [NotNull] string filename) : base(host, filter, filename)
  14. {
  15. }
  16. protected override void Initialize()
  17. {
  18. base.Initialize();
  19. _statuses = new Tuple<Guid, TimeSpan, TimeSpan>[] { };
  20. }
  21. private Tuple<Guid, TimeSpan, TimeSpan>[] _statuses;
  22. public bool IsClockedOn(Guid id) => _statuses.Any(x => x.Item1.Equals(id) && x.Item3.Equals(TimeSpan.Zero));
  23. public TimeSpan StartTime(Guid id) => _statuses.FirstOrDefault(x => x.Item1.Equals(id))?.Item2 ?? TimeSpan.Zero;
  24. public TimeSpan FinishTime(Guid id) => _statuses.FirstOrDefault(x => x.Item1.Equals(id))?.Item3 ?? TimeSpan.Zero;
  25. public override void BeforeLoad(MultiQuery query)
  26. {
  27. base.BeforeLoad(query);
  28. query.Add<TimeSheet>(
  29. new Filter<TimeSheet>(x=>x.EmployeeLink.ID)
  30. .InQuery(Filter(), x=>x.ID)
  31. .And(x=>x.Date).IsEqualTo(DateTime.Today),
  32. new Columns<TimeSheet>(x=>x.EmployeeLink.ID)
  33. .Add(x=>x.Start)
  34. .Add(x=>x.Finish)
  35. );
  36. }
  37. public override void AfterLoad(MultiQuery query)
  38. {
  39. base.AfterLoad(query);
  40. _statuses = query.Get<TimeSheet>()
  41. .ToTuples<TimeSheet, Guid, TimeSpan, TimeSpan>(x => x.EmployeeLink.ID, x => x.Start, x => x.Finish).ToArray();
  42. }
  43. }
  44. }