lu
2025-04-14 ecb7a60de1639f520712ce95f99414b0dd2c9713
DevApp/Gs.DevApp/DevFrm/Sys/DocNoRule.cs
@@ -1,12 +1,12 @@
using System;
using System.Collections.Generic;
using System.Data;
using System.Windows.Forms;
using DevExpress.XtraEditors;
using DevExpress.XtraEditors;
using DevExpress.XtraEditors.Controls;
using Gs.DevApp.Entity;
using Gs.DevApp.ToolBox;
using Newtonsoft.Json;
using System;
using System.Collections.Generic;
using System.Data;
using System.Windows.Forms;
namespace Gs.DevApp.DevFrm.Sys
{
@@ -23,37 +23,31 @@
            toolBarMenu1.btnEscClick += ToolBarMenu1_btnEscClick;
            toolBarMenu1.btnChkClick += ToolBarMenu1_btnChkClick;
            toolBarMenu1.btnFChkClick += ToolBarMenu1_btnFChkClick;
            gcMain.MouseDoubleClick += GcMain_MouseDoubleClick;
            getPageList(1, UtilityHelper.GetPageSize());
            this.toolBarMenu1.getXmlConfig();
            Gs.DevApp.ToolBox.UtilityHelper.SetGridViewParameter(gridView1, picCheckBox, this, "checkStatus", "", (value) =>
            {
                Gs.DevApp.ToolBox.UtilityHelper.JumpTab(xtraTabControl1, 0);
            }, tips);
            Gs.DevApp.ToolBox.UtilityHelper.SetTabParameter(gridView1, xtraTabControl1, pageBar1, (value) =>
            {
                getModel(value);
            }, (value) =>
            {
                getPageList(this.pageBar1.CurrentPage);
            }, lbGuid);
            getPageList(1);
            pageBar1.PagerEvent += PageBar1_PagerEvent;
            getTree();
            txt_docCode.EditValueChanged += Txt_docCode_EditValueChanged;
            txxtItem1.EditValueChanged += TxxtItem1_EditValueChanged;
            txxtItem2.EditValueChanged += TxxtItem1_EditValueChanged;
            txxtItem3.EditValueChanged += TxxtItem1_EditValueChanged;
            txxtItem4.EditValueChanged += TxxtItem1_EditValueChanged;
            txt_noLength.ValueChanged += Txt_noLength_ValueChanged;
            txt_isIncludeDoc.CheckedChanged +=
                Txt_flagIncludeDocCode_CheckedChanged;
            txt_isSpilit.CheckedChanged +=
                Txt_flagIncludeDocCode_CheckedChanged;
        }
            txt_docCode.EditValueChanged += (s, e) => { DoPreviewCode(); };
            txxtItem1.EditValueChanged += (s, e) => { DoPreviewCode(); };
            txxtItem2.EditValueChanged += (s, e) => { DoPreviewCode(); };
            txxtItem3.EditValueChanged += (s, e) => { DoPreviewCode(); };
            txxtItem4.EditValueChanged += (s, e) => { DoPreviewCode(); };
            txxtItem5.EditValueChanged += (s, e) => { DoPreviewCode(); };
            txt_noLength.ValueChanged += (s, e) => { DoPreviewCode(); };
            txt_isIncludeDoc.CheckedChanged += (s, e) => { DoPreviewCode(); };
            txt_isSpilit.CheckedChanged += (s, e) => { DoPreviewCode(); };
        /// <summary>
        ///     双击事件
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void GcMain_MouseDoubleClick(object sender, MouseEventArgs e)
        {
            var rowGuid =
                UtilityHelper.GetCurrentDoubleRow(gridView1, e, "guid");
            if (!string.IsNullOrEmpty(rowGuid))
            {
                getModel(rowGuid, false, 999);
                txxtItem1.Enabled = txxtItem2.Enabled =
                    txxtItem3.Enabled = txxtItem4.Enabled = false;
            }
        }
        /// <summary>
@@ -63,7 +57,7 @@
        /// <param name="pageSize"></param>
        private void PageBar1_PagerEvent(int curPage, int pageSize)
        {
            getPageList(curPage, pageSize);
            getPageList(curPage);
        }
        /// <summary>
@@ -74,11 +68,7 @@
        /// <exception cref="NotImplementedException"></exception>
        private void ToolBarMenu1_btnFChkClick(object sender, EventArgs e)
        {
            toolBarMenu1.guidKey = "";
            string rowGuid, rowName;
            (rowGuid, rowName) = UtilityHelper.GetCurrentRow(xtraTabControl1,
                lbGuid, txt_docCode, gridView1);
            toolBarMenu1.guidKey = rowGuid;
            _toolCk(0);
        }
        /// <summary>
