WorkOfEmployeePage.xaml.cs 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Text;
  5. using System.Threading.Tasks;
  6. using System.Windows;
  7. using System.Windows.Controls;
  8. using System.Windows.Data;
  9. using System.Windows.Documents;
  10. using System.Windows.Input;
  11. using System.Windows.Media;
  12. using System.Windows.Media.Imaging;
  13. using System.Windows.Navigation;
  14. using System.Windows.Shapes;
  15. namespace SchoolProject
  16. {
  17. /// <summary>
  18. /// Логика взаимодействия для WorkOfEmployeePage.xaml
  19. /// </summary>
  20. public partial class WorkOfEmployeePage : Page
  21. {
  22. public WorkOfEmployeePage()
  23. {
  24. InitializeComponent();
  25. DataContext = new Employee();
  26. Load();
  27. }
  28. public void Load()
  29. {
  30. CmbPosition.ItemsSource = DB.db.Position.ToList();
  31. CmbSubdivision.ItemsSource = DB.db.Subdivision.ToList();
  32. }
  33. public WorkOfEmployeePage(int IDEmployee)
  34. {
  35. InitializeComponent();
  36. DataContext = DB.db.Employee.Find(IDEmployee);
  37. Title = "Редатирование сотрудника";
  38. BtnAddOrEditEmployee.Content = "Редактировать";
  39. Load();
  40. }
  41. public bool Check(Employee NewEmployee)
  42. {
  43. if (NewEmployee.LastName == string.Empty ||
  44. NewEmployee.Name == string.Empty ||
  45. NewEmployee.MiddleName == string.Empty ||
  46. NewEmployee.BirthDate == null ||
  47. NewEmployee.Position == null ||
  48. NewEmployee.Subdivision == null
  49. )
  50. {
  51. Helper.ErrorMessage("Не все значения введены");
  52. return false;
  53. }
  54. if (NewEmployee.LastName.All(char.IsLetter) == false ||
  55. NewEmployee.Name.All(char.IsLetter) == false ||
  56. (NewEmployee.MiddleName != string.Empty && NewEmployee.MiddleName.All(char.IsLetter) == false))
  57. {
  58. Helper.ErrorMessage("Не корректное ФИО");
  59. return false;
  60. }
  61. return true;
  62. }
  63. public bool AddEmployee(Employee NewEmployee)
  64. {
  65. if (Check(NewEmployee) == false)
  66. {
  67. return false;
  68. }
  69. DB.db.Employee.Add(NewEmployee);
  70. if (DB.Save() == false)
  71. {
  72. return false;
  73. }
  74. else
  75. {
  76. Helper.InformationMessage("Сотрудник добавлен");
  77. DataContext = new Employee();
  78. return true;
  79. }
  80. }
  81. public bool EditEmployee()
  82. {
  83. Employee CurrentEmployee = DataContext as Employee;
  84. if (Check(CurrentEmployee) == false)
  85. {
  86. return false;
  87. }
  88. if (DB.Save() == false)
  89. {
  90. return false;
  91. }
  92. Helper.InformationMessage("Сотрудник изменён");
  93. return true;
  94. }
  95. private void BtnAddOrEditEmployee_Click(object sender, RoutedEventArgs e)
  96. {
  97. Employee employee = DataContext as Employee;
  98. employee.IsWorking = true;
  99. if (employee.EmployeeID == 0)
  100. {
  101. AddEmployee(employee);
  102. return;
  103. }
  104. EditEmployee();
  105. }
  106. }
  107. }