/*******************************************************************************
* 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
}
}