Window1.xaml.cs 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  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.Shapes;
  14. namespace practice
  15. {
  16. /// <summary>
  17. /// Логика взаимодействия для Window1.xaml
  18. /// </summary>
  19. public partial class Window1 : Window
  20. {
  21. private gr692_pavContext _context;
  22. public Window1()
  23. {
  24. InitializeComponent();
  25. _context = new gr692_pavContext();
  26. Load();
  27. }
  28. // вывод данных
  29. private void Load()
  30. {
  31. inventoryGrid.ItemsSource = _context.inventory.ToList();
  32. }
  33. // добавление данных
  34. private void Insert_Click(object sender, RoutedEventArgs e)
  35. {
  36. InsertInventory(TbName.Text, TbType.Text);
  37. }
  38. public bool InsertInventory(string name, string type)
  39. {
  40. if(string.IsNullOrWhiteSpace(name) || string.IsNullOrWhiteSpace(type))
  41. return false;
  42. inventory inv = new inventory()
  43. {
  44. inventory_name = name,
  45. inventory_type = type
  46. };
  47. _context.inventory.Add(inv);
  48. _context.SaveChanges();
  49. Load();
  50. return true;
  51. }
  52. // изменение данных
  53. private void Update_Click(object sender, RoutedEventArgs e)
  54. {
  55. UpdateInventory(TbName.Text, TbType.Text);
  56. }
  57. public bool UpdateInventory(string name, string type)
  58. {
  59. if(inventoryGrid.SelectedItem is inventory selectedInventory)
  60. {
  61. if (string.IsNullOrWhiteSpace(name) || string.IsNullOrWhiteSpace(type))
  62. return false;
  63. selectedInventory.inventory_name = name;
  64. selectedInventory.inventory_type = type;
  65. _context.SaveChanges();
  66. Load();
  67. return true;
  68. }
  69. return false;
  70. }
  71. // удаление данных
  72. private void Delete_Click(object sender, RoutedEventArgs e)
  73. {
  74. DeleteInventory();
  75. }
  76. public void DeleteInventory()
  77. {
  78. if(inventoryGrid.SelectedItem is inventory selectedInventory)
  79. {
  80. _context.inventory.Remove(selectedInventory);
  81. _context.SaveChanges();
  82. Load();
  83. }
  84. }
  85. // выбор строки
  86. private void inventoryGrid_SelectionChanged(object sender, SelectionChangedEventArgs e)
  87. {
  88. if(inventoryGrid.SelectedItem is inventory selectedInventory)
  89. {
  90. TbName.Text = selectedInventory.inventory_name;
  91. TbType.Text = selectedInventory.inventory_type;
  92. }
  93. }
  94. }
  95. }