/*******************************************************************************
* Copyright(c) 2019 DongkeSoft All rights reserved. / Confidential
* 类的信息:
* 1.程序名称:F_PM_3201.cs
* 2.功能描述:半检一览
* 编辑履历:
* 作者 日期 版本 修改内容
* xuwei 2019-12-12 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_3201 : DockPanelBase
{
#region 成员变量
// 窗体的单例模式
private static Dictionary _dicInstance;
// 当前工序ID
private int _currentProcedureID = 0;
// 最后选择行
private int _selecedRow;
// 窗体显示的Title
private string _fromTitle;
#endregion
#region 构造函数
public F_PM_3201()
{
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;
this.Text = _fromTitle;
}
#endregion
#region 单例模式
///
/// 一个工序ID有一个单例,防止重复创建窗体
///
/// 工序ID
///
public static F_PM_3201 Instance(int procedureID, string fromTitle)
{
F_PM_3201 fInstance = null;
if (_dicInstance == null)
{
_dicInstance = new Dictionary();
fInstance = new F_PM_3201();
_dicInstance.Add(procedureID, fInstance);
}
else if (_dicInstance.ContainsKey(procedureID))
{
fInstance = _dicInstance[procedureID];
}
else
{
fInstance = new F_PM_3201();
_dicInstance.Add(procedureID, fInstance);
}
fInstance._currentProcedureID = procedureID;
fInstance._fromTitle = fromTitle;
fInstance.Text = fromTitle;
return fInstance;
}
#endregion
#region 事件
///
/// 窗体加载事件
///
///
///
private void F_PM_3201_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_3201_FormClosed(object sender, System.Windows.Forms.FormClosedEventArgs e)
{
_dicInstance = 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();
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)
{
tsbtnEdit.Enabled = true;
this.dgvProduction.DataSource = this.DataSource.Tables[0];
selectRowIndex = 0;
if (this.DataSource.Tables[0].Rows.Count <= Constant.INT_IS_ZERO)
{
tsbtnEdit.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_3202 frmPM3202 = new F_PM_3202(_currentProcedureID, _fromTitle);
DialogResult dialogResult = frmPM3202.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 tsbtnEdit_Click(object sender, EventArgs e)
{
try
{
if (this.dgvProduction.CurrentRow != null)
{
int ProductionDataID = Convert.ToInt32(this.dgvProduction.CurrentRow.Cells["ProductionDataID"].Value);
string BarCode = this.dgvProduction.CurrentRow.Cells["BarCode"].Value.ToString();
int CompleteProcedureID = (int)DoAsync(new AsyncMethod(() =>
{
return PMModuleProxy.Service.GetCompleteProcedureID(BarCode);
}));
bool isView = true;
if (CompleteProcedureID != -Constant.INT_IS_ONE && CompleteProcedureID == this._currentProcedureID)
{
// 尽管等于当前工序,但是如果该条码又插入了一条生产数据,在编辑此数据时,也应该为只读,即重烧后添加的生产数据,编辑上一次生产数据ID
int CompleteProductionDataID = (int)DoAsync(new AsyncMethod(() =>
{
return PMModuleProxy.Service.GetCompleteProductionDataID(BarCode);
}));
if (ProductionDataID == CompleteProductionDataID)
{
//是否己报损,如果已经报损也是查看记录
//DataSet dsReturn = (DataSet)DoAsync(new AsyncMethod(() =>
//{
// return PMModuleProxy.Service.GetSubstandardInfo(BarCode);
//}));
//if (dsReturn != null && dsReturn.Tables[0].Rows.Count > 0) //有报损记录
//{
// if (this.dgvProduction.CurrentRow.Cells["GoodsGrade"].Value.ToString() != "次品")
// {
// isView = true;
// }
// else
// {
// isView = false;
// }
//}
//else
//{
// isView = false;
//}
//if(!isView)
//{
int auditstatus = (int)DoAsync(new AsyncMethod(() =>
{
return PMModuleProxy.Service.CheckScrapProduct(BarCode);
}));
if (auditstatus != -100)
{
isView = true;
}
else
{
isView = false;
}
// }
}
}
F_PM_3202 frmPM3202 = new F_PM_3202(_currentProcedureID, _fromTitle, ProductionDataID, isView);
DialogResult dialogResult = frmPM3202.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 = 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 = _currentProcedureID;
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
}
}