lu
8 小时以前 40036d84a94b47b82b2d6316fb63df5e2847c6df
DevApp/Gs.DevApp/DevFrm/FQC/Frm_FqcDetect01.cs
@@ -1,4 +1,5 @@
using Gs.DevApp.Entity;
using Gs.DevApp.DevFrm.Work;
using Gs.DevApp.Entity;
using Gs.DevApp.ToolBox;
using Gs.DevApp.UserControl;
using Newtonsoft.Json;
@@ -13,6 +14,7 @@
{
    public partial class Frm_FqcDetect01 : DevExpress.XtraEditors.XtraForm
    {
        string _strTag = "N:不合格";
        string _webServiceName = "FqcManager/";
        List<FilterEntity> _filterList = new List<FilterEntity>();
        public Frm_FqcDetect01()
@@ -26,7 +28,8 @@
            this.toolBarMenu1.btnEscClick += ToolBarMenu1_btnEscClick;
            this.toolBarMenu1.btnQueryClick += ToolBarMenu1_btnQueryClick;
            toolBarMenu1.btnLogClick += ToolBarMenu1_btnLogClick;
            toolBarMenu1.btnJianYanClick += ToolBarMenu1_btnJianYanClick;
            toolBarMenu1.btnChkClick += ToolBarMenu1_btnChkClick;
            toolBarMenu1.btnFChkClick += ToolBarMenu1_btnFChkClick;
            this.toolBarMenu1.getXmlConfig();
            Gs.DevApp.ToolBox.UtilityHelper.SetGridViewParameterMx(gvMx1);
            Gs.DevApp.ToolBox.UtilityHelper.SetGridViewParameterMx(gvMx2);
@@ -50,16 +53,10 @@
            gvMx1.FocusedRowChanged += GvMx1_FocusedRowChanged;
            btnIpt.Click += BtnIpt_Click;
            txt_suppId.getSuppler("");
            txt_lineId.getSuppler("");
            txt_itemId.Click += (s, e) =>
            //选择工单
            txt_lotNo.Click += (s, e) =>
            {
                string _lineId = txt_lineId.GetId();
                if (string.IsNullOrEmpty(_lineId))
                {
                    Gs.DevApp.ToolBox.MsgHelper.ShowInformation("请先选择产线!");
                    return;
                }
                var frm = new SelectFqcItem(_lineId);
                var frm = new SelectFqcDaa();
                frm.UpdateParent += (ss, ee) =>
                {
                    try
@@ -71,6 +68,10 @@
                        txt_itemName.Text = lst[0].itemName;
                        txt_itemNo.Text = lst[0].itemNo;
                        txt_lotNo.Text = lst[0].gdbh;
                        txt_lineName.Text = lst[0].lineName;
                        txt_lineId.Text = lst[0].lineId;
                        txt_checkStates.Text = "W:未知";
                        txt_fcheckResu.Text = "W:未知";
                    }
                    catch (Exception ex)
                    {
@@ -79,8 +80,47 @@
                };
                frm.ShowDialog();
            };
            //选择箱码
            txt_kbList.Click += (s, e) =>
            {
                string _lotNo = txt_lotNo.Text.Trim();
                if (string.IsNullOrEmpty(_lotNo))
                {
                    Gs.DevApp.ToolBox.MsgHelper.ShowInformation("请先选择工单!");
                    return;
                }
                var frm = new SelectFqcBox(_lotNo);
                frm.UpdateParent += (ss, ee) =>
                {
                    try
                    {
                        var lst = new List<dynamic>();
                        lst = ee.DynamicList;
                        System.Text.StringBuilder sb = new System.Text.StringBuilder();
                        decimal kbSl = 0;
                        foreach (var item in lst)
                        {
                            if (sb.Length > 0)
                                sb.Append(",");
                            sb.Append(item.itemBarcode);
                            kbSl += decimal.Parse(item.sl.ToString());
                        };
                        txt_kbList.Text = sb.ToString();
                        txt_kbSl.Text = kbSl.ToString();
                    }
                    catch (Exception ex)
                    {
                        MessageBox.Show(ex.Message);
                    }
                };
                frm.ShowDialog();
            };
            // 读取缺陷等级
            getRptDefectLevel();
            //工序
            txt_fmrmode.getSuppler("", " and  isnull(isBack,0)=1");
        }
        /// <summary>
        /// 批量录入
        /// </summary>
@@ -258,63 +298,19 @@
            toolBarMenu1.guidKey = rowGuid;
        }
        /// <summary>
        ///提交检验事件
        ///审核事件
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        /// <exception cref="NotImplementedException"></exception>
        private void ToolBarMenu1_btnJianYanClick(object sender, EventArgs e)
        private void ToolBarMenu1_btnChkClick(object sender, EventArgs e)
        {
            toolBarMenu1.guidKey = "";
            string rowGuid, rowName;
            (rowGuid, rowName) = UtilityHelper.GetCurrentRow(xtraTabControl1,
                lbGuid, txt_releaseNo, gridView1, "releaseNo");
            toolBarMenu1.guidKey = rowGuid;
            if (string.IsNullOrEmpty(rowGuid))
            {
                MsgHelper.Warning("请先选择你要操作的行!");
                return;
            }
            if (!MsgHelper.AskQuestion("你选择了【" + rowName + "】,确定提交检验吗?"))
                return;
            if (txt_fcheckResu.Text.Trim() == "不合格")
            {
                if (string.IsNullOrEmpty(txt_msg.TextTxt.Trim()))
                {
                    MsgHelper.Warning("单据为不合格时,请填写违规信息!");
                    return;
                }
            };
            var _obj = new
            {
                guid = rowGuid,
            };
            try
            {
                var strJson = UtilityHelper.HttpPost("",
                    _webServiceName + "EditModelSubmit",
                    JsonConvert.SerializeObject(_obj));
                var _rtn = UtilityHelper.ReturnToDynamic(strJson);
                MsgHelper.Warning("提示:" + _rtn.rtnData.outMsg);
                if (_rtn.rtnCode > 0 && _rtn.rtnData.outSum * 1 > 0)
                {
                    if (xtraTabControl1.SelectedTabPageIndex == 1)
                    {
                        getModel(lbGuid.Text.Trim(), "0");
                    }
                    int rowHandle = gridView1.LocateByValue(1, gridView1.Columns["guid"], rowGuid);
                    gridView1.FocusedRowHandle = rowHandle;
                    int _inFieldValue = 1;
                    UtilityHelper.SetCheckIco(gridView1, "fsubmitTxt", "", "iqcDate", picCheckBox, this, _inFieldValue.ToString());
                }
            }
            catch (Exception ex)
            {
                MsgHelper.Warning("提示:" + ex.Message);
            }
            _toolCk(1);
        }
        private void ToolBarMenu1_btnFChkClick(object sender, EventArgs e)
        {
            _toolCk(0);
        }
        /// <summary>
        /// 取消事件
        /// </summary>
