/*******************************************************************************
* Copyright(c) 2014 DongkeSoft All rights reserved. / Confidential
* 类的信息:
* 1.程序名称:F_PM_3401.cs
* 2.功能描述:成品检验一览
* 编辑履历:
* 作者 日期 版本 修改内容
* 王鑫 2014/10/18 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.Basics.Library;
using Dongke.IBOSS.PRD.Client.CommonModule;
using Dongke.IBOSS.PRD.Client.Controls;
using Dongke.IBOSS.PRD.Client.DataModels;
using Dongke.IBOSS.PRD.WCF.DataModels;
using Dongke.IBOSS.PRD.WCF.DataModels.PMModule;
using Dongke.IBOSS.PRD.WCF.Proxys;
namespace Dongke.IBOSS.PRD.Client.PMModule
{
///
/// 成品检验一览
///
public partial class F_PM_3401 : DKDockPanelBase
{
#region 成员变量
private static F_PM_3401 _instance;
// 最后选择行
private int _selecedRow;
#endregion
#region 构造函数
public F_PM_3401()
{
InitializeComponent();
this.tsbtnAdd.Text = ButtonText.TSBTN_ADD;
//撤销
this.tsbtnFinishedCancle.Text = ButtonText.TSBTN_FINISHEDCANCELHANDOVER;
//自动适应列宽
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 单例模式
///
/// 单例模式,防止重复创建窗体
///
public static F_PM_3401 Instance
{
get
{
if (_instance == null)
{
_instance = new F_PM_3401();
}
return _instance;
}
}
/////
///// 一个工序ID有一个单例,防止重复创建窗体
/////
///// 工序ID
/////
//public static F_PM_3401 Instance(int procedureID, string fromTitle)
//{
// F_PM_3401 fInstance = null;
// if (_dicInstance == null)
// {
// _dicInstance = new Dictionary();
// fInstance = new F_PM_3401();
// _dicInstance.Add(procedureID, fInstance);
// }
// else if (_dicInstance.ContainsKey(procedureID))
// {
// fInstance = _dicInstance[procedureID];
// }
// else
// {
// fInstance = new F_PM_3401();
// _dicInstance.Add(procedureID, fInstance);
// }
// fInstance._currentProcedureID = procedureID;
// fInstance._fromTitle = fromTitle;
// fInstance.Text = fromTitle;
// return fInstance;
//}
#endregion
#region 事件
///
/// 窗体加载事件
///
///
///
private void F_PM_3401_Load(object sender, System.EventArgs e)
{
try
{
// 加载权限
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);
// 设置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_3401_FormClosed(object sender, System.Windows.Forms.FormClosedEventArgs e)
{
_instance = 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;
}
///
/// 查询按钮事件
///
///
///
private void btnSearch_Click(object sender, EventArgs e)
{
try
{
// 记录当前选中行
int selectRowIndex = this._selecedRow;
// 异步处理
this.btnSearch.Enabled = false;
this.btnClearCondition.Enabled = false;
SearchProductionDataEntity requestEntity = CreatesearchProductionDataRequestEntity();
ClientRequestEntity cre = new ClientRequestEntity();
cre.NameSpace = "F_PM_3401";
cre.Name = "GetProductionData";
cre.Properties.Add("RequestEntity", JsonHelper.ToJson(requestEntity));
ServiceResultEntity sre = DoAsync(() =>
{
return PCModuleProxyNew.Service.HandleRequest(cre);
});
if (sre.Data != null && sre.Data.Tables.Count > 0 )
{
DataTable dtProductionData = sre.Data.Tables[0].Copy();
dtProductionData.TableName = "dtProductionData";
//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)
{
tsbtnFinishedCancle.Enabled = true;
this.dgvProduction.DataSource = this.DataSource.Tables[0];
selectRowIndex = 0;
if (this.DataSource.Tables[0].Rows.Count <= Constant.INT_IS_ZERO)
{
tsbtnFinishedCancle.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_3402 frmPM3402 = new F_PM_3402(12, "成品检验");
DialogResult dialogResult = frmPM3402.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;
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 tsbtnFinishedCancle_Click(object sender, EventArgs e)
{
try
{
if (this.dgvProduction.CurrentRow != null)
{
int ProductionDataID = Convert.ToInt32(this.dgvProduction.CurrentRow.Cells["ProductionDataID"].Value);
ClientRequestEntity cre = new ClientRequestEntity();
cre.NameSpace = "F_PM_3401";
cre.Name = "FinishedCancleData";
cre.Properties.Add("ProductionDataID", ProductionDataID);
ServiceResultEntity sre = DoAsync(() =>
{
return PCModuleProxyNew.Service.HandleRequest(cre);
});
//撤销成功
if (sre.OtherStatus > 0)
{
// 提示信息
MessageBox.Show(string.Format(Messages.MSG_CMN_I001, this.Text, "撤销"),
this.Text, MessageBoxButtons.OK, MessageBoxIcon.Information);
this.btnSearch_Click(sender,e);
}
// 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.tsbtnFinishedCancle.Enabled = true;
}
else
{
this.tsbtnFinishedCancle.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 = "";
// 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;
//result.ProcedureID = 12;
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();
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
}
}