@@ -88,11 +78,7 @@
        /// <param name="e"></param>
        private void ToolBarMenu1_btnChkClick(object sender, EventArgs e)
        {
            toolBarMenu1.guidKey = "";
            string rowGuid, rowName;
            (rowGuid, rowName) = UtilityHelper.GetCurrentRow(xtraTabControl1,
                lbGuid, txt_docCode, gridView1);
            toolBarMenu1.guidKey = rowGuid;
            _toolCk(1);
        }
        /// <summary>
@@ -102,7 +88,7 @@
        /// <param name="e"></param>
        private void ToolBarMenu1_btnEscClick(object sender, EventArgs e)
        {
            UtilityHelper.JumpToTab(xtraTabControl1, 0);
            Gs.DevApp.ToolBox.UtilityHelper.JumpTab(xtraTabControl1, 1);
        }
        /// <summary>
@@ -114,7 +100,7 @@
        {
            string rowGuid, rowName;
            (rowGuid, rowName) = UtilityHelper.GetCurrentRow(xtraTabControl1,
                lbGuid, txt_docCode, gridView1);
                lbGuid, txt_docCode, gridView1, "docCode");
            if (string.IsNullOrEmpty(rowGuid))
            {
                MsgHelper.Warning("请先选择你要操作的行!");
@@ -134,10 +120,12 @@
                var _rtn = UtilityHelper.ReturnToDynamic(strJson);
                if (_rtn.rtnCode > 0)
                {
                    UtilityHelper.JumpToTab(xtraTabControl1, 0);
                    getPageList(1, UtilityHelper.GetPageSize());
                    if (xtraTabControl1.SelectedTabPageIndex == 0)
                    { }
                    else
                        Gs.DevApp.ToolBox.UtilityHelper.JumpTab(xtraTabControl1, 2);
                    getPageList(this.pageBar1.CurrentPage);
                }
                MsgHelper.Warning("提示:" + _rtn.rtnMsg);
            }
            catch (Exception ex)
@@ -153,8 +141,20 @@
        /// <param name="e"></param>
        private void ToolBarMenu1_btnLoadClick(object sender, EventArgs e)
        {
            UtilityHelper.JumpToTab(xtraTabControl1, 0);
            getPageList(1, UtilityHelper.GetPageSize());
            if (xtraTabControl1.SelectedTabPageIndex == 1)
                getModel(lbGuid.Text.Trim());
            else
            {
                //_filterList.Clear();
                //if (gridView1.ActiveFilter.Count > 0)
                //{
                //    gridView1.ColumnFilterChanged -= GridView1_ColumnFilterChanged;
                //    gridView1.ActiveFilter.Clear();
                //    gridView1.ColumnFilterChanged += GridView1_ColumnFilterChanged;
                //}
                //getPageList(1);
                getPageList(this.pageBar1.CurrentPage);
            }
        }
        /// <summary>
@@ -172,10 +172,16 @@
                MsgHelper.Warning("请先选择你要操作的行!");
                return;
            }
            getModel(rowGuid, true, 1);
            txxtItem1.Enabled = txxtItem2.Enabled = txxtItem3.Enabled =
                txxtItem4.Enabled = panelControl1.Enabled = true;
            Gs.DevApp.ToolBox.UtilityHelper.JumpTab(xtraTabControl1, 3);
            if (xtraTabControl1.SelectedTabPageIndex == 1)
            {
                getModel(rowGuid);
            }
            else
            {
                UtilityHelper.ChangeEnableByControl(panel1.Controls, true);
            }
            txxtItem1.Enabled = txxtItem2.Enabled = txxtItem3.Enabled = txxtItem4.Enabled = txxtItem5.Enabled = panelControl1.Enabled = true;
        }
        /// <summary>
@@ -185,13 +191,14 @@
        /// <param name="e"></param>
        private void ToolBarMenu1_btnAddClick(object sender, EventArgs e)
        {
            UtilityHelper.JumpToTab(xtraTabControl1, 1);
            lbGuid.Text = "";
            Gs.DevApp.ToolBox.UtilityHelper.JumpTab(xtraTabControl1, 4);
            UtilityHelper.CleanValueByControl(panel1.Controls, true);
            txxtItem1.SelectedIndex = txxtItem2.SelectedIndex =
                txxtItem3.SelectedIndex = txxtItem4.SelectedIndex = 0;
                txxtItem3.SelectedIndex = txxtItem4.SelectedIndex = txxtItem5.SelectedIndex = 0;
            txxtItem1.Enabled = txxtItem2.Enabled = txxtItem3.Enabled =
                txxtItem4.Enabled = panelControl1.Enabled = true;
                txxtItem4.Enabled = txxtItem5.Enabled = panelControl1.Enabled = true;
            txt_docCode.EditValue = null;
        }
        /// <summary>