@@ -345,7 +341,6 @@
            var _obj = new
            {
                guid = rowGuid,
                mxGuid = Guid.Empty.ToString(),
            };
            try
            {
@@ -404,6 +399,8 @@
            UtilityHelper.CleanValueByControl(this.layoutMx1.Controls, true, gridViews);
            Gs.DevApp.ToolBox.UtilityHelper.SetDefaultTable(gcMx1, gvMx1);
            this.ucUpFileList1.pGuid = "";
            this.ucChouJianList1.pGuid = "";
            this.setEable(false);
        }
        /// <summary>
        /// 修改事件
@@ -447,36 +444,19 @@
            string _txt_fbatchQty = txt_fbatchQty.Text.Trim();//抽检数量
            string _txt_lifnr = txt_lifnr.Text.Trim();//客户订单
            string _txt_suppId = txt_suppId.GetId();//客户id
            string _txt_lineId = txt_lineId.GetId();//产线
            string _txt_itemId = txt_itemId.Text.Trim();//产品
            string _txt_lineId = "";//产线
            string _txt_itemId = "";//产品
            string _txt_remarks = txt_remarks.Text.Trim();//备注
            string _txt_epTag = txt_epTag.Text.Trim();//环保
            string _txt_msg = txt_msg.TextTxt;//异常
            string _txt_fmanageNo = txt_fmanageNo.Text.Trim();//流程编号
            string _txt_lotNo1 = txt_lotNo1.Text.Trim();//送检批号
            string _txt_lotNo = txt_lotNo.Text.Trim();//生产工单
            string _kbList = txt_kbList.Text.Trim();
            if (txt_djType.SelectedIndex <= 0)
            {
                Gs.DevApp.ToolBox.MsgHelper.Warning("单据类型不能为空!");
                txt_djType.Focus();
                return;
            }
            if (string.IsNullOrEmpty(_txt_fbatchQty.Trim()))
            {
                Gs.DevApp.ToolBox.MsgHelper.Warning("抽检数量不能为空!");
                txt_fbatchQty.Focus();
                return;
            }
            if (string.IsNullOrEmpty(_txt_lineId.Trim()))
            {
                Gs.DevApp.ToolBox.MsgHelper.Warning("产线不能为空!");
                txt_lineId.Focus();
                return;
            }
            if (string.IsNullOrEmpty(_txt_itemId.Trim()))
            {
                Gs.DevApp.ToolBox.MsgHelper.Warning("产品不能为空!");
                txt_itemId.Focus();
                return;
            }
            if (string.IsNullOrEmpty(_txt_lotNo.Trim()))
