TimeSheetLeaveRequestGrid.cs 6.1 KB

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