FormKladovschik.cs 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265
  1. using System;
  2. using System.Collections.Generic;
  3. using System.ComponentModel;
  4. using System.Data;
  5. using System.Data.SqlClient;
  6. using System.Drawing;
  7. using System.Linq;
  8. using System.Text;
  9. using System.Threading.Tasks;
  10. using System.Windows.Forms;
  11. namespace СУБД_Швейная_фабрика
  12. {
  13. public partial class FormKladovschik : Form
  14. {
  15. public FormKladovschik()
  16. {
  17. InitializeComponent();
  18. }
  19. void FillListZakaz()
  20. {
  21. SqlConnection con = new SqlConnection(Properties.Settings.Default.fab2021ConnectionString);
  22. con.Open();
  23. string txtquery =
  24. @"select Izdeliya.nameizd as izd,
  25. Zakaz.countizd as countizd,
  26. Tkani.nametkan as tkan,
  27. Furnitura.namefur as fur,
  28. Zakaz.countfur as countfur,
  29. UsersMan.fam as manager, UsersZak.fam as zakazchik
  30. from Zakaz, Users as UsersMan, Users as UsersZak,
  31. Tkani, Furnitura, Izdeliya
  32. where
  33. UsersMan.iduser = Zakaz.idman
  34. and UsersZak.iduser = Zakaz.idzakazchik
  35. and Tkani.idtkan = Zakaz.idtkan
  36. and Furnitura.idfur = Zakaz.idfur
  37. and Izdeliya.idizd = Zakaz.idizd";
  38. SqlCommand query1 = new SqlCommand(txtquery, con);
  39. // выполнить запрос
  40. SqlDataReader sqlrez = query1.ExecuteReader();
  41. DgvZakaz.Rows.Clear(); // очистить от старых строк
  42. // перебирать результаты запроса
  43. while (sqlrez.Read())
  44. {
  45. DgvZakaz.Rows.Add(sqlrez["izd"], sqlrez["countizd"],
  46. sqlrez["tkan"], sqlrez["fur"], sqlrez["countfur"],
  47. sqlrez["manager"], sqlrez["zakazchik"]);
  48. }
  49. con.Close();
  50. }
  51. public struct Tkani
  52. {
  53. public string IdTkan, NameTkan, ColorTkan, Width, Length, Description;
  54. public Image PhotoTkan;
  55. }
  56. List<Tkani> LstTkani = new List<Tkani>();
  57. /// <summary>
  58. /// получить из базы данных сведения о тканях
  59. /// </summary>
  60. void GetTkaniFromDB()
  61. {
  62. SqlConnection con = new SqlConnection(Properties.Settings.Default.fab2021ConnectionString);
  63. con.Open();
  64. SqlCommand Query = new SqlCommand("select * from Tkani where length > 0", con);
  65. SqlDataReader Data = Query.ExecuteReader();
  66. while (Data.Read())
  67. {
  68. Tkani Tk = new Tkani();
  69. Tk.IdTkan = Data["idtkan"].ToString();
  70. Tk.NameTkan = Data["nametkan"].ToString();
  71. Tk.ColorTkan = Data["color"].ToString();
  72. Tk.Width = Data["width"].ToString();
  73. Tk.Length = Data["length"].ToString();
  74. Tk.Description = Data["description"].ToString();
  75. try
  76. {
  77. // загрузить из таблицы БД байты фотографии в массив
  78. byte[] PhotoByte = (byte[])Data["phototkan"];
  79. ImageConverter ImConverter = new ImageConverter();
  80. // сконвертировать массив байт в изображение
  81. Tk.PhotoTkan = (Bitmap)ImConverter.ConvertFrom(PhotoByte);
  82. }
  83. catch
  84. {
  85. // в случае ошибки загрузить пустое изображение из ресурсов
  86. Tk.PhotoTkan = Properties.Resources.tmp;
  87. }
  88. LstTkani.Add(Tk); // добавить в список новую ткань
  89. }
  90. con.Close();
  91. }
  92. /// <summary>
  93. /// заполнение таблицы с фотографиями тканей
  94. /// </summary>
  95. void FillLVTkani()
  96. {
  97. LVTkani.Items.Clear();
  98. ImageListTkani.Images.Clear();
  99. foreach (Tkani Tk in LstTkani)
  100. {
  101. // новый элемент для ListView с названием ткани
  102. ListViewItem LV = new ListViewItem(Tk.NameTkan);
  103. // в ImageList добавить изображение ткани
  104. ImageListTkani.Images.Add(Tk.PhotoTkan);
  105. // связать последнее добавленное изображение с новым элементом ListView
  106. LV.ImageIndex = ImageListTkani.Images.Count - 1;
  107. LVTkani.Items.Add(LV); // добавить новый элемент к ListView
  108. }
  109. }
  110. public struct Furnitura
  111. {
  112. public string IdFur, NameFur, CountFur;
  113. public Image PhotoFur;
  114. }
  115. List<Furnitura> LstFurnitura = new List<Furnitura>();
  116. /// <summary>
  117. /// получить данные о фурнитурах из базы данных
  118. /// </summary>
  119. void GetFurnituraFromDB()
  120. {
  121. SqlConnection con = new SqlConnection(Properties.Settings.Default.fab2021ConnectionString);
  122. con.Open();
  123. SqlCommand Query = new SqlCommand("select * from Furnitura where countfur > 0", con);
  124. SqlDataReader Data = Query.ExecuteReader();
  125. while (Data.Read())
  126. {
  127. Furnitura Fr = new Furnitura();
  128. Fr.IdFur = Data["idfur"].ToString();
  129. Fr.NameFur = Data["namefur"].ToString();
  130. Fr.CountFur = Data["countfur"].ToString();
  131. try
  132. {
  133. // загрузить из таблицы БД байты фотографии в массив
  134. byte[] PhotoByte = (byte[])Data["photo"];
  135. ImageConverter ImConverter = new ImageConverter();
  136. // сконвертировать массив байт в изображение
  137. Fr.PhotoFur = (Bitmap)ImConverter.ConvertFrom(PhotoByte);
  138. }
  139. catch
  140. {
  141. // в случае ошибки загрузить пустое изображение из ресурсов
  142. Fr.PhotoFur = Properties.Resources.tmp;
  143. }
  144. LstFurnitura.Add(Fr); // добавить в список новую фурнитуру
  145. }
  146. con.Close();
  147. }
  148. /// <summary>
  149. /// заполнить таблицу с фотографиями фурнитур
  150. /// </summary>
  151. void FillLVFurnitura()
  152. {
  153. LVFurnitura.Items.Clear();
  154. ImageListFur.Images.Clear();
  155. foreach (Furnitura Fr in LstFurnitura)
  156. {
  157. // новый элемент для ListView с названием фурнитуры
  158. ListViewItem LV = new ListViewItem(Fr.NameFur);
  159. // в ImageList добавить изображение фурнитуры
  160. ImageListFur.Images.Add(Fr.PhotoFur);
  161. // связать последнее добавленное изображение с новым элементом ListView
  162. LV.ImageIndex = ImageListFur.Images.Count - 1;
  163. LVFurnitura.Items.Add(LV); // добавить новый элемент к ListView
  164. }
  165. }
  166. private void FormKladovschik_Load(object sender, EventArgs e)
  167. {
  168. // TODO: This line of code loads data into the 'fab2021DataSet1.Users' table. You can move, or remove it, as needed.
  169. this.usersTableAdapter.Fill(this.fab2021DataSet1.Users);
  170. FillListZakaz();
  171. GetTkaniFromDB();
  172. FillLVTkani();
  173. GetFurnituraFromDB();
  174. FillLVFurnitura();
  175. }
  176. private void LVTkani_SelectedIndexChanged(object sender, EventArgs e)
  177. {
  178. if (LVTkani.SelectedItems.Count > 0) // есть выделенные элементы
  179. {
  180. int num = LVTkani.SelectedIndices[0]; // номер выделенного элемента
  181. NametkanTextBox.Text = LstTkani[num].NameTkan;
  182. ColorTextBox.Text = LstTkani[num].ColorTkan;
  183. WidthTextBox.Text = LstTkani[num].Width;
  184. LengthTextBox.Text = LstTkani[num].Length;
  185. DescriptionTextBox.Text = LstTkani[num].Description;
  186. }
  187. else // нет выделенных элементов
  188. {
  189. NametkanTextBox.Text = "";
  190. ColorTextBox.Text = "";
  191. WidthTextBox.Text = "";
  192. LengthTextBox.Text = "";
  193. DescriptionTextBox.Text = "";
  194. }
  195. }
  196. private void LVFurnitura_SelectedIndexChanged(object sender, EventArgs e)
  197. {
  198. if (LVFurnitura.SelectedItems.Count > 0) // есть выделенные элементы
  199. {
  200. int num = LVFurnitura.SelectedIndices[0]; // номер выделенного элемента
  201. TbxNameFur.Text = LstFurnitura[num].NameFur;
  202. TbxCountFurSklad.Text = LstFurnitura[num].CountFur;
  203. }
  204. else // нет выделенных элементов
  205. {
  206. TbxNameFur.Text = "";
  207. TbxCountFurSklad.Text = "";
  208. }
  209. }
  210. private void BtnProfile_Click(object sender, EventArgs e)
  211. {
  212. FormProfile frm = new FormProfile();
  213. // на форму для редактирования профиля передать
  214. // фильтр для выборки авторизовавшегося пользователя
  215. frm.BsUsers.Filter = this.BsUsers.Filter;
  216. if (frm.ShowDialog() == DialogResult.OK)
  217. {
  218. this.usersTableAdapter.Fill(this.fab2021DataSet1.Users);
  219. }
  220. }
  221. private void BtnGetMaterial_Click(object sender, EventArgs e)
  222. {
  223. FormGetMaterial frm = new FormGetMaterial();
  224. frm.ShowDialog();
  225. //GetTkaniFromDB();
  226. //FillLVTkani();
  227. //GetFurnituraFromDB();
  228. //FillLVFurnitura();
  229. }
  230. private void BtnSpisMaterial_Click(object sender, EventArgs e)
  231. {
  232. FormSpisMaterial frm = new FormSpisMaterial();
  233. frm.ShowDialog();
  234. //GetTkaniFromDB();
  235. //FillLVTkani();
  236. //GetFurnituraFromDB();
  237. //FillLVFurnitura();
  238. }
  239. }
  240. }