UIContactTask.cs 7.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215
  1. using System;
  2. using System.Collections.Generic;
  3. using System.ComponentModel;
  4. using System.Data;
  5. using System.Drawing;
  6. using System.Linq;
  7. using System.Text;
  8. using System.Threading.Tasks;
  9. using System.Windows.Forms;
  10. using System.Xml.XPath;
  11. using static DataManager.UIConstants;
  12. namespace DataManager
  13. {
  14. public partial class frmContactTask : Form
  15. {
  16. private ContactTask task = null;
  17. private string memo = string.Empty;
  18. // 模式:0-新任务,1-编辑已有任务
  19. private int mode = 0;
  20. public frmContactTask(int userId)
  21. {
  22. task = new ContactTask();
  23. task.UserId = userId;
  24. task.TaskType = 1; // 建立联系
  25. task.TaskDate = DateTime.Now;
  26. task.Priority = 2; // 高
  27. task.Isvalid = 3; // 等待答复
  28. task.FollowUpDate = DateTime.Now.AddDays(3); // 缺省3天之后跟进
  29. InitializeComponent();
  30. this.mode = 0;
  31. InitializeData();
  32. }
  33. public frmContactTask(ContactTask contactTask)
  34. {
  35. this.task = contactTask;
  36. InitializeComponent();
  37. this.mode = 1;
  38. InitializeData();
  39. memo = GetTaskMemo();
  40. }
  41. private void InitializeData()
  42. {
  43. this.Text = this.Text + " " + (mode == 0 ? "新任务" : task.TaskId.ToString());
  44. BindingSource bs1 = new BindingSource();
  45. bs1.DataSource = UIConstants.ContactTaskType;
  46. this.cmbTaskType.DataSource = bs1;
  47. this.cmbTaskType.DisplayMember = "Value";
  48. this.cmbTaskType.ValueMember = "Key";
  49. this.cmbTaskType.SelectedValue = (int)task.TaskType;
  50. // 已有任务不可以改变任务类型
  51. cmbTaskType.Enabled = (mode == 0 ? true : false);
  52. this.dtpTaskDate.Text = task.TaskDate.ToString();
  53. this.txtCompanyShortName.Text = task.CompanyShortName;
  54. if (mode == 1)
  55. {
  56. this.cmbTaskType.Enabled = false;
  57. this.dtpTaskDate.Enabled = false;
  58. this.txtCompanyShortName.ReadOnly = true;
  59. this.btnCompanySearch.Enabled = false;
  60. }
  61. BindingSource bs = new BindingSource();
  62. bs.DataSource = UIConstants.TaskPriority;
  63. this.cmbPriority.DataSource = bs;
  64. this.cmbPriority.DisplayMember = "Value";
  65. this.cmbPriority.ValueMember = "Key";
  66. this.cmbPriority.SelectedValue = (int)task.Priority;
  67. BindingSource bs2 = new BindingSource();
  68. bs2.DataSource = UIConstants.ContactTaskStatus;
  69. this.cmbIsValid.DataSource = bs2;
  70. this.cmbIsValid.DisplayMember = "Value";
  71. this.cmbIsValid.ValueMember = "Key";
  72. this.cmbIsValid.SelectedValue = (int)task.Isvalid;
  73. this.dtpFollowUpDate.ShowCheckBox = true;
  74. if (task.FollowUpDate != null)
  75. {
  76. this.dtpFollowUpDate.Text = task.FollowUpDate.ToString();
  77. this.dtpFollowUpDate.Checked = true;
  78. }
  79. else
  80. this.dtpFollowUpDate.Checked = false;
  81. }
  82. private string GetTaskMemo()
  83. {
  84. string memo = string.Empty;
  85. if (task != null && task.TaskId > 0)
  86. {
  87. DataTable dt = DataAccess.Get_dm_memo((sbyte)UIConstants.JobType.Contact, task.TaskId);
  88. if (dt != null && dt.Rows.Count > 0)
  89. {
  90. memo = dt.Rows[0]["memo"].ToString().Trim();
  91. }
  92. }
  93. txtMemo.Text = memo;
  94. return memo;
  95. }
  96. private void SaveTaskMemo()
  97. {
  98. string newMemo = txtMemo.Text.Trim();
  99. if (memo != newMemo)
  100. {
  101. DataAccess.Set_dm_memo((sbyte)UIConstants.JobType.Contact, task.TaskId, newMemo, task.UserId);
  102. }
  103. return;
  104. }
  105. private void btnSaveTask_Click(object sender, EventArgs e)
  106. {
  107. if (task.CompanyId == null || task.CompanyId.Length != 10)
  108. {
  109. MessageBox.Show("还没输入公司呢...");
  110. txtCompanyShortName.Focus();
  111. return;
  112. }
  113. task.TaskType = Int16.Parse(cmbTaskType.SelectedValue.ToString());
  114. task.TaskDate = DateTime.Parse(dtpTaskDate.Text);
  115. task.Priority = SByte.Parse(cmbPriority.SelectedValue.ToString());
  116. task.Isvalid = SByte.Parse(cmbIsValid.SelectedValue.ToString());
  117. if (dtpFollowUpDate.Checked == false)
  118. task.FollowUpDate = null;
  119. else
  120. task.FollowUpDate = DateTime.Parse(dtpFollowUpDate.Text);
  121. // 写回数据库时,新记录会INSERT记录并产生一个自增长的task_id
  122. task.TaskId = task.SaveToSQL(task.UserId);
  123. SaveTaskMemo();
  124. this.DialogResult = DialogResult.OK;
  125. this.Close();
  126. }
  127. private void btnCompanySearch_Click(object sender, EventArgs e)
  128. {
  129. if(txtCompanyShortName.TextLength < 2)
  130. {
  131. MessageBox.Show("请输入至少两个字,不然结果太多看不过来 @@");
  132. txtCompanyShortName.Focus();
  133. return;
  134. }
  135. // 只搜索私募公司
  136. DataTable companys = DataAccess.Search_dm_company(UIConstants.CompanyType.FirstOrDefault(x=>x.Value== "私募证券投资").Key, txtCompanyShortName.Text.Trim());
  137. if (companys == null || companys.Rows.Count == 0)
  138. {
  139. MessageBox.Show("- - 没有找到结果,换个关键字试试?");
  140. txtCompanyShortName.Focus();
  141. return;
  142. }
  143. grdCompany.DataSource = companys;
  144. grdCompany.Columns["company_id"].Visible = false;
  145. grdCompany.Columns["company_name"].Visible = false;
  146. grdCompany.Columns["company_asset_size"].Visible = false;
  147. grdCompany.AutoSizeColumnsMode = DataGridViewAutoSizeColumnsMode.Fill;
  148. grdCompany.Columns["company_short_name"].AutoSizeMode = DataGridViewAutoSizeColumnMode.DisplayedCells;
  149. grdCompany.Visible = true;
  150. }
  151. private void grdCompany_CellContentClick(object sender, DataGridViewCellEventArgs e)
  152. {
  153. int rowIndex = e.RowIndex;
  154. int columnIndex = e.ColumnIndex;
  155. if (columnIndex < 0 || rowIndex < 0) return;
  156. task.CompanyId = grdCompany.Rows[rowIndex].Cells["company_id"].Value.ToString();
  157. txtCompanyShortName.Text = grdCompany.Rows[rowIndex].Cells["company_short_name"].Value.ToString().Trim();
  158. grdCompany.Visible = false;
  159. return;
  160. }
  161. }
  162. }