FormKladov.cs 9.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241
  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 FormKladov : Form
  14. {
  15. public FormKladov()
  16. {
  17. InitializeComponent();
  18. }
  19. void FillListZakaz()
  20. {
  21. SqlConnection con = new SqlConnection(Properties.Settings.Default.FabricDeryugoConnectionString);
  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. void GetTkaniFromDB()
  58. {
  59. SqlConnection con = new SqlConnection(Properties.Settings.Default.FabricDeryugoConnectionString);
  60. con.Open();
  61. SqlCommand Query = new SqlCommand("select * from Tkani where length > 0", con);
  62. SqlDataReader Data = Query.ExecuteReader();
  63. while (Data.Read())
  64. {
  65. Tkani Tk = new Tkani();
  66. Tk.IdTkan = Data["idtkan"].ToString();
  67. Tk.NameTkan = Data["nametkan"].ToString();
  68. Tk.ColorTkan = Data["color"].ToString();
  69. Tk.Width = Data["width"].ToString();
  70. Tk.Length = Data["length"].ToString();
  71. Tk.Description = Data["description"].ToString();
  72. try
  73. {
  74. // загрузить из таблицы БД байты фотографии в массив
  75. byte[] PhotoByte = (byte[])Data["phototkan"];
  76. ImageConverter ImConverter = new ImageConverter();
  77. // сконвертировать массив байт в изображение
  78. Tk.PhotoTkan = (Bitmap)ImConverter.ConvertFrom(PhotoByte);
  79. }
  80. catch
  81. {
  82. // в случае ошибки загрузить пустое изображение из ресурсов
  83. Tk.PhotoTkan = Properties.Resources.tmp;
  84. }
  85. LstTkani.Add(Tk); // добавить в список новую ткань
  86. }
  87. con.Close();
  88. }
  89. void FillLVTkani()
  90. {
  91. LVTkani.Items.Clear();
  92. ImageListTkani.Images.Clear();
  93. foreach (Tkani Tk in LstTkani)
  94. {
  95. // новый элемент для ListView с названием ткани
  96. ListViewItem LV = new ListViewItem(Tk.NameTkan);
  97. // в ImageList добавить изображение ткани
  98. ImageListTkani.Images.Add(Tk.PhotoTkan);
  99. // связать последнее добавленное изображение с новым элементом ListView
  100. LV.ImageIndex = ImageListTkani.Images.Count - 1;
  101. LVTkani.Items.Add(LV); // добавить новый элемент к ListView
  102. }
  103. }
  104. public struct Furnitura
  105. {
  106. public string IdFur, NameFur, CountFur;
  107. public Image PhotoFur;
  108. }
  109. List<Furnitura> LstFurnitura = new List<Furnitura>();
  110. void GetFurnituraFromDB()
  111. {
  112. SqlConnection con = new SqlConnection(Properties.Settings.Default.FabricDeryugoConnectionString);
  113. con.Open();
  114. SqlCommand Query = new SqlCommand("select * from Furnitura where countfur > 0", con);
  115. SqlDataReader Data = Query.ExecuteReader();
  116. while (Data.Read())
  117. {
  118. Furnitura Fr = new Furnitura();
  119. Fr.IdFur = Data["idfur"].ToString();
  120. Fr.NameFur = Data["namefur"].ToString();
  121. Fr.CountFur = Data["countfur"].ToString();
  122. try
  123. {
  124. // загрузить из таблицы БД байты фотографии в массив
  125. byte[] PhotoByte = (byte[])Data["photo"];
  126. ImageConverter ImConverter = new ImageConverter();
  127. // сконвертировать массив байт в изображение
  128. Fr.PhotoFur = (Bitmap)ImConverter.ConvertFrom(PhotoByte);
  129. }
  130. catch
  131. {
  132. // в случае ошибки загрузить пустое изображение из ресурсов
  133. Fr.PhotoFur = Properties.Resources.tmp;
  134. }
  135. LstFurnitura.Add(Fr); // добавить в список новую фурнитуру
  136. }
  137. con.Close();
  138. }
  139. void FillLVFurnitura()
  140. {
  141. LVFurnitura.Items.Clear();
  142. ImageListFur.Images.Clear();
  143. foreach (Furnitura Fr in LstFurnitura)
  144. {
  145. // новый элемент для ListView с названием фурнитуры
  146. ListViewItem LV = new ListViewItem(Fr.NameFur);
  147. // в ImageList добавить изображение фурнитуры
  148. ImageListFur.Images.Add(Fr.PhotoFur);
  149. // связать последнее добавленное изображение с новым элементом ListView
  150. LV.ImageIndex = ImageListFur.Images.Count - 1;
  151. LVFurnitura.Items.Add(LV); // добавить новый элемент к ListView
  152. }
  153. }
  154. private void FormKladov_Load(object sender, EventArgs e)
  155. {
  156. // TODO: This line of code loads data into the 'fabricDeryugoDataSet.Users' table. You can move, or remove it, as needed.
  157. this.usersTableAdapter.Fill(this.fabricDeryugoDataSet.Users);
  158. FillListZakaz();
  159. GetTkaniFromDB();
  160. FillLVTkani();
  161. GetFurnituraFromDB();
  162. FillLVFurnitura();
  163. }
  164. private void LVTkani_SelectedIndexChanged(object sender, EventArgs e)
  165. {
  166. if (LVTkani.SelectedItems.Count > 0) // есть выделенные элементы
  167. {
  168. int num = LVTkani.SelectedIndices[0]; // номер выделенного элемента
  169. NametkanTextBox.Text = LstTkani[num].NameTkan;
  170. ColorTextBox.Text = LstTkani[num].ColorTkan;
  171. WidthTextBox.Text = LstTkani[num].Width;
  172. LengthTextBox.Text = LstTkani[num].Length;
  173. DescriptionTextBox.Text = LstTkani[num].Description;
  174. }
  175. else // нет выделенных элементов
  176. {
  177. NametkanTextBox.Text = "";
  178. ColorTextBox.Text = "";
  179. WidthTextBox.Text = "";
  180. LengthTextBox.Text = "";
  181. DescriptionTextBox.Text = "";
  182. }
  183. }
  184. private void LVFurnitura_SelectedIndexChanged(object sender, EventArgs e)
  185. {
  186. if (LVFurnitura.SelectedItems.Count > 0) // есть выделенные элементы
  187. {
  188. int num = LVFurnitura.SelectedIndices[0]; // номер выделенного элемента
  189. TbxNameFur.Text = LstFurnitura[num].NameFur;
  190. TbxCountFurSklad.Text = LstFurnitura[num].CountFur;
  191. }
  192. else // нет выделенных элементов
  193. {
  194. TbxNameFur.Text = "";
  195. TbxCountFurSklad.Text = "";
  196. }
  197. }
  198. private void BtnProfile_Click(object sender, EventArgs e)
  199. {
  200. FormProfil frm = new FormProfil();
  201. frm.usersBindingSource.Filter = this.usersBindingSource.Filter;
  202. if (frm.ShowDialog() == DialogResult.OK)
  203. {
  204. this.usersTableAdapter.Fill(this.fabricDeryugoDataSet.Users);
  205. }
  206. }
  207. private void BtnGetMaterial_Click(object sender, EventArgs e)
  208. {
  209. FormGetMaterial frm = new FormGetMaterial();
  210. frm.ShowDialog();
  211. }
  212. private void BtnSpisMaterial_Click(object sender, EventArgs e)
  213. {
  214. FormSpisokMaterial frm = new FormSpisokMaterial();
  215. frm.ShowDialog();
  216. }
  217. private void usersBindingNavigatorSaveItem_Click(object sender, EventArgs e)
  218. {
  219. this.Validate();
  220. this.usersBindingSource.EndEdit();
  221. this.tableAdapterManager.UpdateAll(this.fabricDeryugoDataSet);
  222. }
  223. }
  224. }