FrmGroupofDjBl.cs 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410
  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.Windows.Forms;
  9. using Core.Mes.Client.Comm.Server;
  10. using CoreFS.CA06;
  11. using System.Collections;
  12. using Core.Mes.Client.Comm.Control;
  13. using Infragistics.Win.UltraWinGrid;
  14. using Infragistics.Win;
  15. using System.IO;
  16. using Infragistics.Excel;
  17. using System.Diagnostics;
  18. using Core.Mes.Client.Comm;
  19. using Core.Mes.Client.Comm.Tool;
  20. using com.steering.pss.plnsaleord.order.model;
  21. namespace Core.StlMes.Client.PlnSaleOrd
  22. {
  23. /// <summary>
  24. /// 备料组选择界面
  25. /// @author:杨天海
  26. /// @version:v1.1
  27. /// @date:2015.05.01
  28. /// </summary>
  29. public partial class FrmGroupofDjBl : FrmBase
  30. {
  31. /// <summary>
  32. /// 质量设计desginKey
  33. /// </summary>
  34. private string desginKey = "";
  35. /// <summary>
  36. /// 备料组
  37. /// </summary>
  38. private string groupNum = "";
  39. /// <summary>
  40. /// 交货行PK
  41. /// </summary>
  42. private string ordLnDlyPk = "";
  43. /// <summary>
  44. /// 合同计划支数
  45. /// </summary>
  46. private int orderNum = 0;
  47. /// <summary>
  48. /// 短节最大长度
  49. /// </summary>
  50. private double lenMax = 0;
  51. /// <summary>
  52. /// 形成短节合同状态
  53. /// </summary>
  54. private bool isCreatOk = false;
  55. public bool IsCreatOk
  56. {
  57. get { return isCreatOk; }
  58. set { isCreatOk = value; }
  59. }
  60. /// <summary>
  61. /// 交货行PK
  62. /// </summary>
  63. public string OrdLnDlyPk
  64. {
  65. get { return ordLnDlyPk; }
  66. set { ordLnDlyPk = value; }
  67. }
  68. /// <summary>
  69. /// 质量设计desginKey
  70. /// </summary>
  71. public string DesginKey
  72. {
  73. get { return desginKey; }
  74. set { desginKey = value; }
  75. }
  76. /// <summary>
  77. /// 备料组
  78. /// </summary>
  79. public string GroupNum
  80. {
  81. get { return groupNum; }
  82. set { groupNum = value; }
  83. }
  84. public FrmGroupofDjBl()
  85. {
  86. InitializeComponent();
  87. }
  88. /// <summary>
  89. /// 构造
  90. /// </summary>
  91. /// <param name="ob"></param>
  92. public FrmGroupofDjBl(OpeBase ob)
  93. {
  94. this.ob = ob;
  95. InitializeComponent();
  96. }
  97. private void FrmGroupofDjBl_Load(object sender, EventArgs e)
  98. {
  99. PlanComm.setGridActivation(ultraGrid1.DisplayLayout.Bands[0], "CHECK");
  100. PlanComm.setGridActivation(ultraGrid1.DisplayLayout.Bands[1], "JGBL_REQ_NUM");
  101. DoQuery();
  102. }
  103. /// <summary>
  104. /// 查询
  105. /// </summary>
  106. private void DoQuery()
  107. {
  108. if (desginKey.Equals(""))
  109. {
  110. MessageUtil.ShowTips("未找到评审数据!");
  111. return;
  112. }
  113. DataTable dtGroup = ServerHelper.GetData("com.steering.pss.plnsaleord.order.CorePlnOrdJgDjDeal.queryBlGroup",
  114. new object[] { desginKey, ordLnDlyPk }, this.ob);
  115. GridHelper.CopyDataToDatatable(dtGroup, dataTable1, true);
  116. foreach (UltraGridRow uRow in ultraGrid1.Rows)
  117. {
  118. uRow.Expanded = true;
  119. }
  120. foreach (UltraGridRow uRow in ultraGrid1.Rows)
  121. {
  122. if (uRow.Cells["GROUP_NUM"].Value.ToString().Equals(groupNum))
  123. {
  124. uRow.Cells["CHECK"].Value = true;
  125. }
  126. }
  127. dataTable2.Clear();
  128. #region 查询短节
  129. int.TryParse(dtGroup.Rows[0]["ORDERNUM"].ToString(), out orderNum);
  130. double.TryParse(dtGroup.Rows[0]["LENGTHMAX"].ToString(), out lenMax);
  131. DataTable dtBlList = ServerHelper.GetData("com.steering.pss.plnsaleord.order.CorePlnOrdJgDjDeal.queryDesginBlList",
  132. new object[] { desginKey }, this.ob);
  133. if (dtBlList == null || dtBlList.Rows.Count < 0)
  134. {
  135. return;
  136. }
  137. foreach (DataRow dr in dtBlList.Rows)
  138. {
  139. double min_d = Convert.ToDouble(dr["MIN_D"]);
  140. double min_h = Convert.ToDouble(dr["MIN_H"]);
  141. double Weight_One = PlanComm.WeightOfMi(min_d, min_h);//米单重(吨/米)
  142. double lengthMax = Convert.ToDouble(dr["MAX_L"]);
  143. double lengthMin = Convert.ToDouble(dr["MIN_L"]);
  144. double aimlength = (lengthMax + lengthMin) / 2;
  145. double singleweight = aimlength * Weight_One;//单重
  146. if (lenMax <= lengthMax)
  147. {
  148. if (aimlength < lenMax)
  149. {
  150. aimlength = lenMax;
  151. }
  152. }
  153. else
  154. {
  155. continue;
  156. }
  157. int eatchBlnum = (int)(aimlength / lenMax);//每只备料管可切短节支数。
  158. DataRow drNew = dataTable2.NewRow();
  159. drNew["GROUP_NUM"] = dr["GROUP_NUM"].ToString();
  160. drNew["PSC_BL"] = dr["PSC_BL"].ToString();
  161. drNew["PRODUCNAME"] = dr["PRODUCNAME"].ToString();
  162. drNew["STD_NAME"] = dr["STD_NAME"].ToString();
  163. drNew["STEELNAME"] = dr["STEELNAME"].ToString();
  164. drNew["STD_STYLE_DESC"] = dr["STD_STYLE_DESC"].ToString();
  165. drNew["MODEL_DESC"] = dr["MODEL_DESC"].ToString();
  166. drNew["MIN_D"] = dr["MIN_D"].ToString();
  167. drNew["MIN_H"] = dr["MIN_H"].ToString();
  168. drNew["USE_DESC"] = dr["USE_DESC"].ToString();
  169. drNew["MIN_L"] = dr["MIN_L"].ToString();
  170. drNew["MAX_L"] = dr["MAX_L"].ToString();
  171. drNew["MEMO"] = dr["MEMO"].ToString();
  172. drNew["SINGLEWEIGHT"] = singleweight;
  173. drNew["STEELCODE"] = dr["STEELCODE"].ToString();
  174. drNew["STD_CODE"] = dr["STD_CODE"].ToString();
  175. drNew["PRODUCCODE"] = dr["PRODUCCODE"].ToString();
  176. drNew["STD_STYLE"] = dr["STD_STYLE"].ToString();
  177. drNew["BLGTODJNUM"] = eatchBlnum;
  178. if (orderNum % eatchBlnum == 0)
  179. {
  180. drNew["JGBL_REQ_NUM"] = (int)(orderNum / eatchBlnum);
  181. drNew["JGBL_REQ_WEIGHT"] = (int)(orderNum / eatchBlnum) * singleweight;
  182. }
  183. else
  184. {
  185. drNew["JGBL_REQ_NUM"] = (int)(orderNum / eatchBlnum) + 1;
  186. drNew["JGBL_REQ_WEIGHT"] = ((int)(orderNum / eatchBlnum) + 1) * singleweight;
  187. }
  188. dataTable2.Rows.Add(drNew);
  189. }
  190. #endregion
  191. }
  192. /// <summary>
  193. /// 确定按钮
  194. /// </summary>
  195. /// <param name="sender"></param>
  196. /// <param name="e"></param>
  197. private void ultraButton1_Click(object sender, EventArgs e)
  198. {
  199. foreach(UltraGridRow uRow in ultraGrid1.Rows)
  200. {
  201. if (Convert.ToBoolean(uRow.Cells["CHECK"].Text))
  202. {
  203. DataTable dtStatus = ServerHelper.GetData("com.steering.pss.plnsaleord.order.CorePlnOrdJgDjDeal.querySaleByPrimary",
  204. new object[] { ordLnDlyPk }, this.ob);
  205. if (dtStatus == null || dtStatus.Rows.Count <= 0)
  206. {
  207. MessageUtil.ShowTips("查询销售合同状态失败!");
  208. return;
  209. }
  210. if (dtStatus.Rows[0]["PORDERSTATUS"].ToString().CompareTo("4") < 0
  211. && dtStatus.Rows[0]["DJBL_REQ_IS_OK"].ToString().Equals("0"))
  212. {
  213. ArrayList listBL = new ArrayList();
  214. ArrayList paramUpdate = new ArrayList();
  215. ArrayList listupdate = new ArrayList();
  216. foreach (UltraGridRow cRow in uRow.ChildBands[0].Rows)
  217. {
  218. #region 短节备料需求处理
  219. string strPSC = "";//产品码
  220. string strCodeBl = cRow.Cells["PSC_BL"].Value.ToString();//备料码
  221. double aimlength = (Convert.ToDouble(cRow.Cells["MAX_L"].Value)
  222. + Convert.ToDouble(cRow.Cells["MIN_L"].Value)) / 2;
  223. string specSameSale = "0";
  224. if (dtStatus.Rows[0]["OUTDIAMETER"].ToString().Equals(cRow.Cells["MIN_D"].Value.ToString())
  225. && dtStatus.Rows[0]["WALLTHICK"].ToString().Equals(cRow.Cells["MIN_H"].Value.ToString())
  226. && dtStatus.Rows[0]["STEELCODE"].ToString().Equals(cRow.Cells["STEELCODE"].Value.ToString()))
  227. {
  228. specSameSale = "1";
  229. }
  230. PlnPorderBlReqEntity blReqEntity = new PlnPorderBlReqEntity();
  231. blReqEntity.Bltype = "短节备料";
  232. blReqEntity.OrdLnDlyPk = ordLnDlyPk;
  233. blReqEntity.OrderNo = dtStatus.Rows[0]["ORDER_NO"].ToString();
  234. blReqEntity.OrderSeq = dtStatus.Rows[0]["ORDER_SEQ"].ToString();
  235. blReqEntity.DeliveryNo = dtStatus.Rows[0]["DELIVERY_NO"].ToString();
  236. blReqEntity.CodeDjBl = strCodeBl;
  237. blReqEntity.CreateName = UserInfo.GetUserName();
  238. strPSC = QueryPsc(cRow.Cells["PRODUCCODE"].Value.ToString(),
  239. cRow.Cells["STD_CODE"].Value.ToString(),
  240. cRow.Cells["STEELCODE"].Value.ToString(),
  241. cRow.Cells["STD_STYLE"].Value.ToString());
  242. blReqEntity.Psc = strPSC;
  243. blReqEntity.Msc = QueryPscForMsc(strPSC);
  244. blReqEntity.Singleweight = cRow.Cells["SINGLEWEIGHT"].Value.ToString();
  245. blReqEntity.SpecSameSale = specSameSale;
  246. blReqEntity.JgblReqWeight = cRow.Cells["JGBL_REQ_WEIGHT"].Value.ToString(); //备料需求量
  247. blReqEntity.JgblReqNum = cRow.Cells["JGBL_REQ_NUM"].Value.ToString(); //备料需求支数
  248. listBL.Add(blReqEntity);
  249. #endregion
  250. }
  251. //更新销售合同
  252. paramUpdate.Add("1");
  253. paramUpdate.Add(dtStatus.Rows[0]["ORD_LN_DLY_PK"].ToString());
  254. listupdate.Add(paramUpdate);
  255. int isSucceed = ServerHelper.SetData("com.steering.pss.plnsaleord.order.CorePlnOrdJgDjDeal.tranSactionDj",
  256. new object[] { listBL, listupdate }, this.ob);
  257. if (isSucceed > 0)
  258. {
  259. MessageUtil.ShowTips("形成短节合同成功!");
  260. IsCreatOk = true;
  261. }
  262. }
  263. groupNum = uRow.Cells["GROUP_NUM"].Value.ToString();
  264. this.Close();
  265. return;
  266. }
  267. }
  268. MessageBox.Show("请选择短节备料组!");
  269. }
  270. /// <summary>
  271. /// 取消按钮
  272. /// </summary>
  273. /// <param name="sender"></param>
  274. /// <param name="e"></param>
  275. private void ultraButton2_Click(object sender, EventArgs e)
  276. {
  277. this.Close();
  278. }
  279. /// <summary>
  280. /// 控制单选
  281. /// </summary>
  282. /// <param name="sender"></param>
  283. /// <param name="e"></param>
  284. private void ultraGrid1_CellChange(object sender, CellEventArgs e)
  285. {
  286. if (e.Cell.Column.Key.Equals("CHECK"))
  287. {
  288. if (Convert.ToBoolean(e.Cell.Row.Cells["CHECK"].Text))
  289. {
  290. foreach (UltraGridRow uRow in ultraGrid1.Rows)
  291. {
  292. if (uRow != e.Cell.Row)
  293. {
  294. uRow.Cells["CHECK"].Value = false;
  295. }
  296. }
  297. }
  298. }
  299. }
  300. private void ultraGrid1_AfterCellUpdate(object sender, CellEventArgs e)
  301. {
  302. if (e.Cell.Column.Key.Equals("JGBL_REQ_NUM") && e.Cell.Row.Cells["JGBL_REQ_NUM"].DataChanged)
  303. {
  304. e.Cell.Row.Update();
  305. int num = 0;
  306. double singleweight = 0;
  307. if (int.TryParse(e.Cell.Row.Cells["JGBL_REQ_NUM"].Value.ToString(), out num) &&
  308. double.TryParse(e.Cell.Row.Cells["SINGLEWEIGHT"].Value.ToString(), out singleweight))
  309. {
  310. e.Cell.Row.Cells["JGBL_REQ_WEIGHT"].Value = (num * singleweight).ToString();
  311. }
  312. else
  313. {
  314. e.Cell.Row.Cells["JGBL_REQ_NUM"].Value = 0;
  315. e.Cell.Row.Cells["JGBL_REQ_WEIGHT"].Value = 0;
  316. }
  317. }
  318. }
  319. /// <summary>
  320. /// 查询产品码
  321. /// </summary>
  322. /// <param name="parms">备料品名、标准、钢级、标准类别</param>
  323. /// <returns>产品码</returns>
  324. public string QueryPsc(string producCode, string stdCode, string steelCode, string stdStyle)
  325. {
  326. try
  327. {
  328. ArrayList param = new ArrayList();
  329. param.Add(producCode);
  330. param.Add(stdCode);
  331. param.Add(steelCode);
  332. param.Add(stdStyle);
  333. param.Add(stdStyle);
  334. param.Add(stdStyle);
  335. DataTable dt = ServerHelper.GetData("com.steering.pss.plnsaleord.order.CorePlnOrdJgDjDeal.queryblPsc",
  336. new object[] { param }, this.ob);
  337. if (dt != null && dt.Rows.Count > 0)
  338. {
  339. return dt.Rows[0]["PSC"].ToString();
  340. }
  341. else
  342. {
  343. return "";
  344. }
  345. }
  346. catch
  347. {
  348. return "";
  349. }
  350. }
  351. /// <summary>
  352. /// 查询产品码与冶金规范对应关系\
  353. /// </summary>
  354. /// <param name="strPsc">产品码</param>
  355. /// <returns>冶金规范码</returns>
  356. public string QueryPscForMsc(string strPsc)
  357. {
  358. try
  359. {
  360. DataTable dt = ServerHelper.GetData("com.steering.pss.plnsaleord.order.CorePlnOrdJgDjDeal.queryPscForMsc",
  361. new object[] { strPsc }, this.ob);
  362. if (dt != null && dt.Rows.Count > 0)
  363. {
  364. return dt.Rows[0]["MSC"].ToString();
  365. }
  366. else
  367. {
  368. return "";
  369. }
  370. }
  371. catch
  372. {
  373. return "";
  374. }
  375. }
  376. }
  377. }