using ComponentFactory.Krypton.Toolkit; using NXWMS.Client.Code.Extends; using NXWMS.Client.Model.AppModels.Condition; using NXWMS.Client.Model.AppModels.Condition.Base; using NXWMS.Client.Model.AppModels.Condition.Common; using NXWMS.Client.Model.AppModels.Condition.Instock; using NXWMS.Client.Model.AppModels.Result; using NXWMS.Client.Model.AppModels.Result.Base; using NXWMS.Client.Model.AppModels.Result.Common; using NXWMS.Client.Model.AppModels.Result.Instock; using NXWMS.Client.Model.CoreModels; using NXWMS.Commons; using NXWMS.Forms.Instock.frmInstockChild; using NXWMS.Services; using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; using System.Text; using System.Text.RegularExpressions; using System.Web.UI.WebControls; using System.Windows.Forms; namespace NXWMS.Forms.Instock { /// /// 退料单窗体 /// public partial class frmWmsInRetreat : KryptonForm { /// /// 窗体构造函数 /// public frmWmsInRetreat() { InitializeComponent(); // 获取窗体的全类名 _CrrentClassName = System.Reflection.MethodBase.GetCurrentMethod().DeclaringType.FullName; } #region 全局变量 /// /// 客户端字段排序列表(退料单主表) /// private List _clientFieldOrderList; /// /// 客户端字段排序列表(退料单单明细表) /// private List _clientFieldOrderDtlList; /// /// 当前窗体类名 /// private string _CrrentClassName; /// /// 退料单主键ID,用于记录主表选中行的主键信息。 /// 目前由于 加载控件不能传递具有参数的函数,所以临时使用全局变量。 /// ToDo:后续修改优化加载控件的实现方式,支持传递具有参数的函数。 /// 孙亚龙 舍弃于2020年9月7日 /// //string RetreatId = string.Empty; /// /// 用于控制明细表数据的加载时机。 /// 由于主表DataGridView数据加载时,会默认触发选中项更改事件。这时候加载明细表数据会发生异常。 /// 使用全局变量,控制明细表的数据的加载时机,只能在主表数据全部初始化完成后,并且选中了一行主表数据的时候。 /// bool isControlRetreatDtlShow = false; /// /// 定义委托 /// 用于执行刷新页面数据的函数 /// public delegate void dlgRefreshFrmHost(); /// /// 定义委托变量 /// 用于绑定刷新页面数据的函数 /// public static dlgRefreshFrmHost RefreshFrmHost; #endregion #region 初始化数据 /// /// 窗体加载事件 /// /// /// private void frmWmsInRetreat_Load(object sender, EventArgs e) { #region 获取主、明细表的显示列信息 //获取退料单主表数据源配置 var result = ConfigServices.configService.GetDataViewOrderList(new ClientFieldOrderCondition { SourceCode = $"{_CrrentClassName}" }); if (result.Status == OperateStatus.Success) { _clientFieldOrderList = result.Data; } //获取退料单明细表表数据源配置 var resultDtl = ConfigServices.configService.GetDataViewOrderList(new ClientFieldOrderCondition { SourceCode = $"{_CrrentClassName}_Dtl" }); if (resultDtl.Status == OperateStatus.Success) { _clientFieldOrderDtlList = resultDtl.Data; } #endregion InitComboBoxItemData(); kdtp_startCreateTime.Value = DateTime.Parse(DateTime.Now.ToString("yyyy-MM-dd 00:00:00")); kdtp_endCreateTime.Value = DateTime.Parse(DateTime.Now.ToString("yyyy-MM-dd 23:59:59")); kdtp_startCreateTime.Checked = false; kdtp_endCreateTime.Checked = false; kdtp_startProcudtTime.Value = DateTime.Parse(DateTime.Now.ToString("yyyy-MM-dd 00:00:00")); kdtp_endProcudtTime.Value = DateTime.Parse(DateTime.Now.ToString("yyyy-MM-dd 23:59:59")); kdtp_startProcudtTime.Checked = false; kdtp_endProcudtTime.Checked = false; kdtp_startExpTime.Value = DateTime.Parse(DateTime.Now.ToString("yyyy-MM-dd 00:00:00")); kdtp_endExptTime.Value = DateTime.Parse(DateTime.Now.ToString("yyyy-MM-dd 23:59:59")); kdtp_startExpTime.Checked = false; kdtp_endExptTime.Checked = false; RefreshFrmHost = new dlgRefreshFrmHost(RefreshRetreatSearchData); } /// /// 初始化下拉列表数据 /// private void InitComboBoxItemData() { /* ToDo:后续把下拉列表转为 后台获取数据,目前是写死的。 */ List results = new List(); #region 单据类型 results = BasDictionaryUtil.basDictionaryResultLst.FindAll(x => x.DICTIONARY_CODE == "RetreatTypeDesc"); if (results.Count > 0) { kcmb_retreatType.Items.Clear(); kcmb_retreatType.Items.Add(new ListItem { Value = "", Text = "请选择", }); foreach (var item in results) { kcmb_retreatType.Items.Add(new ListItem { Value = item.DICTIONARY_ITEM_CODE, Text = item.DICTIONARY_ITEM_NAME, }); } kcmb_retreatType.SelectedIndex = 0; } else { KryptonMessageBox.Show("未找到退料单类型的字典项数据!"); } #endregion #region 单据状态 results = BasDictionaryUtil.basDictionaryResultLst.FindAll(x => x.DICTIONARY_CODE == "RetreatOrderStatusDesc"); if (results.Count > 0) { kcmb_retreatStatus.Items.Clear(); kcmb_retreatStatus.Items.Add(new ListItem { Value = "", Text = "请选择", }); foreach (var item in results) { kcmb_retreatStatus.Items.Add(new ListItem { Value = item.DICTIONARY_ITEM_CODE, Text = item.DICTIONARY_ITEM_NAME, }); } kcmb_retreatStatus.SelectedIndex = 0; } else { KryptonMessageBox.Show("未找到退料单状态的字典项数据!"); } #endregion #region 供应商信息 var result = BaseServices.supplierService.GetList(new SupplierSearchCondition { IsUsed = true, PageIndex = 1, PageSize = 10000 }); if (result.Status == OperateStatus.Success) { kcmb_supplierMsg.Items.Clear(); kcmb_supplierMsg.Items.Add(new ListItem { Value = "", Text = "请选择", }); foreach (SupplierResult item in result.Data.RowData.ToList()) { kcmb_supplierMsg.Items.Add(new ListItem { Value = item.SUPPLIER_CODE, Text = item.SUPPLIER_NAME, }); } kcmb_supplierMsg.SelectedIndex = 0; } else { kcmb_supplierMsg.Items.Clear(); KryptonMessageBox.Show(result.Message); } #endregion } #endregion #region 查询退料单数据 /// /// 查询退料单数据 /// /// /// private void kbtnSearch_Click(object sender, EventArgs e) { var loadfrm = new frmLoading(); loadfrm.Show(); var message = loadfrm.EventCalExec(LoadWmsInRetreatData); } /// /// 刷新退料单的查询数据 /// private void RefreshRetreatSearchData() { var loadfrm = new frmLoading(); loadfrm.Show(); var message = loadfrm.EventCalExec(LoadWmsInRetreatData); if (!string.IsNullOrWhiteSpace(message)) { KryptonMessageBox.Show($"查询失败!\r\n{message}", "提示信息", MessageBoxButtons.OK, MessageBoxIcon.Information); } } /// /// 调用服务端接口,请求退料单主表数据 /// /// private string LoadWmsInRetreatData() { var result = WmsInstockService.wmsInRetreatService.GetWmsInRetreatListForPage(new WmsInRetreatSearchMd { RetreatNoMsg = ktb_retreatNo.Text, SourceNoMsg = ktb_sourceNo.Text, RetreaterMsg = ktb_retreaterMsg.Text, MaterielMsg = ktb_materialMsg.Text, BatchNoMsg = ktb_batchNoMsg.Text, RetreatType = ((ListItem)kcmb_retreatType.SelectedItem).Value, RetreatStatus = ((ListItem)kcmb_retreatStatus.SelectedItem).Value, SupplierMsg = ((ListItem)kcmb_supplierMsg.SelectedItem).Value, StartCreateTime = kdtp_startCreateTime.Checked ? kdtp_startCreateTime.Value.ToString() : null, EndCreateTime = kdtp_endCreateTime.Checked ? kdtp_endCreateTime.Value.ToString() : null, StartProductTime = kdtp_startProcudtTime.Checked ? kdtp_startProcudtTime.Value.ToString() : null, EndProductTime = kdtp_endProcudtTime.Checked ? kdtp_endProcudtTime.Value.ToString() : null, StartExpTime = kdtp_startExpTime.Checked ? kdtp_startExpTime.Value.ToString() : null, EndExpTime = kdtp_endExptTime.Checked ? kdtp_endExptTime.Value.ToString() : null, PageNum = pageToolbar1.PageIndex, EveryPageQty = pageToolbar1.PageSize }); ; ; if (result.Status == OperateStatus.Success) { kdgv_WmsInRetreat.Columns.Clear(); kdgv_WmsInRetreatDtl.DataSource = null; //RetreatId = string.Empty; isControlRetreatDtlShow = false; kdgv_WmsInRetreat.DataSource = result.Data; kdgv_WmsInRetreat.BuildDataGridView(_clientFieldOrderList.GetFieldOrderDic()); kdgv_WmsInRetreat.ClearSelection(); isControlRetreatDtlShow = true; SetStatusCellBackColor(kdgv_WmsInRetreat, "RETREAT_STATUS_NAME"); this.pageToolbar1.DataCount = result.DataCount; ktb_retreatNo.Focus(); return string.Empty; } else { ktb_retreatNo.Focus(); return result.Message; } } #endregion #region 查询退料单明细表数据 /// /// 退料单主表选中行事件 /// /// /// private void kdgv_WmsInRetreat_SelectionChanged(object sender, EventArgs e) { if (kdgv_WmsInRetreat.SelectedRows.Count > 0 && isControlRetreatDtlShow) { //RetreatId = kdgv_WmsInRetreat.SelectedRows[0].Cells[1].Value.ToString(); int mainTableId = Convert.ToInt32(kdgv_WmsInRetreat.SelectedRows[0].Cells[1].Value); var loadfrm = new frmLoading(); loadfrm.Show(); var message = loadfrm.EventCalExecExt1(LoadWmsInRetreatDtlData, mainTableId); if (!string.IsNullOrWhiteSpace(message)) { KryptonMessageBox.Show($"查询失败!\r\n{message}", "提示信息", MessageBoxButtons.OK, MessageBoxIcon.Information); } } } /// /// 调用服务端接口,请求到货通知单明细表数据 /// /// private string LoadWmsInRetreatDtlData(int mainTableId) { //if (string.IsNullOrEmpty(RetreatId)) //{ // return "请选择记录!"; //} var result = WmsInstockService.wmsInRetreatService.GetWmsInRetreatDtlListForId(new WmsInRetreatResult { RETREAT_ID = Convert.ToInt32(mainTableId), REMARKS1 = "查询已删除明细数据" }); if (result.Status == OperateStatus.Success) { kdgv_WmsInRetreatDtl.Columns.Clear(); kdgv_WmsInRetreatDtl.DataSource = result.Data.WmsInRetreatDtlList; kdgv_WmsInRetreatDtl.BuildDataGridView(_clientFieldOrderDtlList.GetFieldOrderDic(), true, false); kdgv_WmsInRetreatDtl.ClearSelection(); SetStatusCellBackColor(kdgv_WmsInRetreatDtl, "RETREAT_DTL_STATUS_NAME"); return string.Empty; } else { return result.Message; } } #endregion #region 退料单增、删、改、强制完成、退料组盘、重置条件操作 /// /// 新增退料单 /// /// /// private void kbtnAdd_Click(object sender, EventArgs e) { frmChildAddWmsInRetreat frm = new frmChildAddWmsInRetreat(); frm.ShowDialog(); } /// /// 编辑退料单 /// /// /// private void kbtnEdit_Click(object sender, EventArgs e) { int rowsSelectedNum = 0; string retreatId = string.Empty; int rowSelectIndex = 0; foreach (DataGridViewRow item in kdgv_WmsInRetreat.Rows) { DataGridViewCheckBoxCell checkCell = (DataGridViewCheckBoxCell)item.Cells[0]; object obj = checkCell.EditedFormattedValue; if (Convert.ToBoolean(obj)) { rowsSelectedNum++; retreatId = item.Cells[1].Value.ToString(); rowSelectIndex = item.Index; } } if (rowsSelectedNum > 0) { if (rowsSelectedNum == 1) { int retreatStatus = Convert.ToInt32(kdgv_WmsInRetreat.Rows[rowSelectIndex].Cells["RETREAT_STATUS"].Value); if (retreatStatus == (int)RetreatStatus.初始创建) { frmChildEditWmsInRetreat frm = new frmChildEditWmsInRetreat(); frm.RetreatId = retreatId; frm.ShowDialog(); } else if (retreatStatus < (int)RetreatStatus.退料完成) { KryptonMessageBox.Show($"第【{rowSelectIndex + 1}】行的退料单不处于【初始创建】状态,无法再次进行编辑!"); } else if (retreatStatus == (int)RetreatStatus.强制完成) { KryptonMessageBox.Show($"第【{rowSelectIndex + 1}】行的退料单已被【强制完成】,无法再次进行编辑!"); } else if (retreatStatus == (int)RetreatStatus.已删除) { KryptonMessageBox.Show($"第【{rowSelectIndex + 1}】行的退料单【已被删除】,无法再次进行编辑!"); } else if (retreatStatus == (int)RetreatStatus.退料完成) { KryptonMessageBox.Show($"第【{rowSelectIndex + 1}】行的退料单【已完成】,无法再次进行编辑!"); } else { KryptonMessageBox.Show($"第【{rowSelectIndex + 1}】行的退料单状态【{retreatStatus}】是未知的,无法进行编辑!"); } } else { KryptonMessageBox.Show("不能对勾选的多行数据进行编辑,请重新勾选一行数据!"); } } else { KryptonMessageBox.Show("请勾选要编辑的数据行!"); } } /// /// 删除退料单 /// /// /// private void kbtnRemove_Click(object sender, EventArgs e) { int rowsSelected = 0; string retreatId = string.Empty; Dictionary dic_IndexAndArrivalStatus = new Dictionary(); foreach (DataGridViewRow item in kdgv_WmsInRetreat.Rows) { DataGridViewCheckBoxCell checkCell = (DataGridViewCheckBoxCell)item.Cells[0]; object obj = checkCell.EditedFormattedValue; if (Convert.ToBoolean(obj)) { rowsSelected++; retreatId += item.Cells[1].Value.ToString() + ","; int retreatStatus = Convert.ToInt32(item.Cells["RETREAT_STATUS"].Value); dic_IndexAndArrivalStatus.Add(item.Index, retreatStatus); } } if (rowsSelected > 0) { DialogResult dr = KryptonMessageBox.Show("确定要删除所勾选的退料单数据吗?", "提示", MessageBoxButtons.OKCancel, MessageBoxIcon.Question); if (dr == DialogResult.OK) { foreach (var item in dic_IndexAndArrivalStatus) { if (item.Value == (int)ArrivalStatus.初始创建) { } else if (item.Value < (int)ArrivalStatus.已完成) { KryptonMessageBox.Show($"不能对第【{item.Key + 1}】行不处于【初始创建】状态的退料单,执行删除操作!"); return; } else if (item.Value == (int)ArrivalStatus.强制完成) { KryptonMessageBox.Show($"不能对第【{item.Key + 1}】行处于【强制完成】状态的退料单,执行删除操作!"); return; } else if (item.Value == (int)ArrivalStatus.已删除) { KryptonMessageBox.Show($"不能对第【{item.Key + 1}】行处于【已删除】状态的退料单,执行删除操作!"); return; } else if (item.Value == (int)ArrivalStatus.已完成) { KryptonMessageBox.Show($"不能对第【{item.Key + 1}】行处于【已完成】状态的退料单,执行删除操作!"); return; } else { KryptonMessageBox.Show($"不能对第【{item.Key + 1}】行处于未知状态【{item.Value}】的退料单,执行删除操作!"); return; } } retreatId = retreatId.Substring(0, retreatId.Length - 1); var result = WmsInstockService.wmsInRetreatService.DeleteWmsInRetreatData(new WmsInRetreatResult { RETREAT_NO = retreatId, UPDATE_BY = AppConfig.UserLoginResult.UserInfo.UserId }); if (result.Status == OperateStatus.Success) { KryptonMessageBox.Show(result.Message); RefreshRetreatSearchData(); } else { KryptonMessageBox.Show(result.Message); } } } else { KryptonMessageBox.Show("请勾选要删除的退料单数据行!"); } } /// /// 退料组盘 /// /// /// private void kbtn_RetreatTray_Click(object sender, EventArgs e) { int rowsSelectedNum = 0; string retreatId = string.Empty; string retreatNo = string.Empty; int rowSelectIndex = 0; foreach (DataGridViewRow item in kdgv_WmsInRetreat.Rows) { DataGridViewCheckBoxCell checkCell = (DataGridViewCheckBoxCell)item.Cells[0]; object obj = checkCell.EditedFormattedValue; if (Convert.ToBoolean(obj)) { rowsSelectedNum++; retreatId = item.Cells[1].Value.ToString(); retreatNo = item.Cells["RETREAT_NO"].Value.ToString(); rowSelectIndex = item.Index; } } if (rowsSelectedNum > 0) { if (rowsSelectedNum == 1) { int retreatStatus = Convert.ToInt32(kdgv_WmsInRetreat.Rows[rowSelectIndex].Cells["RETREAT_STATUS"].Value); if (retreatStatus < (int)RetreatStatus.退料完成) { frmChildRetreatTray frm = new frmChildRetreatTray(); frm.RetreatId = retreatId; frm.RetreatNo = retreatNo; frm.ShowDialog(); } else if (retreatStatus == (int)RetreatStatus.强制完成) { KryptonMessageBox.Show($"第【{rowSelectIndex + 1}】行的退料单已被【强制完成】,无法再次进行退料组盘!"); } else if (retreatStatus == (int)RetreatStatus.已删除) { KryptonMessageBox.Show($"第【{rowSelectIndex + 1}】行的退料单【已被删除】,无法再次进行退料组盘!"); } else if (retreatStatus == (int)RetreatStatus.退料完成) { KryptonMessageBox.Show($"第【{rowSelectIndex + 1}】行的退料单【已完成】,无法再次进行退料组盘!"); } else { KryptonMessageBox.Show($"第【{rowSelectIndex + 1}】行的退料单状态【{retreatStatus}】是未知的,无法进行退料组盘!"); } } else { KryptonMessageBox.Show("不能对勾选的多行数据进行退料组盘,请重新勾选一行数据!"); } } else { KryptonMessageBox.Show("请勾选要退料组盘的数据行!"); } } private void kbtn_ForceFinish_Click(object sender, EventArgs e) { } #endregion #region 导入、导出、打印退料单数据 /// /// 重置退料单查询条件 /// /// /// private void kbtnReset_Click(object sender, EventArgs e) { ktb_retreatNo.Text = ""; ktb_sourceNo.Text = ""; ktb_materialMsg.Text = ""; ktb_batchNoMsg.Text = ""; ktb_retreaterMsg.Text = ""; kcmb_retreatType.SelectedIndex = 0; kcmb_retreatStatus.SelectedIndex = 0; kcmb_supplierMsg.SelectedIndex = 0; kdtp_startCreateTime.Value = DateTime.Parse(DateTime.Now.ToString("yyyy-MM-dd 00:00:00")); kdtp_startCreateTime.Checked = false; kdtp_endCreateTime.Value = DateTime.Parse(DateTime.Now.ToString("yyyy-MM-dd 23:59:59")); kdtp_endCreateTime.Checked = false; kdtp_startProcudtTime.Value = DateTime.Parse(DateTime.Now.ToString("yyyy-MM-dd 00:00:00")); kdtp_startProcudtTime.Checked = false; kdtp_endProcudtTime.Value = DateTime.Parse(DateTime.Now.ToString("yyyy-MM-dd 23:59:59")); kdtp_endProcudtTime.Checked = false; kdtp_startExpTime.Value = DateTime.Parse(DateTime.Now.ToString("yyyy-MM-dd 00:00:00")); kdtp_startExpTime.Checked = false; kdtp_endExptTime.Value = DateTime.Parse(DateTime.Now.ToString("yyyy-MM-dd 23:59:59")); kdtp_endExptTime.Checked = false; } /// /// 导出退料单数据 /// /// /// private void kbtnExport_Click(object sender, EventArgs e) { List retreatIdList = new List(); foreach (DataGridViewRow item in kdgv_WmsInRetreat.Rows) { DataGridViewCheckBoxCell checkCell = (DataGridViewCheckBoxCell)item.Cells[0]; object obj = checkCell.EditedFormattedValue; if (Convert.ToBoolean(obj)) { retreatIdList.Add(item.Cells[1].Value.ToString()); } } if (retreatIdList.Count > 0) { List wmsInRetreatList = new List(); foreach (string item in retreatIdList) { var result = WmsInstockService.wmsInRetreatService.GetWmsInRetreatDtlListForId(new WmsInRetreatResult { RETREAT_ID = Convert.ToInt32(item) }); if (result.Status == OperateStatus.Success) { wmsInRetreatList.Add(result.Data); } } NxExcelHelper.ExportToExcel(GetWmsRetreatExportExcelData(wmsInRetreatList), "退料单数据"); } else { KryptonMessageBox.Show("请勾选要导出的数据行!"); } } private DataTable GetWmsRetreatExportExcelData(List wmsInRetreatList) { DataTable dt = new DataTable(); #region 准备导出列名 DataColumn dc = new DataColumn("退料单号"); dt.Columns.Add(dc); dc = new DataColumn("来源单号"); dt.Columns.Add(dc); dc = new DataColumn("单据类型"); dt.Columns.Add(dc); dc = new DataColumn("退料退料人"); dt.Columns.Add(dc); dc = new DataColumn("退料时间"); dt.Columns.Add(dc); dc = new DataColumn("物料类型编码"); dt.Columns.Add(dc); dc = new DataColumn("物料类型名称"); dt.Columns.Add(dc); dc = new DataColumn("物料编码"); dt.Columns.Add(dc); dc = new DataColumn("物料名称"); dt.Columns.Add(dc); dc = new DataColumn("物料条码"); dt.Columns.Add(dc); dc = new DataColumn("规格"); dt.Columns.Add(dc); dc = new DataColumn("单位"); dt.Columns.Add(dc); dc = new DataColumn("批次号"); dt.Columns.Add(dc); dc = new DataColumn("到货数量"); dt.Columns.Add(dc); dc = new DataColumn("退料单明细数量"); dt.Columns.Add(dc); dc = new DataColumn("退料组盘数量"); dt.Columns.Add(dc); dc = new DataColumn("上架数量"); dt.Columns.Add(dc); dc = new DataColumn("供应商编码"); dt.Columns.Add(dc); dc = new DataColumn("供应商名称"); dt.Columns.Add(dc); dc = new DataColumn("生产日期"); dt.Columns.Add(dc); dc = new DataColumn("失效日期"); dt.Columns.Add(dc); dc = new DataColumn("明细状态"); dt.Columns.Add(dc); dc = new DataColumn("质检状态"); dt.Columns.Add(dc); dc = new DataColumn("物品状态"); dt.Columns.Add(dc); #endregion foreach (WmsInRetreatResult retreatMd in wmsInRetreatList) { foreach (WmsInRetreatDtlResult retreatDtlMd in retreatMd.WmsInRetreatDtlList) { DataRow dr = dt.NewRow(); dr["退料单号"] = retreatMd.RETREAT_NO; dr["来源单号"] = retreatMd.SOUCE_NO; dr["单据类型"] = retreatMd.RETREAT_TYPE_NAME; dr["退料退料人"] = retreatMd.RETREATER; dr["退料时间"] = retreatMd.RETREAT_TIME; dr["物料类型编码"] = retreatDtlMd.MATERIEL_TYPE_CODE; dr["物料类型名称"] = retreatDtlMd.MATERIEL_TYPE_NAME; dr["物料编码"] = retreatDtlMd.MATERIEL_CODE; dr["物料名称"] = retreatDtlMd.MATERIEL_NAME; dr["物料条码"] = retreatDtlMd.MATERIEL_BARCODE; dr["规格"] = retreatDtlMd.MATERIEL_SPEC; dr["单位"] = retreatDtlMd.UNIT_CODE; dr["批次号"] = retreatDtlMd.BATCH_NO; dr["退料单明细数量"] = retreatDtlMd.RETREAT_QTY; dr["退料组盘数量"] = retreatDtlMd.RETREAT_TRAY_QTY; dr["上架数量"] = retreatDtlMd.PUTAWAY_QTY; dr["供应商编码"] = retreatDtlMd.SUPPLIER_CODE; dr["供应商名称"] = retreatDtlMd.SUPPLIER_NAME; dr["生产日期"] = retreatDtlMd.PRODUCT_DATE; dr["失效日期"] = retreatDtlMd.EXP_DATE; dr["明细状态"] = retreatDtlMd.RETREAT_DTL_STATUS_NAME; dr["质检状态"] = retreatDtlMd.INSPECTION_RESULT_NAME; dr["物品状态"] = retreatDtlMd.ITEM_STATUS_NAME; dt.Rows.Add(dr); } } return dt; } private void kbtnImport_Click(object sender, EventArgs e) { } private void kbtnPrint_Click(object sender, EventArgs e) { } #endregion #region DatatGridView 事件 /// /// 设置DatatGridView的第一列复选框的背景色 /// /// /// private void kdgv_WmsInRetreat_CellContentClick(object sender, DataGridViewCellEventArgs e) { if (e.ColumnIndex == 0) { DataGridViewCheckBoxCell checkCell = (DataGridViewCheckBoxCell)kdgv_WmsInRetreat.CurrentCell; if (Convert.ToBoolean(checkCell.EditedFormattedValue)) { kdgv_WmsInRetreat.CurrentCell.Style.BackColor = Color.FromArgb(51, 153, 255); } else { kdgv_WmsInRetreat.CurrentCell.Style.BackColor = Color.Transparent; } } } /// /// 设置状态列的背景色 /// /// dataGridView控件 /// 状态列的列名称 private void SetStatusCellBackColor(KryptonDataGridView dataGridView, string columnName) { foreach (DataGridViewRow item in dataGridView.Rows) { string arrivalDtlStatus = item.Cells[columnName].Value.ToString(); switch (Enum.Parse(typeof(RetreatStatus), arrivalDtlStatus)) { case RetreatStatus.初始创建: //item.Cells[columnName].Style.ForeColor = Color.White; item.Cells[columnName].Style.BackColor = Color.FromArgb(214, 228, 243); break; case RetreatStatus.退料审核: //item.Cells[columnName].Style.ForeColor = Color.White; item.Cells[columnName].Style.BackColor = Color.LightYellow; break; case RetreatStatus.退料收货中: //item.Cells[columnName].Style.ForeColor = Color.White; item.Cells[columnName].Style.BackColor = Color.LightGreen; break; case RetreatStatus.退料完成: //item.Cells[columnName].Style.ForeColor = Color.White; item.Cells[columnName].Style.BackColor = Color.LightGray; break; case RetreatStatus.强制完成: //item.Cells[columnName].Style.ForeColor = Color.White; item.Cells[columnName].Style.BackColor = Color.DarkGray; break; case RetreatStatus.已删除: //item.Cells[columnName].Style.ForeColor = Color.White; item.Cells[columnName].Style.BackColor = Color.FromArgb(255, 69, 0); break; default: break; } } } private void kdgv_WmsInRetreat_DataError(object sender, DataGridViewDataErrorEventArgs e) { } private void kdgv_WmsInRetreatDtl_DataError(object sender, DataGridViewDataErrorEventArgs e) { } #endregion #region 鼠标右键单击事件 /// /// 刷新明细表数据 /// /// /// private void 刷新ToolStripMenuItem1_Click(object sender, EventArgs e) { if (kdgv_WmsInRetreatDtl.Rows.Count > 0) { if (kdgv_WmsInRetreat.SelectedRows.Count > 0 && isControlRetreatDtlShow) { //RetreatId = kdgv_WmsInRetreat.SelectedRows[0].Cells[1].Value.ToString(); int mainTableId = Convert.ToInt32(kdgv_WmsInRetreat.SelectedRows[0].Cells[1].Value); var loadfrm = new frmLoading(); loadfrm.Show(); var message = loadfrm.EventCalExecExt1(LoadWmsInRetreatDtlData, mainTableId); if (!string.IsNullOrWhiteSpace(message)) { KryptonMessageBox.Show($"查询失败!\r\n{message}", "提示信息", MessageBoxButtons.OK, MessageBoxIcon.Information); } } } } /// /// 刷新主表数据 /// /// /// private void 刷新ToolStripMenuItem_Click(object sender, EventArgs e) { if (kdgv_WmsInRetreat.Rows.Count > 0) { RefreshRetreatSearchData(); } } #endregion private void pageToolbar1_OnPageChange(int PageIndex, int PageSzie) { this.kbtnSearch_Click(null, null); } } }