| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452 |
- using System;
- using System.Collections.Generic;
- using System.ComponentModel;
- using System.Data;
- using System.Drawing;
- using System.Linq;
- using System.Text;
- using System.Windows.Forms;
- using Core.Mes.Client.Comm.Server;
- using CoreFS.CA06;
- using CoreFS.SA06;
- using System.Collections;
- using Core.Mes.Client.Comm.Control;
- using Infragistics.Win.UltraWinGrid;
- using Infragistics.Win;
- using Infragistics.Win.UltraWinGrid.ExcelExport;
- using System.IO;
- using Infragistics.Excel;
- using System.Diagnostics;
- using Core.Mes.Client.Comm;
- namespace Core.StlMes.Client.Plan.Order
- {
- /// <summary>
- /// 备料组选择界面
- /// @author:杨天海
- /// @version:v1.1
- /// @date:2015.05.01
- /// </summary>
- public partial class FrmGroupofDjBl : FrmBase
- {
- /// <summary>
- /// 质量设计desgin_key
- /// </summary>
- private string desgin_key = "";
- public string Desgin_key
- {
- get { return desgin_key; }
- set { desgin_key = value; }
- }
- /// <summary>
- /// 备料组
- /// </summary>
- private string group_num = "";
- public string Group_num
- {
- get { return group_num; }
- set { group_num = value; }
- }
- /// <summary>
- /// 合同计划支数
- /// </summary>
- private string plan_num = "";
- public string Plan_num
- {
- get { return plan_num; }
- set { plan_num = value; }
- }
- /// <summary>
- /// 合同号
- /// </summary>
- private string order_no = "";
- public string Order_no
- {
- get { return order_no; }
- set { order_no = value; }
- }
- /// <summary>
- /// 和同行号
- /// </summary>
- private string order_seq = "";
- public string Order_seq
- {
- get { return order_seq; }
- set { order_seq = value; }
- }
- /// <summary>
- /// 交货编码
- /// </summary>
- private string delivery_no = "";
- public string Delivery_no
- {
- get { return delivery_no; }
- set { delivery_no = value; }
- }
- /// <summary>
- /// 合同长度描述
- /// </summary>
- private string lengthdisc = "";
- public string Lengthdisc
- {
- get { return lengthdisc; }
- set { lengthdisc = value; }
- }
- /// <summary>
- /// 形成短节合同状态
- /// </summary>
- private bool isCreatOk = false;
- public bool IsCreatOk
- {
- get { return isCreatOk; }
- set { isCreatOk = value; }
- }
- private double lengthMax = 0;
- /// <summary>
- /// 销售合同短节长度上限
- /// </summary>
- public double LengthMax
- {
- get { return lengthMax; }
- set { lengthMax = value; }
- }
- private int orderNum = 0;
- /// <summary>
- /// 短节合同订货支数
- /// </summary>
- public int OrderNum
- {
- get { return orderNum; }
- set { orderNum = value; }
- }
- /// <summary>
- /// 钢级(牌号)代码
- /// </summary>
- private string steelcode;
- /// <summary>
- /// 钢级(牌号)代码
- /// </summary>
- public string Steelcode
- {
- get { return steelcode; }
- set { steelcode = value; }
- }
- /// <summary>
- /// 钢级(牌号)名称
- /// </summary>
- private string steelname;
- /// <summary>
- /// 钢级(牌号)名称
- /// </summary>
- public string Steelname
- {
- get { return steelname; }
- set { steelname = value; }
- }
- /// <summary>
- /// 外径
- /// </summary>
- private string outdiameter;
- /// <summary>
- /// 外径
- /// </summary>
- public string Outdiameter
- {
- get { return outdiameter; }
- set { outdiameter = value; }
- }
- /// <summary>
- /// 壁厚
- /// </summary>
- private string wallthick;
- /// <summary>
- /// 壁厚
- /// </summary>
- public string Wallthick
- {
- get { return wallthick; }
- set { wallthick = value; }
- }
- public FrmGroupofDjBl()
- {
- InitializeComponent();
- }
- /// <summary>
- /// 构造
- /// </summary>
- /// <param name="ob"></param>
- public FrmGroupofDjBl(OpeBase ob)
- {
- this.ob = ob;
- InitializeComponent();
- }
- private void FrmGroupofDjBl_Load(object sender, EventArgs e)
- {
- FrmSaleOrderOP SaleOrder = new FrmSaleOrderOP(this.ob);
- DataTable dt = SaleOrder.QueryBlCode(Desgin_key);
- DataTable dtGroup = ServerHelper.GetData("com.steering.pss.plan.order.CoreSaleOrderOP.queryBlGroup",
- new object[] { Desgin_key }, this.ob);
- GridHelper.CopyDataToDatatable(dtGroup, dataTable1, true);
- foreach (UltraGridRow uRow in ultraGrid1.Rows)
- {
- uRow.Cells["PLAN_NUM"].Value = Plan_num;
- uRow.Cells["LENGTHDISC"].Value = Lengthdisc;
- uRow.Cells["STEELCODE"].Value = steelcode;
- uRow.Cells["STEELNAME"].Value = steelname;
- uRow.Cells["OUTDIAMETER"].Value = outdiameter;
- uRow.Cells["WALLTHICK"].Value = wallthick;
- if (uRow.Cells["GROUP_NUM"].Value.ToString().Equals(Group_num))
- {
- uRow.Cells["CHECK"].Value = true;
- }
- }
- dataTable2.Clear();
- if (dt != null && dt.Rows.Count > 0)
- {
- foreach (DataRow dr in dt.Rows)
- {
- DataTable dtBlList = SaleOrder.QueryBlList(dr["PSC_BL"].ToString());
-
- if (dtBlList != null && dtBlList.Rows.Count > 0)
- {
- double min_d = Convert.ToDouble(dtBlList.Rows[0]["MIN_D"]);
- double min_h = Convert.ToDouble(dtBlList.Rows[0]["MIN_H"]);
- double Weight_One = PlanComm.WeightOfMi(min_d, min_h);//米单重(吨/米)
- double aimlength = (Convert.ToDouble(dtBlList.Rows[0]["MAX_L"])
- + Convert.ToDouble(dtBlList.Rows[0]["MIN_L"])) / 2;
- double singleweight = aimlength * Weight_One;//单重
- double eatchBlnum = aimlength / lengthMax;//每只备料管可切短节支数。
-
- DataRow drNew = dataTable2.NewRow();
- drNew["GROUP_NUM"] = dr["GROUP_NUM"].ToString();
- drNew["PSC_BL"] = dtBlList.Rows[0]["PSC_BL"].ToString();
- drNew["PRODUCNAME"] = dtBlList.Rows[0]["PRODUCNAME"].ToString();
- drNew["STD_NAME"] = dtBlList.Rows[0]["STD_NAME"].ToString();
- drNew["STEELNAME"] = dtBlList.Rows[0]["STEELNAME"].ToString();
- drNew["STD_STYLE_DESC"] = dtBlList.Rows[0]["STD_STYLE_DESC"].ToString();
- drNew["MODEL_DESC"] = dtBlList.Rows[0]["MODEL_DESC"].ToString();
- drNew["MIN_D"] = dtBlList.Rows[0]["MIN_D"].ToString();
- drNew["MIN_H"] = dtBlList.Rows[0]["MIN_H"].ToString();
- drNew["USE_DESC"] = dtBlList.Rows[0]["USE_DESC"].ToString();
- drNew["MIN_L"] = dtBlList.Rows[0]["MIN_L"].ToString();
- drNew["MAX_L"] = dtBlList.Rows[0]["MAX_L"].ToString();
- drNew["MEMO"] = dtBlList.Rows[0]["MEMO"].ToString();
- drNew["SINGLEWEIGHT"] = singleweight;
- drNew["STEELCODE"] = dtBlList.Rows[0]["STEELCODE"].ToString();
- drNew["STD_CODE"] = dtBlList.Rows[0]["STD_CODE"].ToString();
- drNew["PRODUCCODE"] = dtBlList.Rows[0]["PRODUCCODE"].ToString();
- drNew["STD_STYLE"] = dtBlList.Rows[0]["STD_STYLE"].ToString();
- drNew["BLGTODJNUM"] = eatchBlnum;
- if (OrderNum % eatchBlnum == 0)
- {
- drNew["JGBL_REQ_NUM"] = (int)(OrderNum / eatchBlnum);
- drNew["JGBL_REQ_WEIGHT"] = (int)(OrderNum / eatchBlnum) * singleweight;
- }
- else
- {
- drNew["JGBL_REQ_NUM"] = (int)(OrderNum / eatchBlnum) + 1;
- drNew["JGBL_REQ_WEIGHT"] = ((int)(OrderNum / eatchBlnum) + 1) * singleweight;
- }
- dataTable2.Rows.Add(drNew);
- }
- }
- }
- PlanComm.setGridActivation(ultraGrid1.DisplayLayout.Bands[0], "CHECK");
- PlanComm.setGridActivation(ultraGrid1.DisplayLayout.Bands[1], "JGBL_REQ_NUM");
- }
- /// <summary>
- /// 确定按钮
- /// </summary>
- /// <param name="sender"></param>
- /// <param name="e"></param>
- private void ultraButton1_Click(object sender, EventArgs e)
- {
- foreach(UltraGridRow uRow in ultraGrid1.Rows)
- {
- if (Convert.ToBoolean(uRow.Cells["CHECK"].Text))
- {
- ArrayList status = new ArrayList();
- status.Add(this.Order_no);
- status.Add(this.Order_seq);
- status.Add(this.Delivery_no);
- DataTable dtStatus = ServerHelper.GetData("com.steering.pss.plan.order.CoreSaleOrderOP.querySaleByPrimary",
- new object[] { status }, this.ob);
- if (dtStatus == null || dtStatus.Rows.Count <= 0)
- {
- Core.Mes.Client.Comm.Tool.MessageUtil.ShowTips("查询销售合同状态失败!");
- return;
- }
- if (dtStatus.Rows[0]["PORDERSTATUS"].ToString().Equals("1")
- && dtStatus.Rows[0]["DJBL_REQ_IS_OK"].ToString().Equals("0"))
- {
- ArrayList listBL = new ArrayList();
- ArrayList paramUpdate = new ArrayList();
- ArrayList listupdate = new ArrayList();
- foreach (UltraGridRow cRow in uRow.ChildBands[0].Rows)
- {
- #region 短节备料需求处理
- FrmSaleOrderOP SaleOrder = new FrmSaleOrderOP(this.ob);
- string strPSC = "";//产品码
- string strCodeBl = cRow.Cells["PSC_BL"].Value.ToString();//备料码
- ArrayList parms = new ArrayList();
- double aimlength = (Convert.ToDouble(cRow.Cells["MAX_L"].Value)
- + Convert.ToDouble(cRow.Cells["MIN_L"].Value)) / 2;
- string specSameSale = "0";
- if (dtStatus.Rows[0]["OUTDIAMETER"].ToString().Equals(cRow.Cells["MIN_D"].Value.ToString())
- && dtStatus.Rows[0]["WALLTHICK"].ToString().Equals(cRow.Cells["MIN_H"].Value.ToString())
- && dtStatus.Rows[0]["STEELCODE"].ToString().Equals(cRow.Cells["STEELCODE"].Value.ToString()))
- {
- specSameSale = "1";
- }
- parms.Add("短节备料");
- parms.Add(Order_no);
- parms.Add(Order_seq);
- parms.Add(Delivery_no);
- parms.Add(strCodeBl);
- parms.Add("0"); //计划状态
- parms.Add(CoreUserInfo.UserInfo.GetUserName());
- parms.Add(DateTime.Now.ToString("yyyy/MM/dd HH:mm:ss"));
- #region 备料清单信息
- parms.Add(cRow.Cells["STEELCODE"].Value.ToString());
- parms.Add(cRow.Cells["STEELNAME"].Value.ToString());
- parms.Add("");//钢种代码
- parms.Add(cRow.Cells["MIN_D"].Value.ToString());//外径
- parms.Add(cRow.Cells["MIN_H"].Value.ToString());//壁厚
- parms.Add("");//控制壁厚
- parms.Add(cRow.Cells["MAX_L"].Value.ToString());
- parms.Add(cRow.Cells["MIN_L"].Value.ToString());
- parms.Add(aimlength.ToString());//控制长度
- parms.Add(cRow.Cells["STD_CODE"].Value.ToString());
- parms.Add(cRow.Cells["STD_NAME"].Value.ToString());
- strPSC = SaleOrder.QueryPsc(cRow.Cells["PRODUCCODE"].Value.ToString(),
- cRow.Cells["STD_CODE"].Value.ToString(),
- cRow.Cells["STEELCODE"].Value.ToString(),
- cRow.Cells["STD_STYLE"].Value.ToString());
- parms.Add(SaleOrder.QueryPscForMsc(strPSC));
- parms.Add(cRow.Cells["SINGLEWEIGHT"].Value.ToString()); //单重
- #endregion
- parms.Add(cRow.Cells["JGBL_REQ_WEIGHT"].Value.ToString()); //备料需求量
- parms.Add(cRow.Cells["JGBL_REQ_NUM"].Value.ToString()); //备料需求支数
- parms.Add(specSameSale);
- listBL.Add(parms);
- #endregion
- }
- //更新销售合同
- paramUpdate.Add("1");
- paramUpdate.Add(dtStatus.Rows[0]["ORD_LN_DLY_PK"].ToString());
- listupdate.Add(paramUpdate);
- int isSucceed = ServerHelper.SetData("com.steering.pss.plan.order.CoreSaleOrderOP.tranSactionDj",
- new object[] { listBL,listupdate }, this.ob);
- if (isSucceed > 0)
- {
- Core.Mes.Client.Comm.Tool.MessageUtil.ShowTips("形成短节合同成功!");
- IsCreatOk = true;
- }
- else
- {
- Core.Mes.Client.Comm.Tool.MessageUtil.ShowError("形成短节合同失败!");
- }
- }
- Group_num = uRow.Cells["GROUP_NUM"].Value.ToString();
- this.Close();
- return;
- }
- }
- MessageBox.Show("请选择短节备料组!");
- }
- /// <summary>
- /// 取消按钮
- /// </summary>
- /// <param name="sender"></param>
- /// <param name="e"></param>
- private void ultraButton2_Click(object sender, EventArgs e)
- {
- this.Close();
- }
- /// <summary>
- /// 控制单选
- /// </summary>
- /// <param name="sender"></param>
- /// <param name="e"></param>
- private void ultraGrid1_CellChange(object sender, CellEventArgs e)
- {
- if (e.Cell.Column.Key.Equals("CHECK"))
- {
- if (Convert.ToBoolean(e.Cell.Row.Cells["CHECK"].Text))
- {
- foreach (UltraGridRow uRow in ultraGrid1.Rows)
- {
- if (uRow != e.Cell.Row)
- {
- uRow.Cells["CHECK"].Value = false;
- }
- }
- }
- }
- }
- private void ultraGrid1_AfterCellUpdate(object sender, CellEventArgs e)
- {
- if (e.Cell.Column.Key.Equals("JGBL_REQ_NUM") && e.Cell.Row.Cells["JGBL_REQ_NUM"].DataChanged)
- {
- e.Cell.Row.Update();
- int num = 0;
- double singleweight = 0;
- if (int.TryParse(e.Cell.Row.Cells["JGBL_REQ_NUM"].Value.ToString(), out num) &&
- double.TryParse(e.Cell.Row.Cells["SINGLEWEIGHT"].Value.ToString(), out singleweight))
- {
- e.Cell.Row.Cells["JGBL_REQ_WEIGHT"].Value = (num * singleweight).ToString();
- }
- else
- {
- e.Cell.Row.Cells["JGBL_REQ_NUM"].Value = 0;
- e.Cell.Row.Cells["JGBL_REQ_WEIGHT"].Value = 0;
- }
- }
- }
- }
- }
|