/******************************************************************************* * Copyright(c) 2017 DongkeSoft All rights reserved. / Confidential * 类的信息: * 1.程序名称:F_PM_2501.cs * 2.功能描述:回收计件一览 * 编辑履历: * 作者 日期 版本 修改内容 * 王鑫 2017/7/20 1.00 新建 *******************************************************************************/ using System; using System.Collections.Generic; using System.Data; using System.Windows.Forms; 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; using Dongke.IBOSS.PRD.WCF.Proxys; using Dongke.IBOSS.PRD.WCF.Proxys.PMModuleService; namespace Dongke.IBOSS.PRD.Client.PMModule { /// /// 回收计件一览 /// public partial class F_PM_2501 : DockPanelBase { #region 成员变量 // 窗体的单例模式 private static Dictionary _dicInstance; // 当前工序ID private int _currentProcedureID = 0; // 最后选择行 private int _selecedRow; // 窗体显示的Title private string _fromTitle; #endregion #region 构造函数 public F_PM_2501() { 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; } #endregion #region 单例模式 /// /// 一个工序ID有一个单例,防止重复创建窗体 /// /// 工序ID /// public static F_PM_2501 Instance(int procedureID, string fromTitle) { F_PM_2501 fInstance = null; if (_dicInstance == null) { _dicInstance = new Dictionary(); fInstance = new F_PM_2501(); _dicInstance.Add(procedureID, fInstance); } else if (_dicInstance.ContainsKey(procedureID)) { fInstance = _dicInstance[procedureID]; } else { fInstance = new F_PM_2501(); _dicInstance.Add(procedureID, fInstance); } fInstance._currentProcedureID = procedureID; fInstance._fromTitle = fromTitle; fInstance.Text = fromTitle; return fInstance; } #endregion #region 事件 /// /// 窗体加载事件 /// /// /// private void F_PM_2001_Load(object sender, System.EventArgs e) { try { // 加载权限 FormPermissionManager.FormPermissionControl(this.Name, this, LogInUserInfo.CurrentUser.CurrentUserEntity.UserRightData, LogInUserInfo.CurrentUser.CurrentUserEntity.FunctionData); // 设置表格不自动创建列 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); // 设置ToolStripButton状态 this.SetToolStripButtonEnable(); } catch (Exception ex) { // 对异常进行共通处理 ExceptionManager.HandleEventException(this.ToString(), System.Reflection.MethodBase.GetCurrentMethod().Name, this.Text, ex); } } /// /// 窗体关闭事件 /// /// /// private void F_PM_2001_FormClosed(object sender, System.Windows.Forms.FormClosedEventArgs e) { _dicInstance = null; } /// /// 自动适应列宽 /// /// /// private void tsbtnAdaptive_Click(object sender, EventArgs e) { this.dgvProduction.AutoResizeColumns(DataGridViewAutoSizeColumnsMode.AllCells); } /// /// 清空条件按钮事件 /// /// /// private void btnClearCondition_Click(object sender, EventArgs e) { this.txtBarCode.Text = ""; this.txtGoodsCode.Text = ""; this.txtGoodsName.Text = ""; this.txtUserCode.Text = ""; this.scbOrganization.ClearValue(); //this.txtRemarks.Text = ""; //this.statusIsReworked.ClearItemCheck(); 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); } /// /// 查询按钮事件 /// /// /// private void btnSearch_Click(object sender, EventArgs e) { try { // 记录当前选中行 int selectRowIndex = this._selecedRow; // 异步处理 this.btnSearch.Enabled = false; this.btnClearCondition.Enabled = false; ClientRequestEntity cre = CreatesearchProductionDataRequestEntity(); ServiceResultEntity sre = (ServiceResultEntity)DoAsync(() => { return PMModuleProxyNew.Service.HandleRequest(cre); }); if (sre == null) { return; } DataSet dsProductionData = sre.Data; 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) { this.dgvProduction.DataSource = this.DataSource.Tables[0]; if (this.DataSource.Tables[0].Rows.Count <= Constant.INT_IS_ZERO) { // 提示未查找到数据 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_2502 frmPM2502 = new F_PM_2502(_currentProcedureID, _fromTitle); DialogResult dialogResult = frmPM2502.ShowDialog(); // 重新加载GridView if (dialogResult == DialogResult.OK) { this.btnSearch_Click(null, null); } } 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 ClientRequestEntity CreatesearchProductionDataRequestEntity() { ClientRequestEntity cre = new ClientRequestEntity(); cre.NameSpace = "ProductionData"; cre.Name = "GetProductionData_8"; cre.Properties["BarCode"] = this.txtBarCode.Text.Trim(); cre.Properties["GoodsCode"] = this.txtGoodsCode.Text.Trim(); cre.Properties["GoodsName"] = this.txtGoodsName.Text.Trim(); cre.Properties["UserCode"] = this.txtUserCode.Text.Trim(); cre.Properties["OrganizationID"] = this.scbOrganization.SearchedPKMember; cre.Properties["BeginDate"] = this.dtpStartTime.Value; cre.Properties["EndDate"] = this.dtpEndTime.Value.AddDays(1); cre.Properties["ProcedureID"] = _currentProcedureID; cre.Properties["GoodsTypeCode"] = scbGoodsType.SearchedValue + ""; return cre; } #endregion } }