179 lines
6.7 KiB
C#
179 lines
6.7 KiB
C#
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 fSaveCostData : FCOMMON.fBase
|
|
{
|
|
dsPRJ.EETGW_SaveCostRow dr = null;
|
|
public fSaveCostData(dsPRJ.EETGW_SaveCostRow pidx_)
|
|
{
|
|
InitializeComponent();
|
|
this.UseFormSetting = false;
|
|
this.dr = pidx_;
|
|
this.dsPRJ.ProjectsHistory.TableNewRow += ProjectsHistory_TableNewRow;
|
|
}
|
|
|
|
void ProjectsHistory_TableNewRow(object sender, DataTableNewRowEventArgs e)
|
|
{
|
|
e.Row["wuid"] = FCOMMON.info.Login.no;
|
|
e.Row["wdate"] = DateTime.Now;
|
|
e.Row["pidx"] = this.dr.idx;
|
|
e.Row["div"] = "";
|
|
e.Row["remark"] = string.Empty;
|
|
e.Row["pdate"] = DateTime.Now.ToShortDateString();
|
|
}
|
|
private void fProjectData_Load(object sender, EventArgs e)
|
|
{
|
|
//상태
|
|
var dt_eetproc = FCOMMON.DBM.getCodeTable("10");
|
|
this.cmbProcess.DisplayMember = "Value";
|
|
this.cmbProcess.ValueMember = "Value";
|
|
this.cmbProcess.DataSource = dt_eetproc;
|
|
|
|
//파트
|
|
var dt_part = FCOMMON.DBM.getCodeTable("11");
|
|
this.cmbPart.DisplayMember = "Value";
|
|
this.cmbPart.ValueMember = "Value";
|
|
this.cmbPart.DataSource = dt_part;
|
|
|
|
|
|
var db = new EEEntities();
|
|
|
|
//담당파트목록
|
|
var lst_uid = db.EETGW_SaveCost.Where(t => string.IsNullOrEmpty(t.eepart) == false).OrderBy(t => t.eepart).GroupBy(t => t.eepart).Select(t => t.FirstOrDefault());
|
|
this.cmbEEPart.Items.AddRange(lst_uid.Select(t => t.eepart).ToArray());
|
|
|
|
//WorkGroup
|
|
var lst_wgp = db.EETGW_SaveCost.Where(t => string.IsNullOrEmpty(t.workgroup) == false).OrderBy(t => t.workgroup).GroupBy(t => t.workgroup).Select(t => t.FirstOrDefault());
|
|
this.cmbWorkgrp.Items.AddRange(lst_wgp.Select(t => t.workgroup).ToArray());
|
|
|
|
//Site
|
|
var lst_sit = db.EETGW_SaveCost.Where(t => string.IsNullOrEmpty(t.site) == false).OrderBy(t => t.site).GroupBy(t => t.site).Select(t => t.FirstOrDefault());
|
|
this.cmbSite.Items.AddRange(lst_sit.Select(t => t.site).ToArray());
|
|
|
|
//category
|
|
var lst_cat = db.EETGW_SaveCost.Where(t => string.IsNullOrEmpty(t.category) == false).OrderBy(t => t.category).GroupBy(t => t.category).Select(t => t.FirstOrDefault());
|
|
this.cmbCate.Items.AddRange(lst_cat.Select(t => t.category).ToArray());
|
|
|
|
//Sub Cate
|
|
var lst_sct = db.EETGW_SaveCost.Where(t => string.IsNullOrEmpty(t.subcate) == false).OrderBy(t => t.subcate).GroupBy(t => t.subcate).Select(t => t.FirstOrDefault());
|
|
this.cmbsubCate.Items.AddRange(lst_sct.Select(t => t.subcate).ToArray());
|
|
|
|
|
|
//site 기본값
|
|
var prelist = new string[] { "ATK", "ATC", "ATEP", "ATP", "J-Device" };
|
|
foreach (var item in prelist)
|
|
if (cmbSite.Items.Contains(item) == false) cmbSite.Items.Add(item);
|
|
|
|
//기본값(담당파트)
|
|
prelist = new string[] { "EE1", "EE2", "K5EE" };
|
|
foreach (var item in prelist)
|
|
if (cmbEEPart.Items.Contains(item) == false) cmbEEPart.Items.Add(item);
|
|
|
|
|
|
//기본값(워크그룹)
|
|
prelist = new string[] { "Automation", "Bump", "Development", "FOL", "EOL", "K5EE", "Machine Shop", "SMT", "TCDS" };
|
|
foreach (var item in prelist)
|
|
if (cmbWorkgrp.Items.Contains(item) == false) cmbWorkgrp.Items.Add(item);
|
|
|
|
|
|
//기본값추가
|
|
prelist = new string[] { "Capex", "R&M" };
|
|
foreach (var item in prelist)
|
|
if (cmbCate.Items.Contains(item) == false) cmbCate.Items.Add(item);
|
|
|
|
//sub category
|
|
prelist = new string[] { "비용절감", "생산성", "자동화", "품질", "환경안전" };
|
|
foreach (var item in prelist)
|
|
if (cmbsubCate.Items.Contains(item) == false) cmbsubCate.Items.Add(item);
|
|
|
|
|
|
this.bs.DataSource = dr;
|
|
|
|
this.cmbProcess.Text = dr.process;
|
|
this.cmbPart.Text = dr.part;
|
|
|
|
//일반사용자의경우에는 상태를 변경하지 못한다.
|
|
int curLevel = Math.Max(FCOMMON.info.Login.level, FCOMMON.DBM.getAuth(FCOMMON.DBM.eAuthType.project));
|
|
if (curLevel >= 5)
|
|
{
|
|
|
|
}
|
|
else
|
|
{
|
|
|
|
}
|
|
}
|
|
|
|
|
|
private void btSave_Click(object sender, EventArgs e)
|
|
{
|
|
this.dr.process = cmbProcess.Text;
|
|
this.dr.part = cmbPart.Text;
|
|
this.dr.edate = edateTextBox.Text;
|
|
|
|
|
|
|
|
this.Validate();
|
|
this.bs.EndEdit();
|
|
|
|
this.DialogResult = System.Windows.Forms.DialogResult.OK;
|
|
//this.tableAdapterManager.UpdateAll(this.dsPRJ);
|
|
}
|
|
|
|
|
|
|
|
void SelectDate(TextBox ctl)
|
|
{
|
|
DateTime dt;
|
|
var dateStr = ctl.Text.Trim();
|
|
if (dateStr == "") dateStr = DateTime.Now.ToShortDateString();
|
|
else
|
|
{
|
|
if (DateTime.TryParse(dateStr, out dt)) dateStr = dt.ToShortDateString();
|
|
else
|
|
{
|
|
FCOMMON.Util.MsgE("날짜 형식으로 변환할 수 없는 문자열 입니다.\n" +
|
|
"기준일자가 금일로 변경 됩니다");
|
|
dateStr = DateTime.Now.ToShortDateString();
|
|
}
|
|
}
|
|
dt = DateTime.Parse(dateStr);
|
|
var f = new FCOMMON.fSelectDay(dt);
|
|
if (f.ShowDialog() == System.Windows.Forms.DialogResult.OK)
|
|
{
|
|
ctl.Text = f.dtPick.SelectionStart.ToShortDateString();
|
|
}
|
|
}
|
|
private void linkLabel2_LinkClicked(object sender, LinkLabelLinkClickedEventArgs e)
|
|
{
|
|
SelectDate(sdateTextBox);
|
|
}
|
|
|
|
private void linkLabel4_LinkClicked(object sender, LinkLabelLinkClickedEventArgs e)
|
|
{
|
|
SelectDate(edateTextBox);
|
|
}
|
|
|
|
|
|
private void bs_CurrentChanged(object sender, EventArgs e)
|
|
{
|
|
|
|
}
|
|
|
|
private void linkLabel1_LinkClicked(object sender, LinkLabelLinkClickedEventArgs e)
|
|
{
|
|
var f = new FCOMMON.fSFI("O",0f,0f);
|
|
if (f.ShowDialog() == DialogResult.OK)
|
|
textBox5.Text = f.Value.ToString("N2");
|
|
}
|
|
}
|
|
}
|