@@ -485,6 +465,108 @@
                txt_lotNo.Focus();
                return;
            }
            if (string.IsNullOrEmpty(_kbList.Trim()))
            {
                Gs.DevApp.ToolBox.MsgHelper.Warning("送检箱码不能为空!");
                txt_kbList.Focus();
                return;
            }
            if (string.IsNullOrEmpty(txt_kbSl.Text.Trim()))
            {
                Gs.DevApp.ToolBox.MsgHelper.Warning("送检数量不能为空!");
                txt_kbList.Focus();
                return;
            }
            if (string.IsNullOrEmpty(_txt_fbatchQty.Trim()))
            {
                Gs.DevApp.ToolBox.MsgHelper.Warning("抽检数量不能为空!");
                txt_fbatchQty.Focus();
                return;
            }
            if (!Gs.DevApp.ToolBox.UtilityHelper.IsNumeric2(_txt_fbatchQty))
            {
                Gs.DevApp.ToolBox.MsgHelper.Warning("请输入正确的抽检数量!");
                txt_fbatchQty.Focus();
                return;
            }
            if (!Gs.DevApp.ToolBox.UtilityHelper.IsNumeric2(txt_kbSl.Text.Trim()))
            {
                Gs.DevApp.ToolBox.MsgHelper.Warning("请输入正确的送检数量!");
                txt_kbList.Focus();
                return;
            }
            if (Gs.DevApp.ToolBox.UtilityHelper.ToDecimal(_txt_fbatchQty) > Gs.DevApp.ToolBox.UtilityHelper.ToDecimal(txt_kbSl.Text.Trim()))
            {
                Gs.DevApp.ToolBox.MsgHelper.Warning("抽检数量不能大于送检数量!");
                txt_fbatchQty.Focus();
                return;
            }
            //当不合格时的检查
            string _txt_fngHandle = txt_fngHandle.Text.Trim();
            string _txt_fmrmode = txt_fmrmode.GetCode();
            string _txt_fzrId = txt_fzrId.GetId();
            string _txt_workNo = txt_workNo.Text.Trim();
            string _txt_zrType = txt_zrType.Text.Trim();
            if (txt_fcheckResu.Text.Trim() == _strTag)
            {
                if (string.IsNullOrEmpty(txt_msg.TextTxt.Trim()))
                {
                    MsgHelper.Warning("当不合格时,请填写违规信息!");
                    txt_msg.Focus();
                    return;
                }
                if (txt_fngHandle.SelectedIndex <= 0)
                {
                    Gs.DevApp.ToolBox.MsgHelper.Warning("当不合格时,请选择处置结果!");
                    txt_fngHandle.Focus();
                    return;
                }
                if (txt_zrType.SelectedIndex <= 0)
                {
                    Gs.DevApp.ToolBox.MsgHelper.Warning("当不合格时,请选择责任判定!");
                    txt_zrType.Focus();
                    return;
                }
                if (_txt_fzrId.Length <= 0)
                {
                    Gs.DevApp.ToolBox.MsgHelper.Warning("当不合格时,请选择责任人!");
                    txt_fzrId.Focus();
                    return;
                }
                //当处置结果为反工时,要选择工序和反工编号
                if (txt_fngHandle.SelectedIndex == 1)
                {
                    if (string.IsNullOrEmpty(_txt_workNo))
                    {
                        Gs.DevApp.ToolBox.MsgHelper.Warning("当不合格时,请填写反工单号!");
                        txt_workNo.Focus();
                        return;
                    }
                    if (string.IsNullOrEmpty(_txt_fmrmode))
                    {
                        Gs.DevApp.ToolBox.MsgHelper.Warning("当不合格时,请填选择反工工序!");
                        txt_fmrmode.Focus();
                        return;
                    }
                }
                else
                {
                    if (!string.IsNullOrEmpty(_txt_workNo))
                    {
                        Gs.DevApp.ToolBox.MsgHelper.Warning("不需要填写反工单号!");
                        txt_workNo.Focus();
                        return;
                    }
                    if (!string.IsNullOrEmpty(_txt_fmrmode))
                    {
                        Gs.DevApp.ToolBox.MsgHelper.Warning("不需要选择反工工序!");
                        txt_fmrmode.Focus();
                        return;
                    }
                }
            };
            var _obj = new
            {
                guid = UtilityHelper.ToGuid(lbGuid.Text.Trim()), //主建
@@ -500,8 +582,47 @@
                fmanageNo = _txt_fmanageNo,//流程编号
                lotNo1 = _txt_lotNo1,//送检批号
                lotNo = _txt_lotNo,//生产工单
                edtType = 0
                kbList = _kbList,
                fngHandle = _txt_fngHandle,
                fzrId = _txt_fzrId,
                workNo = _txt_workNo,
                fmrmode = _txt_fmrmode,
                zrType = _txt_zrType,
                list = new List<dynamic>(),
            };
            gvMx1.CloseEditor();
            gvMx1.PostEditor();
            gvMx1.UpdateCurrentRow();
            for (var i = 0; i < gvMx1.DataRowCount; i++)
            {
                var row = gvMx1.GetDataRow(i);
                if (row != null)
                {
                    Guid _guid = UtilityHelper.ToGuid(row["guid"].ToString());
                    string _defectLevel = row["defectLevel"].ToString();
                    string _defectDetails = row["defectDetails"].ToString();
                    string _fcheckResu = row["fcheckResu"].ToString();
                    if (_fcheckResu == _strTag)
                    {
                        if (string.IsNullOrEmpty(_defectLevel))
                        {
                            MsgHelper.ShowError("请选择缺陷等级!");
                            return;
                        }
                        if (string.IsNullOrEmpty(_defectDetails))
                        {
                            MsgHelper.ShowError("请填写缺陷描述!");
                            return;
                        }
                        _obj.list.Add(new
                        {
                            guid5 = _guid,
                            defectLevel = _defectLevel,
                            defectDetails = _defectDetails,
                        });
                    }
                }
            }
            try
            {
                string strJson = UtilityHelper.HttpPost("", _webServiceName + "EditModel", JsonConvert.SerializeObject(_obj));
@@ -516,7 +637,7 @@
                    this.setEable(false);
                    toolBarMenu1.currentAction = "";
                    Gs.DevApp.ToolBox.UtilityHelper.JumpTab(xtraTabControl1, 6);
                    getModel(lbGuid.Text,"0");
                    getModel(lbGuid.Text, "0");
                }
            }
            catch (Exception ex)
