FormManager.cs 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360
  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.IO;
  8. using System.Linq;
  9. using System.Text;
  10. using System.Threading.Tasks;
  11. using System.Windows.Forms;
  12. using Word = Microsoft.Office.Interop.Word;
  13. namespace СУБД_Швейная_фабрика
  14. {
  15. public partial class FormManager : Form
  16. {
  17. public FormManager()
  18. {
  19. InitializeComponent();
  20. }
  21. void FillListZakaz()
  22. {
  23. SqlConnection con = new SqlConnection(Properties.Settings.Default.FabricDeryugoConnectionString);
  24. con.Open();
  25. string TxtQuery =
  26. @"select Izdeliya.nameizd as izd,
  27. Zakaz.countizd as countizd,
  28. Tkani.nametkan as tkan,
  29. Furnitura.namefur as fur,
  30. Zakaz.countfur as countfur,
  31. Users.fam as zakazchik
  32. from Zakaz, Users, Tkani, Furnitura, Izdeliya
  33. where Users.iduser = Zakaz.idzakazchik
  34. and Tkani.idtkan = Zakaz.idtkan
  35. and Furnitura.idfur = Zakaz.idfur
  36. and Izdeliya.idizd = Zakaz.idizd
  37. and Zakaz.idman = " + LblIdManager.Text;
  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["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 FormManager_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. // TODO: This line of code loads data into the 'fabricDeryugoDataSet.Izdeliya' table. You can move, or remove it, as needed.
  159. this.izdeliyaTableAdapter.Fill(this.fabricDeryugoDataSet.Izdeliya);
  160. FillListZakaz();
  161. GetTkaniFromDB();
  162. FillLVTkani();
  163. GetFurnituraFromDB();
  164. FillLVFurnitura();
  165. }
  166. private void BtnProfile_Click(object sender, EventArgs e)
  167. {
  168. FormProfil frm = new FormProfil();
  169. frm.usersBindingSource.Filter = this.usersBindingSource.Filter;
  170. if (frm.ShowDialog() == DialogResult.OK)
  171. {
  172. this.usersTableAdapter.Fill(this.fabricDeryugoDataSet.Users);
  173. }
  174. }
  175. private void LVFurnitura_SelectedIndexChanged(object sender, EventArgs e)
  176. {
  177. if (LVFurnitura.SelectedItems.Count > 0) // есть выделенные элементы
  178. {
  179. int num = LVFurnitura.SelectedIndices[0]; // номер выделенного элемента
  180. TbxNameFur.Text = LstFurnitura[num].NameFur;
  181. TbxCountFurSklad.Text = LstFurnitura[num].CountFur;
  182. }
  183. else // нет выделенных элементов
  184. {
  185. TbxNameFur.Text = "";
  186. TbxCountFurSklad.Text = "";
  187. }
  188. }
  189. private void BtnAdd_Click(object sender, EventArgs e)
  190. {
  191. izdeliyaBindingSource.AddNew();
  192. BtnSave.Enabled = true;
  193. BtnAdd.Enabled = false;
  194. BtnEdit.Enabled = false;
  195. DgvIzd.Enabled = false;
  196. TbxNameIzd.Enabled = true;
  197. TbxLengthIzd.Enabled = true;
  198. TbxWidthIzd.Enabled = true;
  199. }
  200. private void BtnEdit_Click(object sender, EventArgs e)
  201. {
  202. BtnSave.Enabled = true;
  203. BtnAdd.Enabled = false;
  204. BtnEdit.Enabled = false;
  205. DgvIzd.Enabled = false;
  206. TbxNameIzd.Enabled = true;
  207. TbxLengthIzd.Enabled = true;
  208. TbxWidthIzd.Enabled = true;
  209. }
  210. private void BtnSave_Click(object sender, EventArgs e)
  211. {
  212. izdeliyaBindingSource.EndEdit();
  213. this.izdeliyaTableAdapter.Update(this.fabricDeryugoDataSet.Izdeliya);
  214. BtnSave.Enabled = false;
  215. BtnAdd.Enabled = true;
  216. BtnEdit.Enabled = true;
  217. DgvIzd.Enabled = true;
  218. TbxNameIzd.Enabled = false;
  219. TbxLengthIzd.Enabled = false;
  220. TbxWidthIzd.Enabled = false;
  221. }
  222. private void BtnAll_Click(object sender, EventArgs e)
  223. {
  224. if (RbtWord.Checked)
  225. {
  226. Word.Application app = new Word.Application();
  227. app.Visible = true;
  228. Word.Document doc = app.Documents.Open(Application.StartupPath + "\\Заказы.docx", null, true);
  229. Word.Bookmarks WBmark = doc.Bookmarks; // закладки из документа
  230. WBmark["man"].Range.Text = FamLabel.Text + " " + NameLabel.Text + " " + OtchLabel.Text;
  231. string num = "", izd = "", countizd = "", tkan = "",
  232. fur = "", countfur = "", zakazchik = "";
  233. for (int i = 0; i <= DgvZakaz.RowCount - 1; i++) // перебор записей в таблице
  234. {
  235. num += (i + 1).ToString() + "." + "\r\n";
  236. izd += DgvZakaz.Rows[i].Cells[0].Value + "\r\n";
  237. countizd += DgvZakaz.Rows[i].Cells[1].Value + "\r\n";
  238. tkan += DgvZakaz.Rows[i].Cells[2].Value + "\r\n";
  239. fur += DgvZakaz.Rows[i].Cells[3].Value + "\r\n";
  240. countfur += DgvZakaz.Rows[i].Cells[4].Value + "\r\n";
  241. zakazchik += DgvZakaz.Rows[i].Cells[5].Value + "\r\n";
  242. }
  243. WBmark["num"].Range.Text = num.Trim();
  244. WBmark["izd"].Range.Text = izd.Trim();
  245. WBmark["countizd"].Range.Text = countizd.Trim();
  246. WBmark["tkan"].Range.Text = tkan.Trim();
  247. WBmark["fur"].Range.Text = fur.Trim();
  248. WBmark["countfur"].Range.Text = countfur.Trim();
  249. WBmark["zak"].Range.Text = zakazchik.Trim();
  250. }
  251. else
  252. {
  253. if (saveFileDialog1.ShowDialog() == DialogResult.OK)
  254. {
  255. StreamWriter f = new StreamWriter(saveFileDialog1.FileName);
  256. string t = "izd;countizd;tkan;furnitura;countfur;zakazchik";
  257. f.WriteLine(t);
  258. for (int i = 0; i <= DgvZakaz.RowCount - 1; i++)
  259. {
  260. t = "";
  261. t += DgvZakaz.Rows[i].Cells[0].Value + ";";
  262. t += DgvZakaz.Rows[i].Cells[1].Value + ";";
  263. t += DgvZakaz.Rows[i].Cells[2].Value + ";";
  264. t += DgvZakaz.Rows[i].Cells[3].Value + ";";
  265. t += DgvZakaz.Rows[i].Cells[4].Value + ";";
  266. t += DgvZakaz.Rows[i].Cells[5].Value;
  267. f.WriteLine(t);
  268. }
  269. f.Close();
  270. }
  271. }
  272. }
  273. private void BtnSelect_Click(object sender, EventArgs e)
  274. {
  275. if (RbtWord.Checked)
  276. {
  277. Word.Application app = new Word.Application();
  278. app.Visible = true;
  279. Word.Document doc = app.Documents.Open(Application.StartupPath + "\\Заказы.docx", null, true);
  280. Word.Bookmarks WBmark = doc.Bookmarks; // закладки из документа
  281. WBmark["man"].Range.Text = FamLabel.Text + " " + NameLabel.Text + " " + OtchLabel.Text;
  282. string num = "", izd = "", countizd = "", tkan = "",
  283. fur = "", countfur = "", zakazchik = "";
  284. for (int i = 0; i <= DgvZakaz.SelectedRows.Count - 1; i++) // перебор записей в таблице
  285. {
  286. num += (i + 1).ToString() + "." + "\r\n";
  287. izd += DgvZakaz.SelectedRows[i].Cells[0].Value + "\r\n";
  288. countizd += DgvZakaz.SelectedRows[i].Cells[1].Value + "\r\n";
  289. tkan += DgvZakaz.SelectedRows[i].Cells[2].Value + "\r\n";
  290. fur += DgvZakaz.SelectedRows[i].Cells[3].Value + "\r\n";
  291. countfur += DgvZakaz.SelectedRows[i].Cells[4].Value + "\r\n";
  292. zakazchik += DgvZakaz.SelectedRows[i].Cells[5].Value + "\r\n";
  293. }
  294. WBmark["num"].Range.Text = num.Trim();
  295. WBmark["izd"].Range.Text = izd.Trim();
  296. WBmark["countizd"].Range.Text = countizd.Trim();
  297. WBmark["tkan"].Range.Text = tkan.Trim();
  298. WBmark["fur"].Range.Text = fur.Trim();
  299. WBmark["countfur"].Range.Text = countfur.Trim();
  300. WBmark["zak"].Range.Text = zakazchik.Trim();
  301. }
  302. else
  303. {
  304. if (saveFileDialog1.ShowDialog() == DialogResult.OK)
  305. {
  306. StreamWriter f = new StreamWriter(saveFileDialog1.FileName);
  307. string t = "izd;countizd;tkan;furnitura;countfur;zakazchik";
  308. f.WriteLine(t);
  309. for (int i = 0; i <= DgvZakaz.SelectedRows.Count - 1; i++)
  310. {
  311. t = "";
  312. t += DgvZakaz.SelectedRows[i].Cells[0].Value + ";";
  313. t += DgvZakaz.SelectedRows[i].Cells[1].Value + ";";
  314. t += DgvZakaz.SelectedRows[i].Cells[2].Value + ";";
  315. t += DgvZakaz.SelectedRows[i].Cells[3].Value + ";";
  316. t += DgvZakaz.SelectedRows[i].Cells[4].Value + ";";
  317. t += DgvZakaz.SelectedRows[i].Cells[5].Value;
  318. f.WriteLine(t);
  319. }
  320. f.Close();
  321. }
  322. }
  323. }
  324. private void izdeliyaBindingNavigatorSaveItem_Click(object sender, EventArgs e)
  325. {
  326. this.Validate();
  327. this.izdeliyaBindingSource.EndEdit();
  328. this.tableAdapterManager.UpdateAll(this.fabricDeryugoDataSet);
  329. }
  330. }
  331. }