| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455 |
- /*******************************************************************************
- * Copyright(c) 2015 DongkeSoft All rights reserved. / Confidential
- * 类的信息:
- * 1.程序名称:F_RPT_030101_1.cs
- * 2.功能描述:工序产量统计表
- * 编辑履历:
- * 作者 日期 版本 修改内容
- * 袁新成 2015/4/14 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.Controls;
- using Dongke.IBOSS.PRD.Client.DataModels;
- using Dongke.IBOSS.PRD.WCF.DataModels;
- using Dongke.IBOSS.PRD.WCF.Proxys;
- namespace Dongke.IBOSS.PRD.Client.ReportModule
- {
- /// <summary>
- /// 产品产量汇总表
- /// </summary>
- public partial class F_RPT_030101_1 : DKDockPanelBase
- {
- #region 成员变量
- // 窗体的单例模式
- private static F_RPT_030101_1 _instance;
- //实体类
- private RPT030101_SE rptse = new RPT030101_SE();
- //默认清空工序,重置回用户当前权限工序
- private string _currentUserPurview = null;
- //默认清空生产线,重置回用户当前权限生产线
- private string _currentUserLinePuview = null;
- #endregion
- #region 构造函数
- public F_RPT_030101_1()
- {
- InitializeComponent();
- // 窗体显示的Title
- this.Text = FormTitles.F_RPT_030101;
- 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 单例模式
- /// <summary>
- /// 单例模式,防止重复创建窗体
- /// </summary>
- public static F_RPT_030101_1 Instance
- {
- get
- {
- if (_instance == null || _instance.IsDisposed)
- {
- _instance = new F_RPT_030101_1();
- }
- return _instance;
- }
- }
- #endregion
- #region 事件处理
- /// <summary>
- /// 窗体加载事件
- /// </summary>
- /// <param name="sender"></param>
- /// <param name="e"></param>
- private void F_RPT_030101_1_Load(object sender, EventArgs e)
- {
- try
- {
- // 加载权限
- FormPermissionManager.FormPermissionControl(this.Name, this,
- LogInUserInfo.CurrentUser.CurrentUserEntity.UserRightData, LogInUserInfo.CurrentUser.CurrentUserEntity.FunctionData);
- // 设置表格不自动创建列
- this.dgvReportModuleDetail.AutoGenerateColumns = false;
- this.dgvReportModule.AutoGenerateColumns = false;
- this.scbOrganization.Focus();
- this.dkproductionLineSearchBox.IsEnablePurview = true;
- this.dkProcedureSearchBox.IsEnablePurview = true;
- // 初始化时间控件为当前日期
- this.dtpAccountDateStart.Value = DateTime.Now.Date;
- this.dtpAccountDateEnd.Value = DateTime.Now.Date.AddDays(1).AddSeconds(-1);
- getPurview();
- getPurviewLine();
- }
- catch (Exception ex)
- {
- // 对异常进行共通处理
- ExceptionManager.HandleEventException(this.ToString(),
- System.Reflection.MethodBase.GetCurrentMethod().Name, this.Text, ex);
- }
- }
- /// <summary>
- /// 自动适应列宽
- /// </summary>
- /// <param name="sender"></param>
- /// <param name="e"></param>
- private void tsbtnAdaptive_Click(object sender, EventArgs e)
- {
- if (this.tblReportModule.SelectedIndex == Constant.INT_IS_ZERO)//产品产量汇总查询
- {
- this.dgvReportModule.AutoResizeColumns(DataGridViewAutoSizeColumnsMode.AllCells);
- }
- else//产品产量明细查询
- {
- this.dgvReportModuleDetail.AutoResizeColumns(DataGridViewAutoSizeColumnsMode.AllCells);
- }
- }
- /// <summary>
- /// 窗体关闭事件
- /// </summary>
- /// <param name="sender"></param>
- /// <param name="e"></param>
- private void F_RPT_030101_1_FormClosed(object sender, FormClosedEventArgs e)
- {
- _instance = null;
- }
- /// <summary>
- /// 关闭按钮
- /// </summary>
- /// <param name="sender"></param>
- /// <param name="e"></param>
- private void tsbtnClose_Click(object sender, EventArgs e)
- {
- this.Close();
- }
- /// <summary>
- /// 查询按钮事件
- /// </summary>
- /// <param name="sender"></param>
- /// <param name="e"></param>
- private void btnSearch_Click(object sender, EventArgs e)
- {
- try
- {
- if (string.IsNullOrEmpty(this._currentUserPurview))
- {
- // 提示未查找到数据
- MessageBox.Show(Messages.MSG_CMN_I002, this.Text,
- MessageBoxButtons.OK, MessageBoxIcon.Information);
- return;
- }
- CreateSearchCondition();
- if (this.tblReportModule.SelectedIndex == Constant.INT_IS_ZERO)
- {
- this.dgvReportModule.DataSource = null;
- this.dgvReportModule.DataSource = GetSearchTotalData();
- }
- else
- {
- this.dgvReportModuleDetail.DataSource = null;
- this.dgvReportModuleDetail.DataSource = GetSearchDetailData();
- }
- }
- catch (Exception ex)
- {
- this.btnSearch.Enabled = true;
- this.btnClearCondition.Enabled = true;
- // 对异常进行共通处理
- ExceptionManager.HandleEventException(this.ToString(),
- System.Reflection.MethodBase.GetCurrentMethod().Name, this.Text, ex);
- }
- }
- /// <summary>
- /// 清空条件按钮事件
- /// </summary>
- /// <param name="sender"></param>
- /// <param name="e"></param>
- private void btnClearCondition_Click(object sender, EventArgs e)
- {
- this.scbOrganization.ClearValue();
- this.scbGoods.ClearValue();
- this.scbGoodsType.ClearValue();
- this.dkProcedureSearchBox.ClearControl();
- this.dkproductionLineSearchBox.ClearControl();
- this.dtpAccountDateStart.Value = DateTime.Now.Date;
- this.dtpAccountDateEnd.Value = DateTime.Now.Date.AddDays(1).AddSeconds(-1);
- this.dkProcedureSearchBox.ProcedureIDS = this._currentUserPurview;
- this.dkproductionLineSearchBox.ProductionLineIDS = this._currentUserLinePuview;
- this.chkFlag.Checked = false;
- }
- /// <summary>
- /// 双击单元格事件
- /// </summary>
- /// <param name="sender"></param>
- /// <param name="e"></param>
- private void dgvReportModule_CellDoubleClick(object sender, DataGridViewCellEventArgs e)
- {
- try
- {
- if (this.dgvReportModule.CurrentRow == null)
- {
- return;
- }
- //获取数据信息
- DataGridViewRow dgvr = dgvReportModule.CurrentRow;
- string goodsId = dgvr.Cells["GoodsID"].Value.ToString();
- string procedureId = dgvr.Cells["Procedureid"].Value.ToString();
- if (goodsId.Equals("小计") || goodsId.Equals("--"))
- {
- return;
- }
- else
- {
- //跳转页
- this.tblReportModule.SelectTab(1);
- //获取条件
- CreateSearchCondition();
- rptse.GoodsIDS = goodsId.ToString();
- rptse.ProcedureIDS = procedureId.ToString();
- //清空数据
- this.dgvReportModuleDetail.DataSource = null;
- this.dgvReportModuleDetail.DataSource = GetSearchDetailData();
- }
- }
- catch (Exception ex)
- {
- this.btnSearch.Enabled = true;
- this.btnClearCondition.Enabled = true;
- // 对异常进行共通处理
- ExceptionManager.HandleEventException(this.ToString(),
- System.Reflection.MethodBase.GetCurrentMethod().Name, this.Text, ex);
- }
- }
- #endregion
- #region 私有方法
- /// <summary>
- /// 搜索条件
- /// </summary>
- /// <returns></returns>
- private void CreateSearchCondition()
- {
- rptse = new RPT030101_SE();
- rptse.OrganizationIDS = this.scbOrganization.CheckedPKMember;
- rptse.GoodsIDS = scbGoods.CheckedPKMember;
- rptse.GoodsTypeIDS = scbGoodsType.SearchedValue + "";
- rptse.ProductionLineIDS = this.dkproductionLineSearchBox.ProductionLineIDS;
- rptse.ProcedureIDS = this.dkProcedureSearchBox.ProcedureIDS;
- rptse.AccountDateStart = DateTime.Parse(this.dtpAccountDateStart.Value.ToString("yyyy-MM-dd HH:mm") + ":00");
- rptse.AccountDateEnd = DateTime.Parse(this.dtpAccountDateEnd.Value.ToString("yyyy-MM-dd HH:mm") + ":59");
- rptse.ProductionFlag = this.chkFlag.Checked ? "1" : "0";
- rptse.Building = this.BuildingNumber.Text.ToString();
- }
- /// <summary>
- /// 获取权限(生产线)
- /// </summary>
- protected void getPurviewLine()
- {
- try
- {
- StringBuilder sbProcedurePurview = new StringBuilder();
- //得到工序查看权限
- DataSet dsProcedurePurview = (DataSet)DoAsync(new AsyncMethod(() =>
- {
- return SystemModuleProxy.Service.GetUserPurview(7, LogInUserInfo.CurrentUser.UserID);
- }));
- if (dsProcedurePurview != null)
- {
- DataRow[] drPurview = dsProcedurePurview.Tables[Constant.INT_IS_ZERO].Select("PurviewID=-1");
- if (drPurview.Length == 0)
- {
- 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.dkproductionLineSearchBox.Purview = sbProcedurePurview.ToString().Substring(Constant.INT_IS_ZERO, sbProcedurePurview.Length - 1);
- this.dkproductionLineSearchBox.ProductionLineIDS = sbProcedurePurview.ToString().Substring(Constant.INT_IS_ZERO, sbProcedurePurview.Length - 1);
- this._currentUserLinePuview = sbProcedurePurview.ToString().Substring(Constant.INT_IS_ZERO, sbProcedurePurview.Length - 1);
- }
- }
- else
- {
- ProductionLineEntity line = new ProductionLineEntity();
- line.ValueFlags = new object[] { 1 };
- dsProcedurePurview = (DataSet)DoAsync(() =>
- {
- return PCModuleProxy.Service.SearchProductionLine(line);
- });
- foreach (DataRow dr in dsProcedurePurview.Tables[Constant.INT_IS_ZERO].Rows)
- {
- sbProcedurePurview.Append(dr["productionlineID"].ToString() + ",");
- }
- if (sbProcedurePurview.Length != Constant.INT_IS_ZERO)
- {
- this.dkproductionLineSearchBox.Purview = sbProcedurePurview.ToString().Substring(Constant.INT_IS_ZERO, sbProcedurePurview.Length - 1);
- this.dkproductionLineSearchBox.ProductionLineIDS = sbProcedurePurview.ToString().Substring(Constant.INT_IS_ZERO, sbProcedurePurview.Length - 1);
- this._currentUserLinePuview = sbProcedurePurview.ToString().Substring(Constant.INT_IS_ZERO, sbProcedurePurview.Length - 1);
- }
- }
- }
- }
- catch (Exception ex)
- {
- throw ex;
- }
- }
- /// <summary>
- /// 查询产品产量汇总表
- /// </summary>
- private DataTable GetSearchTotalData()
- {
- try
- {
- // 调用服务器端获取数据集
- ServiceResultEntity sre = DoAsync<ServiceResultEntity>(() =>
- {
- return ReportModuleProxy.Service.GetRPT030101SData(rptse);
- }
- );
- if (sre.Status == Constant.ServiceResultStatus.Success)
- {
- //if (sre.Data.Tables[0].Rows.Count <= Constant.INT_IS_ZERO)
- //{
- // // 提示未查找到数据
- // MessageBox.Show(Messages.MSG_CMN_I002, this.Text,
- // MessageBoxButtons.OK, MessageBoxIcon.Warning);
- // //清空数据
- // return null;
- //}
- return sre.Data.Tables[0];
- }
- return null;
- }
- catch (Exception ex)
- {
- throw ex;
- }
- }
- /// <summary>
- /// 查询损坏明细表
- /// </summary>
- private DataTable GetSearchDetailData()
- {
- try
- {
- // 调用服务器端获取数据集
- ServiceResultEntity sre = DoAsync<ServiceResultEntity>(() =>
- {
- return ReportModuleProxy.Service.GetRPT030101IData(rptse);
- }
- );
- if (sre.Status == Constant.ServiceResultStatus.Success)
- {
- //if (sre.Data.Tables[0].Rows.Count <= Constant.INT_IS_ZERO)
- //{
- // // 提示未查找到数据
- // MessageBox.Show(Messages.MSG_CMN_I002, this.Text,
- // MessageBoxButtons.OK, MessageBoxIcon.Warning);
- // //清空数据
- // return null;
- //}
- return sre.Data.Tables[0];
- }
- return null;
- }
- catch (Exception ex)
- {
- throw ex;
- }
- }
- /// <summary>
- /// 获取权限
- /// </summary>
- protected void getPurview()
- {
- try
- {
- StringBuilder sbProcedurePurview = new StringBuilder();
- //得到工序查看权限
- DataSet dsProcedurePurview = (DataSet)DoAsync(new AsyncMethod(() =>
- {
- return SystemModuleProxy.Service.GetUserPurview(9, LogInUserInfo.CurrentUser.UserID);
- }));
- if (dsProcedurePurview != null)
- {
- DataRow[] drPurview = dsProcedurePurview.Tables[Constant.INT_IS_ZERO].Select("PurviewID=-1");
- if (drPurview.Length == 0)
- {
- 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.dkProcedureSearchBox.Purview = sbProcedurePurview.ToString().Substring(Constant.INT_IS_ZERO, sbProcedurePurview.Length - 1);
- this.dkProcedureSearchBox.ProcedureIDS = sbProcedurePurview.ToString().Substring(Constant.INT_IS_ZERO, sbProcedurePurview.Length - 1);
- this._currentUserPurview = sbProcedurePurview.ToString().Substring(Constant.INT_IS_ZERO, sbProcedurePurview.Length - 1);
- }
- }
- else
- {
- SearchProductionLineEntity line = new SearchProductionLineEntity();
- dsProcedurePurview = SystemModuleProxy.Service.GetProdureList(line);
- foreach (DataRow dr in dsProcedurePurview.Tables[Constant.INT_IS_ZERO].Rows)
- {
- sbProcedurePurview.Append(dr["ProcedureID"].ToString() + ",");
- }
- if (sbProcedurePurview.Length != Constant.INT_IS_ZERO)
- {
- this.dkProcedureSearchBox.Purview = sbProcedurePurview.ToString().Substring(Constant.INT_IS_ZERO, sbProcedurePurview.Length - 1);
- this.dkProcedureSearchBox.ProcedureIDS = sbProcedurePurview.ToString().Substring(Constant.INT_IS_ZERO, sbProcedurePurview.Length - 1);
- this._currentUserPurview = sbProcedurePurview.ToString().Substring(Constant.INT_IS_ZERO, sbProcedurePurview.Length - 1);
- }
- }
- }
- }
- catch (Exception ex)
- {
- throw ex;
- }
- }
- #endregion
- }
- }
|