C#
C# - PDA 프로그램 개발 업데이트
이준호
2023. 3. 12. 20:03
반응형
using System;
using System.Linq;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Text;
using System.Windows.Forms;
using System.Data.SqlClient;
using System.Threading;
namespace JCNH_MES_PDA
{
public partial class Main : Form
{
public Main()
{
InitializeComponent();
}
#region Load Method
private void Main_Load(object sender, EventArgs e)
{
this.SetGrid();
}
#endregion
#region User Method
/// <summary>
/// 지시 -> 시작 ! 메서드
/// </summary>
/// <param name="ordCD"></param>
private void StartOrd(string ordCD)
{
SqlCommand Cmd = new SqlCommand();
Cmd.Connection = new SqlConnection(Common.DBConn);
Cmd.CommandType = CommandType.StoredProcedure;
Cmd.CommandText = "USP_PDA_SET_MGR_SUNGUAPROCESS_START";
Cmd.Parameters.Add(new SqlParameter("@ORDCD", ordCD));
SqlTransaction trans = null;
try
{
Cursor.Current = Cursors.WaitCursor;
Cmd.Connection.Open();
trans = Cmd.Connection.BeginTransaction();
Cmd.Transaction = trans;
Cmd.ExecuteNonQuery();
trans.Commit();
}
catch (Exception ex)
{
trans.Rollback();
MessageBox.Show(ex.Message);
}
finally
{
Cursor.Current = Cursors.Default;
Cmd.Connection.Close();
}
}
/// <summary>
/// 지시 번호 DB 저장 메서드
/// </summary>
/// <param name="dt"></param>
private void SaveOrdNo(DataTable dt)
{
SqlCommand Cmd = new SqlCommand();
Cmd.Connection = new SqlConnection(Common.DBConn);
Cmd.CommandType = CommandType.StoredProcedure;
Cmd.CommandText = "USP_PDA_SET_REG_MGR_SUNGUAPROCESSORD_ORDNO";
SqlTransaction trans = null;
int cnt = 0;
try
{
Cmd.Connection.Open();
trans = Cmd.Connection.BeginTransaction();
Cmd.Transaction = trans;
foreach (DataRow dr in dt.Rows)
{
Cmd.Parameters.Clear();
Cmd.Parameters.Add(new SqlParameter("@SUNGUAPROCESSORDCD", Convert.ToString(dr["지시"]).Trim()));
Cmd.Parameters.Add(new SqlParameter("@ORDNO", ++cnt));
Cmd.ExecuteNonQuery();
}
trans.Commit();
}
catch (Exception ex)
{
trans.Rollback();
MessageBox.Show(ex.Message);
}
finally
{
Cmd.Connection.Close();
}
}
/// <summary>
/// 그리드 세팅 메서드
/// </summary>
private void SetGrid()
{
object isComplete = false;
if (this.Rbtn_Complete.Checked)
isComplete = true;
SqlCommand Cmd = new SqlCommand();
Cmd.Connection = new SqlConnection(Common.DBConn);
Cmd.CommandType = CommandType.StoredProcedure;
Cmd.CommandText = "USP_PDA_GET_LIST_MGR_SUNGUAPROCESS";
Cmd.Parameters.Add(new SqlParameter("@ISCOMPLETE", isComplete));
DataTable dt = new DataTable();
try
{
Cursor.Current = Cursors.WaitCursor;
Cmd.Connection.Open();
SqlDataAdapter adp = new SqlDataAdapter(Cmd);
adp.Fill(dt);
this.Grid_List.DataSource = dt;
this.Txt_BarFocus();
}
catch (Exception ex)
{
MessageBox.Show(ex.Message);
}
finally
{
Cmd.Connection.Close();
Cursor.Current = Cursors.Default;
}
}
#endregion
#region Control Method
/// <summary>
/// 업버튼 클릭 이벤트
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void Btn_GoUp_Click(object sender, EventArgs e)
{
try
{
Cursor.Current = Cursors.WaitCursor;
if (!this.Rbtn_Ord.Checked)
return;
int prevRowIndex = this.Grid_List.CurrentRowIndex - 1;
if (prevRowIndex < 0)
return;
string statusNM = Convert.ToString(this.Grid_List[this.Grid_List.CurrentRowIndex - 1, 0]).Trim();
if (statusNM.Equals("작업"))
return;
DataTable dt = this.Grid_List.DataSource as DataTable;
DataRow dr = dt.NewRow();
dr[0] = dt.Rows[this.Grid_List.CurrentRowIndex - 1][0];
dr[1] = dt.Rows[this.Grid_List.CurrentRowIndex - 1][1];
dr[2] = dt.Rows[this.Grid_List.CurrentRowIndex - 1][2];
dr[3] = dt.Rows[this.Grid_List.CurrentRowIndex - 1][3];
dt.Rows.InsertAt(dr, this.Grid_List.CurrentRowIndex + 1);
dt.Rows.RemoveAt(this.Grid_List.CurrentRowIndex - 1);
dt.AcceptChanges();
this.SaveOrdNo(dt);
}
catch (Exception ex)
{
MessageBox.Show(ex.Message);
}
finally
{
Cursor.Current = Cursors.Default;
this.Txt_BarFocus();
}
}
/// <summary>
/// 다운 버튼 클릭 이벤트
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void Btn_GoDown_Click(object sender, EventArgs e)
{
try
{
Cursor.Current = Cursors.WaitCursor;
if (!this.Rbtn_Ord.Checked)
return;
string statusNM = Convert.ToString(this.Grid_List[this.Grid_List.CurrentRowIndex, 0]).Trim();
if (statusNM.Equals("작업"))
return;
DataTable dt = this.Grid_List.DataSource as DataTable;
if (dt.Rows.Count == (this.Grid_List.CurrentRowIndex + 1))
return;
DataRow dr = dt.NewRow();
dr[0] = dt.Rows[this.Grid_List.CurrentRowIndex][0];
dr[1] = dt.Rows[this.Grid_List.CurrentRowIndex][1];
dr[2] = dt.Rows[this.Grid_List.CurrentRowIndex][2];
dr[3] = dt.Rows[this.Grid_List.CurrentRowIndex][3];
dt.Rows.InsertAt(dr, this.Grid_List.CurrentRowIndex + 2);
dt.Rows.RemoveAt(this.Grid_List.CurrentRowIndex);
dt.AcceptChanges();
this.SaveOrdNo(dt);
}
catch (Exception ex)
{
MessageBox.Show(ex.Message);
}
finally
{
Cursor.Current = Cursors.Default;
this.Txt_BarFocus();
}
}
/// <summary>
/// 리프레시 버튼 이벤트
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void Btn_Refresh_Click(object sender, EventArgs e)
{
this.SetGrid();
this.Txt_BarFocus();
}
/// <summary>
/// 지시 라디오 버튼 클릭 이벤트
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void Rbtn_Ord_Click(object sender, EventArgs e)
{
this.SetGrid();
this.Txt_BarFocus();
}
/// <summary>
/// 완료 라디오버튼 클릭 이벤트
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void Rbtn_Complete_Click(object sender, EventArgs e)
{
this.SetGrid();
this.Txt_BarFocus();
}
/// <summary>
/// 텍스트 박스 바코드 키다운 이벤트
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void TxtBox_Barcode_KeyDown(object sender, KeyEventArgs e)
{
if (e.KeyData != Keys.Enter)
return;
string ordCD = this.TxtBox_Barcode.Text.Trim();
if (ordCD.Equals(""))
return;
this.SetGrid();
DataTable dt = this.Grid_List.DataSource as DataTable;
if (dt.Rows.Count < 1)
return;
string gridOrdCd = Convert.ToString(this.Grid_List[0, 1]).Trim();
if (ordCD != gridOrdCd)
{
MessageBox.Show("현재 순번의 접수증 번호가 아닙니다.");
this.TxtBox_Barcode.Text = "";
return;
}
this.StartOrd(ordCD);
this.SetGrid();
this.Txt_BarClear();
this.Txt_BarFocus();
}
/// <summary>
/// 로그인 버튼 이벤트
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void Btn_Login_Click(object sender, EventArgs e)
{
SqlCommand Cmd = new SqlCommand();
Cmd.Connection = new SqlConnection(Common.DBConn);
Cmd.CommandType = CommandType.StoredProcedure;
Cmd.CommandText = "USP_PDA_CHK_LOGIN";
object loginID = this.TxtBox_ID.Text.Trim();
object loginPwd = this.TxtBox_Pwd.Text.Trim();
Cmd.Parameters.Add(new SqlParameter("@LOGINID", loginID));
Cmd.Parameters.Add(new SqlParameter("@PASSWD", loginPwd));
try
{
Cmd.Connection.Open();
bool isUser = Convert.ToBoolean(Cmd.ExecuteScalar());
if (isUser)
{
this.Panel_Login.Visible = false;
this.Txt_BarFocus();
}
else
{
MessageBox.Show("사용자 정보가 올바르지 않습니다.");
}
}
catch (Exception ex)
{
MessageBox.Show(ex.Message);
}
finally
{
Cmd.Connection.Close();
}
}
private void Txt_BarClear()
{
Thread.Sleep(1000);
this.TxtBox_Barcode.Text = "";
}
private void Txt_BarFocus()
{
TxtBox_Barcode.Focus();
}
#endregion
private void Grid_List_Click(object sender, EventArgs e)
{
this.Txt_BarFocus();
}
private void Grid_List_DoubleClick(object sender, EventArgs e)
{
this.Txt_BarFocus();
}
private void Grid_List_GotFocus(object sender, EventArgs e)
{
this.Txt_BarFocus();
}
}
}
반응형