FrmChangeIndex.cs 63 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257
  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 CoreFS.CA06;
  10. using Core.Mes.Client.Comm.Tool;
  11. using com.steering.pss.plnsaleord.order.model;
  12. using Core.Mes.Client.Comm;
  13. using System.Collections;
  14. using Core.Mes.Client.Comm.Server;
  15. using Infragistics.Win.UltraWinGrid;
  16. using com.steering.pss.plnsaleord.ordAmCal.model;
  17. using Core.StlMes.Client.PlnSaleOrd.BaseMethod;
  18. namespace Core.StlMes.Client.PlnSaleOrd.PopupWindow
  19. {
  20. public partial class FrmChangeIndex : FrmBase
  21. {
  22. /// <summary>
  23. /// 交货pk
  24. /// </summary>
  25. private string ordLnDlyPk = "";
  26. /// <summary>
  27. /// 补量需求编号
  28. /// </summary>
  29. private string rNumId = "";
  30. private string ordLnDlyPkL = "";
  31. private string plnDivideId = "";
  32. private string orderSource = "";
  33. public FrmChangeIndex()
  34. {
  35. InitializeComponent();
  36. EntityHelper.ShowGridCaption<PlnSaleordProcEntity>(ultraGridProc.DisplayLayout.Bands[0]);
  37. }
  38. public FrmChangeIndex(OpeBase _ob, string _ordLnDlyPk, string _plnDivideId,string _orderSource)
  39. {
  40. this.ob = _ob;
  41. ordLnDlyPkL = _ordLnDlyPk;
  42. plnDivideId = _plnDivideId;
  43. orderSource = _orderSource;
  44. this.IsLoadUserView = true;
  45. InitializeComponent();
  46. EntityHelper.ShowGridCaption<PlnSaleordProcEntity>(ultraGridProc.DisplayLayout.Bands[0]);
  47. }
  48. private void FrmChangeIndex_Load(object sender, EventArgs e)
  49. {
  50. this.comMscPilneCtrl1.ComBLL(this.ob);
  51. string ordLnPk = "";
  52. if (ordLnDlyPk.Length > 3)
  53. {
  54. ordLnPk = ordLnDlyPk.Substring(0, ordLnDlyPk.Length - 3);
  55. }
  56. this.comMscPilneCtrl1.OrdLnPk = ordLnPk;
  57. if (!rNumId.Equals(""))
  58. {
  59. ultraToolbarsManager1.Tools.Remove(ultraToolbarsManager1.Tools["Add"]);
  60. ultraToolbarsManager1.Tools.Remove(ultraToolbarsManager1.Tools["Save"]);
  61. ultraToolbarsManager1.Tools.Remove(ultraToolbarsManager1.Tools["Delete"]);
  62. ultraGridProc.DisplayLayout.Bands[0].Columns["RNumId"].Hidden = false;
  63. PlanComm.setGridActivation(this.ultraGridProc.DisplayLayout.Bands[0], "CHC");
  64. }
  65. else
  66. {
  67. PlanComm.setGridActivation(this.ultraGridProc.DisplayLayout.Bands[0], "CHC", "OrderQtyD");
  68. }
  69. PlanComm.setGridDigitalCol(this.ultraGridProc.DisplayLayout.Bands[0], 5, 3,
  70. "PlanWtD", "FinishWt", "PlanPMain", "OrderQtyD", "AimLenEnd", "AimLenRoll", "PlanPMainMin", "AimWtEnd", "WeightJg");
  71. PlanComm.setGridDigitalCol(this.ultraGridProc.DisplayLayout.Bands[0], 5, 2,
  72. "TotLenOneP", "PlanTotLenD", "HeightYlg", "DimaterYlg", "AimWallthick", "RollLength", "AimOutdiameter", "FeedRate", "Coefficient", "CoefficientMin", "CheckJVal");
  73. PlanComm.setGridDigitalCol(this.ultraGridProc.DisplayLayout.Bands[0], 7, 0, "PlanNumD", "CutNumP");
  74. PlanComm.setGridDigitalCol(this.ultraGridProc.DisplayLayout.Bands[0], 3, 6, "WeightPerM", "WeightKzM");
  75. PlanComm.setGridSummarySet(this.ultraGridProc, 3, "PlanWtD","FinishWt", "PlanPMain", "OrderQtyD","PlanPMainMin");
  76. DoQuery();
  77. }
  78. private void ultraToolbarsManager1_ToolClick(object sender, Infragistics.Win.UltraWinToolbars.ToolClickEventArgs e)
  79. {
  80. switch (e.Tool.Key)
  81. {
  82. case "Query":
  83. DoQuery();
  84. break;
  85. case "Add":
  86. DoNew();
  87. break;
  88. case "Modify":
  89. DoModify();
  90. break;
  91. case "Save":
  92. DoSave();
  93. break;
  94. case "Delete":
  95. DoDelete();
  96. break;
  97. case "Colse":
  98. this.Close();
  99. break;
  100. }
  101. }
  102. /// <summary>
  103. /// 查询
  104. /// </summary>
  105. private void DoQuery()
  106. {
  107. this.slmPlnSaleordProcEntitybindingSource.DataSource = EntityHelper.GetData<PlnSaleordProcEntity>(
  108. "com.steering.pss.plnsaleord.order.CoreChangeIndex.queryPlnOrderProc", new object[] { ordLnDlyPk, rNumId, plnDivideId }, this.ob);
  109. DataTable dt = ServerHelper.GetData("com.steering.pss.plnsaleord.order.CorePlnSaleOrder.querySaleStatus",
  110. new object[] { ordLnDlyPk }, this.ob);
  111. if (dt != null && dt.Rows.Count > 0)
  112. {
  113. ultraNumericOrderWt.Value = 0;
  114. ultraTextOrderUnit.Value = dt.Rows[0]["ORDER_UNIT"].ToString();
  115. }
  116. }
  117. /// <summary>
  118. /// 新增交货行拆分
  119. /// </summary>
  120. private void DoNew()
  121. {
  122. try
  123. {
  124. UltraGridRow ugr = ultraGridProc.ActiveRow;
  125. if (ugr == null)
  126. {
  127. return;
  128. }
  129. double orderQty = 0;
  130. double orderQtyD = 0;
  131. ArrayList list = new ArrayList();
  132. if (!double.TryParse(ultraNumericOrderWt.Value.ToString(), out orderQtyD))
  133. {
  134. MessageUtil.ShowTips("拆分量未指定!");
  135. return;
  136. }
  137. if (orderQtyD <= 0)
  138. {
  139. MessageUtil.ShowTips("拆分量未指定!");
  140. return;
  141. }
  142. ArrayList param = new ArrayList();
  143. PlnSaleordProcEntity ordProcEntity = new PlnSaleordProcEntity();
  144. comMscPilneCtrl1.UltraGridMscPline.UpdateData();
  145. IQueryable<UltraGridRow> checkRows = comMscPilneCtrl1.UltraGridMscPline.Rows.AsQueryable().Where("CHC = 'True'");
  146. if (checkRows.Count() <= 0)
  147. {
  148. MessageUtil.ShowError("没有选择的制程工艺!");
  149. return;
  150. }
  151. string desginKey = this.comMscPilneCtrl1.DesginKey;
  152. ordProcEntity.IndexSeq = this.comMscPilneCtrl1.CheMscPline;
  153. ordProcEntity.CraftFileMan = this.comMscPilneCtrl1.CheCraftName;
  154. ordProcEntity.CraftFileNo = this.comMscPilneCtrl1.CheCraftNo;
  155. ordProcEntity.CraftSeq = this.comMscPilneCtrl1.CheCraftSeq;
  156. ordProcEntity.GradecodeAll = this.comMscPilneCtrl1.GradeNameAll;
  157. ordProcEntity.OrdLnDlyPk = ordLnDlyPk;
  158. ordProcEntity.OrderSource = "销售合同";
  159. string finalUser = ""; //最终用户
  160. string produccode = ""; //品名代码
  161. double outdiameter = 0;
  162. double wallthick = 0;
  163. double delvryRangeMax = 0;
  164. double delvryRangeMin = 0;
  165. double lengthmax = 0;
  166. double lengthmin = 0;
  167. string delvryRangeTpe = "";
  168. DataTable dtStatus = ServerHelper.GetData("com.steering.pss.plnsaleord.order.CoreChangeIndex.queryPlnSaleOrderProc",
  169. new object[] { ordLnDlyPk }, this.ob);
  170. if (dtStatus != null && dtStatus.Rows.Count > 0)
  171. {
  172. //判断制程有误重复
  173. //foreach (DataRow dr in dtStatus.Rows)
  174. //{
  175. // if (dr["CRAFT_SEQ"].Equals(comMscPilneCtrl1.CheCraftSeq))
  176. // {
  177. // MessageUtil.ShowError("序号:“" + comMscPilneCtrl1.CheCraftSeq + "”的工艺已经被使用!");
  178. // return;
  179. // }
  180. //}
  181. if (dtStatus.Rows[0]["MERGETYPE"].ToString().Equals("3"))
  182. {
  183. MessageUtil.ShowError("管坯类型的合同不允许拆分!");
  184. return;
  185. }
  186. DataTable dtProc = ServerHelper.GetData("com.steering.pss.plnsaleord.order.CoreChangeIndex.queryPlnOrdProcById",
  187. new object[] { ordLnDlyPk, ugr.Cells["PlnDivideId"].Value.ToString() }, this.ob);
  188. if (dtProc == null || dtProc.Rows.Count <= 0)
  189. {
  190. return;
  191. }
  192. if (dtProc.Rows[0]["PLANSTATUS"].ToString().CompareTo("1") > 0)
  193. {
  194. MessageUtil.ShowTips("交货行拆分项已经下发,不可用再进行拆分!");
  195. return;
  196. }
  197. if (!double.TryParse(dtProc.Rows[0]["ORDER_QTY_D"].ToString(), out orderQty))
  198. {
  199. return;
  200. }
  201. if (orderQty <= 0)
  202. {
  203. MessageUtil.ShowTips("合同原订货量有误!");
  204. return;
  205. }
  206. if (orderQtyD > orderQty)
  207. {
  208. MessageUtil.ShowTips("拆分量不能大于原订货量!");
  209. return;
  210. }
  211. double.TryParse(dtStatus.Rows[0]["OUTDIAMETER"].ToString(), out outdiameter);
  212. double.TryParse(dtStatus.Rows[0]["WALLTHICK"].ToString(), out wallthick);
  213. double.TryParse(dtStatus.Rows[0]["DELVRY_RANGE_MAX"].ToString(), out delvryRangeMax);
  214. double.TryParse(dtStatus.Rows[0]["DELVRY_RANGE_MIN"].ToString(), out delvryRangeMin);
  215. double.TryParse(dtStatus.Rows[0]["LENGTHMAX"].ToString(), out lengthmax);
  216. double.TryParse(dtStatus.Rows[0]["LENGTHMIN"].ToString(), out lengthmin);
  217. delvryRangeTpe = dtStatus.Rows[0]["DELVRY_RANGE_TPE"].ToString();
  218. finalUser = dtStatus.Rows[0]["FINAL_USER"].ToString();
  219. produccode = dtStatus.Rows[0]["PRODUCCODE"].ToString();
  220. ordProcEntity.Msc = dtStatus.Rows[0]["MSC"].ToString();
  221. ordProcEntity.MaterialNo = dtStatus.Rows[0]["MATERIAL_NO"].ToString();
  222. ordProcEntity.WeightPerM = dtProc.Rows[0]["WEIGHT_PER_M"].ToString();
  223. ordProcEntity.OrderUnit = dtProc.Rows[0]["ORDER_UNIT"].ToString();
  224. ordProcEntity.Prdcrpro = FrmPlnSaleOrder.getOrdPrdcrpro(
  225. dtStatus.Rows[0]["PRDCR_NO"].ToString(),
  226. comMscPilneCtrl1.CheMscPline, this.ob);
  227. ordProcEntity.GradecodeAll = dtProc.Rows[0]["GRADECODE_ALL"].ToString();
  228. ordProcEntity.IfExport = dtProc.Rows[0]["IF_EXPORT"].ToString();
  229. }
  230. string outsStlPipeFl = dtStatus.Rows[0]["OUTS_STL_PIPE_FL"].ToString();
  231. string outsBilletFl = dtStatus.Rows[0]["OUTS_BILLET_FL"].ToString();
  232. param.Add(desginKey);
  233. param.Add(ordProcEntity.IndexSeq);
  234. DataTable dtProcess = ServerHelper.GetData("com.steering.pss.plnsaleord.order.CorePlnSaleOrder.queryMscplPrc",
  235. new object[] { param }, this.ob);
  236. if (dtProcess != null && dtProcess.Rows.Count > 0)
  237. {
  238. ordProcEntity.ProcessSeq = dtProcess.Rows[0]["WHOLE_BACKLOG"].ToString();
  239. if (ordProcEntity.ProcessSeq.Equals(""))
  240. {
  241. MessageUtil.ShowError("未找到制程经过的工序点,请联系管理员。");
  242. return;
  243. }
  244. ordProcEntity.BjType = "/";
  245. ordProcEntity.EIsOk = "2";
  246. foreach (DataRow dr in dtProcess.Rows)
  247. {
  248. if (dr["PROCESS_CODE"].ToString().Equals("E"))
  249. {
  250. //经过镦拔扩工序
  251. ordProcEntity.EIsOk = "0";
  252. ordProcEntity.BjType = dr["PROCESS_DESC_C"].ToString();
  253. }
  254. }
  255. }
  256. double weightJg=0;
  257. double checkJval=0;
  258. DataTable dtJg = ServerHelper.GetData("com.steering.pss.plnsaleord.order.CorePlnSaleOrder.queryJgBase",
  259. new object[] { dtStatus.Rows[0]["CODE_JG"].ToString() }, this.ob);
  260. if(dtJg!=null&&dtJg.Rows.Count>0){
  261. weightJg=double.Parse(dtJg.Rows[0]["WEIGHT_JG"].ToString());
  262. checkJval=double.Parse(dtJg.Rows[0]["CHECK_J_VAL"].ToString());
  263. }
  264. //查询物料信息
  265. //param.Clear();
  266. //param.Add(ordProcEntity.IndexSeq);
  267. //param.Add(ordProcEntity.Msc);
  268. //param.Add(ordProcEntity.MaterialNo);
  269. //param.Add(ordProcEntity.ProcessSeq);
  270. string outsBillet = "0";
  271. if (outsStlPipeFl.Equals("")
  272. || outsStlPipeFl.Equals("121901"))
  273. {
  274. if (outsBilletFl.Equals("121801"))
  275. {
  276. outsBilletFl = "1";
  277. }
  278. else
  279. {
  280. outsBilletFl = "0";
  281. }
  282. }
  283. else
  284. {
  285. if (outsBilletFl.Equals("121802"))
  286. {
  287. outsBilletFl = "0";
  288. }
  289. else
  290. {
  291. outsBilletFl = "1";
  292. }
  293. }
  294. DataTable dtBom = ServerHelper.GetData("com.steering.pss.plnsaleord.order.CoreOrderDesignBom.getOrdLineMscBom",
  295. new object[] { desginKey, ordProcEntity.Msc, ordProcEntity.IndexSeq }, this.ob);
  296. if (dtBom != null && dtBom.Rows.Count > 0)
  297. {
  298. bool isAvailBom = false;//是否存在可用BOM
  299. string errReason = "";//不可用原因
  300. foreach (DataRow dr in dtBom.Rows)
  301. {
  302. //查询是否自炼,外购钢种
  303. DataTable dt = ServerHelper.GetData("com.steering.pss.plnsaleord.order.CoreOrderDesignBom.getGradeCode",
  304. new object[] { dr["GRADECODE"].ToString(), outsBillet }, this.ob);
  305. if (dt != null && dt.Rows.Count > 0)
  306. {
  307. ordProcEntity.Gradecode = dr["GRADECODE"].ToString();
  308. }
  309. else
  310. {
  311. continue;
  312. }
  313. ordProcEntity.Bom = dr["BOM"].ToString();
  314. ordProcEntity.GroupRollAll = dr["D_PLINE"].ToString();
  315. ordProcEntity.EInMaterialDesc = dr["E_IN_MATERIAL_DESC"].ToString();
  316. ordProcEntity.EInMaterialNo = dr["E_IN_MATERIAL_NO"].ToString();
  317. ordProcEntity.DimaterYlg = dr["DIMATER"].ToString();
  318. ordProcEntity.HeightYlg = dr["HEIGHT"].ToString();
  319. ordProcEntity.GroupJgx = FrmDefGroup.DefJgxGourp(desginKey,
  320. ordProcEntity.IndexSeq, dr["BOM"].ToString(), this.ob);
  321. ordProcEntity.GroupRcl = FrmDefGroup.DefRclGourp(desginKey,
  322. ordProcEntity.IndexSeq, dr["BOM"].ToString(), this.ob);
  323. #region 判断坯料的属性
  324. string dinMaterial = "";
  325. ///轧管投入物料(炼钢末工序产出物料)
  326. if (!dr["D_IN_MATERIAL_NO"].ToString().Equals(""))
  327. {
  328. dinMaterial = dr["D_IN_MATERIAL_NO"].ToString();
  329. }
  330. else if (!dr["C_OUT_MATERIAL_NO"].ToString().Equals(""))
  331. {
  332. dinMaterial = dr["C_OUT_MATERIAL_NO"].ToString();
  333. }
  334. else if (!dr["B_OUT_MATERIAL_NO"].ToString().Equals(""))
  335. {
  336. dinMaterial = dr["B_OUT_MATERIAL_NO"].ToString();
  337. }
  338. else
  339. {
  340. dinMaterial = dr["A_OUT_MATERIAL_NO"].ToString();
  341. }
  342. ordProcEntity.StuffProperty = PlnSaleOrderBase.stuffProperty(dinMaterial);
  343. #endregion
  344. //轧管去向
  345. ordProcEntity.Abc = PlnSaleOrderBase.getPlnOrdZgAbc(dr["WHOLE_BACKLOG"].ToString(), dr["WHOLE_BACKLOG_DESC"].ToString());
  346. if (ordProcEntity.ProcessSeq.Contains("D"))
  347. {
  348. #region 默认轧管产线
  349. ArrayList paramPline = new ArrayList();
  350. paramPline.Add(dr["D_IN_MATERIAL_NO"].ToString());
  351. paramPline.Add(dr["D_OUT_MATERIAL_NO"].ToString());
  352. paramPline.Add(desginKey);
  353. paramPline.Add(ordProcEntity.IndexSeq);
  354. paramPline.Add(finalUser);
  355. paramPline.Add(produccode);
  356. DataTable dtDpl = ServerHelper.GetData("com.steering.pss.plnsaleord.order.CoreOrderDesignBom.getBomMaterialDpl",
  357. new object[] { paramPline }, this.ob);
  358. if (dtDpl != null && dtDpl.Rows.Count > 0)
  359. {
  360. //如果存在ASSEL机组,优选ASSEL机组
  361. if (PlanComm.isInDataTable(dtDpl, "PLINE_CODE", "C012"))
  362. {
  363. if (FrmPlnSaleOrder.queryAsselFl(this.comMscPilneCtrl1.OrdLnPk, this.ob))
  364. {
  365. ordProcEntity.GroupRoll = "C012";
  366. }
  367. else
  368. {
  369. bool isPline = false;
  370. foreach (DataRow drPine in dtDpl.Rows)
  371. {
  372. if (!drPine["PLINE_CODE"].ToString().Equals("C012"))
  373. {
  374. isPline = true;
  375. ordProcEntity.GroupRoll = drPine["PLINE_CODE"].ToString();
  376. break;
  377. }
  378. }
  379. if (!isPline)
  380. {
  381. ordProcEntity.GroupRoll = dtDpl.Rows[0]["PLINE_CODE"].ToString();
  382. }
  383. }
  384. }
  385. else
  386. {
  387. ordProcEntity.GroupRoll = dtDpl.Rows[0]["PLINE_CODE"].ToString();
  388. }
  389. }
  390. #endregion
  391. }
  392. if (ordProcEntity.ProcessSeq.Contains("D")
  393. && !ordProcEntity.GroupRoll.Trim().Equals("C072")
  394. && !outsStlPipeFl.Equals("121903")
  395. && !outsStlPipeFl.Equals("121902")
  396. || ordProcEntity.OrderUnit.Trim().Equals("支"))
  397. {
  398. #region 合同量转换
  399. OutOrdParamEntity outOrdParam = new OutOrdParamEntity();
  400. InOrdParamEntity inOrdParam = new InOrdParamEntity();
  401. PlnGetOrdAmount ordAmountCal = new PlnGetOrdAmount(this.ob);
  402. DateTime date = new DateTime();
  403. string errMessage = "";
  404. double putRate = 1;
  405. double height = 0;
  406. if (DateTime.TryParse(dtStatus.Rows[0]["ROLL_MONTH"].ToString(), out date))
  407. {
  408. //投料率
  409. putRate = FrmPlnSaleOrder.queryPutRate(date.Year, date.Month, this.ob);
  410. }
  411. inOrdParam = ordAmountCal.getInOrdPlnQtyParam(
  412. orderQtyD, ordProcEntity.OrderUnit, desginKey, ordProcEntity.IndexSeq,
  413. ordLnDlyPk, ordProcEntity.GroupRoll, ordProcEntity.Bom,
  414. dtStatus.Rows[0]["CODE_JG"].ToString(), putRate);
  415. if (!ordAmountCal.isRightParam(inOrdParam, desginKey, dtStatus.Rows[0]["CODE_JG"].ToString(),
  416. ordProcEntity.Bom, ordProcEntity.GroupRoll, out errMessage))
  417. {
  418. errReason = errMessage;
  419. continue;
  420. }
  421. ordAmountCal.InEnity = inOrdParam;
  422. outOrdParam = ordAmountCal.getOrdAmount();
  423. if (outOrdParam.ErrCode == -1)
  424. {
  425. errReason = "合同量转换出错(" + outOrdParam.ErrMessage + ")。";
  426. continue;
  427. }
  428. ordProcEntity.WeightPerM = outOrdParam.WeightMi.ToString();
  429. ordProcEntity.PlanWtD = outOrdParam.WeightInA.ToString();
  430. ordProcEntity.PlanNumD = outOrdParam.PlanNum.ToString();
  431. ordProcEntity.AimLenRoll = outOrdParam.AimlengthZg.ToString();
  432. ordProcEntity.AimLenEnd = outOrdParam.AimLength.ToString();
  433. ordProcEntity.PlanPMain = outOrdParam.WeightPc.ToString();
  434. ordProcEntity.PlanTotLenD = (outOrdParam.PlanNum * outOrdParam.AimLength).ToString();
  435. ordProcEntity.TotLenOneP = outOrdParam.TotLenOneP.ToString();
  436. ordProcEntity.CutNumP = outOrdParam.CutNumP.ToString();
  437. ordProcEntity.RollLength = outOrdParam.RollLength.ToString();
  438. ordProcEntity.AimWallthick = outOrdParam.AimWallthick.ToString();
  439. ordProcEntity.OrderQtyD = orderQtyD.ToString();
  440. ordProcEntity.LenRollMax = outOrdParam.LenRollMax.ToString();
  441. ordProcEntity.LenRollMin = outOrdParam.LenRollMin.ToString();
  442. ordProcEntity.AimOutdiameter = outOrdParam.AimOutdiameter.ToString();
  443. ordProcEntity.FeedRate = putRate.ToString();
  444. ordProcEntity.Coefficient = outOrdParam.Coefficient.ToString();
  445. ordProcEntity.CoefficientMin = outOrdParam.CoefficientMin.ToString();
  446. ordProcEntity.PlanPMainMin = outOrdParam.PlanPMainMin.ToString();
  447. ordProcEntity.AimWtEnd = outOrdParam.AimWtEnd.ToString();
  448. ordProcEntity.WeightKzM = outOrdParam.WeightKzM.ToString();
  449. // 查询控制壁厚
  450. if (inOrdParam.StdWallthickMax == inOrdParam.NkWallthickMax
  451. && inOrdParam.StdWallthickMin == inOrdParam.NkWallthickMin
  452. && inOrdParam.Wallthick > 0)
  453. {
  454. ordProcEntity.HeightNkMax = (100 * inOrdParam.StdWallthickMax
  455. / inOrdParam.Wallthick).ToString();
  456. ordProcEntity.HeightNkMin = (100 * inOrdParam.StdWallthickMin
  457. / inOrdParam.Wallthick).ToString();
  458. }
  459. else if (double.TryParse(dr["HEIGHT"].ToString(), out height)
  460. && height > 0)
  461. {
  462. ordProcEntity.HeightNkMax = (100 * inOrdParam.NkWallthickMax / height).ToString();
  463. ordProcEntity.HeightNkMin = (100 * inOrdParam.NkWallthickMin / height).ToString();
  464. }
  465. #endregion
  466. }
  467. else
  468. {
  469. #region 外购管
  470. double orderWeight = 0; //合同量
  471. double aimlength = 0; //目标长度
  472. int planNum = 0;//合同支数
  473. OrderStdSic std = new OrderStdSic(this.ob);
  474. std.DesginKey = desginKey;
  475. std.Outdiameter = outdiameter;
  476. std.Wallthick = wallthick;
  477. std.getStdTolerance();
  478. double weightMI = PlanComm.WeightOfMi(outdiameter, std.AimWallthick);//米单重
  479. double rate = 0;
  480. double rateMin = 0;
  481. DateTime date = new DateTime();
  482. if (delvryRangeTpe.Trim().Equals("绝对值"))
  483. {
  484. delvryRangeMax = (delvryRangeMax / orderQtyD) * 100;
  485. delvryRangeMin = (delvryRangeMin / orderQtyD) * 100;
  486. }
  487. if (ordProcEntity.OrderUnit.Equals("米"))
  488. {
  489. orderWeight = Math.Round((orderQtyD * weightMI), 3);
  490. }
  491. else if (ordProcEntity.OrderUnit.Equals("英尺"))
  492. {
  493. double lengqty = PlanComm.FootoMi(orderQtyD);
  494. orderWeight = Math.Round((lengqty * weightMI), 3);
  495. }
  496. else if (ordProcEntity.OrderUnit.Equals("英磅"))
  497. {
  498. orderWeight = PlanComm.PoundtoTon(orderQtyD);
  499. }
  500. else
  501. {
  502. orderWeight = orderQtyD;
  503. }
  504. //目标长度,取长度上下限中间值,计算计划支数
  505. aimlength = (lengthmax + lengthmin) / 2;
  506. if ((orderWeight % (aimlength * weightMI)) == 0)
  507. {
  508. planNum = (int)(orderWeight / (aimlength * weightMI));
  509. }
  510. else
  511. {
  512. planNum = (int)(orderWeight / (aimlength * weightMI)) + 1;
  513. }
  514. double putrate= FrmPlnSaleOrder.queryPutRate(
  515. date.Year, date.Month, this.ob);
  516. if (DateTime.TryParse(dtStatus.Rows[0]["ROLL_MONTH"].ToString(), out date))
  517. {
  518. rate = ((delvryRangeMax + delvryRangeMin) * putrate - delvryRangeMin) / 100;
  519. rateMin = 1 - delvryRangeMin / 100;
  520. }
  521. ordProcEntity.OrderQtyD = orderQtyD.ToString();
  522. ordProcEntity.PlanWtD = orderWeight.ToString();
  523. ordProcEntity.PlanNumD = planNum.ToString();
  524. ordProcEntity.WeightPerM = Math.Round(weightMI, 6).ToString();
  525. ordProcEntity.AimLenEnd = aimlength.ToString();
  526. ordProcEntity.PlanPMain = ((1 + rate) * orderWeight).ToString();
  527. ordProcEntity.PlanTotLenD = (planNum * aimlength).ToString();
  528. ordProcEntity.AimWallthick = std.AimWallthick.ToString();
  529. ordProcEntity.AimOutdiameter =outdiameter.ToString();
  530. ordProcEntity.FeedRate =putrate.ToString();
  531. ordProcEntity.Coefficient =(1 + rate).ToString();
  532. ordProcEntity.CoefficientMin = rateMin.ToString();
  533. ordProcEntity.AimWtEnd = (weightJg / 1000 + weightMI * (aimlength - checkJval / 1000)).ToString();
  534. ordProcEntity.WeightKzM = Math.Round(weightMI, 6).ToString();
  535. ordProcEntity.PlanPMainMin = (rateMin * orderWeight).ToString();
  536. // 查询控制壁厚
  537. ordProcEntity.HeightNkMax = (100 * std.StdMax / wallthick).ToString();
  538. ordProcEntity.HeightNkMin = (100 * std.StdMin / wallthick).ToString();
  539. #endregion
  540. }
  541. isAvailBom = true;
  542. break;
  543. }
  544. if (!isAvailBom)
  545. {
  546. MessageUtil.ShowError(errReason);
  547. return;
  548. }
  549. }
  550. #region 各工序信息确认
  551. if (ordProcEntity.ProcessSeq.Contains("F"))
  552. {
  553. //判断是否经过热处理工序
  554. ordProcEntity.FIsOk = "0";
  555. }
  556. else
  557. {
  558. ordProcEntity.FIsOk = "2";
  559. }
  560. if (ordProcEntity.ProcessSeq.Contains("G"))
  561. {
  562. //判断是否经过管加工工序
  563. ordProcEntity.GIsOk = "0";
  564. }
  565. else
  566. {
  567. ordProcEntity.GIsOk = "2";
  568. }
  569. if (ordProcEntity.ProcessSeq.Contains("D"))
  570. {
  571. //判断是否经过轧管工序
  572. ordProcEntity.DIsOk = "0";
  573. }
  574. else
  575. {
  576. ordProcEntity.DIsOk = "2";
  577. }
  578. if (ordProcEntity.ProcessSeq.Contains("E"))
  579. {
  580. //判断是否经过镦拔扩工序
  581. ordProcEntity.EIsOk = "0";
  582. }
  583. else
  584. {
  585. ordProcEntity.EIsOk = "2";
  586. }
  587. #endregion
  588. list.Add((orderQty - orderQtyD).ToString());
  589. list.Add(OrdLnDlyPk);
  590. list.Add(ugr.Cells["PlnDivideId"].Value.ToString());
  591. int succeed = ServerHelper.SetData("com.steering.pss.plnsaleord.order.CoreChangeIndex.newPlnOrdProc",
  592. new object[] { ordProcEntity, list }, this.ob);
  593. if (succeed > 0)
  594. {
  595. MessageUtil.ShowTips("新增成功。");
  596. }
  597. }
  598. catch (Exception ex)
  599. {
  600. if (!(ex is MESException))
  601. {
  602. MessageUtil.ShowError(ex.Message);
  603. }
  604. }
  605. DoQuery();
  606. }
  607. /// <summary>
  608. /// 修改
  609. /// </summary>
  610. private void DoModify()
  611. {
  612. try
  613. {
  614. ArrayList param = new ArrayList();
  615. PlnSaleordProcEntity ordProcEntity = new PlnSaleordProcEntity();
  616. UltraGridRow ugr = ultraGridProc.ActiveRow;
  617. if (ugr == null)
  618. {
  619. return;
  620. }
  621. comMscPilneCtrl1.UltraGridMscPline.UpdateData();
  622. IQueryable<UltraGridRow> checkRows = comMscPilneCtrl1.UltraGridMscPline.Rows.AsQueryable().Where("CHC = 'True'");
  623. if (checkRows.Count() <= 0)
  624. {
  625. MessageUtil.ShowError("没有选择的制程工艺!");
  626. return;
  627. }
  628. string desginKey = this.comMscPilneCtrl1.DesginKey;
  629. ordProcEntity.IndexSeq = this.comMscPilneCtrl1.CheMscPline;
  630. ordProcEntity.CraftFileMan = this.comMscPilneCtrl1.CheCraftName;
  631. ordProcEntity.CraftFileNo = this.comMscPilneCtrl1.CheCraftNo;
  632. ordProcEntity.CraftSeq = this.comMscPilneCtrl1.CheCraftSeq;
  633. ordProcEntity.GradecodeAll = this.comMscPilneCtrl1.GradeNameAll;
  634. ordProcEntity.OrdLnDlyPk = ordLnDlyPk;
  635. ordProcEntity.PlnDivideId = ugr.Cells["PlnDivideId"].Value.ToString();
  636. string finalUser = ""; //最终用户
  637. string produccode = ""; //品名代码
  638. DataTable dtStatus = ServerHelper.GetData("com.steering.pss.plnsaleord.order.CoreChangeIndex.queryPlnSaleOrderProc",
  639. new object[] { ordLnDlyPk }, this.ob);
  640. if (dtStatus != null && dtStatus.Rows.Count > 0)
  641. {
  642. if (dtStatus.Rows[0]["PORDERSTATUS"].ToString().CompareTo("3") > 0)
  643. {
  644. MessageUtil.ShowTips("合同:" + dtStatus.Rows[0]["ORDER_NO"].ToString() + "/"
  645. + dtStatus.Rows[0]["ORDER_SEQ"].ToString()
  646. + dtStatus.Rows[0]["DELIVERY_NO"].ToString() + "已经生产完成了。");
  647. return;
  648. }
  649. //判断制程有误重复
  650. //foreach (DataRow dr in dtStatus.Rows)
  651. //{
  652. // if (dr["CRAFT_SEQ"].Equals(comMscPilneCtrl1.CheCraftSeq))
  653. // {
  654. // MessageUtil.ShowError("序号:“" + comMscPilneCtrl1.CheCraftSeq + "”的工艺已经被使用!");
  655. // return;
  656. // }
  657. //}
  658. finalUser = dtStatus.Rows[0]["FINAL_USER"].ToString();
  659. produccode = dtStatus.Rows[0]["PRODUCCODE"].ToString();
  660. ordProcEntity.Msc = dtStatus.Rows[0]["MSC"].ToString();
  661. ordProcEntity.MaterialNo = dtStatus.Rows[0]["MATERIAL_NO"].ToString();
  662. ordProcEntity.OrderNo = dtStatus.Rows[0]["ORDER_NO"].ToString();
  663. ordProcEntity.OrderSeq = dtStatus.Rows[0]["ORDER_SEQ"].ToString();
  664. ordProcEntity.WeightPerM = dtStatus.Rows[0]["WEIGHT_PER_M"].ToString();
  665. }
  666. string outsStlPipeFl = dtStatus.Rows[0]["OUTS_STL_PIPE_FL"].ToString();
  667. string outsBilletFl = dtStatus.Rows[0]["OUTS_BILLET_FL"].ToString();
  668. DataTable dtProc = ServerHelper.GetData("com.steering.pss.plnsaleord.order.CoreChangeIndex.queryPlnOrdProcById",
  669. new object[] { ordLnDlyPk, ugr.Cells["PlnDivideId"].Value.ToString() }, this.ob);
  670. if (dtProc == null || dtProc.Rows.Count <= 0)
  671. {
  672. MessageUtil.ShowError("找不到排产记录:"
  673. + ugr.Cells["PlnDivideId"].Value.ToString());
  674. return;
  675. }
  676. if (!dtProc.Rows[0]["INDEX_SEQ"].ToString().Equals(ordProcEntity.IndexSeq)
  677. || !dtProc.Rows[0]["DESGIN_KEY"].ToString().Equals(desginKey))
  678. {
  679. param.Add(desginKey);
  680. param.Add(ordProcEntity.IndexSeq);
  681. DataTable dtProcess = ServerHelper.GetData("com.steering.pss.plnsaleord.order.CorePlnSaleOrder.queryMscplPrc",
  682. new object[] { param }, this.ob);
  683. if (dtProcess != null && dtProcess.Rows.Count > 0)
  684. {
  685. ordProcEntity.ProcessSeq = dtProcess.Rows[0]["WHOLE_BACKLOG"].ToString();
  686. if (ordProcEntity.ProcessSeq.Equals(""))
  687. {
  688. MessageUtil.ShowError("未找到制程经过的工序点,请联系管理员。");
  689. return;
  690. }
  691. ordProcEntity.BjType = "/";
  692. ordProcEntity.EIsOk = "2";
  693. foreach (DataRow dr in dtProcess.Rows)
  694. {
  695. if (dr["PROCESS_CODE"].ToString().Equals("E"))
  696. {
  697. //经过镦拔扩工序
  698. ordProcEntity.EIsOk = "0";
  699. ordProcEntity.BjType = dr["PROCESS_DESC_C"].ToString();
  700. }
  701. if (dr["PROCESS_CODE"].ToString().Equals("F"))
  702. {
  703. //经过热处理工序
  704. ordProcEntity.ProcDescCRcl = dr["PROCESS_DESC_C"].ToString();
  705. }
  706. }
  707. }
  708. //查询物料信息
  709. //param.Clear();
  710. //param.Add(ordProcEntity.IndexSeq);
  711. //param.Add(ordProcEntity.Msc);
  712. //param.Add(ordProcEntity.MaterialNo);
  713. //param.Add(ordProcEntity.ProcessSeq);
  714. string outsBillet = "0";
  715. if (outsStlPipeFl.Equals("")
  716. || outsStlPipeFl.Equals("121901"))
  717. {
  718. if (outsBilletFl.Equals("121801"))
  719. {
  720. outsBilletFl = "1";
  721. }
  722. else
  723. {
  724. outsBilletFl = "0";
  725. }
  726. }
  727. else
  728. {
  729. if (outsBilletFl.Equals("121802"))
  730. {
  731. outsBilletFl = "0";
  732. }
  733. else
  734. {
  735. outsBilletFl = "1";
  736. }
  737. }
  738. DataTable dtBom = ServerHelper.GetData("com.steering.pss.plnsaleord.order.CoreOrderDesignBom.getOrdLineMscBom",
  739. new object[] { desginKey, ordProcEntity.Msc, ordProcEntity.IndexSeq }, this.ob);
  740. if (dtBom != null && dtBom.Rows.Count > 0)
  741. {
  742. bool isAvailBom = false;//是否存在可用BOM
  743. string errReason = "";//不可用原因
  744. foreach (DataRow dr in dtBom.Rows)
  745. {
  746. if (outsBillet.Equals("1"))
  747. {
  748. //查询是否自炼,外购钢种
  749. DataTable dt = ServerHelper.GetData("com.steering.pss.plnsaleord.order.CoreOrderDesignBom.getGradeCode",
  750. new object[] { dr["GRADECODE"].ToString(), outsBillet }, this.ob);
  751. if (dt != null && dt.Rows.Count > 0)
  752. {
  753. ordProcEntity.Gradecode = dr["GRADECODE"].ToString();
  754. }
  755. else
  756. {
  757. errReason = "无外购钢种!";
  758. continue;
  759. }
  760. }
  761. ordProcEntity.Bom = dr["BOM"].ToString();
  762. ordProcEntity.GroupRollAll = dr["D_PLINE"].ToString();
  763. ordProcEntity.Gradecode = dr["GRADECODE"].ToString();
  764. ordProcEntity.EInMaterialDesc = dr["E_IN_MATERIAL_DESC"].ToString();
  765. ordProcEntity.EInMaterialNo = dr["E_IN_MATERIAL_NO"].ToString();
  766. ordProcEntity.DimaterYlg = dr["DIMATER"].ToString();
  767. ordProcEntity.HeightYlg = dr["HEIGHT"].ToString();
  768. ordProcEntity.GroupJgx = FrmDefGroup.DefJgxGourp(desginKey,
  769. ordProcEntity.IndexSeq, dr["BOM"].ToString(), this.ob);
  770. ordProcEntity.GroupRcl = FrmDefGroup.DefRclGourp(desginKey,
  771. ordProcEntity.IndexSeq, dr["BOM"].ToString(), this.ob);
  772. #region 判断坯料的属性
  773. string dinMaterial = "";
  774. ///轧管投入物料(炼钢末工序产出物料)
  775. if (!dr["D_IN_MATERIAL_NO"].ToString().Equals(""))
  776. {
  777. dinMaterial = dr["D_IN_MATERIAL_NO"].ToString();
  778. }
  779. else if (!dr["C_OUT_MATERIAL_NO"].ToString().Equals(""))
  780. {
  781. dinMaterial = dr["C_OUT_MATERIAL_NO"].ToString();
  782. }
  783. else if (!dr["B_OUT_MATERIAL_NO"].ToString().Equals(""))
  784. {
  785. dinMaterial = dr["B_OUT_MATERIAL_NO"].ToString();
  786. }
  787. else
  788. {
  789. dinMaterial = dr["A_OUT_MATERIAL_NO"].ToString();
  790. }
  791. ordProcEntity.StuffProperty = PlnSaleOrderBase.stuffProperty(dinMaterial);
  792. #endregion
  793. //轧管去向
  794. ordProcEntity.Abc = PlnSaleOrderBase.getPlnOrdZgAbc(dr["WHOLE_BACKLOG"].ToString(), dr["WHOLE_BACKLOG_DESC"].ToString());
  795. ordProcEntity.DIsOk = "2";
  796. if (ordProcEntity.ProcessSeq.Contains("D"))
  797. {
  798. #region 默认轧管产线
  799. ArrayList paramPline = new ArrayList();
  800. paramPline.Add(dr["D_IN_MATERIAL_NO"].ToString());
  801. paramPline.Add(dr["D_OUT_MATERIAL_NO"].ToString());
  802. paramPline.Add(desginKey);
  803. paramPline.Add(ordProcEntity.IndexSeq);
  804. paramPline.Add(finalUser);
  805. paramPline.Add(produccode);
  806. DataTable dtDpl = ServerHelper.GetData("com.steering.pss.plnsaleord.order.CoreOrderDesignBom.getBomMaterialDpl",
  807. new object[] { paramPline }, this.ob);
  808. if (dtDpl != null && dtDpl.Rows.Count > 0)
  809. {
  810. if (PlanComm.isInDataTable(dtDpl, "PLINE_CODE", dtProc.Rows[0]["GROUP_ROLL"].ToString()))
  811. {
  812. ordProcEntity.GroupRoll = dtProc.Rows[0]["GROUP_ROLL"].ToString();
  813. ordProcEntity.DIsOk = "1";
  814. }
  815. //如果存在ASSEL机组,优选ASSEL机组
  816. else
  817. {
  818. ordProcEntity.DIsOk = "0";
  819. if (PlanComm.isInDataTable(dtDpl, "PLINE_CODE", "C012"))
  820. {
  821. if (FrmPlnSaleOrder.queryAsselFl(this.comMscPilneCtrl1.OrdLnPk, this.ob))
  822. {
  823. ordProcEntity.GroupRoll = "C012";
  824. }
  825. else
  826. {
  827. bool isPline = false;
  828. foreach (DataRow drPine in dtDpl.Rows)
  829. {
  830. if (!drPine["PLINE_CODE"].ToString().Equals("C012"))
  831. {
  832. isPline = true;
  833. ordProcEntity.GroupRoll = drPine["PLINE_CODE"].ToString();
  834. break;
  835. }
  836. }
  837. if (!isPline)
  838. {
  839. ordProcEntity.GroupRoll = dtDpl.Rows[0]["PLINE_CODE"].ToString();
  840. }
  841. }
  842. }
  843. else
  844. {
  845. ordProcEntity.GroupRoll = dtDpl.Rows[0]["PLINE_CODE"].ToString();
  846. }
  847. }
  848. }
  849. #endregion
  850. }
  851. if (ordProcEntity.ProcessSeq.Contains("D")
  852. && !ordProcEntity.GroupRoll.Trim().Equals("C072")
  853. && !outsStlPipeFl.Equals("121903")
  854. && !outsStlPipeFl.Equals("121902"))
  855. {
  856. #region 合同量转换
  857. OutOrdParamEntity outOrdParam = new OutOrdParamEntity();
  858. InOrdParamEntity inOrdParam = new InOrdParamEntity();
  859. PlnGetOrdAmount ordAmountCal = new PlnGetOrdAmount(this.ob);
  860. DateTime date = new DateTime();
  861. string errMessage = "";
  862. double putRate = 1;
  863. if (DateTime.TryParse(dtStatus.Rows[0]["ROLL_MONTH"].ToString(), out date))
  864. {
  865. //投料率
  866. putRate = FrmPlnSaleOrder.queryPutRate(date.Year, date.Month, this.ob);
  867. }
  868. inOrdParam = ordAmountCal.getInOrdPlnParam(desginKey, ordProcEntity.IndexSeq,
  869. ordLnDlyPk, ordProcEntity.PlnDivideId, ordProcEntity.GroupRoll,
  870. ordProcEntity.Bom, dtStatus.Rows[0]["CODE_JG"].ToString(), putRate);
  871. if (!ordAmountCal.isRightParam(inOrdParam, desginKey, dtStatus.Rows[0]["CODE_JG"].ToString(),
  872. ordProcEntity.Bom, ordProcEntity.GroupRoll, out errMessage))
  873. {
  874. errReason = errMessage;
  875. continue;
  876. }
  877. ordAmountCal.InEnity = inOrdParam;
  878. outOrdParam = ordAmountCal.getOrdAmount();
  879. if (outOrdParam.ErrCode == -1)
  880. {
  881. errReason = "合同量转换出错(" + outOrdParam.ErrMessage + ")。";
  882. continue;
  883. }
  884. ordProcEntity.WeightPerM = outOrdParam.WeightMi.ToString();
  885. ordProcEntity.PlanWtD = outOrdParam.WeightInA.ToString();
  886. ordProcEntity.PlanNumD = outOrdParam.PlanNum.ToString();
  887. ordProcEntity.AimLenRoll = outOrdParam.AimlengthZg.ToString();
  888. ordProcEntity.AimLenEnd = outOrdParam.AimLength.ToString();
  889. ordProcEntity.PlanPMain = outOrdParam.WeightPc.ToString();
  890. ordProcEntity.PlanTotLenD = (outOrdParam.PlanNum * outOrdParam.AimLength).ToString();
  891. ordProcEntity.TotLenOneP = outOrdParam.TotLenOneP.ToString();
  892. ordProcEntity.CutNumP = outOrdParam.CutNumP.ToString();
  893. ordProcEntity.RollLength = outOrdParam.RollLength.ToString();
  894. ordProcEntity.AimWallthick = outOrdParam.AimWallthick.ToString();
  895. ordProcEntity.LenRollMax = outOrdParam.LenRollMax.ToString();
  896. ordProcEntity.LenRollMin = outOrdParam.LenRollMin.ToString();
  897. #endregion
  898. }
  899. isAvailBom = true;
  900. break;
  901. }
  902. if (!isAvailBom)
  903. {
  904. MessageUtil.ShowError(errReason);
  905. return;
  906. }
  907. }
  908. }
  909. CoreClientParam ccp = new CoreClientParam();
  910. ccp.ServerName = "com.steering.pss.plnsaleord.order.CoreChangeIndex";
  911. ccp.MethodName = "updatePlnOrdProcIndex";
  912. ccp.ServerParams = new object[] { ordProcEntity, desginKey };
  913. ccp = this.ExecuteNonQuery(ccp, CoreInvokeType.Internal);
  914. if (ccp.ReturnCode != -1)
  915. {
  916. MessageUtil.ShowTips("修改成功");
  917. }
  918. else
  919. {
  920. MessageUtil.ShowError("修改失败!" + ccp.ReturnInfo);
  921. }
  922. }
  923. catch (Exception ex)
  924. {
  925. if (!(ex is MESException))
  926. {
  927. MessageUtil.ShowError(ex.Message);
  928. }
  929. }
  930. DoQuery();
  931. }
  932. /// <summary>
  933. /// 保存
  934. /// </summary>
  935. private void DoSave()
  936. {
  937. try
  938. {
  939. double planQty = 0;
  940. double orderQty = 0;
  941. ArrayList list = new ArrayList();
  942. DataTable dtStatus = ServerHelper.GetData("com.steering.pss.plnsaleord.order.CorePlnSaleOrder.querySaleStatus",
  943. new object[] { ordLnDlyPk }, this.ob);
  944. if (dtStatus == null || dtStatus.Rows.Count <= 0)
  945. {
  946. return;
  947. }
  948. double.TryParse(dtStatus.Rows[0]["ORDER_QTY"].ToString(), out orderQty);
  949. foreach (UltraGridRow uRow in ultraGridProc.Rows)
  950. {
  951. PlnSaleordProcEntity ordProcEntity = new PlnSaleordProcEntity();
  952. double finishWt = 0;
  953. double orderQtyD = 0;
  954. double.TryParse(uRow.Cells["OrderQtyD"].Value.ToString(), out orderQtyD);
  955. if (orderQtyD != 0)
  956. {
  957. DataTable dtProc = ServerHelper.GetData("com.steering.pss.plnsaleord.order.CoreChangeIndex.queryPlnOrdProcById",
  958. new object[] { ordLnDlyPk, uRow.Cells["PlnDivideId"].Value.ToString() }, this.ob);
  959. if (dtProc == null || dtProc.Rows.Count <= 0)
  960. {
  961. MessageUtil.ShowError("找不到排产记录:"
  962. + uRow.Cells["PlnDivideId"].Value.ToString());
  963. return;
  964. }
  965. string outsStlPipeFl = dtProc.Rows[0]["OUTS_STL_PIPE_FL"].ToString();
  966. string processSeq = dtProc.Rows[0]["PROCESS_SEQ"].ToString();
  967. string desginKey = dtProc.Rows[0]["DESGIN_KEY"].ToString();
  968. string mscpline = dtProc.Rows[0]["INDEX_SEQ"].ToString();
  969. string bom = dtProc.Rows[0]["BOM"].ToString();
  970. string plineD = dtProc.Rows[0]["GROUP_ROLL"].ToString();
  971. double.TryParse(dtProc.Rows[0]["FINISH_WT"].ToString(), out finishWt);
  972. double orderWeight = 0;
  973. if (processSeq.Contains("D")
  974. && !plineD.Trim().Equals("C072")
  975. && !outsStlPipeFl.Equals("121903")
  976. && !outsStlPipeFl.Equals("121902")
  977. || dtProc.Rows[0]["ORDER_UNIT"].ToString().Trim().Equals("支"))
  978. {
  979. #region 合同量转换
  980. OutOrdParamEntity outOrdParam = new OutOrdParamEntity();
  981. InOrdParamEntity inOrdParam = new InOrdParamEntity();
  982. PlnGetOrdAmount ordAmountCal = new PlnGetOrdAmount(this.ob);
  983. string errMessage = "";
  984. DateTime date = new DateTime();
  985. double putRate = 1;
  986. if (DateTime.TryParse(dtStatus.Rows[0]["ROLL_MONTH"].ToString(), out date))
  987. {
  988. //投料率
  989. putRate = FrmPlnSaleOrder.queryPutRate(date.Year, date.Month, this.ob);
  990. }
  991. inOrdParam = ordAmountCal.getInOrdPlnQtyParam(orderQtyD, dtStatus.Rows[0]["ORDER_UNIT"].ToString(),
  992. desginKey, mscpline, ordLnDlyPk, plineD,
  993. bom, dtStatus.Rows[0]["CODE_JG"].ToString(), putRate);
  994. if (!ordAmountCal.isRightParam(inOrdParam, desginKey,
  995. dtStatus.Rows[0]["CODE_JG"].ToString(), bom, plineD, out errMessage))
  996. {
  997. MessageUtil.ShowError(errMessage);
  998. return;
  999. }
  1000. ordAmountCal.InEnity = inOrdParam;
  1001. outOrdParam = ordAmountCal.getOrdAmount();
  1002. if (outOrdParam.ErrCode == -1)
  1003. {
  1004. MessageUtil.ShowError("合同量转换出错(" + outOrdParam.ErrMessage + ")。");
  1005. return;
  1006. }
  1007. ordProcEntity.WeightPerM = outOrdParam.WeightMi.ToString();
  1008. ordProcEntity.PlanWtD = outOrdParam.WeightInA.ToString();
  1009. ordProcEntity.PlanNumD = outOrdParam.PlanNum.ToString();
  1010. ordProcEntity.AimLenRoll = outOrdParam.AimlengthZg.ToString();
  1011. ordProcEntity.AimLenEnd = outOrdParam.AimLength.ToString();
  1012. ordProcEntity.PlanPMain = outOrdParam.WeightPc.ToString();
  1013. ordProcEntity.PlanTotLenD = (outOrdParam.PlanNum * outOrdParam.AimLength).ToString();
  1014. ordProcEntity.TotLenOneP = outOrdParam.TotLenOneP.ToString();
  1015. ordProcEntity.CutNumP = outOrdParam.CutNumP.ToString();
  1016. ordProcEntity.RollLength = outOrdParam.RollLength.ToString();
  1017. ordProcEntity.AimWallthick = outOrdParam.AimWallthick.ToString();
  1018. ordProcEntity.LenRollMax = outOrdParam.LenRollMax.ToString();
  1019. ordProcEntity.LenRollMin = outOrdParam.LenRollMin.ToString();
  1020. orderWeight = outOrdParam.WeightInA;
  1021. ordProcEntity.AimOutdiameter = outOrdParam.AimOutdiameter.ToString();
  1022. ordProcEntity.FeedRate = putRate.ToString();
  1023. ordProcEntity.Coefficient = outOrdParam.Coefficient.ToString();
  1024. ordProcEntity.CoefficientMin = outOrdParam.CoefficientMin.ToString();
  1025. ordProcEntity.PlanPMainMin = outOrdParam.PlanPMainMin.ToString();
  1026. ordProcEntity.AimWtEnd = outOrdParam.AimWtEnd.ToString();
  1027. ordProcEntity.WeightKzM = outOrdParam.WeightKzM.ToString();
  1028. #endregion
  1029. }
  1030. else
  1031. {
  1032. #region 外购管
  1033. double aimLenEnd = 0;
  1034. double weightPerM = 0;
  1035. int planNum = 0;
  1036. double rateMin = 0;
  1037. double.TryParse(dtProc.Rows[0]["WEIGHT_PER_M"].ToString(), out weightPerM);
  1038. double.TryParse(dtProc.Rows[0]["AIM_LEN_END"].ToString(), out aimLenEnd);
  1039. double.TryParse(dtProc.Rows[0]["COEFFICIENT_MIN"].ToString(), out rateMin);
  1040. if (dtProc.Rows[0]["ORDER_UNIT"].ToString().Equals("米"))
  1041. {
  1042. orderWeight = Math.Round((orderQtyD * weightPerM), 3);
  1043. }
  1044. else if (dtProc.Rows[0]["ORDER_UNIT"].ToString().Equals("英尺"))
  1045. {
  1046. double lengqty = PlanComm.FootoMi(orderQtyD);
  1047. orderWeight = Math.Round((lengqty * weightPerM), 3);
  1048. }
  1049. else if (dtProc.Rows[0]["ORDER_UNIT"].ToString().Equals("英磅"))
  1050. {
  1051. orderWeight = PlanComm.PoundtoTon(orderQtyD);
  1052. }
  1053. else
  1054. {
  1055. orderWeight = orderQtyD;
  1056. }
  1057. //目标长度,取长度上下限中间值,计算计划支数
  1058. if ((orderWeight % (aimLenEnd * weightPerM)) == 0)
  1059. {
  1060. planNum = (int)(orderWeight / (aimLenEnd * weightPerM));
  1061. }
  1062. else
  1063. {
  1064. planNum = (int)(orderWeight / (aimLenEnd * weightPerM)) + 1;
  1065. }
  1066. ordProcEntity.PlanWtD = orderWeight.ToString();
  1067. ordProcEntity.PlanNumD = planNum.ToString();
  1068. ordProcEntity.AimLenEnd = aimLenEnd.ToString();
  1069. ordProcEntity.PlanPMain = orderWeight.ToString();
  1070. ordProcEntity.PlanTotLenD = (planNum * aimLenEnd).ToString();
  1071. ordProcEntity.PlanPMainMin = (rateMin*orderWeight).ToString();
  1072. #endregion
  1073. }
  1074. if (Math.Round(orderWeight, 3) < Math.Round(finishWt, 3))
  1075. {
  1076. MessageUtil.ShowError("计划量必须大于等于已完成量!");
  1077. return;
  1078. }
  1079. }
  1080. ordProcEntity.OrderQtyD = orderQtyD.ToString();
  1081. ordProcEntity.OrdLnDlyPk = ordLnDlyPk;
  1082. ordProcEntity.PlnDivideId = uRow.Cells["PlnDivideId"].Value.ToString();
  1083. planQty += orderQtyD;
  1084. list.Add(ordProcEntity);
  1085. }
  1086. planQty = Math.Round(planQty, 3);
  1087. if (planQty != orderQty)
  1088. {
  1089. MessageUtil.ShowError("合同订货量" + orderQty.ToString()
  1090. + "吨,与合同分解订货总量" + planQty.ToString() + "不符合!");
  1091. return;
  1092. }
  1093. int succeed = ServerHelper.SetData("com.steering.pss.plnsaleord.order.CoreChangeIndex.updatePlnOrdProc",
  1094. new object[] { list }, this.ob);
  1095. if (succeed > 0)
  1096. {
  1097. MessageUtil.ShowTips("保存成功。");
  1098. }
  1099. }
  1100. catch (Exception ex)
  1101. {
  1102. if (!(ex is MESException))
  1103. {
  1104. MessageUtil.ShowError(ex.Message);
  1105. }
  1106. }
  1107. DoQuery();
  1108. }
  1109. /// <summary>
  1110. /// 删除
  1111. /// </summary>
  1112. private void DoDelete()
  1113. {
  1114. try
  1115. {
  1116. double planWtD = 0;
  1117. ArrayList list = new ArrayList();
  1118. ArrayList param = new ArrayList();
  1119. UltraGridRow ugr = ultraGridProc.ActiveRow;
  1120. if (ugr == null)
  1121. {
  1122. return;
  1123. }
  1124. DataTable dtStatus = ServerHelper.GetData("com.steering.pss.plnsaleord.order.CoreChangeIndex.queryPlnOrdProcById",
  1125. new object[] { ordLnDlyPk, ugr.Cells["PlnDivideId"].Value.ToString() }, this.ob);
  1126. if (dtStatus == null || dtStatus.Rows.Count <= 0)
  1127. {
  1128. return;
  1129. }
  1130. if (!double.TryParse(dtStatus.Rows[0]["PLAN_WT_D"].ToString(), out planWtD))
  1131. {
  1132. return;
  1133. }
  1134. if (planWtD != 0)
  1135. {
  1136. MessageUtil.ShowError("该交货行分解量大于零,不能删除!");
  1137. return;
  1138. }
  1139. param.Add(ordLnDlyPk);
  1140. param.Add(ugr.Cells["PlnDivideId"].Value.ToString());
  1141. list.Add(param);
  1142. int succeed = ServerHelper.SetData("com.steering.pss.plnsaleord.order.CoreChangeIndex.deletePlnOrdProc",
  1143. new object[] { list }, this.ob);
  1144. if (succeed > 0)
  1145. {
  1146. MessageUtil.ShowTips("删除成功。");
  1147. }
  1148. }
  1149. catch (Exception ex)
  1150. {
  1151. if (!(ex is MESException))
  1152. {
  1153. MessageUtil.ShowError(ex.Message);
  1154. }
  1155. }
  1156. DoQuery();
  1157. }
  1158. private void ultraGridProc_AfterRowActivate(object sender, EventArgs e)
  1159. {
  1160. this.comMscPilneCtrl1.CheMscPline = ultraGridProc.ActiveRow.Cells["IndexSeq"].Value.ToString();
  1161. this.comMscPilneCtrl1.CheCraftSeq = ultraGridProc.ActiveRow.Cells["CraftSeq"].Value.ToString();
  1162. this.comMscPilneCtrl1.OrderSource = orderSource;
  1163. this.comMscPilneCtrl1.OrdLnDivPk = ordLnDlyPk;
  1164. this.comMscPilneCtrl1.DoQuery();
  1165. }
  1166. /// <summary>
  1167. /// 交货pk
  1168. /// </summary>
  1169. public string OrdLnDlyPk
  1170. {
  1171. get { return ordLnDlyPk; }
  1172. set { ordLnDlyPk = value; }
  1173. }
  1174. /// <summary>
  1175. /// 补量需求编号
  1176. /// </summary>
  1177. public string RNumId
  1178. {
  1179. get { return rNumId; }
  1180. set { rNumId = value; }
  1181. }
  1182. }
  1183. }