Employee.cs 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191
  1. using System;
  2. using System.Collections.Generic;
  3. using System.ComponentModel;
  4. using System.Linq;
  5. using System.Linq.Expressions;
  6. using InABox.Core;
  7. namespace Comal.Classes
  8. {
  9. [UserTracking("Human Resources")]
  10. public class Employee : Entity, IEmployee, ISchedulable, IPersistent, IRemotable, IOrgChart<EmployeeLink>, ILicense<CoreLicense>, IExportable,
  11. IImportable
  12. {
  13. [UniqueCodeEditor(Visible = Visible.Default, Editable = Editable.Enabled)]
  14. [EditorSequence(1)]
  15. public string Code { get; set; } = "";
  16. [EditorSequence(2)]
  17. public string Name { get; set; } = "";
  18. [EditorSequence("Payroll", 3)]
  19. public EmployeeType Type { get; set; }
  20. [EditorSequence(4)]
  21. [AddressEditor(true)]
  22. public Address Address { get; set; }
  23. [EditorSequence(5)]
  24. public string Email { get; set; }
  25. [EditorSequence(6)]
  26. [TextBoxEditor(Alignment = Alignment.MiddleCenter, Width = 120)]
  27. public string Mobile { get; set; }
  28. [DateEditor]
  29. [EditorSequence(7)]
  30. public DateTime DateOfBirth { get; set; }
  31. [EditorSequence(8)]
  32. public UserLink User { get; set; }
  33. [Obsolete("Replaced by User")]
  34. public UserLink UserLink
  35. {
  36. get => User;
  37. set { }
  38. }
  39. [CodeEditor(Editable = Editable.Enabled)]
  40. [EditorSequence(9)]
  41. [Obsolete("Replaced with EmployeeGroup", true)]
  42. public string Department { get; set; }
  43. [EditorSequence(10)]
  44. public EmployeeGroupLink Group { get; set; }
  45. [EditorSequence(11)]
  46. public ImageDocumentLink Thumbnail { get; set; }
  47. [SecondaryIndex]
  48. [CheckBoxEditor]
  49. [EditorSequence(12)]
  50. public bool CanAllocateTasks { get; set; }
  51. [CheckBoxEditor]
  52. [EditorSequence(13)]
  53. [Caption("Show In/Out Status?")]
  54. public bool ShowOnInOutBoard { get; set; }
  55. [SecondaryIndex]
  56. [DateEditor]
  57. [EditorSequence("Payroll", 1)]
  58. public DateTime StartDate { get; set; }
  59. [SecondaryIndex]
  60. [DateEditor]
  61. [EditorSequence("Payroll", 2)]
  62. public DateTime FinishDate { get; set; }
  63. public EmployeeRosterLink RosterTemplate { get; set; }
  64. [EditorSequence("Payroll", 3)]
  65. [EmbeddedListEditor(typeof(EmployeeRosterItem), DirectEdit = true)]
  66. [Obsolete("Use Template system instead")]
  67. public string Roster { get; set; }
  68. [EditorSequence("Payroll", 4)]
  69. [DateTimeEditor(Visible = Visible.Optional)]
  70. public DateTime RosterStart { get; set; }
  71. [EditorSequence("Payroll",5)]
  72. public OvertimeRuleLink OvertimeRule { get; set; }
  73. [Obsolete("Replaced by OvertimeRule")]
  74. public OvertimeRuleLink OvertimeRuleLink
  75. {
  76. get => OvertimeRule;
  77. set { }
  78. }
  79. [CodeEditor(Editable = Editable.Enabled)]
  80. [EditorSequence("Payroll",6)]
  81. public string PayrollID { get; set; }
  82. [CurrencyEditor]
  83. [Security(typeof(CanViewHourlyRates))]
  84. [EditorSequence("Payroll",7)]
  85. [Comment("Hourly rate of the employee; used for assignment costing")]
  86. public double HourlyRate { get; set; }
  87. [EditorSequence("Payroll",8)]
  88. [Caption("Leave Approval")]
  89. public LeaveRequestApprovalSetLink LeaveRequestApprovalSet { get; set; }
  90. [EditorSequence("Org Chart", 1)]
  91. public EmployeePositionLink Position { get; set; }
  92. private class EmployeeLookup : LookupDefinitionGenerator<Employee, Employee>
  93. {
  94. public override Filter<Employee> DefineFilter(Employee[] items)
  95. {
  96. var result = LookupFactory.DefineFilter<Employee>();
  97. result.Ands.Add(Filter<Employee>.Where(x => x.ID).NotInList(items.Select(x => x.ID).ToArray()));
  98. return result;
  99. }
  100. public override Columns<Employee> DefineFilterColumns()
  101. => Columns.None<Employee>().Add(x => x.ID);
  102. }
  103. [LookupDefinition(typeof(EmployeeLookup))]
  104. [EditorSequence("Org Chart", 2)]
  105. [EntityRelationship(DeleteAction.Cascade)]
  106. public EmployeeLink Manager { get; set; }
  107. [EditorSequence("Org Chart", 3)]
  108. public OrgChartSettings<EmployeeLink> OrgChart { get; set; }
  109. [NullEditor]
  110. [Obsolete("Replaced with UserLink.ID", true)]
  111. public Guid UserID { get; set; }
  112. [NullEditor]
  113. public int ActiveSchedules { get; set; }
  114. [NullEditor]
  115. public byte[]? Signature { get; set; }
  116. [NullEditor]
  117. [Obsolete("Replaced with EmployeeRoster class", true)]
  118. public TimeSpan UsualStart { get; set; }
  119. [NullEditor]
  120. [Obsolete("Replaced with EmployeeRoster class", true)]
  121. public TimeSpan UsualFinish { get; set; }
  122. static Employee()
  123. {
  124. DefaultColumns.Add<Employee>(x => x.Code);
  125. DefaultColumns.Add<Employee>(x => x.Name);
  126. DefaultColumns.Add<Employee>(x => x.User.UserID, caption: "User");
  127. DefaultColumns.Add<Employee>(x => x.Group.Code, caption: "Group");
  128. DefaultColumns.Add<Employee>(x => x.Email);
  129. DefaultColumns.Add<Employee>(x => x.Mobile);
  130. DefaultColumns.Add<Employee>(x => x.Type, width: 70);
  131. DefaultColumns.Add<Employee>(x => x.ShowOnInOutBoard, caption: "In/Out?");
  132. }
  133. protected override void DoPropertyChanged(string name, object? before, object? after)
  134. {
  135. base.DoPropertyChanged(name, before, after);
  136. if(name == $"{Type}")
  137. {
  138. ShowOnInOutBoard = Type == EmployeeType.Employee;
  139. }
  140. }
  141. public override string ToString()
  142. {
  143. return Name;
  144. }
  145. public static Filter<Employee> ActiveEmployees(DateTime date)
  146. {
  147. var start = Filter<Employee>.Where(x => x.StartDate).IsEqualTo(DateTime.MinValue).Or(x => x.StartDate).IsLessThanOrEqualTo(date);
  148. var finish = Filter<Employee>.Where(x => x.FinishDate).IsEqualTo(DateTime.MinValue).Or(x => x.FinishDate).IsGreaterThanOrEqualTo(date);
  149. return start.And(finish);
  150. }
  151. }
  152. }