Fav.xaml.cs 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196
  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. using System.IO;
  15. using System.Net;
  16. using Newtonsoft.Json;
  17. using Newtonsoft.Json.Linq;
  18. using System.Text.RegularExpressions;
  19. using System.Data.SqlClient;
  20. using System.Data;
  21. using System.Configuration;
  22. namespace kursach.Windows
  23. {
  24. /// <summary>
  25. /// Логика взаимодействия для Fav.xaml
  26. /// </summary>
  27. public partial class Fav : Window
  28. {
  29. string connectionString;
  30. SqlDataAdapter adapter = new SqlDataAdapter();
  31. DataTable usersTable = new DataTable();
  32. List<Plane> planeList = new List<Plane>();
  33. public Fav(int IdUser)
  34. {
  35. InitializeComponent();
  36. //получаем строку подключения из app.config
  37. connectionString = ConfigurationManager.ConnectionStrings["DefaultConnection"].ConnectionString;
  38. SqlConnection connection = new SqlConnection(connectionString);
  39. connection.Open();
  40. SqlCommand command = new SqlCommand();
  41. command.CommandText = "SELECT Icao24 FROM Favourites WHERE IdUser = " + Menu.UserId;
  42. command.Connection = connection;
  43. adapter.SelectCommand = command;
  44. adapter.Fill(usersTable);
  45. try
  46. {
  47. foreach (DataRow dr in usersTable.Rows)
  48. {
  49. string answer = Connect("https://opensky-network.org/api/states/all?icao24=" + dr[0]);
  50. planeList.Add(GetPlane(answer));
  51. }
  52. planeGrid.ItemsSource = planeList;
  53. }
  54. catch
  55. {
  56. MessageBox.Show("Проблемы с подключением...");
  57. }
  58. connection.Close();
  59. }
  60. //подключение к api
  61. public string Connect(string apiUrl)
  62. {
  63. WebRequest request = WebRequest.Create(apiUrl);
  64. request.Method = "GET";
  65. WebResponse response = request.GetResponse();
  66. string answer = string.Empty;
  67. using (Stream s = response.GetResponseStream())
  68. {
  69. using (StreamReader reader = new StreamReader(response.GetResponseStream()))
  70. {
  71. answer = reader.ReadToEnd();
  72. }
  73. }
  74. response.Close();
  75. return answer;
  76. }
  77. //заполнение таблицы
  78. public Plane GetPlane(string answer)
  79. {
  80. Plane plane = new Plane();
  81. JObject answerJson = JObject.Parse(answer);
  82. // get JSON result objects into a list
  83. IList<JToken> results = answerJson["states"].Children().ToList();
  84. // serialize JSON results into .NET objects
  85. foreach (JToken result in results)
  86. {
  87. List<string> resultString = result.ToString().TrimStart('[').TrimEnd(']').Split(',').ToList<string>();
  88. plane.Icao24 = resultString[0].Trim();
  89. plane.Callsign = resultString[1].Trim().TrimStart('"').TrimEnd('"');
  90. plane.Country = resultString[2].Trim().TrimStart('"').TrimEnd('"');
  91. plane.Longitude = resultString[5].Trim();
  92. plane.Latitude = resultString[6].Trim();
  93. plane.On_ground = resultString[8].Trim();
  94. plane.Velocity = resultString[9].Trim();
  95. plane.Altitude = resultString[13].Trim();
  96. }
  97. return plane;
  98. }
  99. //возвращение к предыдущему окну
  100. private void Back(object sender, RoutedEventArgs e)
  101. {
  102. //вернуться назад
  103. Windows.Account acc = new Windows.Account(Menu.UserId);
  104. acc.Show();
  105. Close();
  106. }
  107. //удаление строки из избранного
  108. private void Delete(object sender, RoutedEventArgs e)
  109. {
  110. if (planeGrid.SelectedItem != null)
  111. {
  112. Plane plane = (Plane)planeGrid.SelectedItem;
  113. if(string.IsNullOrEmpty(plane.Icao24))
  114. {
  115. MessageBox.Show("Не удаётся удалить, повторите попытку позже");
  116. return;
  117. }
  118. SqlConnection connection = new SqlConnection(connectionString);
  119. connection.Open();
  120. SqlCommand command = new SqlCommand();
  121. command.CommandText = "DELETE Favourites WHERE IdUser = " + Menu.UserId + " AND Icao24 = '" + plane.Icao24.Trim('"') + "'";
  122. command.Connection = connection;
  123. command.ExecuteNonQuery();
  124. connection.Close();
  125. Fun();
  126. }
  127. else
  128. {
  129. MessageBox.Show("Нет выделенной строки");
  130. }
  131. }
  132. //кнопка обновление
  133. private void Upd(object sender, RoutedEventArgs e)
  134. {
  135. Fun();
  136. }
  137. //функция обновление
  138. private void Fun()
  139. {
  140. try
  141. {
  142. planeGrid.ItemsSource = new List<int>();
  143. planeList.Clear();
  144. usersTable.Clear();
  145. //получаем строку подключения из app.config
  146. connectionString = ConfigurationManager.ConnectionStrings["DefaultConnection"].ConnectionString;
  147. SqlConnection connection = new SqlConnection(connectionString);
  148. connection.Open();
  149. SqlCommand command = new SqlCommand();
  150. command.CommandText = "SELECT Icao24 FROM Favourites WHERE IdUser = " + Menu.UserId;
  151. command.Connection = connection;
  152. adapter.SelectCommand = command;
  153. adapter.Fill(usersTable);
  154. foreach (DataRow dr in usersTable.Rows)
  155. {
  156. string answer = Connect("https://opensky-network.org/api/states/all?icao24=" + dr[0]);
  157. planeList.Add(GetPlane(answer));
  158. }
  159. planeGrid.ItemsSource = planeList;
  160. connection.Close();
  161. }
  162. catch
  163. {
  164. MessageBox.Show("Проблемы с подключением...");
  165. }
  166. }
  167. }
  168. }