/*******************************************************************************
* Copyright(c) 2014 DongkeSoft All rights reserved. / Confidential
* 类的信息:
* 1.程序名称:F_PM_1401.cs
* 2.功能描述:在产产品数据
* 编辑履历:
* 作者 日期 版本 修改内容
* 宋扬 2014/10/22 1.00 新建
*******************************************************************************/
using System;
using System.Data;
using System.Text;
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_1401 : DockPanelBase
{
#region 成员变量
// 窗体的单例模式
private static F_PM_1401 _instance;
//在产产品实体类
private SearchInProductionEntity _inProductionEntity = new SearchInProductionEntity();
//生产线权限集
private string _productionLinePurviews = string.Empty;
//成型线权限集
private string _groutingLinePurviews = string.Empty;
//完成工序权限集
private string _procedurePurviews = string.Empty;
//生产工号权限集
private string _userPurviews = string.Empty;
#endregion
#region 构造函数
public F_PM_1401()
{
InitializeComponent();
//自动适应列宽
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;
// 窗体显示的Title
this.Text = FormTitles.F_PM_1401;
this.tsbtnMoreCondition.Text = ButtonText.TSBTN_MORECONDITION;
}
#endregion
#region 单例模式
///
/// 单例模式,防止重复创建窗体
///
public static F_PM_1401 Instance
{
get
{
if (_instance == null || _instance.IsDisposed)
{
_instance = new F_PM_1401();
}
return _instance;
}
}
#endregion
#region 事件
///
/// 窗体加载事件
///
///
///
private void F_PM_1401_Load(object sender, EventArgs e)
{
try
{
// 加载权限
FormPermissionManager.FormPermissionControl(this.Name, this,
LogInUserInfo.CurrentUser.CurrentUserEntity.UserRightData, LogInUserInfo.CurrentUser.CurrentUserEntity.FunctionData);
// 设置表格不自动创建列
this.dgvInProduction.AutoGenerateColumns = false;
// 初始化时间控件为当前日期
this.dtpCreateTimeStart.Value = new DateTime(DateTime.Now.Year, DateTime.Now.Month, DateTime.Now.Day);
this.dtpCreateTimeEnd.Value = new DateTime(DateTime.Now.Year, DateTime.Now.Month, DateTime.Now.Day);
}
catch (Exception ex)
{
// 对异常进行共通处理
ExceptionManager.HandleEventException(this.ToString(),
System.Reflection.MethodBase.GetCurrentMethod().Name, this.Text, ex);
}
}
///
/// 窗体关闭事件
///
///
///
private void F_PM_1401_FormClosed(object sender, FormClosedEventArgs e)
{
_instance = null;
}
///
/// 关闭按钮事件
///
///
///
private void tsbtnClose_Click(object sender, EventArgs e)
{
this.Close();
}
///
/// 查询按钮事件
///
///
///
private void btnSearch_Click(object sender, EventArgs e)
{
try
{
SearchInProductionEntity requestEntity = CreatesearchProductionDataRequestEntity();
DataSet dsInProductioData = (DataSet)DoAsync(new AsyncMethod(() =>
{
return PMModuleProxy.Service.GetInProductionData(requestEntity);
}));
if (dsInProductioData != null)
{
if (dsInProductioData.Tables[Constant.INT_IS_ZERO].Rows.Count <= Constant.INT_IS_ZERO)
{
// 提示未查找到数据
MessageBox.Show(Messages.MSG_CMN_I002, this.Text,
MessageBoxButtons.OK, MessageBoxIcon.Information);
//清空数据
this.dgvInProduction.DataSource = null;
}
else
{
this.dgvInProduction.DataSource = dsInProductioData.Tables[Constant.INT_IS_ZERO];
}
}
}
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 tsbtnAdaptive_Click(object sender, EventArgs e)
{
this.dgvInProduction.AutoResizeColumns(DataGridViewAutoSizeColumnsMode.AllCells);
}
///
/// 清空条件按钮事件
///
///
///
private void btnClearCondition_Click(object sender, EventArgs e)
{
//清空更多条件内容
this.scbGoods.ClearValue();
this.scbGMouldType.ClearValue();
this.scbGroutingLine.ClearValue();
this.dkProcedureSearchBox.ClearControl();
this.dkproductionLineSearchBox.ClearControl();
this.scbUser.ClearValue();
this.dtpCreateTimeStart.Value = new DateTime(DateTime.Now.Year, DateTime.Now.Month, DateTime.Now.Day);
this.dtpCreateTimeEnd.Value = new DateTime(DateTime.Now.Year, DateTime.Now.Month, DateTime.Now.Day);
}
///
/// 更多条件按钮事件
///
///
///
private void tsbtnMoreCondition_Click(object sender, EventArgs e)
{
F_PM_1402 fpm1402 = new F_PM_1402();
fpm1402.searchInProductionEntity = _inProductionEntity;
if (fpm1402.ShowDialog() == DialogResult.OK)
{
this._inProductionEntity = fpm1402.searchInProductionEntity;
}
}
#endregion
#region 私有方法
///
/// 搜索条件
///
///
private SearchInProductionEntity CreatesearchProductionDataRequestEntity()
{
SearchInProductionEntity searchInProductionEntity = new SearchInProductionEntity();
searchInProductionEntity.BarCode = this.txtBarCode.Text.Trim();
searchInProductionEntity.GoodsIDS = this.scbGoods.CheckedPKMember;
searchInProductionEntity.ProductionLineIDS = this.dkproductionLineSearchBox.ProductionLineIDS;
searchInProductionEntity.ProcedureIDS = this.dkProcedureSearchBox.ProcedureIDS;
searchInProductionEntity.GMouldTypeIDS = this.scbGMouldType.CheckedPKMember;
searchInProductionEntity.UserIDS = scbUser.CheckedPKMember;
searchInProductionEntity.GroutingLineIDS = this.scbGroutingLine.CheckedPKMember;
string createTimeStart = this.dtpCreateTimeStart.Value.ToString("yyyy-MM-dd") + " 0:0:0";
searchInProductionEntity.CreateTimeStart = Convert.ToDateTime(createTimeStart);
string createTimeEnd = this.dtpCreateTimeEnd.Value.ToString("yyyy-MM-dd") + " 23:59:59";
searchInProductionEntity.CreateTimeEnd = Convert.ToDateTime(createTimeEnd);
return searchInProductionEntity;
}
///
/// 获取当前用户的权限
///
protected void getPurview()
{
try
{
//得到生产线查看权限
StringBuilder sbProductionlinePurview = new StringBuilder();
DataSet dsProductionlinePurview = (DataSet)DoAsync(new AsyncMethod(() =>
{
return SystemModuleProxy.Service.GetUserPurview(7, LogInUserInfo.CurrentUser.UserID);
}));
if (dsProductionlinePurview != null)
{
foreach (DataRow dr in dsProductionlinePurview.Tables[Constant.INT_IS_ZERO].Rows)
{
sbProductionlinePurview.Append(dr[Constant.INT_IS_ZERO].ToString() + ",");
}
if (sbProductionlinePurview.Length != Constant.INT_IS_ZERO)
{
this._productionLinePurviews = sbProductionlinePurview.ToString().Substring(Constant.INT_IS_ZERO, sbProductionlinePurview.Length - 1);
this.dkproductionLineSearchBox.Purview = this._productionLinePurviews;
}
}
//得到工序查看权限
StringBuilder sbProcedurePurview = new StringBuilder();
DataSet dsProcedurePurview = (DataSet)DoAsync(new AsyncMethod(() =>
{
return SystemModuleProxy.Service.GetUserPurview(9, LogInUserInfo.CurrentUser.UserID);
}));
if (dsProcedurePurview != null)
{
foreach (DataRow dr in dsProcedurePurview.Tables[Constant.INT_IS_ZERO].Rows)
{
sbProcedurePurview.Append(dr[Constant.INT_IS_ZERO].ToString() + ",");
}
if (sbProcedurePurview.Length != Constant.INT_IS_ZERO)
{
this._procedurePurviews = sbProcedurePurview.ToString().Substring(Constant.INT_IS_ZERO, sbProcedurePurview.Length - 1);
this.dkProcedureSearchBox.Purview = this._procedurePurviews;
}
}
//得到成型线查看权限
//StringBuilder sbGroutingLinePurview = new StringBuilder();
//DataSet dsGroutingLinePurview = (DataSet)DoAsync(new AsyncMethod(() =>
//{
// return SystemModuleProxy.Service.GetUserPurview(5, LogInUserInfo.CurrentUser.UserID);
//}));
//if (dsGroutingLinePurview != null)
//{
// foreach (DataRow dr in dsGroutingLinePurview.Tables[Constant.INT_IS_ZERO].Rows)
// {
// sbGroutingLinePurview.Append(dr[Constant.INT_IS_ZERO].ToString() + ",");
// }
// if (sbGroutingLinePurview.Length != Constant.INT_IS_ZERO)
// {
// this._groutingLinePurviews = sbGroutingLinePurview.ToString().Substring(Constant.INT_IS_ZERO, sbGroutingLinePurview.Length - 1);
// this.dkGroutingLineSearchBox.Purview = this._groutingLinePurviews;
// }
//}
//得到生产工号查看权限
StringBuilder sbUserPurview = new StringBuilder();
DataSet dsUserPurview = (DataSet)DoAsync(new AsyncMethod(() =>
{
return SystemModuleProxy.Service.GetUserPurview(3, LogInUserInfo.CurrentUser.UserID);
}));
if (dsUserPurview != null)
{
foreach (DataRow dr in dsUserPurview.Tables[Constant.INT_IS_ZERO].Rows)
{
sbUserPurview.Append(dr[Constant.INT_IS_ZERO].ToString() + ",");
}
if (sbUserPurview.Length != Constant.INT_IS_ZERO)
{
this._userPurviews = sbUserPurview.ToString().Substring(Constant.INT_IS_ZERO, sbUserPurview.Length - 1);
}
}
}
catch (Exception ex)
{
throw ex;
}
}
#endregion
}
}