pageServicesList.xaml.cs 9.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242
  1. using school.FolderClasses;
  2. using System;
  3. using System.Collections.Generic;
  4. using System.Linq;
  5. using System.Text;
  6. using System.Threading.Tasks;
  7. using System.Windows;
  8. using System.Windows.Controls;
  9. using System.Windows.Data;
  10. using System.Windows.Documents;
  11. using System.Windows.Input;
  12. using System.Windows.Media;
  13. using System.Windows.Media.Imaging;
  14. using System.Windows.Navigation;
  15. using System.Windows.Shapes;
  16. namespace school
  17. {
  18. /// <summary>
  19. /// Логика взаимодействия для pageServicesList.xaml
  20. /// </summary>
  21. public partial class pageServicesList : Page
  22. {
  23. public pageServicesList()
  24. {
  25. InitializeComponent();
  26. init();
  27. }
  28. /// <summary>
  29. /// Функция загрузки элементов экрана
  30. /// </summary>
  31. public void init()
  32. {
  33. List<Service> services = baseConnect.thisBase.Service.ToList();
  34. LVServiseList.ItemsSource = services;
  35. TBCountRecord.Text = $"{services.Count} из {services.Count}";//количество записей
  36. CBDiscount.ItemsSource = dataConstant.Discount;
  37. CBDiscount.SelectedIndex = 0;
  38. TBSearchDiscription.Text = "";
  39. TBSearchName.Text = "";
  40. RBSalaryDown.IsChecked = false;
  41. RBSalaryUp.IsChecked = false;
  42. if (services.Count > 0) TBNoSevise.Visibility = Visibility.Collapsed;
  43. else TBNoSevise.Visibility = Visibility.Visible;
  44. if (dataUser.user == null) BtnAdminAuthorizstion.Visibility = Visibility.Visible;
  45. else BtnAdminAuthorizstion.Visibility = Visibility.Collapsed;
  46. if (dataAdminRoot.adminRoot == ("0000").GetHashCode())
  47. {
  48. BtnAdd.Visibility = Visibility.Visible;
  49. BtnRead.Visibility = Visibility.Visible;
  50. }
  51. else
  52. {
  53. BtnAdd.Visibility = Visibility.Collapsed;
  54. BtnRead.Visibility = Visibility.Collapsed;
  55. }
  56. }
  57. private void BtnAdminAuthorizstionClick(object sender, RoutedEventArgs e)
  58. {
  59. winAdminAuthorization window = new winAdminAuthorization();
  60. window.ShowDialog();
  61. dataFrame.mainFrame.Navigate(new pageServicesList());//перезагружаем окошко
  62. }
  63. /// <summary>
  64. /// Метод для сортировки и фильтрациии листа с услугами
  65. /// </summary>
  66. private void sort()
  67. {
  68. List<Service> services = baseConnect.thisBase.Service.ToList();//все данные таблицы
  69. int firstCount = services.Count;//запоминаем изначальное количество элементов
  70. //выбираем данные подходищие под название
  71. if (!string.IsNullOrWhiteSpace(TBSearchName.Text))
  72. {
  73. services = services.Where(tb => tb.Title.ToLower().Contains(TBSearchName.Text.ToLower())).ToList();
  74. }
  75. //выбираем данные подходищие под описание
  76. if (!string.IsNullOrWhiteSpace(TBSearchDiscription.Text))
  77. {
  78. services = services.Where(tb => tb.Description != null && tb.Description.ToLower().Contains(TBSearchDiscription.Text.ToLower())).ToList();
  79. }
  80. //данные подходящие под размер скидки
  81. if (CBDiscount.SelectedIndex > 0)
  82. {
  83. string line = CBDiscount.SelectedItem.ToString().Replace("до ", "").Replace("от ", "").Replace("%", "");//убираем у строки все лишнее оставляя только числв через пробел
  84. string[] valueArr = line.Split(' ');//записываем числа разбивая по последнему пробелу
  85. double min;
  86. if (Convert.ToDouble(valueArr[0]) != 0)//проверяем 1 число, чтобы не возникло ошибки деления на 0
  87. {
  88. min = Convert.ToDouble(valueArr[0]) / 100;
  89. }
  90. else
  91. {
  92. min = 0;
  93. }
  94. double max = Convert.ToDouble(valueArr[1]) / 100;
  95. if (min == 0)
  96. {
  97. services = services.Where(tb => tb.Discount >= min && tb.Discount < max || tb.Discount == null).ToList();
  98. }
  99. else
  100. {
  101. services = services.Where(tb => tb.Discount >= min && tb.Discount < max).ToList();
  102. }
  103. }
  104. //сортировка по возрастанию и убыванию
  105. if (RBSalaryUp.IsChecked == true)
  106. {
  107. services = services.OrderBy(tb => tb.priceEnd).ToList();//по возрастанию
  108. }
  109. if (RBSalaryDown.IsChecked == true)
  110. {
  111. services = services.OrderByDescending(tb => tb.priceEnd).ToList();//по убыванию
  112. }
  113. LVServiseList.ItemsSource = services;//иотговый лист
  114. TBCountRecord.Text = $"{services.Count} из {firstCount}";
  115. if (services.Count > 0) TBNoSevise.Visibility = Visibility.Collapsed;
  116. else TBNoSevise.Visibility = Visibility.Visible;
  117. }
  118. private void SortChecked(object sender, RoutedEventArgs e)
  119. {
  120. sort();
  121. }
  122. private void TBSearchTextChanged(object sender, TextChangedEventArgs e)
  123. {
  124. sort();
  125. }
  126. private void CBDiscountSelectionChanged(object sender, SelectionChangedEventArgs e)
  127. {
  128. sort();
  129. }
  130. private void BtnSortClick(object sender, RoutedEventArgs e)
  131. {
  132. if (GSort.Visibility == Visibility.Visible)
  133. {
  134. GSort.Visibility = Visibility.Collapsed;
  135. }
  136. else
  137. {
  138. GSort.Visibility = Visibility.Visible;
  139. }
  140. }
  141. private void BtnNoSortClick(object sender, RoutedEventArgs e)
  142. {
  143. init();
  144. }
  145. private void BtnAddClick(object sender, RoutedEventArgs e)
  146. {
  147. dataFrame.mainFrame.Navigate(new pageEditService());
  148. }
  149. private void BtnEditClick(object sender, RoutedEventArgs e)
  150. {
  151. Button thisBtn = (Button)sender;
  152. int id = Convert.ToInt32(thisBtn.Uid);//находим id выбранной услуги
  153. dataFrame.mainFrame.Navigate(new pageEditService(id));
  154. }
  155. private void BtnDeleteClick(object sender, RoutedEventArgs e)
  156. {
  157. Button thisBtn = (Button)sender;
  158. int id = Convert.ToInt32(thisBtn.Uid);//находим id выбранной услуги
  159. List<ClientService> clientServices = baseConnect.thisBase.ClientService.Where(tb => tb.ServiceID == id).ToList();
  160. if (clientServices.Count > 0)
  161. {
  162. MessageBox.Show("Данную услугу не возможно удалить!", "Ошибка удаления", MessageBoxButton.OK, MessageBoxImage.Error);
  163. }
  164. else
  165. {
  166. switch (MessageBox.Show("Вы действительно хотите удалить эту услугу?", "Подтверждение удаления", MessageBoxButton.YesNo, MessageBoxImage.Stop))
  167. {
  168. case MessageBoxResult.Yes:
  169. {
  170. //код удаления
  171. try
  172. {
  173. Service service = baseConnect.thisBase.Service.Where(tb => tb.ID == id).FirstOrDefault();
  174. baseConnect.thisBase.Service.Remove(service);
  175. baseConnect.thisBase.SaveChanges();
  176. dataFrame.mainFrame.Navigate(new pageServicesList());
  177. MessageBox.Show("Удаление прошло успешно");
  178. }
  179. catch
  180. {
  181. MessageBox.Show("Не удалось удалить объект");
  182. }
  183. break;
  184. }
  185. case MessageBoxResult.No:
  186. {
  187. break;
  188. }
  189. }
  190. }
  191. }
  192. private void BtnWriteClick(object sender, RoutedEventArgs e)
  193. {
  194. if (dataUser.user != null)
  195. {
  196. Button btn = (Button)sender;
  197. int id = Convert.ToInt32(btn.Uid);
  198. winWriteService window = new winWriteService(id);
  199. window.ShowDialog();
  200. }
  201. else
  202. {
  203. switch (MessageBox.Show("Вы не авторизировались, поэтому во время записи произошла ошибка. Хотите авторизироваться?", "Ошибка записи", MessageBoxButton.YesNo, MessageBoxImage.Question))
  204. {
  205. case MessageBoxResult.Yes:
  206. {
  207. BtnAdminAuthorizstionClick(null, null);//окно для авторизации пользователя
  208. break;
  209. }
  210. case MessageBoxResult.No:
  211. {
  212. break;
  213. }
  214. }
  215. }
  216. }
  217. private void BtnReadClick(object sender, RoutedEventArgs e)
  218. {
  219. dataFrame.mainFrame.Navigate(new pageServiceNearRecord());
  220. }
  221. }
  222. }