/******************************************************************************* * Copyright(c) 2014 DongkeSoft All rights reserved. / Confidential * 类的信息: * 1.程序名称:F_PM_0301.cs * 2.功能描述:标准、坯库计件一览 * 编辑履历: * 作者 日期 版本 修改内容 * 王鑫 2014/09/23 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.PMModule; using Dongke.IBOSS.PRD.WCF.Proxys; using Dongke.IBOSS.PRD.WCF.Proxys.PMModuleService; namespace Dongke.IBOSS.PRD.Client.PMModule { /// /// 标准、坯库计件一览 /// public partial class F_PM_0301 : DockPanelBase { #region 成员变量 // 窗体的单例模式 private static Dictionary _dicInstance; // 当前工序ID private int _currentProcedureID = 0; // 最后选择行 private int _selecedRow; // 窗体显示的Title private string _fromTitle; #endregion #region 构造函数 public F_PM_0301() { 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_0301 Instance(int procedureID, string fromTitle) { F_PM_0301 fInstance = null; if (_dicInstance == null) { _dicInstance = new Dictionary(); fInstance = new F_PM_0301(); _dicInstance.Add(procedureID, fInstance); } else if (_dicInstance.ContainsKey(procedureID)) { fInstance = _dicInstance[procedureID]; } else { fInstance = new F_PM_0301(); _dicInstance.Add(procedureID, fInstance); } fInstance._currentProcedureID = procedureID; fInstance._fromTitle = fromTitle; fInstance.Text = fromTitle; return fInstance; } #endregion #region 事件 /// /// 窗体加载事件 /// /// /// private void F_PM_0301_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).AddDays(1).AddMinutes(-1); // 设置ToolStripButton状态 this.SetToolStripButtonEnable(); } catch (Exception ex) { // 对异常进行共通处理 ExceptionManager.HandleEventException(this.ToString(), System.Reflection.MethodBase.GetCurrentMethod().Name, this.Text, ex); } } /// /// 窗体关闭事件 /// /// /// private void F_PM_0301_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).AddDays(1).AddMinutes(-1); } /// /// 查询按钮事件 /// /// /// private void btnSearch_Click(object sender, EventArgs e) { try { // 记录当前选中行 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) { 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_0302 frmPM0402 = new F_PM_0302(_currentProcedureID, _fromTitle); DialogResult dialogResult = frmPM0402.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); } } #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 = scbOrganization.SearchedPKMember; result.Remarks = ""; // this.txtRemarks.Text.Trim(); //object[] objRework = this.statusIsReworked.SelectedValues; string Rework = ""; //for (int i = 0; i < objRework.Length; i++) //{ // Rework += objRework[i] + ","; //} Rework = Rework.TrimEnd(','); result.IsRework = Rework; result.BeginDate = this.dtpStartTime.Value; result.EndDate = this.dtpEndTime.Value;//.AddDays(1) result.ProcedureID = _currentProcedureID; result.GoodsTypeCode = this.scbGoodsType.SearchedValue + ""; return result; } #endregion } }