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;
- }
- }
- }
|