using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; using System.Text; using System.Windows.Forms; namespace FPJ0000 { public partial class fSCCheck : Form { dsPRJ.ProjectsPartDataTable dt; public fSCCheck(dsPRJ.ProjectsPartDataTable dt_) { InitializeComponent(); this.dt = dt_; this.FormClosed += __Closed; //this.bs.DataSource = dt; } private void __Load(object sender, EventArgs e) { //this.sd.Value = DateTime.Now.AddMonths(-1); //this.dtPdate.Value = DateTime.Now; textBox1.AllowDrop = true; this.textBox1.DragDrop += TextBox1_DragDrop; this.textBox1.DragEnter += TextBox1_DragEnter; } private void TextBox1_DragEnter(object sender, DragEventArgs e) { e.Effect = DragDropEffects.All; } private void TextBox1_DragDrop(object sender, DragEventArgs e) { var files = (string[])e.Data.GetData(DataFormats.FileDrop, false); if (files != null && files.Length > 0) { var file = files[0]; if (System.IO.File.Exists(file)) { textBox1.Text = file; } } } void __Closed(object sender, FormClosedEventArgs e) { } private void linkLabel1_LinkClicked(object sender, LinkLabelLinkClickedEventArgs e) { OpenFileDialog od = new OpenFileDialog(); od.Filter = "excel|*.xlsx|all files|*.*"; od.RestoreDirectory = true; od.FilterIndex = 1; od.RestoreDirectory = true; if (od.ShowDialog() != System.Windows.Forms.DialogResult.OK) return; textBox1.Text = od.FileName; } private void button1_Click(object sender, EventArgs e) { if (textBox1.Text == "") { FCOMMON.Util.MsgE("파일을 선택하세요"); textBox1.Focus(); return; } if (!System.IO.File.Exists(textBox1.Text)) { FCOMMON.Util.MsgE("입력하신 파일이 존재하지 않습니다."); textBox1.Focus(); textBox1.SelectAll(); return; } this.dsPRJ.ProjectsPart.Clear(); this.dsPRJ.ProjectsPart.AcceptChanges(); libxl.Book book;// = new libxl.BinBook(); book = new libxl.XmlBook(); book.setKey(FCOMMON.info.libxlCompany, FCOMMON.info.libxlKey); try { book.load(textBox1.Text); } catch (Exception ex) { FCOMMON.Util.MsgE(ex.Message); return; } int sheetNum = (int)numericUpDown1.Value; if (sheetNum > book.sheetCount()) { FCOMMON.Util.MsgE("입력한 시트 번호는 존재하지 않습니다."); book = null; return; } var sheet = book.getSheet(sheetNum - 1); var MaxRow = sheet.lastRow(); var MinRow = sheet.firstRow(); MaxRow = (int)Math.Min(MaxRow, nudE.Value - 1); MinRow = (int)Math.Max(MinRow, nudS.Value - 1); string SID = ""; string 수량 = ""; string 단가 = ""; string PO = ""; string 품명 = ""; string 공급사 = ""; this.progressBar1.Value = 0; this.progressBar1.Maximum = MaxRow - MinRow + 1; this.dv1.Visible = false; try { for (int r = MinRow; r <= MaxRow; r++) { progressBar1.Value += 1; //필수값을 먼저 확인한다. if (nudSID.Value > 0) SID = sheet.readStr(r, (int)nudSID.Value - 1).Trim(); if (nudQty.Value > 0) 수량 = sheet.readStr(r, (int)nudQty.Value - 1).Replace(",", "").Trim(); if (nudPrice.Value > 0) 단가 = sheet.readStr(r, (int)nudPrice.Value - 1).Replace(",", "").Trim(); if (nudPO.Value > 0) PO = sheet.readStr(r, (int)nudPO.Value - 1).Trim(); if (nudSupply.Value > 0) 공급사 = sheet.readStr(r, (int)nudSupply.Value - 1).Trim(); if (nudName.Value > 0) 품명 = sheet.readStr(r, (int)nudName.Value - 1).Trim(); var qty = 0; var price = 0; //sid 공백과 - _ 제거 200506 SID = SID.Replace(" ", "").Replace("-", "").Replace("_", "").Trim(); //필수자료갸ㅏ 없는 경우처리하지 않음 if (PO.Trim() == "") continue; var newdr = this.dsPRJ.SCTable.NewSCTableRow(); newdr.PName = 품명; newdr.SID = SID; newdr.Qty = 0; newdr.Price = 0; newdr.Supply = 공급사; newdr.PO = PO; if (단가 != "") newdr.Price = decimal.Parse(단가); if (수량 != "") newdr.Qty = int.Parse(수량); this.dsPRJ.SCTable.AddSCTableRow(newdr); } //this.dsPRJ.ProjectsPart.AcceptChanges(); } catch (Exception ex) { FCOMMON.Util.MsgE("불러오는 중 오류 발생\n" + ex.Message); } // book = null; //sbSum.Text = string.Format("합계:{0:N0}원", sumamt); //this.bs.DataSource = dt; //this.bn.BindingSource = this.bs; //this.dataGridView1.AutoGenerateColumns = true; //this.dataGridView1.DataSource = this.bs; this.dv1.Visible = true; if (this.bs.Count < 1) { FCOMMON.Util.MsgE("입력된 자료가 없습니다.\n\n지정된 엑셀의 1번째 칸에 값이 없다면 입력되지 않습니다."); } } private void button2_Click(object sender, EventArgs e) { var dlg = FCOMMON.Util.MsgQ("데이터의 SID를 ITEM정보와 확인하여 업데이트 합니다."); if (dlg != System.Windows.Forms.DialogResult.Yes) return; var i = FCOMMON.DBM.UpdateItemIndexbySID(); FCOMMON.Util.MsgI(i.ToString() + "건의 자료가 업데이트 되었습니다."); } private void numericUpDown6_ValueChanged(object sender, EventArgs e) { var ctl = sender as NumericUpDown; if (ctl.Value == 0) ctl.BackColor = Color.Gray; else ctl.BackColor = Color.White; } private void toolStripButton1_Click(object sender, EventArgs e) { //저장버튼 if (dsPRJ.ProjectsPart.Rows.Count < 1) { FCOMMON.Util.MsgE("등록 가능한 자료가 없습니다."); return; } System.Text.StringBuilder sb = new StringBuilder(); sb.AppendLine("다음 자료를 추가하시겠습니까?"); sb.AppendLine(); sb.AppendLine("'저장 완료' 메세지가 나올때 까지 기다려 주세요."); sb.AppendLine(); sb.AppendLine("실행 하려면 '예' 를 누르세요"); var dlg = FCOMMON.Util.MsgQ(sb.ToString()); if (dlg != System.Windows.Forms.DialogResult.Yes) return; ta.Update(this.dsPRJ.ProjectsPart); dsPRJ.ProjectsPart.AcceptChanges(); FCOMMON.Util.MsgI("Save OK"); } private void toolStripButton1_Click_1(object sender, EventArgs e) { var dlg = FCOMMON.Util.MsgQ("SID별 수량 검사를 진행합니다. \n\n구매여부가 자동 선택되며 특이 사항은 비고에 추가 됩니다"); if (dlg != DialogResult.Yes) return; //Sctable 데이터를 sid 별 그룹으로 처리해야함 var sclist = this.dsPRJ.SCTable.GroupBy(t => t.SID); this.progressBar1.Maximum = sclist.Count() ; this.progressBar1.Value = 0; //sc list 의 isd목록을 회전해서,, 파트리스트의 목록과 비교한다. foreach(var scgrp in sclist) { //progress bar if(this.progressBar1.Value < this.progressBar1.Maximum) this.progressBar1.Value += 1; var dr = scgrp.FirstOrDefault(); var sid = dr.SID; var price = dr.Price; var supply = dr.Supply; var qtysum = scgrp.Sum(t => t.Qty); var ptlist = this.dt.Where(t => t.ItemSid == sid); var qtysumPt = ptlist.Sum(t => t.qtybuy); //sc와 pt 의 수량이 다르면 문제이다 if(qtysum != qtysumPt) { var ermsg = "[SC:수량불일치 엑셀:" + qtysum.ToString() + "/파트:" + qtysumPt.ToString() + "]"; foreach (var ptdata in ptlist) { var memo = ptdata.memo; if(memo.StartsWith("[SC:")==false) { ptdata.memo = ermsg + memo;// ptdata.memo; } else { ptdata.memo = ermsg + memo.Substring(memo.IndexOf("]")); } ptdata.EndEdit(); } } else { //수량이 같으면 잘 된거다 // var ermsg = "[SC:수량일치 엑셀:" + qtysum.ToString() + "/파트:" + qtysumPt.ToString() + "]"; foreach (var ptdata in ptlist) { ptdata.bbuy = true; ptdata.price = price; ptdata.ItemSupply = supply; ptdata.ItemSupplyidx = -1; //var memo = ptdata.memo; //if (memo.StartsWith("[SC:") == false) //{ // ptdata.memo = ermsg + memo;// ptdata.memo; //} //else //{ // ptdata.memo = ermsg + memo.Substring(memo.IndexOf("]")); //} ptdata.EndEdit(); } } } } private void toolStripButton2_Click(object sender, EventArgs e) { var dlg = FCOMMON.Util.MsgQ("모든 자료의 구매 확정상태가 해제 됩니다"); if (dlg != DialogResult.Yes) return; foreach (var item in this.dt) { item.bbuy = false; item.EndEdit(); } } } }