TimeSheetStandardLeaveGrid.cs 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Threading;
  5. using System.Windows.Media.Imaging;
  6. using Comal.Classes;
  7. using InABox.Clients;
  8. using InABox.Core;
  9. using InABox.DynamicGrid;
  10. using InABox.WPF;
  11. using PRS.Shared;
  12. namespace PRSDesktop
  13. {
  14. public class TimeSheetStandardLeaveGrid : DynamicDataGrid<StandardLeave>, ISpecificGrid
  15. {
  16. public DateTime From { get; set; }
  17. public DateTime To { get; set; }
  18. public TimeSheetStandardLeaveGrid() : base()
  19. {
  20. ColumnsTag = "TimeSheetStandardLeave";
  21. ActionColumns.Add(new DynamicImageColumn(SelectedImage, SelectedAction));
  22. HiddenColumns.Add(x => x.LeaveType.ID);
  23. HiddenColumns.Add(x => x.From);
  24. HiddenColumns.Add(x => x.FromTime);
  25. HiddenColumns.Add(x => x.To);
  26. HiddenColumns.Add(x => x.ToTime);
  27. HiddenColumns.Add(x => x.Name);
  28. }
  29. protected override void DoReconfigure(DynamicGridOptions options)
  30. {
  31. base.DoReconfigure(options);
  32. options.Clear();
  33. options.SelectColumns = true;
  34. }
  35. public override DynamicGridColumns GenerateColumns()
  36. {
  37. var columns = new DynamicGridColumns();
  38. columns.Add<StandardLeave>(x => x.Name, 0, "Name", "", Alignment.MiddleLeft);
  39. columns.Add<StandardLeave>(x => x.LeaveType.Description, 200, "Type", "", Alignment.MiddleCenter);
  40. columns.Add<StandardLeave>(x => x.From, 80, "", "dd MMM yy", Alignment.MiddleCenter);
  41. columns.Add<StandardLeave>(x => x.To, 80, "", "dd MMM yy", Alignment.MiddleCenter);
  42. return columns;
  43. }
  44. private BitmapImage tick = PRSDesktop.Resources.tick.AsBitmapImage();
  45. public HashSet<Guid> SelectedIDs = new HashSet<Guid>();
  46. private bool SelectedAction(CoreRow? arg)
  47. {
  48. if (arg == null)
  49. {
  50. foreach (var row in Data.Rows)
  51. ToggleRow(row);
  52. }
  53. else
  54. ToggleRow(arg);
  55. return false;
  56. }
  57. private void ToggleRow(CoreRow row)
  58. {
  59. Guid id = row.Get<StandardLeave, Guid>(x => x.ID);
  60. if (!SelectedIDs.Add(id))
  61. SelectedIDs.Remove(id);
  62. InvalidateRow(row);
  63. }
  64. private BitmapImage? SelectedImage(CoreRow? arg)
  65. {
  66. return arg == null
  67. ? tick
  68. : SelectedIDs.Contains(arg.Get<StandardLeave,Guid>(x=>x.ID))
  69. ? tick
  70. : null;
  71. }
  72. protected override void Reload(
  73. Filters<StandardLeave> criteria, Columns<StandardLeave> columns, ref SortOrder<StandardLeave>? sort,
  74. CancellationToken token, Action<CoreTable?, Exception?> action)
  75. {
  76. criteria.Add(new InABox.Core.Filter<StandardLeave>(x => x.From).IsLessThanOrEqualTo(To)
  77. .And(x => x.To).IsGreaterThanOrEqualTo(From)
  78. .And(x =>x.Processed).IsEqualTo(DateTime.MinValue));
  79. base.Reload(criteria, columns, ref sort, token, action);
  80. }
  81. public void Process(IProgress<String> progress)
  82. {
  83. if (SelectedIDs.Count == 0)
  84. return;
  85. progress.Report("Loading Standard Leaves");
  86. var empdates = new Filter<Employee>().All();
  87. empdates.Ands.Add(new Filter<Employee>(x => x.StartDate).IsEqualTo(DateTime.MinValue)
  88. .Or(x => x.StartDate).IsLessThanOrEqualTo(To));
  89. empdates.Ands.Add(new Filter<Employee>(x => x.FinishDate).IsEqualTo(DateTime.MinValue)
  90. .Or(x => x.FinishDate).IsGreaterThanOrEqualTo(From));
  91. var employees = new Client<Employee>().Query(
  92. empdates,
  93. Columns.None<Employee>().Add(x => x.ID)
  94. .Add(x => x.Name)
  95. .Add(x => x.RosterStart)
  96. .Add(x => x.StartDate)
  97. .Add(x => x.FinishDate))
  98. .ToArray<Employee>();
  99. var rosters = Client.Query(
  100. new Filter<EmployeeRosterItem>(x => x.Employee.ID).InList(employees.ToArray(x => x.ID)),
  101. orderby: new SortOrder<EmployeeRosterItem>(x => x.Day))
  102. .ToObjects<EmployeeRosterItem>()
  103. .GroupBy(x => x.Employee.ID)
  104. .ToDictionary(x => x.Key, x => x.ToArray());
  105. int i = 0;
  106. var leaves = new List<StandardLeave>();
  107. foreach (var row in Data.Rows)
  108. {
  109. if (SelectedIDs.Contains(row.Get<StandardLeave,Guid>(x=>x.ID)))
  110. {
  111. var leave = row.ToObject<StandardLeave>();
  112. foreach (var employee in employees)
  113. {
  114. var roster = rosters.GetValueOrDefault(employee.ID);
  115. progress.Report($"Processing Standard Leave {((double)i * 100.0F)/((double)SelectedIDs.Count * employees.Length):F2}%");
  116. var timesheets = RosterUtils.CreateLeaveTimesheets(
  117. employee,
  118. roster,
  119. leave.From,
  120. leave.FromTime,
  121. leave.To,
  122. leave.ToTime,
  123. leave.LeaveType.ID,
  124. (timesheet) =>
  125. {
  126. timesheet.Notes = leave.Name;
  127. timesheet.StandardLeaveLink.ID = leave.ID;
  128. }
  129. );
  130. Client.Save(timesheets, "Updated from TimeSheet leave Processor");
  131. i++;
  132. }
  133. leave.Processed = DateTime.Now;
  134. leaves.Add(leave);
  135. }
  136. }
  137. if (leaves.Count != 0)
  138. {
  139. progress.Report("Saving Standard Leaves");
  140. Client.Save(leaves, "Updated from TimeSheet leave Processor");
  141. }
  142. }
  143. }
  144. }