@@ -227,7 +234,7 @@
            var _obj = new
            {
                guid =UtilityHelper.ToGuid( lbGuid.Text.Trim()), //主建
                guid = UtilityHelper.ToGuid(lbGuid.Text.Trim()), //主建
                docCode = txt_docCode.EditValue.ToString(),
                docFormat = txt_docFormat.Text,
                noLength = txt_noLength.Value.ToString(),
@@ -246,6 +253,8 @@
                    lbGuid.Text = _rtn.rtnData;
                    toolBarMenu1.isSetBtn = true;
                    UtilityHelper.ChangeEnableByControl(panel1.Controls, false);
                    toolBarMenu1.currentAction = "";
                    Gs.DevApp.ToolBox.UtilityHelper.JumpTab(xtraTabControl1, 6);
                }
            }
            catch (Exception ex)
@@ -258,9 +267,9 @@
        /// </summary>
        /// <param name="curPage">第几页</param>
        /// <param name="pageSize">每页几条</param>
        private void getPageList(int curPage, int pageSize)
        private void getPageList(int curPage)
        {
            var pgq = new PageQueryModel(curPage, pageSize, "doc_Code");
            var pgq = new PageQueryModel(curPage, this.pageBar1.RowsCount, "doc_Code");
            var json = JsonConvert.SerializeObject(pgq);
            try
            {
@@ -270,15 +279,13 @@
                if (dd.rtnCode > 0)
                {
                    DataTable dt = dd.rtnData.list;
                    gcMain.BindingContext = new BindingContext();
                    gcMain.DataSource = dt;
                    gcMain.ForceInitialize();
                    int dddd = dd.rtnData.pages;//总页
                    pageBar1.TotalPages = dddd;
                    pageBar1.RecordCount = dd.rtnData.total;//记录总数
                    gcMain1.BindingContext = new BindingContext();
                    gcMain1.DataSource = dt;
                    gcMain1.ForceInitialize();
                    pageBar1.TotalPages = dd.rtnData.pages;//总页
                    pageBar1.CurrentPage = curPage;//当前页
                    pageBar1.RowsCount = pageSize;//每页显示
                    pageBar1.setTxt();
                    pageBar1.RecordCount = dd.rtnData.total;//总记录数
                    gridView1.BestFitColumns(); Gs.DevApp.ToolBox.UtilityHelper.SetGridLayout(gridView1);
                }
                else
                {
@@ -291,15 +298,16 @@
            }
        }
        private void getModel(string strGuid, bool isEdit, int tabIdx)
        private void getModel(string strGuid)
        {
            bool isEdit = false;
            if (toolBarMenu1.currentAction == "add") return;
            if (toolBarMenu1.currentAction == "edit") isEdit = true;
            if (string.IsNullOrEmpty(strGuid))
            {
                MsgHelper.Warning("请先选择你要操作的行!");
                return;
            }
            UtilityHelper.JumpToTab(xtraTabControl1, tabIdx);
            var _obj = new
            {
                guid = strGuid //主建
@@ -326,6 +334,9 @@
                        txxtItem3.Text = "<" + _ary[2];
                    if (_ary.Length > 3)
                        txxtItem4.Text = "<" + _ary[3];
                    if (_ary.Length > 4)
                        txxtItem5.Text = "<" + _ary[4];
                    txxtItem1.Enabled = txxtItem2.Enabled = txxtItem3.Enabled = txxtItem4.Enabled = panelControl1.Enabled = false;
                }
                else
                {
@@ -342,34 +353,65 @@
        {
            var dataTable = new DataTable();
            dataTable.Columns.Add("docCode", typeof(string));
            dataTable.Rows.Add("DH(到货单)");
            dataTable.Rows.Add("JY(检验单)");
            dataTable.Rows.Add("TL(采购退料单)");
            dataTable.Rows.Add("IN(入库单)");
            dataTable.Rows.Add("PB(批量排产)");
            dataTable.Rows.Add("SC(生产工单)");
            dataTable.Rows.Add("OUT(出库单)");
            dataTable.Rows.Add("HB(工单物料合并)");
            dataTable.Rows.Add("CGDH(采购到货)");
            dataTable.Rows.Add("CGJY(采购检验)");
            dataTable.Rows.Add("CGRK(采购入库)");
            dataTable.Rows.Add("CGTHSQ(采购退货申请)");
            dataTable.Rows.Add("CGTHJ(采购检验退)");
            dataTable.Rows.Add("CGTHK(采购库存退)");
            dataTable.Rows.Add("GDPC(工单排产)");
            dataTable.Rows.Add("SCLL(生产领料)");
            dataTable.Rows.Add("SCTLSQ(生产退料申请)");
            dataTable.Rows.Add("SCTL(生产退料)");
            dataTable.Rows.Add("SCHL(生产换料)");
            dataTable.Rows.Add("SCBLSQ(生产补料申请)");
            dataTable.Rows.Add("SCBL(生产补料)");
            dataTable.Rows.Add("SCCLSQ(生产超领申请)");
            dataTable.Rows.Add("SCCL(生产超领)");
            dataTable.Rows.Add("BG(报工)");
            dataTable.Rows.Add("SCRK(生产入库)");
            dataTable.Rows.Add("QTCKSQ(其他出库申请)");
            dataTable.Rows.Add("QTCK(其他出库)");
            dataTable.Rows.Add("QTRKSQ(其他入库申请)");
            dataTable.Rows.Add("QTRK(其他入库)");
            dataTable.Rows.Add("DBSQ(调拨申请)");
            dataTable.Rows.Add("DBK(库存调拨)");
            dataTable.Rows.Add("DBJ(寄存调拨)");
            dataTable.Rows.Add("XSCK(销售出库)");
            dataTable.Rows.Add("XSTH(销售退货)");
            dataTable.Rows.Add("WWPC(委外排产)");
            dataTable.Rows.Add("WWLL(委外领料)");
            dataTable.Rows.Add("WWTLSQ(委外退料申请)");
            dataTable.Rows.Add("WWTL(委外退料)");
            dataTable.Rows.Add("WWCLSQ(委外超领申请)");
            dataTable.Rows.Add("WWCL(委外超领)");
            dataTable.Rows.Add("WWBLSQ(委外补料申请)");
            dataTable.Rows.Add("WWBL(委外补料)");
            dataTable.Rows.Add("SJJYSQ(首检申请)");
            dataTable.Rows.Add("SJJY(首检检验)");
            dataTable.Rows.Add("XJJYSQ(巡检申请)");
            dataTable.Rows.Add("XJJY(巡检检验)");
            dataTable.Rows.Add("FQCSQ(入库检申请)");
            dataTable.Rows.Add("FQC(入库检验)");
            dataTable.Rows.Add("OQCSQ(出库检验申请)");
            dataTable.Rows.Add("OQC(出库检验)");
            dataTable.Rows.Add("TM(条码)");
            dataTable.Rows.Add("FHTZSQ(发货通知申请)");
            dataTable.Rows.Add("FHTZ(发货通知)");
            dataTable.Rows.Add("XSTHSQ(销售退货申请)");
            dataTable.Rows.Add("STRKSQ(受托入库申请)");
            dataTable.Rows.Add("STRK(受托入库)");
            dataTable.Rows.Add("STTLSQ(受托退料申请)");
            dataTable.Rows.Add("STTL(受托退料)");
            dataTable.Rows.Add("IQCYC(IQC异常)");
            dataTable.Rows.Add("IPQCYC(IPQC异常)");
            dataTable.Rows.Add("FQCYC(FQC异常)");
            dataTable.Rows.Add("ZSM(追溯码)");
            dataTable.Rows.Add("TB(托板码)");
            txt_docCode.Properties.DataSource = dataTable;
            txt_docCode.Properties.DisplayMember = "docCode"; // 显示的列
            txt_docCode.Properties.ValueMember = "docCode"; // 实际值的列
            txt_docCode.Properties.TextEditStyle =TextEditStyles.DisableTextEditor;
        }
        private void Txt_flagIncludeDocCode_CheckedChanged(object sender,
            EventArgs e)
        {
            DoPreviewCode();
        }
        private void Txt_noLength_ValueChanged(object sender, EventArgs e)
        {
            DoPreviewCode();
        }
        private void TxxtItem1_EditValueChanged(object sender, EventArgs e)
        {
            DoPreviewCode();
            txt_docCode.Properties.TextEditStyle = TextEditStyles.DisableTextEditor;
        }
        private void DoPreviewCode()
@@ -378,38 +420,87 @@
                || txxtItem1.Enabled == false
                || txxtItem2.Enabled == false
                || txxtItem3.Enabled == false
                || txxtItem4.Enabled == false)
                || txxtItem4.Enabled == false
                 || txxtItem5.Enabled == false)
                return;
            var text = txxtItem1.Text + txxtItem2.Text + txxtItem3.Text +
                       txxtItem4.Text;
            var text = txxtItem1.Text + txxtItem2.Text + txxtItem3.Text + txxtItem4.Text + txxtItem5.Text; ;
            txt_docFormat.Text = text;
            if (txt_docFormat.Text == "")
            //if (txt_docFormat.Text == "")
            //{
            //    lblPreview.Text = "请定义规则.";
            //}
            //else
            //{
            //    var preview = txt_docFormat.Text;
            //    var length = int.Parse(txt_noLength.Value.ToString());
            //    var docCode = "";
            //    if (txt_isIncludeDoc.Checked)
            //        docCode = (txt_docCode.EditValue==null?"": txt_docCode.EditValue.ToString());
            //    preview = docCode + preview;
            //    preview = preview.Replace("无", "");
            //    preview = preview.Replace("年年年年", "2025");
            //    preview = preview.Replace("年年", "25");
            //    preview = preview.Replace("月月", "06");
            //    preview = preview.Replace("日日", "18");
            //    preview = preview + (txt_isSpilit.Checked ? "-" : "") + "8".PadLeft(length, '0');
            //}
        }
        /// <summary>
        /// 工具条事件
        /// </summary>
        /// <param name="inFieldValue"></param>
        private void _toolCk(int _inFieldValue)
        {
            string strMsg = "";
            switch (_inFieldValue)
            {
                lblPreview.Text = "请定义规则.";
                case 1:
                    strMsg = "审核";
                    break;
                case 0:
                    strMsg = "反审核";
                    break;
            };
            toolBarMenu1.guidKey = "";
            string rowGuid, rowName;
            (rowGuid, rowName) = UtilityHelper.GetCurrentRow(xtraTabControl1, lbGuid, txt_docCode, gridView1, "docCode");
            if (string.IsNullOrEmpty(rowGuid))
            {
                MsgHelper.Warning("请先选择你要操作的行!");
                return;
            }
            else
            if (!MsgHelper.AskQuestion("你选择了【" + rowName + "】,确定" + strMsg + "吗?"))
                return;
            var _obj = new
            {
                // txtRuleFormat="<年年>", "<年年年年>", "<月月>", "<日日>" });
                var preview = txt_docFormat.Text;
                var length = int.Parse(txt_noLength.Value.ToString());
                var docCode = "";
                if (txt_isIncludeDoc.Checked)
                    docCode = txt_docCode.EditValue.ToString();
                preview = docCode + preview;
                preview = preview.Replace("<无>", "");
                preview = preview.Replace("<年年年年>", "2024");
                preview = preview.Replace("<年年>", "24");
                preview = preview.Replace("<月月>", "06");
                preview = preview.Replace("<日日>", "18");
                preview = preview + (txt_isSpilit.Checked ? "-" : "") +
                          "8".PadLeft(length, '0');
                lblPreview.Text = "生成编号:" + preview;
                guid = rowGuid,
                ckValue = _inFieldValue,
                parameter = "SYS_DOC_RULE,check_date,check_status,check_by"
            };
            try
            {
                var strJson = UtilityHelper.HttpPost("", "General/GeneralCheck",
                    JsonConvert.SerializeObject(_obj));
                var _rtn = UtilityHelper.ReturnToDynamic(strJson);
                MsgHelper.Warning(_rtn.rtnData.outMsg.ToString());
                if (_rtn.rtnCode > 0)
                {
                    if (xtraTabControl1.SelectedTabPageIndex == 1)
                    {
                        getModel(lbGuid.Text.Trim());
                    }
                    int rowHandle = gridView1.LocateByValue(1, gridView1.Columns["guid"], rowGuid);
                    gridView1.FocusedRowHandle = rowHandle;
                    UtilityHelper.SetCheckIco(gridView1, "checkStatus", "checkBy", "checkDate", picCheckBox, this, _inFieldValue.ToString());
                }
            }
            catch (Exception ex)
            {
                MsgHelper.Warning("提示:" + ex.Message);
            }
        }
        private void Txt_docCode_EditValueChanged(object sender, EventArgs e)
        {
            DoPreviewCode();
        }
    }
}