Esempio n. 1
0
 private void ToolStripMenuItem_BOMPartSearch_Click(object sender, EventArgs e)
 {
     ProgressRuning       = true;
     ProgressBarBot.Value = 0;
     this.treeViewLeft.Nodes.Clear();
     Task taskSync = Task.Factory.StartNew(() =>
     {
         var ds = ERP.GetJobMtl(false, false, tboxPartNum.Text);
         this.BeginInvoke(new Action(() =>
         {
             dataGridViewMain.DataSource = ds;
             DataCount                       = ds.Count;
             ProgressRuning                  = false;
             StatusLabelInfo.Text            = "共获取" + DataCount + "条数据";
             ProgressBarBot.Value            = 100;
             tabControlMain.SelectedIndex    = 0;
             tabControlMain.SelectedTab.Text = "ERP部件物料";
             CurrentDgv                      = dataGridViewMain;
         }));
     }, TaskCreationOptions.None);
 }
        private void BtnOK_Click(object sender, EventArgs e)
        {
            if (string.IsNullOrEmpty(tBoxPartNum.Text))
            {
                MessageBox.Show("物料编码必填!", "系统提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
                return;
            }
            if (string.IsNullOrEmpty(tBoxJobNum.Text) && radioJob.Checked)
            {
                MessageBox.Show("工单号必填!", "系统提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
                return;
            }
            BtnOK.Text    = "对比中...";
            BtnOK.Enabled = false;
            Task.Run(() =>
            {
                //获取ERP设计BOM
                ERP_DES_BOM = new List <DTO_MBOM>();
                ERP.GetERPBOM(tBoxPartNum.Text, ERP_DES_BOM, true, textBoxRev.Text);

                if (radioJob.Checked)
                {
                    //获取工单BOM
                    var JobAsmblDatas = ERP.GetJobAsmbl(tBoxJobNum.Text);
                    var JobMtlDatas   = ERP.GetJobMtl(tBoxJobNum.Text);
                    ERP_JOB_BOM       = new List <DTO_MBOM>();
                    string mainPart   = "";
                    try
                    {
                        mainPart = JobAsmblDatas.Where(o => o.JobNum == tBoxJobNum.Text && o.BomLevel == 0).FirstOrDefault().PartNum;
                    }
                    catch { }
                    ERP.GetJobBom(ERP_JOB_BOM, JobAsmblDatas, JobMtlDatas, mainPart);
                }
                else
                {
                    //获取PLMBOM
                    PLM_BOM = new List <DTO_MBOM>();
                    PLM.GetPLMBOM(tBoxPartNum.Text, PLM_BOM);
                }
                //List<DTO_MBOM> BOM_DIFF = CompareBOM(tBoxPartNum.Text, tBoxJobNum.Text);
                this.BeginInvoke(new Action(() =>
                {
                    BtnOK.Text    = "开始对比";
                    BtnOK.Enabled = true;
                    #region 导出对比结果
                    //var dt = Utility.ListToDataTable(BOM_DIFF, "_", "#");
                    //string rnd = Random.Next(0, 9999).ToString();
                    string filepath = SaveFolderPath + "\\" + tBoxPartNum.Text + "BOM_DIFF.xls";
                    long ticks      = DateTime.Now.Ticks;
                    if (radioJob.Checked)
                    {
                        filepath = SaveFolderPath + "\\DES_JOB_" + tBoxPartNum.Text + "_" + tBoxJobNum.Text + "_Compare" + ticks.ToString() + ".xls";
                        CreateDIFFBook(filepath, ERP_DES_BOM, ERP_JOB_BOM, "设计BOM", "工单BOM");
                    }
                    else
                    {
                        filepath = SaveFolderPath + "\\DES_PLM_" + tBoxPartNum.Text + "_Compare" + ticks.ToString() + ".xls";
                        CreateDIFFBook2(filepath, ERP_DES_BOM, PLM_BOM, "PLMBOM", "设计BOM");
                    }
                    //Utility.ExportExcel(dt, SaveFolderPath + "\\" + tBoxPartNum.Text + "BOM_DIFF" + rnd + ".xls");
                    System.Diagnostics.Process.Start(filepath);
                    #endregion
                }));
            });
        }