@@ -532,7 +653,7 @@
        /// <param name="pageSize">每页几条</param>
        private void getPageList(int curPage)
        {
            var _sbSqlWhere = UtilityHelper.GetSearchWhere(_filterList);
            gcMain1.DataSource = null; var _sbSqlWhere = UtilityHelper.GetSearchWhere(_filterList);
            // _sbSqlWhere += " and isnull(fsubmit,0)=0";
            PageQueryModel pgq = new PageQueryModel(curPage, this.pageBar1.RowsCount, "release_no", "asc", "", _sbSqlWhere.ToString());
            string json = JsonConvert.SerializeObject(pgq);
@@ -609,6 +730,7 @@
                        gcMx1.ForceInitialize();
                        gvMx1.BestFitColumns();
                        ucUpFileList1.pGuid = lbGuid.Text.Trim();
                        ucChouJianList1.pGuid = lbGuid.Text.Trim();
                        if (guid5.Length > 10)
                        {
                            int rowHandle = 0;
@@ -640,6 +762,11 @@
        private void XtraTabControl2_SelectedPageChanged(object sender, DevExpress.XtraTab.TabPageChangedEventArgs e)
        {
            if (e.Page.Name == "tabMxPage2")
            {
                ucChouJianList1.getList14();
            }
            if (e.Page.Name == "tabMxPage3")
            {
                ucUpFileList1.getFileList();
            }
@@ -685,12 +812,191 @@
                MsgHelper.Warning("提示:" + ex.Message);
            }
        }
        private void setEable(bool bl)
        {
            txtJianYan.ReadOnly = !bl;
            btnLoad.Enabled = bl;
            ucChouJianList1.IsReadOnly(!bl);
            btnIpt.Text = (bl == true ? "录入样本" : "查看样本");
        }
        /// <summary>
        /// 读取缺陷等级
        /// </summary>
        /// <param name="curPage"></param>
        private void getRptDefectLevel()
        {
            string _where = " and 1=1 and  a.s_type='缺陷等级'  and a.pid<>'00000000-0000-0000-0000-000000000000'";
            var pgq = new PageQueryModel(1, 999999, "a.defect_code", "asc", "", _where);
            var json = JsonConvert.SerializeObject(pgq);
            try
            {
                var strReturn = UtilityHelper.HttpPost("", "MesDefectCodeManager/GetListPage", json);
                var dd = UtilityHelper.ReturnToTablePage(strReturn);
                var dt = dd.rtnData.list;
                foreach (DataRow dr in dt.Rows)
                {
                    rptDefectLevel.Items.Add(dr["defectName"].ToString());
                }
            }
            catch (Exception ex)
            {
                MsgHelper.Warning("提示:" + ex.Message);
            }
        }
        /// <summary>
        /// 选择缺陷描述
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void rptDefectDetails_ButtonClick(object sender, DevExpress.XtraEditors.Controls.ButtonPressedEventArgs e)
        {
            var rowhandle = gvMx1.FocusedRowHandle;
            if (rowhandle < 0)
                return;
            UcDictionarySelect frm = new UcDictionarySelect("异常描述", "  a.s_type='QC异常描述' and a.pid<>'00000000-0000-0000-0000-000000000000'");
            frm.UpdateParent += (ss, ee) =>
            {
                System.Text.StringBuilder stringBuilder = new System.Text.StringBuilder();
                var lst = ee.DynamicList;
                foreach (dynamic dym in lst)
                {
                    if (stringBuilder.Length > 0)
                        stringBuilder.Append("|");
                    stringBuilder.Append(dym.dicTxt);
                }
                gvMx1.SetFocusedRowCellValue("defectDetails", stringBuilder.ToString());
                // this.TextTxt = ;
            };
            frm.ShowDialog();
        }
        /// <summary>
        /// 检验和反检验
        /// </summary>
        /// <param name="inFieldValue"></param>
        private void _toolCk(int _inFieldValue)
        {
            string strMsg = "";
            switch (_inFieldValue)
            {
                case 1:
                    strMsg = "审核";
                    break;
                case 0:
                    strMsg = "反审核";
                    break;
            };
            toolBarMenu1.guidKey = "";
            string rowGuid, rowName;
            (rowGuid, rowName) = UtilityHelper.GetCurrentRow(xtraTabControl1,
                lbGuid, txt_releaseNo, gridView1, "releaseNo");
            toolBarMenu1.guidKey = rowGuid;
            if (string.IsNullOrEmpty(rowGuid))
            {
                MsgHelper.Warning("请先选择你要操作的行!");
                return;
            }
            if (!MsgHelper.AskQuestion("你选择了【" + rowName + "】,确定" + strMsg + "吗?"))
                return;
            if (_inFieldValue == 1)
            {
                if (txt_fcheckResu.Text.Trim() == _strTag)
                {
                    if (string.IsNullOrEmpty(txt_msg.TextTxt.Trim()))
                    {
                        MsgHelper.Warning("单据为不合格时,请填写违规信息!");
                        return;
                    }
                    string _txt_fngHandle = txt_fngHandle.Text.Trim();
                    string _txt_fmrmode = txt_fmrmode.GetCode();
                    string _txt_fzrId = txt_fzrId.GetId();
                    string _txt_workNo = txt_workNo.Text.Trim();
                    string _txt_msg = txt_msg.TextTxt;
                    string _txt_zrType = txt_zrType.Text.Trim();
                    if (txt_fngHandle.SelectedIndex <= 0)
                    {
                        Gs.DevApp.ToolBox.MsgHelper.Warning("请选择处置结果!");
                        txt_fngHandle.Focus();
                        return;
                    }
                    if (txt_zrType.SelectedIndex <= 0)
                    {
                        Gs.DevApp.ToolBox.MsgHelper.Warning("请选择责任判定!");
                        txt_zrType.Focus();
                        return;
                    }
                    if (_txt_fzrId.Length <= 0)
                    {
                        Gs.DevApp.ToolBox.MsgHelper.Warning("请选择责任人!");
                        txt_fzrId.Focus();
                        return;
                    }
                    //当处置结果为反工时,要选择工序和反工编号
                    if (txt_fngHandle.SelectedIndex == 1)
                    {
                        if (string.IsNullOrEmpty(_txt_workNo))
                        {
                            Gs.DevApp.ToolBox.MsgHelper.Warning("请填写反工单号!");
                            txt_workNo.Focus();
                            return;
                        }
                        if (string.IsNullOrEmpty(_txt_fmrmode))
                        {
                            Gs.DevApp.ToolBox.MsgHelper.Warning("请填选择反工工序!");
                            txt_fmrmode.Focus();
                            return;
                        }
                    }
                    else
                    {
                        if (!string.IsNullOrEmpty(_txt_workNo))
                        {
                            Gs.DevApp.ToolBox.MsgHelper.Warning("不需要填写反工单号!");
                            txt_workNo.Focus();
                            return;
                        }
                        if (!string.IsNullOrEmpty(_txt_fmrmode))
                        {
                            Gs.DevApp.ToolBox.MsgHelper.Warning("不需要选择反工工序!");
                            txt_fmrmode.Focus();
                            return;
                        }
                    }
                };
            }
            var _obj = new
            {
                guid = rowGuid,
                inFieldValue = _inFieldValue,
            };
            try
            {
                var strJson = UtilityHelper.HttpPost("",
                    _webServiceName + "EditModelSubmit",
                    JsonConvert.SerializeObject(_obj));
                var _rtn = UtilityHelper.ReturnToDynamic(strJson);
                MsgHelper.Warning("提示:" + _rtn.rtnData.outMsg);
                if (_rtn.rtnCode > 0 && _rtn.rtnData.outSum * 1 > 0)
                {
                    if (xtraTabControl1.SelectedTabPageIndex == 1)
                    {
                        getModel(lbGuid.Text.Trim(), "0");
                    }
                    int rowHandle = gridView1.LocateByValue(1, gridView1.Columns["guid"], rowGuid);
                    gridView1.FocusedRowHandle = rowHandle;
                    UtilityHelper.SetCheckIco(gridView1, "fsubmitTxt", "", "iqcDate", picCheckBox, this, _inFieldValue.ToString());
                }
            }
            catch (Exception ex)
            {
                MsgHelper.Warning("提示:" + ex.Message);
            }
        }
    }
}