using DevExpress.XtraEditors;
|
using Gs.DevApp.Entity;
|
using Gs.DevApp.ToolBox;
|
using Gs.DevApp.UserControl;
|
using Newtonsoft.Json;
|
using Newtonsoft.Json.Linq;
|
using System;
|
using System.Collections.Generic;
|
using System.Data;
|
using System.Drawing;
|
using System.Threading.Tasks;
|
using System.Windows.Forms;
|
using System.Windows.Media.Animation;
|
|
namespace Gs.DevApp.DevFrm
|
{
|
public partial class Frm_MesItemQtrk : DevExpress.XtraEditors.XtraForm
|
{
|
string _webServiceName = "MesItemQtrkManager/";
|
List<FilterEntity> _filterList = new List<FilterEntity>();
|
public Frm_MesItemQtrk()
|
{
|
InitializeComponent();
|
this.toolBarMenu1.btnAddClick += ToolBarMenu1_btnAddClick;
|
this.toolBarMenu1.btnEdtClick += ToolBarMenu1_btnEdtClick;
|
this.toolBarMenu1.btnSaveClick += ToolBarMenu1_btnSaveClick;
|
this.toolBarMenu1.btnLoadClick += ToolBarMenu1_btnLoadClick;
|
this.toolBarMenu1.btnDelClick += ToolBarMenu1_btnDelClick1;
|
this.toolBarMenu1.btnEscClick += ToolBarMenu1_btnEscClick;
|
this.toolBarMenu1.btnQueryClick += ToolBarMenu1_btnQueryClick;
|
toolBarMenu1.btnChkClick += ToolBarMenu1_btnChkClick;
|
toolBarMenu1.btnFChkClick += ToolBarMenu1_btnFChkClick;
|
toolBarMenu1.btnReportClick += ToolBarMenu1_btnReportClick;
|
toolBarMenu1.btnDesignClick += ToolBarMenu1_btnDesignClick;
|
Gs.DevApp.ToolBox.UtilityHelper.SetGridViewParameter(gridView1, picCheckBox, this, "qt015", "", (value) =>
|
{
|
Gs.DevApp.ToolBox.UtilityHelper.JumpTab(xtraTabControl1, 0);
|
});
|
Gs.DevApp.ToolBox.UtilityHelper.SetTabParameter(gridView1, xtraTabControl1, pageBar1, (value) =>
|
{
|
getModel(value);
|
}, (value) =>
|
{
|
getPageList(this.pageBar1.CurrentPage);
|
});
|
getPageList(1);
|
pageBar1.PagerEvent += PageBar1_PagerEvent;
|
txt_qt011.getSuppler("");
|
txt_qt018.getSuppler("");
|
//设置仓库选择
|
this.txt_qt011.EditChanged += (s, e) =>
|
{
|
|
};
|
//设置供应商选择
|
this.txt_qt018.EditChanged += (s, e) =>
|
{
|
|
};
|
var _obj = new
|
{
|
currentPage = 1,
|
everyPageSize = 999999,
|
sortName = "",
|
keyWhere = "",
|
};
|
var json = JsonConvert.SerializeObject(_obj);
|
try
|
{
|
var strReturn = UtilityHelper.HttpPost("",
|
"MesItemsManager/GetListSelect", json);
|
var rtn = UtilityHelper.ReturnToTablePage(strReturn);
|
var dt = rtn.rtnData.list;
|
this.repositoryItemSearchLookUpEdit1.DataSource = dt;
|
}
|
catch (Exception ex)
|
{
|
MsgHelper.Warning("提示:" + ex.Message);
|
}
|
gcMx1.MouseClick += GcMx1_MouseClick;
|
}
|
private void GridView1_ColumnFilterChanged(object sender, EventArgs e)
|
{
|
_filterList = Gs.DevApp.ToolBox.UtilityHelper.GetDilter(gridView1.Columns);
|
Task.Delay(100);
|
getPageList(1);
|
}
|
|
/// <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>
|
private void ToolBarMenu1_btnQueryClick(object sender, EventArgs e)
|
{
|
gridView1.ColumnFilterChanged -= GridView1_ColumnFilterChanged;
|
gridView1.ActiveFilter.Clear();
|
gridView1.ColumnFilterChanged += GridView1_ColumnFilterChanged;
|
var frm = new ShowFilter(gridView1.Columns, _filterList);
|
frm.UpdateParent += Frm_UpdateParent;
|
frm.ShowDialog();
|
}
|
/// <summary>
|
/// 查询回调
|
/// </summary>
|
/// <param name="sender"></param>
|
/// <param name="e"></param>
|
private void Frm_UpdateParent(object sender, UpdateParentEventArgs e)
|
{
|
_filterList = e.FilterList;
|
getPageList(1);
|
}
|
private void ToolBarMenu1_btnDesignClick(object sender, EventArgs e)
|
{
|
toolBarMenu1.guidKey = "";
|
string rowGuid, rowName;
|
(rowGuid, rowName) = UtilityHelper.GetCurrentRow(xtraTabControl1,
|
lbGuid, txt_qtck, gridView1);
|
toolBarMenu1.guidKey = rowGuid;
|
toolBarMenu1.rptParameter = "rpt_Qtrk{}";
|
}
|
private void ToolBarMenu1_btnReportClick(object sender, EventArgs e)
|
{
|
toolBarMenu1.guidKey = "";
|
string rowGuid, rowName;
|
(rowGuid, rowName) = UtilityHelper.GetCurrentRow(xtraTabControl1,
|
lbGuid, txt_qtck, gridView1);
|
toolBarMenu1.guidKey = rowGuid;
|
if (xtraTabControl1.SelectedTabPageIndex == 0)
|
{
|
getModel(rowGuid);
|
this.toolBarMenu1.rptParameter = "return false";
|
return;
|
}
|
if (string.IsNullOrEmpty(txt_iCount_1.Text.Trim()))
|
{
|
Gs.DevApp.ToolBox.MsgHelper.ShowError("请选择打印条码张数!");
|
txt_iCount_1.Focus();
|
this.toolBarMenu1.rptParameter = "return false";
|
return;
|
}
|
if (string.IsNullOrEmpty(txt_psnQty_1.Text.Trim()))
|
{
|
Gs.DevApp.ToolBox.MsgHelper.ShowError("请选择打印条码数量!");
|
txt_psnQty_1.Focus();
|
this.toolBarMenu1.rptParameter = "return false";
|
return;
|
}
|
this.toolBarMenu1.rptParameter = "rpt_Qtrk{" + lbMxGuid.Text.Trim()
|
+ "," + ""
|
+ "," + ""
|
+ "," + txt_iCount_1.Text.Trim()
|
+ "," + txt_psnQty_1.Text.Trim()
|
+ "}";
|
|
|
//this.toolBarMenu1.rptParameter = "rpt_Arrival{" + ""
|
// + "," + ""
|
// + "," + ""
|
// + "," + txt_iCount_1.Text.Trim()
|
// + "," + txt_psnQty_1.Text.Trim()
|
// + "}";
|
|
|
}
|
|
/// <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_qtck, gridView1, "qtck");
|
if (string.IsNullOrEmpty(rowGuid))
|
{
|
MsgHelper.Warning("请先选择你要操作的行!");
|
return;
|
}
|
if (!MsgHelper.AskQuestion("你选择了【" + rowName + "】,确定删除吗?"))
|
return;
|
var _obj = new
|
{
|
guid = rowGuid,
|
mxGuid = Guid.Empty.ToString(),
|
};
|
try
|
{
|
var strJson = UtilityHelper.HttpPost("",
|
_webServiceName + "DeleteModelOrMx",
|
JsonConvert.SerializeObject(_obj));
|
var _rtn = UtilityHelper.ReturnToDynamic(strJson);
|
if (_rtn.rtnCode > 0)
|
{
|
if (xtraTabControl1.SelectedTabPageIndex == 0)
|
getPageList(this.pageBar1.CurrentPage);
|
else
|
Gs.DevApp.ToolBox.UtilityHelper.JumpTab(xtraTabControl1, 2);
|
}
|
|
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);
|
}
|
}
|
/// <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_qtck, gridView1);
|
if (string.IsNullOrEmpty(rowGuid))
|
{
|
MsgHelper.Warning("请先选择你要操作的行!");
|
return;
|
}
|
Gs.DevApp.ToolBox.UtilityHelper.JumpTab(xtraTabControl1, 3);
|
UtilityHelper.ChangeEnableByControl(panel1.Controls, 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);
|
List<DevExpress.XtraGrid.Views.Grid.GridView> gridViews = new List<DevExpress.XtraGrid.Views.Grid.GridView>();
|
gridViews.Add(gvMx1);
|
UtilityHelper.CleanValueByControl(this.panel1.Controls, true, gridViews);
|
Gs.DevApp.ToolBox.UtilityHelper.SetDefaultTable(gcMx1, gvMx1);
|
}
|
/// <summary>
|
/// 保存事件
|
/// </summary>
|
/// <param name="sender"></param>
|
/// <param name="e"></param>
|
private void ToolBarMenu1_btnSaveClick(object sender, EventArgs e)
|
{
|
toolBarMenu1.isSetBtn = false;
|
string inGys = txt_qt018.GetId();
|
string inCjId = txt_qt011.GetId();
|
if (string.IsNullOrEmpty(inGys))
|
{
|
Gs.DevApp.ToolBox.MsgHelper.Warning("请选择供应商!");
|
txt_qt018.Focus();
|
return;
|
}
|
if (string.IsNullOrEmpty(inCjId))
|
{
|
Gs.DevApp.ToolBox.MsgHelper.Warning("请选择仓库!");
|
txt_qt011.Focus();
|
return;
|
}
|
var _obj = new
|
{
|
guid = UtilityHelper.ToGuid(lbGuid.Text.Trim()), //主建
|
inRklb = txt_qt003.Text.Trim(),//备注
|
inYwlx = txt_qt004.Text.Trim(),//业务类型
|
inRkfs = txt_qt019.Text.Trim(),//入库方式
|
inRklx = txt_qt020.Text.Trim(),//入库类型
|
inGys = inGys,//供应商
|
inCjId = inCjId,//入库仓库
|
inDepart = txt_qt009.GetId(),//申请部门
|
inXsdh = txt_qt021.Text.Trim(),//销售单号
|
inRkyy = txt_qt010.Text.Trim(),//入库原因
|
list = new List<dynamic>(),
|
};
|
gvMx1.CloseEditor();
|
gvMx1.UpdateCurrentRow();
|
if (gvMx1.DataRowCount <= 0)
|
{
|
MsgHelper.ShowError("明细不能为空,请选择你的收料明细!");
|
return;
|
}
|
for (var i = 0; i < gvMx1.DataRowCount; i++)
|
{
|
var row = gvMx1.GetDataRow(i);
|
if (row != null)
|
{
|
Guid? _guid = UtilityHelper.ToGuid(row["guid"].ToString());
|
//string _msl = row["quantity"].ToString();
|
//if (string.IsNullOrEmpty(_msl))
|
//{
|
// MsgHelper.ShowError("数量不能为空!");
|
// return;
|
//}
|
_obj.list.Add(new
|
{
|
Guid = _guid,
|
ItemId = (row["itemId"].ToString()),
|
Sqsl = (row["qd007"].ToString()),
|
Bz = (row["qd010"].ToString()),
|
});
|
}
|
}
|
try
|
{
|
string strJson = UtilityHelper.HttpPost("", _webServiceName + "EditModel", JsonConvert.SerializeObject(_obj));
|
ReturnModel<dynamic> _rtn = ToolBox.UtilityHelper.ReturnToDynamic(strJson);
|
ToolBox.MsgHelper.Warning("提示:" + _rtn.rtnMsg);
|
if (_rtn.rtnCode > 0)
|
{
|
lbGuid.Text = _rtn.rtnData;
|
toolBarMenu1.isSetBtn = true;
|
UtilityHelper.ChangeEnableByControl(this.panel1.Controls, false);
|
}
|
}
|
catch (Exception ex)
|
{
|
ToolBox.MsgHelper.Warning("提示:" + ex.Message);
|
}
|
}
|
|
/// <summary>
|
///
|
/// </summary>
|
/// <param name="curPage">第几页</param>
|
/// <param name="pageSize">每页几条</param>
|
private void getPageList(int curPage)
|
{
|
|
var _sbSqlWhere = UtilityHelper.GetSearchWhere(_filterList);
|
PageQueryModel pgq = new PageQueryModel(curPage, this.pageBar1.RowsCount, "qt001", "asc", "", _sbSqlWhere.ToString());
|
string json = JsonConvert.SerializeObject(pgq);
|
try
|
{
|
var strReturn = UtilityHelper.HttpPost("", _webServiceName + "GetListPage", json);
|
ReturnModel<PageListModel> dd = UtilityHelper.ReturnToTablePage(strReturn);
|
if (dd.rtnCode > 0)
|
{
|
DataTable dt = dd.rtnData.list;
|
gcMain.BindingContext = new BindingContext();
|
gridView1.ColumnFilterChanged -= GridView1_ColumnFilterChanged;
|
if (dt.Rows.Count > 0)
|
{
|
gcMain.DataSource = dt;
|
gcMain.ForceInitialize();
|
}
|
else
|
UtilityHelper.SetDefaultTable(gcMain, gridView1);
|
gridView1.ColumnFilterChanged += GridView1_ColumnFilterChanged;
|
pageBar1.TotalPages = dd.rtnData.pages;//总页
|
pageBar1.CurrentPage = curPage;//当前页
|
pageBar1.RecordCount = dd.rtnData.total;//总记录数
|
}
|
else
|
{
|
ToolBox.MsgHelper.ShowError("提示:" + dd.rtnMsg);
|
}
|
}
|
catch (Exception ex)
|
{
|
ToolBox.MsgHelper.ShowError("提示:" + 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
|
{
|
string strJson = UtilityHelper.HttpPost("", _webServiceName + "GetModel", JsonConvert.SerializeObject(_obj));
|
ReturnModel<dynamic> _rtn = ToolBox.UtilityHelper.ReturnToDynamic(strJson);
|
if (_rtn.rtnCode > 0)
|
{
|
dynamic dy = _rtn.rtnData;
|
lbGuid.Text = strGuid;
|
List<DevExpress.XtraGrid.Views.Grid.GridView> gvList = new List<DevExpress.XtraGrid.Views.Grid.GridView>();
|
gvList.Add(gvMx1);
|
UtilityHelper.SetValueByObj(this.panel1.Controls, dy, isEdit, gvList);
|
JObject _job = JObject.Parse(strJson);
|
JArray array = new JArray();
|
foreach (var a in _job["rtnData"]["list"])
|
{
|
array.Add(a);
|
}
|
DataTable dt = JsonConvert.DeserializeObject<DataTable>(array.ToString());
|
if (dt.Rows.Count > 0)
|
{
|
gcMx1.BindingContext = new BindingContext();
|
gcMx1.DataSource = dt;
|
gcMx1.ForceInitialize();
|
}
|
else
|
{
|
Gs.DevApp.ToolBox.UtilityHelper.SetDefaultTable(gcMx1, gvMx1);
|
}
|
}
|
else
|
ToolBox.MsgHelper.Warning("提示:" + _rtn.rtnMsg);
|
}
|
catch (Exception ex)
|
{
|
ToolBox.MsgHelper.Warning("提示:" + ex.Message);
|
}
|
}
|
|
private void repositoryItemSearchLookUpEdit1_EditValueChanged(object sender, EventArgs e)
|
{
|
|
SearchLookUpEdit LookupEdit = sender as SearchLookUpEdit;
|
DataRowView SelectedDataRow = (DataRowView)LookupEdit.GetSelectedDataRow();
|
gvMx1.SetFocusedRowCellValue("qd002", SelectedDataRow["itemNo"]);
|
gvMx1.SetFocusedRowCellValue("qd003", SelectedDataRow["itemName"]);
|
gvMx1.SetFocusedRowCellValue("qd004", SelectedDataRow["itemModel"]);
|
}
|
|
private void repositoryItemButtonEdit1_ButtonClick(object sender, DevExpress.XtraEditors.Controls.ButtonPressedEventArgs e)
|
{
|
var rowhandle = gvMx1.FocusedRowHandle;
|
if (rowhandle < 0)
|
return;
|
if (e.Button.Index == 0)
|
{
|
var dr = gvMx1.GetDataRow(rowhandle);
|
var mxGuid = dr["guid"].ToString();
|
if (!MsgHelper.AskQuestion("你选择了1条数据,确定删除吗?"))
|
return;
|
if (string.IsNullOrEmpty(mxGuid))
|
{
|
gvMx1.DeleteRow(rowhandle);
|
return;
|
}
|
var _obj = new
|
{
|
guid = lbGuid.Text.Trim(),
|
mxGuid = mxGuid,
|
};
|
try
|
{
|
var strJson = UtilityHelper.HttpPost("",
|
_webServiceName + "DeleteModelOrMx",
|
JsonConvert.SerializeObject(_obj));
|
var _rtn = UtilityHelper.ReturnToDynamic(strJson);
|
if (_rtn.rtnCode > 0)
|
{
|
if (_rtn.rtnCode > 0) getModel(lbGuid.Text);
|
}
|
MsgHelper.Warning("提示:" + _rtn.rtnMsg);
|
}
|
catch (Exception ex)
|
{
|
MsgHelper.Warning("提示:" + ex.Message);
|
}
|
}
|
}
|
|
/// <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>
|
/// <exception cref="NotImplementedException"></exception>
|
private void ToolBarMenu1_btnFChkClick(object sender, EventArgs e)
|
{
|
_toolCk(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_qtck, gridView1, "qtck");
|
if (string.IsNullOrEmpty(rowGuid))
|
{
|
MsgHelper.Warning("请先选择你要操作的行!");
|
return;
|
}
|
if (!MsgHelper.AskQuestion("你选择了【" + rowName + "】,确定" + strMsg + "吗?"))
|
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.ToString());
|
if (_rtn.rtnCode > 0)
|
{
|
if (xtraTabControl1.SelectedTabPageIndex == 1)
|
getModel(lbGuid.Text.Trim());
|
else
|
getPageList(1);
|
}
|
}
|
catch (Exception ex)
|
{
|
MsgHelper.Warning("提示:" + ex.Message);
|
}
|
|
}
|
|
private void GcMx1_MouseClick(object sender, MouseEventArgs e)
|
{
|
string rowGuid = Gs.DevApp.ToolBox.UtilityHelper.GetCurrentDoubleRow(gvMx1, e, "guid");
|
if (string.IsNullOrEmpty(rowGuid))
|
return;
|
lbMxGuid.Text = rowGuid;
|
toolBarMenu1.guidKey = rowGuid;
|
var info = gvMx1.CalcHitInfo(e.Location);
|
var view = info.View;
|
var row = view.GetDataRow(info.RowHandle);
|
txtWlid.Text = row["itemId"].ToString();
|
txtWlgg.Text = row["qd004"].ToString();
|
txtWlmc.Text = row["qd003"].ToString();
|
txtQuantity.Text = row["qd007"].ToString();//申请总量
|
txtYdy.Text = row["YDYNUM"].ToString();//已打印总量
|
kyPrtQty.Text = row["KDYNUM"].ToString();//可打印总量
|
}
|
}
|
}
|