/******************************************************************************* * Copyright(c) 2014 DongkeSoft All rights reserved. / Confidential * 类的信息: * 1.程序名称:F_PM_1201.cs * 2.功能描述:成品检验一览 * 编辑履历: * 作者 日期 版本 修改内容 * 王鑫 2014/10/18 1.00 新建 *******************************************************************************/ using Dongke.IBOSS.PRD.Basics.BaseResources; using Dongke.IBOSS.PRD.Basics.DockPanel; using Dongke.IBOSS.PRD.Client.CommonModule; using Dongke.IBOSS.PRD.Client.DataModels; using Dongke.IBOSS.PRD.WCF.DataModels.PMModule; using Dongke.IBOSS.PRD.WCF.Proxys; using System; using System.Collections.Generic; using System.Data; using System.Windows.Forms; namespace Dongke.IBOSS.PRD.Client.PMModule { /// /// 成品检验一览 /// public partial class F_PM_1201 : DockPanelBase { #region 成员变量 // 窗体的单例模式 private static Dictionary _dicInstance; // 当前工序ID private int _currentProcedureID = 0; // 最后选择行 private int _selecedRow; // 窗体显示的Title private string _fromTitle; #endregion #region 构造函数 public F_PM_1201() { InitializeComponent(); this.tsbtnAdd.Text = ButtonText.TSBTN_ADD; //编辑 this.tsbtnEdit.Text = ButtonText.TSBTN_EDIT; //自动适应列宽 this.tsbtnAdaptive.Text = ButtonText.TSBTN_ADAPTIVE; //关闭 this.tsbtnClose.Text = ButtonText.TSBTN_CLOSE; //查询 this.btnSearch.Text = ButtonText.BTN_SEARCH; //清空条件 this.btnClearCondition.Text = ButtonText.BTN_CLEARCONDITION; //查询条件 this.gbxCondition.Text = Constant.LABEL_QUERY_CONDITIONS; this.Text = _fromTitle; } #endregion #region 单例模式 /// /// 一个工序ID有一个单例,防止重复创建窗体 /// /// 工序ID /// public static F_PM_1201 Instance(int procedureID, string fromTitle) { F_PM_1201 fInstance = null; if (_dicInstance == null) { _dicInstance = new Dictionary(); fInstance = new F_PM_1201(); _dicInstance.Add(procedureID, fInstance); } else if (_dicInstance.ContainsKey(procedureID)) { fInstance = _dicInstance[procedureID]; } else { fInstance = new F_PM_1201(); _dicInstance.Add(procedureID, fInstance); } fInstance._currentProcedureID = procedureID; fInstance._fromTitle = fromTitle; fInstance.Text = fromTitle; return fInstance; } #endregion #region 事件 /// /// 窗体加载事件 /// /// /// private void F_PM_1201_Load(object sender, System.EventArgs e) { try { if (_currentProcedureID == 16 || _currentProcedureID == 28) { this.dgvProduction.Columns["CheckTime"].Visible = false; } else { this.dgvProduction.Columns["CheckTime"].Visible = true; } if (_currentProcedureID != 28 && _currentProcedureID != 61) { this.dgvProduction.Columns["datasource"].Visible = false; } // 加载权限 FormPermissionManager.FormPermissionControl(this.Name, this, LogInUserInfo.CurrentUser.CurrentUserEntity.UserRightData, LogInUserInfo.CurrentUser.CurrentUserEntity.FunctionData); this.tsbtnAdd.Visible = true; // 设置表格不自动创建列 this.dgvProduction.AutoGenerateColumns = false; // 初始化时间控件为当前日期 this.dtpStartTime.Value = new DateTime(DateTime.Now.Year, DateTime.Now.Month, DateTime.Now.Day); this.dtpEndTime.Value = new DateTime(DateTime.Now.Year, DateTime.Now.Month, DateTime.Now.Day).AddDays(1).AddMinutes(-1); // 初始化时间控件为当前日期 this.dtpUpdateTimeStart.Value = new DateTime(DateTime.Now.Year, DateTime.Now.Month, DateTime.Now.Day); this.dtpUpdateTimeEnd.Value = new DateTime(DateTime.Now.Year, DateTime.Now.Month, DateTime.Now.Day).AddDays(1).AddMinutes(-1); // 设置ToolStripButton状态 this.SetToolStripButtonEnable(); #region 设置下拉列表框的数据源 this.cobKilnName.DataSource = GetMSTKilnInfo(); this.cobKilnName.DisplayMember = "KilnName"; this.cobKilnName.ValueMember = "KilnCode"; this.cobKilnCarPosition.DataSource = GetMSTKilnCarPositionInfo(); this.cobKilnCarPosition.DisplayMember = "DictionaryValue"; this.cobKilnCarPosition.ValueMember = "DictionaryID"; #endregion } catch (Exception ex) { // 对异常进行共通处理 ExceptionManager.HandleEventException(this.ToString(), System.Reflection.MethodBase.GetCurrentMethod().Name, this.Text, ex); } } /// /// 窗体关闭事件 /// /// /// private void F_PM_1201_FormClosed(object sender, System.Windows.Forms.FormClosedEventArgs e) { _dicInstance = null; } /// /// 自动适应列宽 /// /// /// private void tsbtnAdaptive_Click(object sender, EventArgs e) { this.dgvProduction.AutoResizeColumns(DataGridViewAutoSizeColumnsMode.AllCells); this.dgvDefect.AutoResizeColumns(DataGridViewAutoSizeColumnsMode.AllCells); } /// /// 清空条件按钮事件 /// /// /// private void btnClearCondition_Click(object sender, EventArgs e) { this.txtBarCode.Text = string.Empty; this.txtGoodsCode.Text = string.Empty; this.txtGoodsName.Text = string.Empty; this.txtUserCode.Text = string.Empty; this.scbOrganization.ClearValue(); //this.txtRemarks.Text = string.Empty; this.scbGoodsType.ClearValue(); this.dtpStartTime.Value = new DateTime(DateTime.Now.Year, DateTime.Now.Month, DateTime.Now.Day); this.dtpEndTime.Value = new DateTime(DateTime.Now.Year, DateTime.Now.Month, DateTime.Now.Day).AddDays(1).AddMinutes(-1); this.cobKilnName.SelectedIndex = Constant.INT_IS_ZERO; this.txtKilnCarName.Text = string.Empty; this.cobKilnCarPosition.SelectedIndex = Constant.INT_IS_ZERO; this.cobworkshop.SelectedIndex = Constant.INT_IS_NEGATIE_ONE; this.txtGroutingUserCode.Text = string.Empty; this.chkCreateTime.Checked = false; this.dtpStartTime.Enabled = false; this.dtpEndTime.Enabled = false; this.chkUpdateTime.Checked = true; this.dtpUpdateTimeStart.Value = new DateTime(DateTime.Now.Year, DateTime.Now.Month, DateTime.Now.Day); this.dtpUpdateTimeEnd.Value = new DateTime(DateTime.Now.Year, DateTime.Now.Month, DateTime.Now.Day).AddDays(1).AddMinutes(-1); this.dtpUpdateTimeStart.Enabled = true; this.dtpUpdateTimeEnd.Enabled = true; this.chkChangeDayFlag.Checked = false; this.chkChangeMontFlag.Checked = false; } /// /// 查询按钮事件 /// /// /// private void btnSearch_Click(object sender, EventArgs e) { try { if (this.chkCreateTime.Checked == false && this.chkUpdateTime.Checked == false) { MessageBox.Show("操作时间和首检时间至少选取一个", this.Text, MessageBoxButtons.OK, MessageBoxIcon.Information); return; } // 记录当前选中行 int selectRowIndex = this._selecedRow; // 异步处理 this.btnSearch.Enabled = false; this.btnClearCondition.Enabled = false; SearchProductionDataEntity requestEntity = CreatesearchProductionDataRequestEntity(); DataTable dtProductionData = (DataTable)DoAsync(new AsyncMethod(() => { return PMModuleProxy.Service.GetProductionData(requestEntity); })); DataSet dsProductionData = new DataSet(); dsProductionData.Tables.Add(dtProductionData); this.btnSearch.Enabled = true; this.btnClearCondition.Enabled = true; if (dsProductionData != null) { base.DataSource = dsProductionData; if (this.DataSource != null && this.DataSource.Tables.Count > Constant.INT_IS_ZERO) { tsbtnEdit.Enabled = true; this.dgvProduction.DataSource = this.DataSource.Tables[0]; selectRowIndex = 0; if (this.DataSource.Tables[0].Rows.Count <= Constant.INT_IS_ZERO) { tsbtnEdit.Enabled = false; this.dgvDefect.DataSource = null; // 提示未查找到数据 MessageBox.Show(Messages.MSG_CMN_I002, this.Text, MessageBoxButtons.OK, MessageBoxIcon.Information); } else { if (selectRowIndex >= Constant.INT_IS_ZERO) { if (selectRowIndex >= dsProductionData.Tables[0].Rows.Count) { this.dgvProduction.Rows[this.dgvProduction.Rows.Count - 1].Selected = true; this.dgvProduction.CurrentCell = this.dgvProduction.Rows[this.dgvProduction.Rows.Count - 1].Cells["GoodsCode"]; } else { this.dgvProduction.Rows[selectRowIndex].Selected = true; this.dgvProduction.CurrentCell = this.dgvProduction.Rows[selectRowIndex].Cells["GoodsCode"]; } } } } } } catch (Exception ex) { this.btnSearch.Enabled = true; this.btnClearCondition.Enabled = true; // 对异常进行共通处理 ExceptionManager.HandleEventException(this.ToString(), System.Reflection.MethodBase.GetCurrentMethod().Name, this.Text, ex); } } /// /// 关闭按钮事件 /// /// /// private void tsbtnClose_Click(object sender, EventArgs e) { this.Close(); } /// /// 新建按钮事件 /// /// /// private void tsbtnAdd_Click(object sender, EventArgs e) { try { F_PM_1202 frmPM1202 = new F_PM_1202(_currentProcedureID, _fromTitle); DialogResult dialogResult = frmPM1202.ShowDialog(); // 重新加载GridView if (dialogResult == DialogResult.OK) { SearchProductionDataEntity requestEntity = CreatesearchProductionDataRequestEntity(); DataTable dtProductionData = (DataTable)DoAsync(new AsyncMethod(() => { return PMModuleProxy.Service.GetProductionData(requestEntity); })); if (dtProductionData != null && dtProductionData.Rows.Count > Constant.INT_IS_ZERO) { this.dgvProduction.DataSource = null; this.dgvProduction.DataSource = dtProductionData; // 设置ToolStripButton按钮状态 this.SetToolStripButtonEnable(); this.dgvProduction.ReadOnly = true; } } } catch (Exception ex) { // 对异常进行共通处理 ExceptionManager.HandleEventException(this.ToString(), System.Reflection.MethodBase.GetCurrentMethod().Name, this.Text, ex); } } /// /// 数据表格选定项改变事件 /// /// /// private void dgvProduction_SelectionChanged(object sender, EventArgs e) { try { if (this.dgvProduction.CurrentCell != null) { if (!this.txtBarCode.ReadOnly) { this._selecedRow = this.dgvProduction.CurrentCell.RowIndex; this.dgvDefect.DataSource = null; string flag = this.dgvProduction.Rows[_selecedRow].Cells["ProductionDataID"].Value.ToString(); if (flag != null && flag != "") { int ProductionDataID = Convert.ToInt32(this.dgvProduction.Rows[_selecedRow].Cells["ProductionDataID"].Value.ToString()); DataSet dsProductionDefect = (DataSet)DoAsync(new AsyncMethod(() => { return PMModuleProxy.Service.GetProductionDefectByProductionDataID(ProductionDataID); })); if (dsProductionDefect != null && dsProductionDefect.Tables.Count > Constant.INT_IS_ZERO && dsProductionDefect.Tables[0].Rows.Count > Constant.INT_IS_ZERO) { this.dgvDefect.DataSource = dsProductionDefect.Tables[0]; } } } } } catch (Exception ex) { // 对异常进行共通处理 ExceptionManager.HandleEventException(this.ToString(), System.Reflection.MethodBase.GetCurrentMethod().Name, this.Text, ex); } } /// /// 编辑按钮事件 /// /// /// private void tsbtnEdit_Click(object sender, EventArgs e) { try { string flag = this.dgvProduction.Rows[_selecedRow].Cells["ProductionDataID"].Value.ToString(); if (this.dgvProduction.CurrentRow != null && (flag != null && flag != "")) { int ProductionDataID = Convert.ToInt32(this.dgvProduction.CurrentRow.Cells["ProductionDataID"].Value); string BarCode = this.dgvProduction.CurrentRow.Cells["BarCode"].Value.ToString(); int CompleteProcedureID = (int)DoAsync(new AsyncMethod(() => { return PMModuleProxy.Service.GetCompleteProcedureID(BarCode); })); bool isView = true; if (CompleteProcedureID != -Constant.INT_IS_ONE && CompleteProcedureID == this._currentProcedureID) { // 尽管等于当前工序,但是如果该条码又插入了一条生产数据,在编辑此数据时,也应该为只读,即重烧后添加的生产数据,编辑上一次生产数据ID int CompleteProductionDataID = (int)DoAsync(new AsyncMethod(() => { return PMModuleProxy.Service.GetCompleteProductionDataID(BarCode); })); if (ProductionDataID == CompleteProductionDataID) { int auditstatus = (int)DoAsync(new AsyncMethod(() => { return PMModuleProxy.Service.CheckScrapProduct(BarCode); })); if (auditstatus != -100) { isView = true; } else { isView = false; } // } } } F_PM_1202 frmPM1202 = new F_PM_1202(_currentProcedureID, _fromTitle, ProductionDataID, isView); DialogResult dialogResult = frmPM1202.ShowDialog(); // 重新加载GridView if (dialogResult == DialogResult.OK) { SearchProductionDataEntity requestEntity = CreatesearchProductionDataRequestEntity(); DataTable dtProductionData = (DataTable)DoAsync(new AsyncMethod(() => { return PMModuleProxy.Service.GetProductionData(requestEntity); })); if (dtProductionData != null && dtProductionData.Rows.Count > Constant.INT_IS_ZERO) { this.dgvProduction.DataSource = null; this.dgvProduction.DataSource = dtProductionData; // 设置ToolStripButton按钮状态 this.SetToolStripButtonEnable(); this.dgvProduction.ReadOnly = true; } } } else { MessageBox.Show("无法编辑小计合计数据 请重新选择", this.Text, MessageBoxButtons.OK, MessageBoxIcon.Information); } } catch (Exception ex) { // 对异常进行共通处理 ExceptionManager.HandleEventException(this.ToString(), System.Reflection.MethodBase.GetCurrentMethod().Name, this.Text, ex); } } #endregion #region 私有方法 /// /// 设置工具按钮的可用状态 /// private void SetToolStripButtonEnable() { if (this.dgvProduction.CurrentCell != null) { this.tsbtnEdit.Enabled = true; } else { this.tsbtnEdit.Enabled = false; } } /// /// 搜索条件 /// /// private SearchProductionDataEntity CreatesearchProductionDataRequestEntity() { SearchProductionDataEntity result = new SearchProductionDataEntity(); result.BarCode = this.txtBarCode.Text.Trim(); result.GoodsCode = this.txtGoodsCode.Text.Trim(); result.GoodsName = this.txtGoodsName.Text.Trim(); result.UserCode = this.txtUserCode.Text.Trim(); result.OrganizationID = this.scbOrganization.SearchedPKMember; result.Remarks = cobworkshop.Text;//暂传车间(成检部分) // 客户端质量登记(包含重烧)需增加首检时间数据列,改判(首检非当天)标识,跨月改判(首检为 25 日 23:59:59 之前)标识,以上内容添加在搜索条件内,质量登记默认搜索条件为首次质量登记时间 if (this.chkCreateTime.Checked == true) { result.BeginDate = this.dtpStartTime.Value; result.EndDate = this.dtpEndTime.Value; result.IsCreateDayFlg = "1"; } if (this.chkUpdateTime.Checked == true) { result.BeginCheckDate = this.dtpUpdateTimeStart.Value; result.EndCheckDate = this.dtpUpdateTimeEnd.Value; result.IsCheckDayFlg = "1"; } result.ChangeDayFlag = this.chkChangeDayFlag.Checked ? "1" : ""; result.ChangeMontFlag = this.chkChangeMontFlag.Checked ? "1" : ""; result.ProcedureID = _currentProcedureID; if (this.cobKilnName.SelectedValue != null && !Constant.CBO_SELECT_ALL_VALUE.ToString().Equals(this.cobKilnName.SelectedValue.ToString())) { result.KilnCode = this.cobKilnName.SelectedValue.ToString(); } result.KilnCarCode = this.txtKilnCarName.Text.Trim(); result.GroutingUserCode = this.txtGroutingUserCode.Text.Trim(); if (this.cobKilnCarPosition.SelectedValue != null && !Constant.CBO_SELECT_ALL_VALUE.ToString().Equals(this.cobKilnCarPosition.SelectedValue.ToString())) { result.KilnCarPosition = Convert.ToInt32(this.cobKilnCarPosition.SelectedValue); } result.GoodsTypeCode = scbGoodsType.SearchedValue + ""; return result; } /// /// 获取窑炉字典信息 /// /// private DataTable GetMSTKilnInfo() { DataSet dsKilnInfo = (DataSet)DoAsync(new AsyncMethod(() => { byte byFlage = Convert.ToByte(Constant.ValueFlag.Invalid); return SystemModuleProxy.Service.GetKilnData(byFlage); })); DataTable dtKilnInfo = dsKilnInfo.Tables[Constant.INT_IS_ZERO]; DataRow newRowDic = dtKilnInfo.NewRow(); newRowDic["KilnID"] = Constant.CBO_SELECT_ALL_VALUE; newRowDic["KilnCode"] = Constant.CBO_SELECT_ALL_VALUE; newRowDic["KilnName"] = Constant.CBO_SELECT_ALL_NAME; dtKilnInfo.Rows.InsertAt(newRowDic, Constant.INT_IS_ZERO); return dtKilnInfo; } /// /// 获取窑车位置字典表数据 /// /// public DataTable GetMSTKilnCarPositionInfo() { DataTable dtDicInfo = (DataTable)DoAsync(new AsyncMethod(() => { return CommonModuleProxy.Service.GetDataDictionaryByType(Constant.TPC_TPC003); })); DataRow newRowDic = dtDicInfo.NewRow(); newRowDic["DictionaryID"] = Constant.CBO_SELECT_ALL_VALUE; newRowDic["DictionaryValue"] = Constant.CBO_SELECT_ALL_NAME; dtDicInfo.Rows.InsertAt(newRowDic, Constant.INT_IS_ZERO); return dtDicInfo; } #endregion /// /// 首检日期 /// /// /// private void chkUpdateTime_CheckedChanged(object sender, EventArgs e) { this.dtpUpdateTimeStart.Enabled = this.chkUpdateTime.Checked; this.dtpUpdateTimeEnd.Enabled = this.chkUpdateTime.Checked; } /// /// 操作日期 /// /// /// private void chkCreateTime_CheckedChanged(object sender, EventArgs e) { this.dtpStartTime.Enabled = this.chkCreateTime.Checked; this.dtpEndTime.Enabled = this.chkCreateTime.Checked; } } }