| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788 | 
							- using System;
 
- using System.Collections.Generic;
 
- using System.Linq;
 
- using System.Windows.Controls;
 
- using Comal.Classes;
 
- using InABox.Core;
 
- using InABox.DynamicGrid;
 
- namespace PRSDesktop
 
- {
 
-     public class LeaveRequestGrid : DynamicDataGrid<LeaveRequest>
 
-     {
 
-         public bool FutureOnly = true;
 
-         private bool InProgressOnly = true;
 
-         public LeaveRequestGrid()
 
-         {
 
-             Options.AddRange(DynamicGridOption.RecordCount, DynamicGridOption.FilterRows, DynamicGridOption.SelectColumns);
 
-             AddButton("Include Complete", null, IncompleteOnlyClick);
 
-             AddButton("Include History", null, ToggleAllRequests);
 
-         }
 
-         private bool IncompleteOnlyClick(Button btn, CoreRow[] arg2)
 
-         {
 
-             InProgressOnly = !InProgressOnly;
 
-             UpdateButton(btn, null, InProgressOnly ? "Include Complete" : "In Progress Only");
 
-             return true;
 
-         }
 
-         private bool ToggleAllRequests(Button btn, CoreRow[] rows)
 
-         {
 
-             FutureOnly = !FutureOnly;
 
-             UpdateButton(btn, null, FutureOnly ? "Include History" : "Future Only");
 
-             return true;
 
-         }
 
-         protected override void Reload(Filters<LeaveRequest> criteria, Columns<LeaveRequest> columns, ref SortOrder<LeaveRequest> sort,
 
-             Action<CoreTable, Exception> action)
 
-         {
 
-             if (InProgressOnly)
 
-                 criteria.Add(new Filter<LeaveRequest>(x => x.Status).IsEqualTo(LeaveRequestStatus.InProgress));
 
-             if (FutureOnly)
 
-                 criteria.Add(new Filter<LeaveRequest>(x => x.To).IsGreaterThanOrEqualTo(DateTime.Today));
 
-             base.Reload(criteria, columns, ref sort, action);
 
-         }
 
-         protected override Dictionary<string, object> EditorValueChanged(DynamicEditorForm editor, LeaveRequest[] items, string name, object value)
 
-         {
 
-             var result = base.EditorValueChanged(editor, items, name, value);
 
-             if (name == "LeaveType.ID")
 
-             {
 
-                 ReloadForms<LeaveRequest, LeaveRequestForm, ActivityForm>(editor, items.FirstOrDefault(), x => x.Activity.ID,
 
-                     value != null ? (Guid)value : Guid.Empty);
 
-             }
 
-             else if (name.Equals("EmployeeLink.ID"))
 
-             {
 
-                 var activity = editor.FindEditor("LeaveType.ID") as ILookupEditorControl;
 
-                 if (activity != null)
 
-                     DefineLookups(activity, items);
 
-             }
 
-             return result;
 
-         }
 
-         protected override void AfterLoad(DynamicEditorForm editor, LeaveRequest[] items)
 
-         {
 
-             base.AfterLoad(editor, items);
 
-             if (items.FirstOrDefault().ID == Guid.Empty)
 
-                 ReloadForms<LeaveRequest, LeaveRequestForm, ActivityForm>(editor, items.FirstOrDefault(), x => x.Activity.ID,
 
-                     items.FirstOrDefault().LeaveType.ID);
 
-         }
 
-         protected override BaseEditor? GetEditor(object item, DynamicGridColumn column)
 
-         {
 
-             var result = base.GetEditor(item, column);
 
-             if (result == null)
 
-                 return null;
 
-             if (!Security.IsAllowed<CanApproveLeaveRequests>() && (column.ColumnName.Equals("Approved") || column.ColumnName.Equals("Status")))
 
-                 result.Editable = Editable.Disabled;
 
-             return result;
 
-         }
 
-     }
 
- }
 
 
  |