using System;
|
using System.Collections.Generic;
|
using System.Data;
|
using System.Drawing;
|
using System.Text;
|
using System.Windows.Forms;
|
using DevExpress.XtraEditors;
|
using DevExpress.XtraEditors.Controls;
|
using DevExpress.XtraGrid.Views.Grid;
|
using Gs.DevApp.Entity;
|
using Gs.DevApp.ToolBox;
|
using Gs.DevApp.UserControl;
|
using MES.Service.Modes;
|
using Newtonsoft.Json;
|
using Newtonsoft.Json.Linq;
|
|
namespace Gs.DevApp.DevFrm
|
{
|
public partial class Frm_MesInvItemArn : XtraForm
|
{
|
private List<FilterEntity> _filterList = new List<FilterEntity>();
|
private readonly string _webServiceName = "MesInvItemArnManager/";
|
public Frm_MesInvItemArn()
|
{
|
InitializeComponent();
|
pageBar1.PagerEvent += PageBar1_PagerEvent;
|
this.gridView1.ColumnPanelRowHeight = 60;
|
this.gridView1.OptionsView.AllowHtmlDrawHeaders = true;
|
this.gridView1.Appearance.HeaderPanel.TextOptions.WordWrap = DevExpress.Utils.WordWrap.Wrap;
|
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.btnQueryClick += ToolBarMenu1_btnQueryClick;
|
toolBarMenu1.btnJianYanClick += ToolBarMenu1_btnJianYanClick;
|
toolBarMenu1.btnFjianYanClick += ToolBarMenu1_btnFjianYanClick;
|
toolBarMenu1.btnLogClick += ToolBarMenu1_btnLogClick;
|
gcMain.MouseDoubleClick += GcMain_MouseDoubleClick;
|
getPageList(1, UtilityHelper.GetPageSize());
|
gridView1.CustomDrawRowIndicator += (s, e) =>
|
{
|
if (e.Info.IsRowIndicator && e.RowHandle >= 0)
|
e.Info.DisplayText = (e.RowHandle + 1).ToString();
|
};
|
gridView1.CustomDrawEmptyForeground += (s, e) =>
|
{
|
var str = "暂未查找到匹配的数据!";
|
var f = new Font("微软雅黑", 16);
|
var r = new Rectangle(gridView1.GridControl.Width / 2 - 100,
|
e.Bounds.Top + 45, e.Bounds.Right - 5, e.Bounds.Height - 5);
|
e.Graphics.DrawString(str, f, Brushes.Gray, r);
|
};
|
//设置仓库选择
|
this.txt_depotsId.KeyFile = "depotId";
|
this.txt_depotsId.EditChanged += (s, e) =>
|
{
|
txtDepotsId.Text = this.txt_depotsId.GetId();
|
};
|
//设置供应商选择
|
this.txt_suppId.KeyFile = "id";
|
this.txt_suppId.EditChanged += (s, e) =>
|
{
|
txtSupplierId.Text = this.txt_suppId.GetId();
|
};
|
//选择需要入库的明细
|
btnSelect.Click += (s, e) =>
|
{
|
if (string.IsNullOrEmpty(this.txt_suppId.GetId()))
|
{
|
Gs.DevApp.ToolBox.MsgHelper.ShowError("请先选择供应商,才能选择来料明细!");
|
return;
|
}
|
var frm = new SelectCgMx(this.txt_suppId.GetId());
|
//赋值给明细表
|
frm.UpdateParent += (ss, ee) =>
|
{
|
try
|
{
|
var lst = new List<string>();
|
lst = ee.StringList;
|
var _obj = lst;
|
var strReturn = UtilityHelper.HttpPost("",
|
"MesInvItemArnDetailManager/GetListPageByCgmxGuid",
|
JsonConvert.SerializeObject(_obj));
|
var dt = UtilityHelper.ReturnToList(strReturn);
|
DataTable _newTable = dt.rtnData;
|
DataTable _oldTable = (DataTable)gcMx1.DataSource;
|
DataRow[] sourceRows = _newTable.Select();
|
for (int i = 0; i < sourceRows.Length; i++)
|
{
|
_oldTable.ImportRow(sourceRows[i]);
|
}
|
gcMx1.BindingContext = new BindingContext();
|
gcMx1.DataSource = _oldTable;
|
gcMx1.ForceInitialize();
|
}
|
catch (Exception ex)
|
{
|
|
MessageBox.Show(ex.Message);
|
}
|
|
};
|
frm.ShowDialog();
|
};
|
//验退
|
btnTui.Click += async (s, e) =>
|
{
|
if (string.IsNullOrEmpty(lbGuid.Text.Trim()))
|
{
|
Gs.DevApp.ToolBox.MsgHelper.ShowError("暂未保存,不能退货!");
|
return;
|
}
|
var lst = new List<string>();
|
for (var i = 0; i < gvMx1.DataRowCount; i++)
|
{
|
var row = gvMx1.GetDataRow(i);
|
if (row != null && row["gvChk"].ToString().ToUpper() == "true".ToUpper())
|
lst.Add(row["guid"].ToString());
|
}
|
if (lst.Count <= 0)
|
{
|
Gs.DevApp.ToolBox.MsgHelper.ShowError("请选择你需要退的物料!");
|
return;
|
}
|
UcLoading _loading = new UcLoading();
|
var _obj = lst;
|
try
|
{
|
var strJson = await UtilityHelper.HttpPostAsync("",
|
_webServiceName + "TuiMx",
|
JsonConvert.SerializeObject(_obj));
|
var _rtn = UtilityHelper.ReturnToDynamic(strJson);
|
if (_rtn.rtnCode > 0)
|
{
|
|
}
|
MsgHelper.ShowError("提示:" + _rtn.rtnMsg);
|
}
|
catch (Exception ex)
|
{
|
MsgHelper.Warning("提示:" + ex.Message);
|
}
|
_loading.Stop();
|
};
|
}
|
/// <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);
|
}
|
|
/// <summary>
|
/// 分页事件
|
/// </summary>
|
/// <param name="curPage"></param>
|
/// <param name="pageSize"></param>
|
private void PageBar1_PagerEvent(int curPage, int pageSize)
|
{
|
getPageList(curPage, pageSize);
|
}
|
|
/// <summary>
|
/// 查询事件
|
/// </summary>
|
/// <param name="sender"></param>
|
/// <param name="e"></param>
|
private void ToolBarMenu1_btnQueryClick(object sender, EventArgs e)
|
{
|
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, pageBar1.RowsCount);
|
}
|
/// <summary>
|
/// 日志
|
/// </summary>
|
/// <param name="sender"></param>
|
/// <param name="e"></param>
|
private void ToolBarMenu1_btnLogClick(object sender, EventArgs e)
|
{
|
toolBarMenu1.guidKey = "";
|
string rowGuid, rowName;
|
(rowGuid, rowName) = UtilityHelper.GetCurrentRow(xtraTabControl1,
|
lbGuid, txt_billNo, gridView1);
|
toolBarMenu1.guidKey = rowGuid;
|
}
|
|
/// <summary>
|
/// 反检验
|
/// </summary>
|
/// <param name="sender"></param>
|
/// <param name="e"></param>
|
private async void ToolBarMenu1_btnFjianYanClick(object sender, EventArgs e)
|
{
|
toolBarMenu1.guidKey = "";
|
string rowGuid, rowName;
|
(rowGuid, rowName) = UtilityHelper.GetCurrentRow(xtraTabControl1,
|
lbGuid, txt_billNo, gridView1);
|
toolBarMenu1.guidKey = rowGuid;
|
if (string.IsNullOrEmpty(rowGuid))
|
{
|
MsgHelper.Warning("请先选择你要操作的行!");
|
return;
|
}
|
if (!MsgHelper.AskQuestion("你选择了【" + rowName + "】,确定撤回已提交的检验吗?"))
|
return;
|
UcLoading _loading = new UcLoading();
|
var _obj = new
|
{
|
guid = rowGuid,
|
};
|
try
|
{
|
var strJson = await UtilityHelper.HttpPostAsync("",
|
_webServiceName + "EditModelSubmitF",
|
JsonConvert.SerializeObject(_obj));
|
var _rtn = UtilityHelper.ReturnToDynamic(strJson);
|
MsgHelper.Warning("提示:" + _rtn.rtnData.outMsg);
|
if (_rtn.rtnCode > 0)
|
{
|
if (xtraTabControl1.SelectedTabPageIndex == 1)
|
getModel(lbGuid.Text.Trim(), false, 999);
|
else
|
getPageList(1, UtilityHelper.GetPageSize());
|
}
|
}
|
catch (Exception ex)
|
{
|
MsgHelper.Warning("提示:" + ex.Message);
|
}
|
_loading.Stop();
|
}
|
|
/// <summary>
|
/// 检验
|
/// </summary>
|
/// <param name="sender"></param>
|
/// <param name="e"></param>
|
private async void ToolBarMenu1_btnJianYanClick(object sender, EventArgs e)
|
{
|
toolBarMenu1.guidKey = "";
|
string rowGuid, rowName;
|
(rowGuid, rowName) = UtilityHelper.GetCurrentRow(xtraTabControl1,
|
lbGuid, txt_billNo, gridView1);
|
toolBarMenu1.guidKey = rowGuid;
|
if (string.IsNullOrEmpty(rowGuid))
|
{
|
MsgHelper.Warning("请先选择你要操作的行!");
|
return;
|
}
|
if (!MsgHelper.AskQuestion("你选择了【" + rowName + "】,确定提交检验吗?"))
|
return;
|
UcLoading _loading = new UcLoading();
|
var _obj = new
|
{
|
guid = rowGuid,
|
};
|
try
|
{
|
var strJson = await UtilityHelper.HttpPostAsync("",
|
_webServiceName + "EditModelSubmit",
|
JsonConvert.SerializeObject(_obj));
|
var _rtn = UtilityHelper.ReturnToDynamic(strJson);
|
MsgHelper.Warning("提示:" + _rtn.rtnData.outMsg);
|
if (_rtn.rtnCode > 0)
|
{
|
if (xtraTabControl1.SelectedTabPageIndex == 1)
|
getModel(lbGuid.Text.Trim(), false, 999);
|
else
|
getPageList(1, UtilityHelper.GetPageSize());
|
}
|
}
|
catch (Exception ex)
|
{
|
MsgHelper.Warning("提示:" + ex.Message);
|
}
|
_loading.Stop();
|
}
|
/// <summary>
|
/// 取消事件
|
/// </summary>
|
/// <param name="sender"></param>
|
/// <param name="e"></param>
|
private void ToolBarMenu1_btnEscClick(object sender, EventArgs e)
|
{
|
UtilityHelper.JumpToTab(xtraTabControl1, 0);
|
}
|
|
/// <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_billNo, gridView1);
|
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)
|
{
|
UtilityHelper.JumpToTab(xtraTabControl1, 0);
|
getPageList(1, UtilityHelper.GetPageSize());
|
}
|
|
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(), false, 999);
|
else
|
getPageList(1, UtilityHelper.GetPageSize());
|
}
|
|
/// <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_billNo, gridView1);
|
if (string.IsNullOrEmpty(rowGuid))
|
{
|
MsgHelper.Warning("请先选择你要操作的行!");
|
return;
|
}
|
|
getModel(rowGuid, true, 1);
|
}
|
|
/// <summary>
|
/// 新增事件
|
/// </summary>
|
/// <param name="sender"></param>
|
/// <param name="e"></param>
|
private void ToolBarMenu1_btnAddClick(object sender, EventArgs e)
|
{
|
UtilityHelper.JumpToTab(xtraTabControl1, 1);
|
lbGuid.Text = "";
|
var gridViews = new List<GridView>();
|
gridViews.Add(gvMx1);
|
UtilityHelper.CleanValueByControl(panel1.Controls, true, gridViews);
|
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;
|
var _ckId = txt_depotsId.GetId(); //仓库编号 depots_code
|
var _gysId = txt_suppId.GetId(); //供应商编号
|
if (string.IsNullOrEmpty(_gysId))
|
{
|
MsgHelper.Warning("请选择供应商!");
|
txt_suppId.Focus();
|
return;
|
}
|
|
if (string.IsNullOrEmpty(_ckId))
|
{
|
MsgHelper.Warning("请选择仓库!");
|
txt_depotsId.Focus();
|
return;
|
}
|
var _obj = new MesInvItemArn()
|
{
|
Guid = Gs.DevApp.ToolBox.UtilityHelper.ToGuid(lbGuid.Text.Trim()), //到货单主键
|
PaperBillNo = txt_paperBillNo.Text.Trim(), //送货单号;
|
Remark = txt_remark.Text.Trim(), //备注
|
SuppId = _gysId, //供应商
|
DepotsId = _ckId,//仓库
|
FType = txt_fType.Checked,//0=采购,1=委外
|
UrgentFlag = txt_urgentFlag.Checked,//0=不急,1=急
|
list = new List<MesInvItemArnDetail>(),
|
};
|
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 MesInvItemArnDetail
|
{
|
Guid = _guid,
|
AboutGuid = Guid.Parse(row["aboutGuid"].ToString()),
|
ItemId = int.Parse(row["itemId"].ToString()),
|
Quantity = decimal.Parse(row["quantity"].ToString())
|
});
|
}
|
}
|
|
try
|
{
|
var strJson = UtilityHelper.HttpPost("",
|
_webServiceName + "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);
|
}
|
}
|
catch (Exception ex)
|
{
|
MsgHelper.Warning("提示:" + ex.Message);
|
}
|
}
|
|
/// <summary>
|
/// </summary>
|
/// <param name="curPage">第几页</param>
|
/// <param name="pageSize">每页几条</param>
|
private async void getPageList(int curPage, int pageSize)
|
{
|
UcLoading _loading = new UcLoading();
|
var _sbSqlWhere = new StringBuilder();
|
foreach (var itm in _filterList)
|
_sbSqlWhere.Append(" and " + itm.fileId + itm.fileOper + "'" +
|
itm.fileValue + "'");
|
var pgq = new PageQueryModel(curPage, pageSize, "create_date",
|
"asc", "", _sbSqlWhere.ToString());
|
var json = JsonConvert.SerializeObject(pgq);
|
try
|
{
|
var strReturn = await UtilityHelper.HttpPostAsync("",
|
_webServiceName + "GetListPage", json);
|
var dd = UtilityHelper.ReturnToTablePage(strReturn);
|
var dt = dd.rtnData.list;
|
gcMain.BindingContext = new BindingContext();
|
gcMain.DataSource = dt;
|
gcMain.ForceInitialize();
|
var dddd = dd.rtnData.pages; //总页
|
pageBar1.TotalPages = dddd;
|
pageBar1.RecordCount = dd.rtnData.total; //记录总数
|
pageBar1.CurrentPage = curPage; //当前页
|
pageBar1.RowsCount = pageSize; //每页显示
|
pageBar1.setTxt();
|
}
|
catch (Exception ex)
|
{
|
MsgHelper.Warning("提示:" + ex.Message);
|
}
|
_loading.Stop();
|
}
|
|
private async void getModel(string strGuid, bool isEdit, int tabIdx)
|
{
|
if (string.IsNullOrEmpty(strGuid))
|
{
|
MsgHelper.Warning("请先选择你要操作的行!");
|
return;
|
}
|
|
UtilityHelper.JumpToTab(xtraTabControl1, tabIdx);
|
UcLoading _loading = new UcLoading();
|
var _obj = new
|
{
|
guid = strGuid //主建
|
};
|
try
|
{
|
var strJson = await UtilityHelper.HttpPostAsync("",
|
_webServiceName + "GetModel",
|
JsonConvert.SerializeObject(_obj));
|
var _rtn = UtilityHelper.ReturnToDynamic(strJson);
|
if (_rtn.rtnCode > 0)
|
{
|
var dy = _rtn.rtnData;
|
lbGuid.Text = strGuid;
|
var gvList = new List<GridView>();
|
gvList.Add(gvMx1);
|
UtilityHelper.SetValueByObj(panel1.Controls, dy, isEdit,
|
gvList);
|
var _job = JObject.Parse(strJson);
|
var array = new JArray();
|
foreach (var a in _job["rtnData"]["listDya"]) array.Add(a);
|
var dt =
|
JsonConvert.DeserializeObject<DataTable>(
|
array.ToString());
|
if (dt.Rows.Count > 0)
|
{
|
gcMx1.BindingContext = new BindingContext();
|
gcMx1.DataSource = dt;
|
gcMx1.ForceInitialize();
|
|
}
|
else
|
{
|
UtilityHelper.SetDefaultTable(gcMx1, gvMx1);
|
}
|
}
|
else
|
{
|
MsgHelper.Warning("提示:" + _rtn.rtnMsg);
|
}
|
}
|
catch (Exception ex)
|
{
|
MsgHelper.Warning("提示:" + ex.Message);
|
}
|
_loading.Stop();
|
}
|
|
/// <summary>
|
/// 明细删除
|
/// </summary>
|
/// <param name="sender"></param>
|
/// <param name="e"></param>
|
private void repositoryItemButtonEdit1_ButtonClick(object sender,
|
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, true, 1);
|
}
|
MsgHelper.Warning("提示:" + _rtn.rtnMsg);
|
}
|
catch (Exception ex)
|
{
|
MsgHelper.Warning("提示:" + ex.Message);
|
}
|
}
|
}
|
}
|
}
|