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
|
{
|
public partial class DocNoRule : XtraForm
|
{
|
public DocNoRule()
|
{
|
InitializeComponent();
|
toolBarMenu1.btnAddClick += ToolBarMenu1_btnAddClick;
|
toolBarMenu1.btnEdtClick += ToolBarMenu1_btnEdtClick;
|
toolBarMenu1.btnSaveClick += ToolBarMenu1_btnSaveClick;
|
toolBarMenu1.btnLoadClick += ToolBarMenu1_btnLoadClick;
|
toolBarMenu1.btnDelClick += ToolBarMenu1_btnDelClick1;
|
toolBarMenu1.btnEscClick += ToolBarMenu1_btnEscClick;
|
toolBarMenu1.btnChkClick += ToolBarMenu1_btnChkClick;
|
toolBarMenu1.btnFChkClick += ToolBarMenu1_btnFChkClick;
|
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 += (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="curPage"></param>
|
/// <param name="pageSize"></param>
|
private void PageBar1_PagerEvent(int curPage, int pageSize)
|
{
|
getPageList(curPage);
|
}
|
|
/// <summary>
|
/// 反审核
|
/// </summary>
|
/// <param name="sender"></param>
|
/// <param name="e"></param>
|
/// <exception cref="NotImplementedException"></exception>
|
private void ToolBarMenu1_btnFChkClick(object sender, EventArgs e)
|
{
|
_toolCk(0);
|
}
|
|
/// <summary>
|
/// 审核事件
|
/// </summary>
|
/// <param name="sender"></param>
|
/// <param name="e"></param>
|
private void ToolBarMenu1_btnChkClick(object sender, EventArgs e)
|
{
|
_toolCk(1);
|
}
|
|
/// <summary>
|
/// 取消事件
|
/// </summary>
|
/// <param name="sender"></param>
|
/// <param name="e"></param>
|
private void ToolBarMenu1_btnEscClick(object sender, EventArgs e)
|
{
|
Gs.DevApp.ToolBox.UtilityHelper.JumpTab(xtraTabControl1, 1);
|
}
|
|
/// <summary>
|
/// 删除事件
|
/// </summary>
|
/// <param name="sender"></param>
|
/// <param name="e"></param>
|
private void ToolBarMenu1_btnDelClick1(object sender, EventArgs e)
|
{
|
string rowGuid, rowName;
|
(rowGuid, rowName) = UtilityHelper.GetCurrentRow(xtraTabControl1,
|
lbGuid, txt_docCode, gridView1, "docCode");
|
if (string.IsNullOrEmpty(rowGuid))
|
{
|
MsgHelper.Warning("请先选择你要操作的行!");
|
return;
|
}
|
|
if (!MsgHelper.AskQuestion("你选择了【" + rowName + "】,确定删除吗?"))
|
return;
|
|
var lst = new List<string>();
|
lst.Add(rowGuid);
|
var _obj = lst;
|
try
|
{
|
var strJson = UtilityHelper.HttpPost("",
|
"DocNoRule/DeleteModel", JsonConvert.SerializeObject(_obj));
|
var _rtn = UtilityHelper.ReturnToDynamic(strJson);
|
if (_rtn.rtnCode > 0)
|
{
|
if (xtraTabControl1.SelectedTabPageIndex == 0)
|
{ }
|
else
|
Gs.DevApp.ToolBox.UtilityHelper.JumpTab(xtraTabControl1, 2);
|
getPageList(this.pageBar1.CurrentPage);
|
}
|
MsgHelper.Warning("提示:" + _rtn.rtnMsg);
|
}
|
catch (Exception ex)
|
{
|
MsgHelper.Warning("提示:" + ex.Message);
|
}
|
}
|
|
/// <summary>
|
/// 刷新事件
|
/// </summary>
|
/// <param name="sender"></param>
|
/// <param name="e"></param>
|
private void ToolBarMenu1_btnLoadClick(object sender, EventArgs e)
|
{
|
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>
|
/// 修改事件
|
/// </summary>
|
/// <param name="sender"></param>
|
/// <param name="e"></param>
|
private void ToolBarMenu1_btnEdtClick(object sender, EventArgs e)
|
{
|
string rowGuid, rowName;
|
(rowGuid, rowName) = UtilityHelper.GetCurrentRow(xtraTabControl1,
|
lbGuid, txt_docCode, gridView1);
|
if (string.IsNullOrEmpty(rowGuid))
|
{
|
MsgHelper.Warning("请先选择你要操作的行!");
|
return;
|
}
|
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>
|
/// 新增事件
|
/// </summary>
|
/// <param name="sender"></param>
|
/// <param name="e"></param>
|
private void ToolBarMenu1_btnAddClick(object sender, EventArgs e)
|
{
|
lbGuid.Text = "";
|
Gs.DevApp.ToolBox.UtilityHelper.JumpTab(xtraTabControl1, 4);
|
UtilityHelper.CleanValueByControl(panel1.Controls, true);
|
txxtItem1.SelectedIndex = txxtItem2.SelectedIndex =
|
txxtItem3.SelectedIndex = txxtItem4.SelectedIndex = txxtItem5.SelectedIndex = 0;
|
txxtItem1.Enabled = txxtItem2.Enabled = txxtItem3.Enabled =
|
txxtItem4.Enabled = txxtItem5.Enabled = panelControl1.Enabled = true;
|
txt_docCode.EditValue = null;
|
}
|
|
/// <summary>
|
/// 保存事件
|
/// </summary>
|
/// <param name="sender"></param>
|
/// <param name="e"></param>
|
private void ToolBarMenu1_btnSaveClick(object sender, EventArgs e)
|
{
|
toolBarMenu1.isSetBtn = false;
|
if (txt_docCode.EditValue == null ||
|
string.IsNullOrEmpty(txt_docCode.EditValue.ToString()))
|
{
|
MsgHelper.Warning("请先选择单据类型!");
|
txt_docCode.Focus();
|
return;
|
}
|
|
if (txxtItem1.SelectedIndex + txxtItem2.SelectedIndex +
|
txxtItem3.SelectedIndex + txxtItem4.SelectedIndex <= 0)
|
{
|
MsgHelper.Warning("请至少选择一个参数!");
|
txxtItem1.Focus();
|
return;
|
}
|
|
if (txt_docFormat.Text.Length <= 0)
|
{
|
MsgHelper.Warning("请先配置参数!");
|
txt_docCode.Focus();
|
return;
|
}
|
|
var _obj = new
|
{
|
guid = UtilityHelper.ToGuid(lbGuid.Text.Trim()), //主建
|
docCode = txt_docCode.EditValue.ToString(),
|
docFormat = txt_docFormat.Text,
|
noLength = txt_noLength.Value.ToString(),
|
resetZero = txt_resetZero.Checked,
|
isSpilit = txt_isSpilit.Checked,
|
isIncludeDoc = txt_isIncludeDoc.Checked
|
};
|
try
|
{
|
var strJson = UtilityHelper.HttpPost("", "DocNoRule/EditModel",
|
JsonConvert.SerializeObject(_obj));
|
var _rtn = UtilityHelper.ReturnToDynamic(strJson);
|
MsgHelper.Warning("提示:" + _rtn.rtnMsg);
|
if (_rtn.rtnCode > 0)
|
{
|
lbGuid.Text = _rtn.rtnData;
|
toolBarMenu1.isSetBtn = true;
|
UtilityHelper.ChangeEnableByControl(panel1.Controls, false);
|
toolBarMenu1.currentAction = "";
|
Gs.DevApp.ToolBox.UtilityHelper.JumpTab(xtraTabControl1, 6);
|
}
|
}
|
catch (Exception ex)
|
{
|
MsgHelper.Warning("提示:" + ex.Message);
|
}
|
}
|
|
/// <summary>
|
/// </summary>
|
/// <param name="curPage">第几页</param>
|
/// <param name="pageSize">每页几条</param>
|
private void getPageList(int curPage)
|
{
|
var pgq = new PageQueryModel(curPage, this.pageBar1.RowsCount, "doc_Code");
|
var json = JsonConvert.SerializeObject(pgq);
|
try
|
{
|
var strReturn =
|
UtilityHelper.HttpPost("", "DocNoRule/GetListPage", json);
|
var dd = UtilityHelper.ReturnToTablePage(strReturn);
|
if (dd.rtnCode > 0)
|
{
|
DataTable dt = dd.rtnData.list;
|
gcMain1.BindingContext = new BindingContext();
|
gcMain1.DataSource = dt;
|
gcMain1.ForceInitialize();
|
pageBar1.TotalPages = dd.rtnData.pages;//总页
|
pageBar1.CurrentPage = curPage;//当前页
|
pageBar1.RecordCount = dd.rtnData.total;//总记录数
|
gridView1.BestFitColumns(); Gs.DevApp.ToolBox.UtilityHelper.SetGridLayout(gridView1);
|
}
|
else
|
{
|
ToolBox.MsgHelper.ShowError("提示:" + dd.rtnMsg);
|
}
|
}
|
catch (Exception ex)
|
{
|
MsgHelper.Warning("提示:" + ex.Message);
|
}
|
}
|
|
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;
|
}
|
var _obj = new
|
{
|
guid = strGuid //主建
|
};
|
try
|
{
|
var strJson = UtilityHelper.HttpPost("", "DocNoRule/GetModel",
|
JsonConvert.SerializeObject(_obj));
|
var _rtn = UtilityHelper.ReturnToDynamic(strJson);
|
if (_rtn.rtnCode > 0)
|
{
|
var dy = _rtn.rtnData;
|
lbGuid.Text = strGuid;
|
UtilityHelper.SetValueByObj(panel1.Controls, dy, isEdit);
|
txt_docCode.EditValue = dy.docCode.ToString();
|
string _rule = dy.docFormat.ToString();
|
var _ary = _rule.Split(new[] { '<' },
|
StringSplitOptions.RemoveEmptyEntries);
|
if (_ary.Length > 0)
|
txxtItem1.Text = "<" + _ary[0];
|
if (_ary.Length > 1)
|
txxtItem2.Text = "<" + _ary[1];
|
if (_ary.Length > 2)
|
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
|
{
|
MsgHelper.Warning("提示:" + _rtn.rtnMsg);
|
}
|
}
|
catch (Exception ex)
|
{
|
MsgHelper.Warning("提示:" + ex.Message);
|
}
|
}
|
|
private void getTree()
|
{
|
var dataTable = new DataTable();
|
dataTable.Columns.Add("docCode", typeof(string));
|
dataTable.Rows.Add("CGDH(采购到货)");
|
dataTable.Rows.Add("CGJY(采购检验)");
|
dataTable.Rows.Add("RKJY(入库检验)");
|
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("SCTKSQ(生产退库申请)");
|
dataTable.Rows.Add("SCTK(生产退库)");
|
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(托板码)");
|
dataTable.Rows.Add("JYSQ(检验申请)");
|
dataTable.Rows.Add("JYFA(检验方案)");
|
txt_docCode.Properties.DataSource = dataTable;
|
txt_docCode.Properties.DisplayMember = "docCode"; // 显示的列
|
txt_docCode.Properties.ValueMember = "docCode"; // 实际值的列
|
txt_docCode.Properties.TextEditStyle = TextEditStyles.DisableTextEditor;
|
}
|
|
private void DoPreviewCode()
|
{
|
if (txt_docCode.Enabled == false
|
|| txxtItem1.Enabled == false
|
|| txxtItem2.Enabled == false
|
|| txxtItem3.Enabled == false
|
|| txxtItem4.Enabled == false
|
|| txxtItem5.Enabled == false)
|
return;
|
var text = txxtItem1.Text + txxtItem2.Text + txxtItem3.Text + txxtItem4.Text + txxtItem5.Text; ;
|
txt_docFormat.Text = 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)
|
{
|
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;
|
}
|
if (!MsgHelper.AskQuestion("你选择了【" + rowName + "】,确定" + strMsg + "吗?"))
|
return;
|
|
var _obj = new
|
{
|
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);
|
}
|
}
|
|
}
|
}
|