/******************************************************************************* * Copyright(c) 2014 DongkeSoft All rights reserved. / Confidential * 类的信息: * 1.程序名称:F_PM_2001.cs * 2.功能描述:干补计件一览 * 编辑履历: * 作者 日期 版本 修改内容 * 袁新成 2015/3/27 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_2001 : DockPanelBase { #region 成员变量 // 窗体的单例模式 private static Dictionary _dicInstance; // 当前工序ID private int _currentProcedureID = 0; // 最后选择行 private int _selecedRow; // 窗体显示的Title private string _fromTitle; #endregion #region 构造函数 public F_PM_2001() { 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_2001 Instance(int procedureID, string fromTitle) { F_PM_2001 fInstance = null; if (_dicInstance == null) { _dicInstance = new Dictionary(); fInstance = new F_PM_2001(); _dicInstance.Add(procedureID, fInstance); } else if (_dicInstance.ContainsKey(procedureID)) { fInstance = _dicInstance[procedureID]; } else { fInstance = new F_PM_2001(); _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; //SearchProductionDataEntity requestEntity = CreatesearchProductionDataRequestEntity(); //DataTable dtProductionData = (DataTable)DoAsync(new AsyncMethod(() => //{ // return PMModuleProxy.Service.GetProductionData(requestEntity); //})); ClientRequestEntity cre = CreatesearchProductionDataRequestEntity(); ServiceResultEntity sre = (ServiceResultEntity)DoAsync(() => { return PMModuleProxyNew.Service.HandleRequest(cre); }); if (sre == null) { return; } DataSet dsProductionData = sre.Data; //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_2002 frmPM2002 = new F_PM_2002(_currentProcedureID, _fromTitle); DialogResult dialogResult = frmPM2002.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; //} 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() { //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.dkOrganization.OrganizationID; //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 = dkGoodsTypeSearchBox.GoodsTypeCode; //return result; 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 } }