FormManager.cs 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172
  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.Drawing.Imaging;
  8. using System.Linq;
  9. using System.Text;
  10. using System.Threading.Tasks;
  11. using System.Windows.Forms;
  12. namespace СУБД_Альфапол
  13. {
  14. public partial class FormManager : Form
  15. {
  16. public FormManager()
  17. {
  18. InitializeComponent();
  19. }
  20. void FillPartner()
  21. {
  22. string additionalUslovie = $" where (surname like '{tbxFind.Text}%' or NamePartner like '{tbxFind.Text}%')";
  23. if(cbxFindReting.Checked)
  24. {
  25. additionalUslovie += $" and Rating >= {tbxMinRating.Text} and Rating <= {tbxMaxReting.Text}";
  26. }
  27. if(cmbTypePartner.Text != "Все типы")
  28. {
  29. additionalUslovie += $" and Type = {cmbTypePartner.Text}";
  30. }
  31. SqlConnection con = new SqlConnection(FormAutorization.txtCon);
  32. con.Open();
  33. string txtQuery = $@"
  34. SELECT Partner.idPartner, TypePartner.Type, Partner.NamePartner, Partner.Surname, Partner.Name, Partner.Patronymic,
  35. Partner.Phone, Partner.Rating, (SELECT sum(CountProduct)
  36. FROM ProductPartner where idPartner = Partner.idPartner) as CountSale
  37. FROM Partner INNER JOIN
  38. TypePartner ON Partner.idTypePartner = TypePartner.idTypePartner" + additionalUslovie;
  39. SqlCommand query = new SqlCommand(txtQuery, con);
  40. SqlDataReader res = null;
  41. try
  42. {
  43. res = query.ExecuteReader();
  44. }
  45. catch
  46. {
  47. dgvPartner.Rows.Clear();
  48. return;
  49. }
  50. dgvPartner.Rows.Clear();
  51. while (res.Read())
  52. {
  53. string info = $@"{res["Type"]} | {res["NamePartner"]}
  54. Директор: {res["Surname"]} {res["Name"]} {res["Patronymic"]}
  55. {res["Phone"]}
  56. Рейтинг: {res["Rating"]}";
  57. string Percent = "0%";
  58. try
  59. {
  60. int countSale = int.Parse(res["CountSale"].ToString());
  61. if (countSale < 10000)
  62. {
  63. Percent = "0%";
  64. }
  65. else if (countSale < 50000)
  66. {
  67. Percent = "5%";
  68. }
  69. else if (countSale < 300000)
  70. {
  71. Percent = "10%";
  72. }
  73. else
  74. {
  75. Percent = "15%";
  76. }
  77. }
  78. catch { }
  79. dgvPartner.Rows.Add(res["idPartner"], info, Percent);
  80. }
  81. con.Close();
  82. }
  83. private void FormManager_Load(object sender, EventArgs e)
  84. {
  85. // TODO: This line of code loads data into the 'dbAlphapolAGDataSet.TypeForFilter' table. You can move, or remove it, as needed.
  86. this.typeForFilterTableAdapter.Fill(this.dbAlphapolAGDataSet.TypeForFilter);
  87. // TODO: This line of code loads data into the 'dbAlphapolAGDataSet.Manager' table. You can move, or remove it, as needed.
  88. this.managerTableAdapter.Fill(this.dbAlphapolAGDataSet.Manager);
  89. try
  90. {
  91. pbxPhoto.Image = Image.FromFile(Application.StartupPath + "\\photo\\" + lblPhoto.Text);
  92. }
  93. catch { }
  94. lblPhoto.Hide();
  95. FillPartner();
  96. }
  97. private void tbxFind_TextChanged(object sender, EventArgs e)
  98. {
  99. FillPartner();
  100. }
  101. private void cbxFindReting_CheckedChanged(object sender, EventArgs e)
  102. {
  103. FillPartner();
  104. }
  105. private void tbxMaxReting_TextChanged(object sender, EventArgs e)
  106. {
  107. FillPartner();
  108. }
  109. private void tbxMinRating_TextChanged(object sender, EventArgs e)
  110. {
  111. FillPartner();
  112. }
  113. private void cmbTypePartner_SelectedIndexChanged(object sender, EventArgs e)
  114. {
  115. FillPartner();
  116. }
  117. private void dgvPartner_CellDoubleClick(object sender, DataGridViewCellEventArgs e)
  118. {
  119. FormAddEdit formAddEdit = new FormAddEdit();
  120. formAddEdit.lblTitle.Text = "Редaктиpование партнера";
  121. formAddEdit.bsPartner.Filter = $"idPartner = {dgvPartner.CurrentRow.Cells[0].Value}";
  122. formAddEdit.ShowDialog();
  123. FillPartner();
  124. }
  125. private void btnHistory_Click(object sender, EventArgs e)
  126. {
  127. FormHistory formHistory = new FormHistory();
  128. formHistory.bsHistorySale.Filter = $"idPartner = {dgvPartner.CurrentRow.Cells[0].Value}";
  129. formHistory.ShowDialog();
  130. }
  131. private void btnAdd_Click(object sender, EventArgs e)
  132. {
  133. FormAddEdit formAddEdit = new FormAddEdit();
  134. formAddEdit.ShowDialog();
  135. FillPartner();
  136. }
  137. private void btnEditProfmanager_Click(object sender, EventArgs e)
  138. {
  139. FormProfile formProfile = new FormProfile();
  140. formProfile.bsMeneger.Filter = bsUsers.Filter;
  141. formProfile.ShowDialog();
  142. this.managerTableAdapter.Fill(this.dbAlphapolAGDataSet.Manager);
  143. try
  144. {
  145. pbxPhoto.Image = Image.FromFile(Application.StartupPath + "\\photo\\" + lblPhoto.Text);
  146. }
  147. catch { }
  148. }
  149. }
  150. }