FrmComBaseMandrel.cs 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304
  1. using Core.Mes.Client.Comm.Control;
  2. using Core.Mes.Client.Comm.Format;
  3. using Core.Mes.Client.Comm.Server;
  4. using Core.Mes.Client.Comm.Tool;
  5. using Core.StlMes.Client.PlnSaleOrd.BaseMethod;
  6. using Core.StlMes.Client.PlnSaleOrd.工序排产.control;
  7. using Core.StlMes.Client.PlnSaleOrd.工序排产.entity;
  8. using CoreFS.CA06;
  9. using Infragistics.Win;
  10. using Infragistics.Win.UltraWinGrid;
  11. using System;
  12. using System.Collections;
  13. using System.Collections.Generic;
  14. using System.ComponentModel;
  15. using System.Data;
  16. using System.Drawing;
  17. using System.Linq;
  18. using System.Text;
  19. using System.Windows.Forms;
  20. namespace Core.StlMes.Client.PlnSaleOrd
  21. {
  22. public partial class FrmComBaseMandrel : FrmBase
  23. {
  24. private string madrelId = "";
  25. private BaseMandrelSpec _baseMandrelSpec;
  26. public FrmComBaseMandrel()
  27. {
  28. InitializeComponent();
  29. }
  30. private void FrmComBaseMandrel_Load(object sender, EventArgs e)
  31. {
  32. BaseHelper.setOtherColumnReadOnly(entityGridMandrel, new string[] { "" });
  33. BaseHelper.InitCellPosition(entityGridMandrel, new string[] { "DiameterMandrel", "LenMandrel" });
  34. BaseHelper.setUltraGridColumnMaxInput(entityGridMandrel, new string[] { "DiameterMandrel" });
  35. InitModel();
  36. _baseMandrelSpec = new BaseMandrelSpec(splitContainer1.Panel2, ob);
  37. _baseMandrelSpec.CreName = this.UserInfo.GetUserName();
  38. }
  39. private void InitModel()
  40. {
  41. DataTable dt = ServerHelper.GetData("com.steering.pss.plnsaleord.processOrder.FrmComBaseMandrel.initModel", new object[] { }, ob);
  42. txtModel1.DropDownListWidth = -1;
  43. txtModel1.DropDownStyle = DropDownStyle.DropDownList;
  44. txtModel1.DataSource = dt;
  45. txtModel1.DisplayMember = "MODEL_DESC";
  46. txtModel1.ValueMember = "MODEL_CODE";
  47. ClsBaseInfo.SetComboItemHeight(txtModel1);
  48. txtModel2.DropDownListWidth = -1;
  49. txtModel2.DropDownStyle = DropDownStyle.DropDownList;
  50. txtModel2.DataSource = dt;
  51. txtModel2.DisplayMember = "MODEL_DESC";
  52. txtModel2.ValueMember = "MODEL_CODE";
  53. ClsBaseInfo.SetComboItemHeight(txtModel2);
  54. ClsBaseInfo.SetComboItemHeight(txtOr);
  55. }
  56. private void chcModel_CheckedChanged(object sender, EventArgs e)
  57. {
  58. if (chcModel.Checked) { txtModel1.ReadOnly = false; } else { txtModel1.ReadOnly = true; }
  59. }
  60. public override void ToolBar_Click(object sender, string ToolbarKey)
  61. {
  62. base.ToolBar_Click(sender, ToolbarKey);
  63. switch (ToolbarKey)
  64. {
  65. case "Query"://查询
  66. Query();
  67. break;
  68. case "Add"://新增
  69. Add();
  70. break;
  71. case "Update"://修改 q
  72. Update();
  73. break;
  74. case "Delete"://删除
  75. Delete();
  76. break;
  77. case "Close"://关闭
  78. this.Close();
  79. break;
  80. case "Export": //导出
  81. GridHelper.ulGridToExcel(entityGridMandrel, "孔型信息");
  82. break;
  83. default:
  84. break;
  85. }
  86. }
  87. private void Query()
  88. {
  89. string modelDesc = "";
  90. if (chcModel.Checked && txtModel1.Value != null)
  91. { modelDesc = txtModel1.Text.ToString(); }
  92. List<ComBaseMandrelEntity> listSource = EntityHelper.GetData<ComBaseMandrelEntity>
  93. ("com.steering.pss.plnsaleord.processOrder.FrmComBaseMandrel.query", new object[] { modelDesc }, ob);
  94. comBaseMandrelEntityBindingSource.DataSource = listSource;
  95. if (!madrelId.Equals("")&&entityGridMandrel.Rows.Count>0)
  96. {
  97. foreach (UltraGridRow ugr in entityGridMandrel.Rows)
  98. {
  99. if (ugr.Cells["MandrelId"].Text.Equals(madrelId))
  100. {
  101. ugr.Activate();
  102. break;
  103. }
  104. }
  105. }
  106. madrelId = "";
  107. }
  108. private void Add()
  109. {
  110. if (!CheckParams()) { return; }
  111. ComBaseMandrelEntity entity = new ComBaseMandrelEntity();
  112. string dimater = txtDiameter.Value.ToString();
  113. string length = txtLength.Value.ToString();
  114. string model = txtModel2.Text;
  115. //if (!CheckMandrel(dimater)) { MessageUtil.ShowWarning("存在相同的芯棒直径 " + dimater + "!", txtDiameter); return; }
  116. string massyOr = txtOr.Text;
  117. string taper = txtTaper.Text.Trim();
  118. string memo = txtMemo.Text.Trim();
  119. ArrayList list = new ArrayList();
  120. list.Add(dimater);
  121. list.Add(length);
  122. list.Add(model);
  123. list.Add(taper);
  124. list.Add(massyOr);
  125. if (!CheckMandrel1(list)) { MessageUtil.ShowWarning("存在相同的芯棒直径、长度、芯棒扣型、锥度、空心实心!"); return; }
  126. entity.CreateName = UserInfo.GetUserName();
  127. entity.DiameterMandrel = (decimal?)Convert.ToDouble(dimater);
  128. entity.LenMandrel = (decimal?)Convert.ToDouble(length);
  129. entity.MandrelId = String.Format("{0:N1}", Convert.ToDouble(dimater));
  130. entity.MassyOrHollow = massyOr;
  131. entity.Memo = memo;
  132. entity.ScrewModel = model;
  133. entity.TaperMandrel = taper;
  134. string jsonStr = JSONFormat.Format(entity);
  135. if (MessageUtil.ShowYesNoAndQuestion("是否新增?") == DialogResult.No)
  136. {
  137. return;
  138. }
  139. madrelId = entity.MandrelId;
  140. int count = ServerHelper.SetData("com.steering.pss.plnsaleord.processOrder.FrmComBaseMandrel.add", new object[] { jsonStr }, ob);
  141. if (count == 0) { MessageUtil.ShowTips("服务端处理失败!"); return; }
  142. else
  143. {
  144. MessageUtil.ShowWarning("新增成功!", entityGridMandrel);
  145. Query();
  146. }
  147. }
  148. private void Update()
  149. {
  150. UltraGridRow ugr = entityGridMandrel.ActiveRow;
  151. if (ugr == null)
  152. {
  153. MessageUtil.ShowWarning("请选择要修改的记录!", entityGridMandrel);
  154. return;
  155. }
  156. if (!CheckParams()) { return; }
  157. ComBaseMandrelEntity entity = (ComBaseMandrelEntity)ugr.ListObject;
  158. string dimater = txtDiameter.Value.ToString();
  159. string length = txtLength.Value.ToString();
  160. string model = txtModel2.Text;
  161. string massyOr = txtOr.Text;
  162. string taper = txtTaper.Text.Trim();
  163. string memo = txtMemo.Text.Trim();
  164. ArrayList list = new ArrayList();
  165. list.Add(dimater);
  166. list.Add(length);
  167. list.Add(model);
  168. list.Add(taper);
  169. list.Add(massyOr);
  170. if (!CheckMandrel1(list)) { MessageUtil.ShowWarning("存在相同的芯棒直径、长度、芯棒扣型、锥度、空心实心!"); return; }
  171. entity.UpdateName = UserInfo.GetUserName();
  172. entity.LenMandrel = (decimal?)Convert.ToDouble(length);
  173. entity.MandrelId = dimater;
  174. entity.MassyOrHollow = massyOr;
  175. entity.Memo = memo;
  176. entity.ScrewModel = model;
  177. entity.TaperMandrel = taper;
  178. string jsonStr = JSONFormat.Format(entity);
  179. if (MessageUtil.ShowYesNoAndQuestion("是否修改?") == DialogResult.No)
  180. {
  181. return;
  182. }
  183. madrelId = entity.MandrelId;
  184. int count = ServerHelper.SetData("com.steering.pss.plnsaleord.processOrder.FrmComBaseMandrel.update", new object[] { jsonStr }, ob);
  185. if (count == 0) { MessageUtil.ShowTips("服务端处理失败!"); return; }
  186. else
  187. {
  188. MessageUtil.ShowWarning("修改成功!", entityGridMandrel);
  189. Query();
  190. }
  191. }
  192. private void Delete()
  193. {
  194. UltraGridRow ugr = entityGridMandrel.ActiveRow;
  195. if (ugr == null)
  196. {
  197. MessageUtil.ShowWarning("请选择要修改的记录!", entityGridMandrel);
  198. return;
  199. }
  200. ComBaseMandrelEntity entity = (ComBaseMandrelEntity)ugr.ListObject;
  201. string jsonStr = JSONFormat.Format(entity);
  202. if (MessageUtil.ShowYesNoAndQuestion("是否删除?") == DialogResult.No)
  203. {
  204. return;
  205. }
  206. int count = ServerHelper.SetData("com.steering.pss.plnsaleord.processOrder.FrmComBaseMandrel.delete", new object[] { jsonStr }, ob);
  207. if (count == 0) { MessageUtil.ShowTips("服务端处理失败!"); return; }
  208. else
  209. {
  210. MessageUtil.ShowWarning("删除成功!", entityGridMandrel);
  211. Query();
  212. }
  213. }
  214. /// <summary>
  215. /// 判断主键是否重复
  216. /// </summary>
  217. /// <param name="mandrel"></param>
  218. /// <returns></returns>
  219. private bool CheckMandrel1(ArrayList list)
  220. {
  221. DataTable dt = ServerHelper.GetData("com.steering.pss.plnsaleord.processOrder.FrmComBaseMandrel.checkMandrel1", new object[] { list }, ob);
  222. int count = Convert.ToInt32(dt.Rows[0][0].ToString());
  223. if (count == 0)
  224. {
  225. return true;
  226. }
  227. else
  228. {
  229. return false;
  230. }
  231. }
  232. /// <summary>
  233. /// 判断芯棒直径,长度,芯棒扣型,锥度,实心空心是否相同
  234. /// </summary>
  235. /// <param name="mandrel"></param>
  236. /// <returns></returns>
  237. private bool CheckMandrel(string mandrel)
  238. {
  239. DataTable dt = ServerHelper.GetData("com.steering.pss.plnsaleord.processOrder.FrmComBaseMandrel.checkMandrel", new object[] { mandrel }, ob);
  240. int count = Convert.ToInt32(dt.Rows[0][0].ToString());
  241. if (count == 0)
  242. {
  243. return true;
  244. }
  245. else
  246. {
  247. return false;
  248. }
  249. }
  250. private bool CheckParams()
  251. {
  252. if (txtDiameter.Value == null ||txtDiameter.Value.ToString().Equals("") ||Convert.ToDouble(txtDiameter.Value.ToString()) <= 0)
  253. { MessageUtil.ShowWarning("请输入芯棒直径!", txtDiameter); return false; }
  254. if (txtLength.Value == null || txtLength.Value.ToString().Equals("") || Convert.ToDouble(txtLength.Value.ToString()) < 0)
  255. { MessageUtil.ShowWarning("请输入长度!", txtLength); return false; }
  256. if (txtModel2.Value == null)
  257. {
  258. MessageUtil.ShowWarning("请选择芯棒扣型!", txtModel2); return false;
  259. }
  260. if (txtOr.Value == null)
  261. {
  262. MessageUtil.ShowWarning("请选择实心空心!", txtOr); return false;
  263. }
  264. if (txtTaper.Text.Trim().Equals(""))
  265. {
  266. MessageUtil.ShowWarning("请输入锥度!", txtTaper); return false;
  267. }
  268. return true;
  269. }
  270. private void entityGridMandrel_AfterRowActivate(object sender, EventArgs e)
  271. {
  272. UltraGridRow ugr = entityGridMandrel.ActiveRow;
  273. if (ugr == null)
  274. {
  275. return;
  276. }
  277. ComBaseMandrelEntity entity = (ComBaseMandrelEntity)ugr.ListObject;
  278. txtDiameter.Value = entity.DiameterMandrel;
  279. txtLength.Value = entity.LenMandrel;
  280. txtModel2.Text = entity.ScrewModel;
  281. txtOr.Value = entity.MassyOrHollow;
  282. txtTaper.Value = entity.TaperMandrel;
  283. txtMemo.Value = entity.Memo;
  284. _baseMandrelSpec.CreName = this.UserInfo.GetUserName();
  285. _baseMandrelSpec.MandrelId = ugr.Cells["MandrelId"].Value.ToString();
  286. _baseMandrelSpec.MandDimater = ugr.Cells["DiameterMandrel"].Text.ToString();
  287. _baseMandrelSpec.Query();
  288. }
  289. }
  290. }