FormManager.cs 4.8 KB

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