spc-kiosk-pb/Window/WinBasic/frmSaleOpen.cs
2019-06-16 14:12:09 +09:00

917 lines
43 KiB
C#

using System;
using System.Collections;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using Cosmos.UserFrame;
using Cosmos.BaseFrame;
using Cosmos.ServiceProvider;
using Cosmos.Common;
using Cosmos.CommonManager;
//using Microsoft.PointOfService;
namespace Cosmos.Win
{
public delegate void ProgressbarInitDelegate();
public delegate void ProgressbarUpdateDelegate(string sMstId, int nProgress);
public delegate void UpdateLabelDelegate(string sMsg);
public delegate void ShowUrgentDelegate(bool bShow);
public delegate void UpdateProgressBarStyleDelegate(ProgressBarStyle pbStyle);
public delegate void StepUpProgressBarDelegate(int iStep);
public delegate void PanelDelegate(bool bShow);
public partial class frmSaleOpen : Form, IFormSaleOpenUs
{
private SManager sManager = new SManager(); // 이 객체를 통해 업무 Service 호출
private StateServer StateObject = (StateServer)StateServer.GetInstance(); // StateObject : StateServer Object (객체)
private PosStatus m_cPosStatus = new PosStatus(); // 기본정보 참조
private TranStatus m_cTrnStatus = new TranStatus(); // 거래정보 참조
IMasterDownUs m_cMstDownSrv = null;
//private IServiceUs cDeviceSrv = null;
private static bool m_bIsOver = false;
/// <summary>
/// 마스터 수신일자
/// </summary>
private string m_sReqDateTime; // 수신일자
public string ReqDateTime { set { this.m_sReqDateTime = value; } get { return m_sReqDateTime; } }
/// <summary>
/// Background 마스터 수신일자
/// </summary>
private string m_sBGReqDateTime = string.Empty;
public string BGReqDateTime { set { this.m_sBGReqDateTime = value; } get { return m_sBGReqDateTime; } }
private string m_sMstDownOp = string.Empty;
public string MstDownOp { set { this.m_sMstDownOp = value; } get { return this.m_sMstDownOp; } }
/// <summary>
/// POS 주변장비 체크 여부
/// </summary>
private string m_sPeripheralChk;
public string PeripheralChk { set { this.m_sPeripheralChk = value; } get { return this.m_sPeripheralChk; } }
/// <summary>
/// 자동/수동 모드
/// </summary>
private string m_sManualMode;
public string ManualMode { set { m_sManualMode = value; } get { return m_sManualMode; } }
/// <summary>
/// 체크할 주변장치 목록
/// </summary>
private string[] aDeviceList = new string[] {
"POSPRINTER",
"ICREADER",
"SIGNPAD",
"CATTERMINAL",
"SCALE",
"SCALEPOLEDISP",
"LABELPRINTER",
//"CASHDRAWER",
//"SCANNER",
//"MSR",
//"NETWORK"
};
public frmSaleOpen()
{
InitializeComponent();
base.SetStyle(ControlStyles.OptimizedDoubleBuffer | ControlStyles.AllPaintingInWmPaint | ControlStyles.ResizeRedraw, true);
//this.UpdateStyles();
m_cPosStatus = (PosStatus)StateObject.POS; // POS 기본정보
m_cTrnStatus = (TranStatus)StateObject.TRAN; // POS 거래정보
m_cMstDownSrv = (IMasterDownUs)sManager.InitServiceInstance(ServiceLists.BSV_BASIC.DLL, ServiceLists.BSV_BASIC.MASTER_DOWN);
InitControl();
}
protected override void OnShown(EventArgs e)
{
UserLog.WriteLogFile(UserCom.LOG_IOS, System.Reflection.Assembly.GetExecutingAssembly().ManifestModule.Name,
System.Reflection.MethodBase.GetCurrentMethod().DeclaringType.Name + "." + System.Reflection.MethodBase.GetCurrentMethod().Name + "()", "");
base.OnShown(e);
InitControl();
// 통신서버 IP가 설정되어 있지 않으면 마스터 다운로드 Skip 처리
// 2016/10/19
if (m_cPosStatus.Base.CommSvrIp.Trim() != "" && m_cPosStatus.Base.MasterDown == "1")
{
System.Threading.Thread worker = new System.Threading.Thread(new System.Threading.ThreadStart(SaleOpenProcess));
worker.Start();
}
else
{
m_bIsOver = true;
}
tmrCheckStatus.Enabled = true;
}
private void frmSaleOpen_FormClosing(object sender, FormClosingEventArgs e)
{
UserLog.WriteLogFile(UserCom.LOG_IOS, System.Reflection.Assembly.GetExecutingAssembly().ManifestModule.Name,
System.Reflection.MethodBase.GetCurrentMethod().DeclaringType.Name + "." + System.Reflection.MethodBase.GetCurrentMethod().Name + "()", "");
}
private void InitControl()
{
try
{
if (m_cPosStatus.Sale.ScreenSizeUser == 1024)
{
// 이미지 로딩 처리
//picBack.Image = ImageManager.GetImage(BaseCom.NxImgPath, ImageManager.POP_FULL_SIZE);
//this.Size = new Size(1024, 696);
//this.Location = new Point(0, 50);
if (m_sManualMode == "K")
FormManager.SetControlSize(picBack, 0, 0, 1024, 696);
else
FormManager.SetControlSize(picBack, 0, 0, 1024, 768);
FormManager.SetControlSize(this, 0, 50, picBack.Size.Width, picBack.Size.Height);
FormManager.SetControlSize(this.progressBar1, 30, 332, 963, 30);
FormManager.SetControlSize(this.btnCancel, 893, 365, 100, 40);
FormManager.SetControlSize(this.lblStatusMsg, 38, 307, 214, 18);
FormManager.SetControlSize(this.pnlDeviceCheck, 30, 385, 963, 163);
FormManager.SetControlSize(this.lblScannerStatus, 661, 103, 96, 28);
FormManager.SetControlSize(this.lblMSRStatus, 851, 103, 96, 28);
FormManager.SetControlSize(this.lblCashDrawerStatus, 472, 99, 96, 28);
FormManager.SetControlSize(this.lblLabelPrinterStatus, 283, 99, 96, 28);
FormManager.SetControlSize(this.lblScalePoleDispStatus, 95, 99, 96, 28);
FormManager.SetControlSize(this.lblScaleStatus, 851, 36, 96, 28);
FormManager.SetControlSize(this.lblCatTerminalStatus, 661, 35, 96, 28);
FormManager.SetControlSize(this.lblSignPadStatus, 472, 35, 96, 28);
FormManager.SetControlSize(this.lblCardReaderStatus, 283, 35, 96, 28);
FormManager.SetControlSize(this.lblPrinterStatus, 95, 35, 96, 28);
FormManager.SetControlSize(this.label10, 766, 12, 1, 140);
FormManager.SetControlSize(this.label8, 8, 150, 950, 1);
FormManager.SetControlSize(this.label7, 8, 81, 950, 1);
FormManager.SetControlSize(this.label6, 9, 11, 950, 1);
FormManager.SetControlSize(this.label5, 958, 11, 1, 140);
FormManager.SetControlSize(this.label4, 576, 12, 1, 140);
FormManager.SetControlSize(this.label3, 199, 11, 1, 140);
FormManager.SetControlSize(this.label1, 388, 12, 1, 140);
FormManager.SetControlSize(this.label2, 8, 11, 1, 140);
FormManager.SetControlSize(this.lblMSR, 769, 99, 75, 32);
FormManager.SetControlSize(this.lblScanner, 579, 99, 75, 32);
FormManager.SetControlSize(this.lblCashDrawer, 391, 99, 75, 32);
FormManager.SetControlSize(this.lblLabelPrinter, 202, 99, 75, 32);
FormManager.SetControlSize(this.lblScalePoleDisp, 11, 99, 75, 32);
FormManager.SetControlSize(this.lblScale, 769, 31, 75, 32);
FormManager.SetControlSize(this.lblCatTerminal, 579, 32, 75, 32);
FormManager.SetControlSize(this.lblSignPad, 391, 31, 75, 32);
FormManager.SetControlSize(this.lblCardReader, 202, 32, 75, 32);
FormManager.SetControlSize(this.lblPrinter, 11, 31, 75, 32);
FormManager.SetControlSize(this.lblPercent, 933, 305, 56, 18);
FormManager.SetControlSize(this.lblUrgent, 41, 277, 221, 21);
FormManager.SetControlSize(this.lblTitleMsg1, 34, 62, 113, 39);
FormManager.SetControlSize(this.lblTitleMsg2, 34, 114, 250, 39);
FormManager.SetControlSize(this.lblTitleMsg3, 34, 166, 297, 53);
}
else
{
// 이미지 로딩 처리
//picBack.Image = ImageManager.GetImage(BaseCom.NxImgPath, ImageManager.POP_SIZE_800X600);
FormManager.SetControlSize(picBack, 0, 0, 800, 600);
FormManager.SetControlSize(this, 0, 0, picBack.Size.Width, picBack.Size.Height);
FormManager.SetControlSize(this.progressBar1, 30, 332, 739, 30);
FormManager.SetControlSize(this.btnCancel, 893, 365, 100, 40);
FormManager.SetControlSize(this.lblStatusMsg, 38, 307, 214, 18);
FormManager.SetControlSize(this.pnlDeviceCheck, 30, 385, 739, 163);
FormManager.SetControlSize(this.lblScannerStatus, 526, 103, 51, 28);
FormManager.SetControlSize(this.lblMSRStatus, 671, 103, 51, 28);
FormManager.SetControlSize(this.lblCashDrawerStatus, 382, 99, 51, 28);
FormManager.SetControlSize(this.lblLabelPrinterStatus, 238, 99, 51, 28);
FormManager.SetControlSize(this.lblScalePoleDispStatus, 95, 99, 51, 28);
FormManager.SetControlSize(this.lblScaleStatus, 671, 36, 51, 28);
FormManager.SetControlSize(this.lblCatTerminalStatus, 526, 35, 51, 28);
FormManager.SetControlSize(this.lblSignPadStatus, 382, 35, 51, 28);
FormManager.SetControlSize(this.lblCardReaderStatus, 238, 35, 51, 28);
FormManager.SetControlSize(this.lblPrinterStatus, 95, 35, 51, 28);
FormManager.SetControlSize(this.label10, 586, 12, 1, 140);
FormManager.SetControlSize(this.label8, 8, 150, 726, 1);
FormManager.SetControlSize(this.label7, 8, 81, 726, 1);
FormManager.SetControlSize(this.label6, 8, 11, 726, 1);
FormManager.SetControlSize(this.label5, 733, 11, 1, 140);
FormManager.SetControlSize(this.label4, 441, 12, 1, 140);
FormManager.SetControlSize(this.label3, 154, 11, 1, 140);
FormManager.SetControlSize(this.label1, 298, 12, 1, 140);
FormManager.SetControlSize(this.label2, 8, 11, 1, 140);
FormManager.SetControlSize(this.lblMSR, 589, 99, 75, 32);
FormManager.SetControlSize(this.lblScanner, 444, 99, 75, 32);
FormManager.SetControlSize(this.lblCashDrawer, 301, 99, 75, 32);
FormManager.SetControlSize(this.lblLabelPrinter, 157, 99, 75, 32);
FormManager.SetControlSize(this.lblScalePoleDisp, 11, 99, 75, 32);
FormManager.SetControlSize(this.lblScale, 589, 31, 75, 32);
FormManager.SetControlSize(this.lblCatTerminal, 444, 32, 75, 32);
FormManager.SetControlSize(this.lblSignPad, 301, 31, 75, 32);
FormManager.SetControlSize(this.lblCardReader, 157, 32, 75, 32);
FormManager.SetControlSize(this.lblPrinter, 11, 31, 75, 32);
FormManager.SetControlSize(this.lblPercent, 709, 305, 56, 18);
FormManager.SetControlSize(this.lblUrgent, 41, 277, 221, 21);
FormManager.SetControlSize(this.lblTitleMsg1, 34, 62, 113, 39);
FormManager.SetControlSize(this.lblTitleMsg2, 34, 114, 250, 39);
FormManager.SetControlSize(this.lblTitleMsg3, 34, 166, 297, 53);
}
this.BackColor = Color.FromArgb(240, 248, 253);
//this.Size = new Size(1024, 768);
//this.Location = new Point(0, 0);
FormManager.MovePopUpForm(this, false, m_cPosStatus.Sale.ScreenSizeUser);
FormManager.SetFormAllControlFont(this, m_cPosStatus.Base.FONT);
FormManager.SetTextBoxGlobalInfo(this, m_cPosStatus.Global.m_stCultureMaster.nGroupingDigits, m_cPosStatus.Global.m_stCultureMaster.strGroupingSymbol
, m_cPosStatus.Global.m_stCultureMaster.nDecimalDigits, m_cPosStatus.Global.m_stCultureMaster.strDecimalSymbol);
picBack.Image = ImageManager.GetImage(BaseCom.NxImgPath, ImageManager.LODING_BACKGROUND);
progressBar1.Minimum = 0;
progressBar1.Maximum = 100;
progressBar1.Value = 0;
lblStatusMsg.Text = string.Empty;
lblPercent.Text = string.Empty;
pnlDeviceCheck.Visible = false;
btnCancel.Visible = true;
m_bIsOver = false;
// Device Check Init
lblPrinterStatus.Image = ImageManager.GetImage(BaseCom.NxImgPath, ImageManager.DEVICE_WAIT);
//lblScannerStatus.Image = ImageManager.GetImage(BaseCom.NxImgPath, ImageManager.DEVICE_WAIT);
lblCardReaderStatus.Image = ImageManager.GetImage(BaseCom.NxImgPath, ImageManager.DEVICE_WAIT);
lblCatTerminalStatus.Image = ImageManager.GetImage(BaseCom.NxImgPath, ImageManager.DEVICE_WAIT);
//lblCashDrawerStatus.Image = ImageManager.GetImage(BaseCom.NxImgPath, ImageManager.DEVICE_WAIT);
lblScaleStatus.Image = ImageManager.GetImage(BaseCom.NxImgPath, ImageManager.DEVICE_WAIT);
lblScalePoleDispStatus.Image = ImageManager.GetImage(BaseCom.NxImgPath, ImageManager.DEVICE_WAIT);
lblSignPadStatus.Image = ImageManager.GetImage(BaseCom.NxImgPath, ImageManager.DEVICE_WAIT);
lblLabelPrinterStatus.Image = ImageManager.GetImage(BaseCom.NxImgPath, ImageManager.DEVICE_WAIT);
//lblMSRStatus.Image = ImageManager.GetImage(BaseCom.NxImgPath, ImageManager.DEVICE_WAIT);
// 주변장치
lblPrinter.Text = MessageManager.GetLabelMessage(POS_MESSAGE.LABEL.MSG_0849);
//lblScanner.Text = MessageManager.GetLabelMessage(POS_MESSAGE.LABEL.MSG_0850);
lblCardReader.Text = MessageManager.GetLabelMessage(POS_MESSAGE.LABEL.MSG_0851);
lblSignPad.Text = MessageManager.GetLabelMessage(POS_MESSAGE.LABEL.MSG_0097);
lblLabelPrinter.Text = MessageManager.GetLabelMessage(POS_MESSAGE.LABEL.MSG_0853);
lblCatTerminal.Text = MessageManager.GetLabelMessage(POS_MESSAGE.LABEL.MSG_0854);
lblScale.Text = MessageManager.GetLabelMessage(POS_MESSAGE.LABEL.MSG_0855);
lblScalePoleDisp.Text = MessageManager.GetLabelMessage(POS_MESSAGE.LABEL.MSG_0695);
//lblMSR.Text = MessageManager.GetLabelMessage(POS_MESSAGE.LABEL.MSG_0857);
//lblCashDrawer.Text = MessageManager.GetLabelMessage(POS_MESSAGE.LABEL.MSG_0693);
lblTitleMsg1.Text = MessageManager.GetLabelMessage(POS_MESSAGE.LABEL.MSG_1011);
lblTitleMsg2.Text = MessageManager.GetLabelMessage(POS_MESSAGE.LABEL.MSG_1012);
lblTitleMsg3.Text = MessageManager.GetLabelMessage(POS_MESSAGE.LABEL.MSG_1013);
lblUrgent.Visible = false;
if (MstDownOp == PosConst.MASTER_DOWN_OP.ALL)
{
ReqDateTime = m_cPosStatus.Mst.ComplexShopType == "0" ? PosConst.BEGINNING_MST_DOWN_DATE : PosConst.BEGINNING_COMPLEX_SHOP_MST_DOWN_DATE;
BGReqDateTime = m_cPosStatus.Mst.ComplexShopType == "0" ? PosConst.BEGINNING_MST_DOWN_DATE : PosConst.BEGINNING_COMPLEX_SHOP_MST_DOWN_DATE;
}
else if(MstDownOp == PosConst.MASTER_DOWN_OP.CHANGED)
{
ReqDateTime = m_cPosStatus.Base.MstDownDate;
BGReqDateTime = m_cPosStatus.Base.MstBatchDownDate;
}
else if(MstDownOp == PosConst.MASTER_DOWN_OP.ALL_CAMPAIGN)
{
ReqDateTime = m_cPosStatus.Mst.ComplexShopType == "0" ? PosConst.BEGINNING_MST_DOWN_DATE : PosConst.BEGINNING_COMPLEX_SHOP_MST_DOWN_DATE;
BGReqDateTime = m_cPosStatus.Mst.ComplexShopType == "0" ? PosConst.BEGINNING_MST_DOWN_DATE : PosConst.BEGINNING_COMPLEX_SHOP_MST_DOWN_DATE;
}
}
catch(Exception ex)
{
WinManager.ExceptionMessage(System.Reflection.Assembly.GetExecutingAssembly().ManifestModule.Name,
System.Reflection.MethodBase.GetCurrentMethod().DeclaringType.Name + "." + System.Reflection.MethodBase.GetCurrentMethod().Name + "()", ex.Message);
}
}
public void SetPanelShowFlag(bool bShow)
{
try
{
if (InvokeRequired)
{
PanelDelegate pnDelegate = new PanelDelegate(SetPanelShowFlag);
this.Invoke(pnDelegate, new object[] { bShow });
}
else
{
pnlDeviceCheck.Visible = bShow;
btnCancel.Visible = !bShow;
}
}
catch (Exception ex)
{
WinManager.ExceptionMessage(System.Reflection.Assembly.GetExecutingAssembly().ManifestModule.Name,
System.Reflection.MethodBase.GetCurrentMethod().DeclaringType.Name + "." + System.Reflection.MethodBase.GetCurrentMethod().Name + "()", ex.Message);
}
}
#region ProgressBar
/// <summary>
/// ProgressBar 초기화
/// </summary>
public void InitProgressbar()
{
try
{
if (InvokeRequired)
{
ProgressbarInitDelegate pbUpdDelegate = new ProgressbarInitDelegate(InitProgressbar);
this.Invoke(pbUpdDelegate, new object[] { });
}
else
{
progressBar1.Value = 0;
progressBar1.Maximum = 100;
lblStatusMsg.Text = string.Empty;
Application.DoEvents();
this.Refresh();
}
}
catch (Exception ex)
{
WinManager.ExceptionMessage(System.Reflection.Assembly.GetExecutingAssembly().ManifestModule.Name,
System.Reflection.MethodBase.GetCurrentMethod().DeclaringType.Name + "." + System.Reflection.MethodBase.GetCurrentMethod().Name + "()", ex.Message);
}
}
/// <summary>
/// ProgressBar 진행 상태 갱신
/// </summary>
/// <param name="sMstId">상태메시지</param>
/// <param name="nProgress">진행률 증가분</param>
public void SaleOpenProgress(string sMstId, int nProgress)
{
try
{
if(InvokeRequired)
{
ProgressbarUpdateDelegate pbUpdDelegate = new ProgressbarUpdateDelegate(SaleOpenProgress);
this.Invoke(pbUpdDelegate, new object[] { sMstId, nProgress });
}
else
{
if (progressBar1.Value + nProgress <= progressBar1.Maximum)
{
progressBar1.Value += nProgress;
}
else
{
progressBar1.Value = progressBar1.Maximum;
}
if (sMstId.Length > 0)
{
lblStatusMsg.Text = sMstId;
}
lblPercent.Text = GetProgressPercentage();
lblPercent.Update();
progressBar1.Update();
//this.Refresh();
Application.DoEvents();
}
}
catch (Exception ex)
{
WinManager.ExceptionMessage(System.Reflection.Assembly.GetExecutingAssembly().ManifestModule.Name,
System.Reflection.MethodBase.GetCurrentMethod().DeclaringType.Name + "." + System.Reflection.MethodBase.GetCurrentMethod().Name + "()", ex.Message);
}
}
/// <summary>
/// 상태메시지 변경
/// </summary>
/// <param name="sMsg"></param>
public void SetLabelMsg(string sMsg)
{
try
{
if(InvokeRequired)
{
UpdateLabelDelegate lblDelegate = new UpdateLabelDelegate(SetLabelMsg);
this.Invoke(lblDelegate, new object[] { sMsg });
}
else
{
lblStatusMsg.Text = sMsg;
lblStatusMsg.Refresh();
}
}
catch (Exception ex)
{
UserLog.WriteLogFile(UserCom.LOG_ERROR,
System.Reflection.Assembly.GetExecutingAssembly().ManifestModule.Name, // Project Name (프로젝트명)
System.Reflection.MethodBase.GetCurrentMethod().DeclaringType.Name + "." + // Class Name (Class Name (클래스명))
System.Reflection.MethodBase.GetCurrentMethod().Name + "()", // Function Name (Function Name (함수명))
ex.Message);
}
}
public void ShowUrgentLabel(bool bShow)
{
try
{
if (InvokeRequired)
{
ShowUrgentDelegate lblDelegate = new ShowUrgentDelegate(ShowUrgentLabel);
this.Invoke(lblDelegate, new object[] { bShow });
}
else
{
lblUrgent.Visible = bShow;
lblUrgent.Refresh();
}
}
catch (Exception ex)
{
UserLog.WriteLogFile(UserCom.LOG_ERROR,
System.Reflection.Assembly.GetExecutingAssembly().ManifestModule.Name, // Project Name (프로젝트명)
System.Reflection.MethodBase.GetCurrentMethod().DeclaringType.Name + "." + // Class Name (Class Name (클래스명))
System.Reflection.MethodBase.GetCurrentMethod().Name + "()", // Function Name (Function Name (함수명))
ex.Message);
}
}
/// <summary>
/// ProgressBar Style 변경
/// </summary>
/// <param name="pbStyle"></param>
public void SetProgressbarStyle(ProgressBarStyle pbStyle)
{
try
{
if (InvokeRequired)
{
UpdateProgressBarStyleDelegate pbDelegate = new UpdateProgressBarStyleDelegate(SetProgressbarStyle);
this.Invoke(pbDelegate, new object[] { pbStyle });
}
else
{
if(pbStyle == ProgressBarStyle.Marquee)
{
lblPercent.Visible = false;
}
else
{
progressBar1.Value = 0;
lblPercent.Text = GetProgressPercentage();
lblPercent.Visible = true;
}
progressBar1.Style = pbStyle;
progressBar1.Refresh();
lblPercent.Refresh();
}
}
catch (Exception ex)
{
UserLog.WriteLogFile(UserCom.LOG_ERROR,
System.Reflection.Assembly.GetExecutingAssembly().ManifestModule.Name, // Project Name (프로젝트명)
System.Reflection.MethodBase.GetCurrentMethod().DeclaringType.Name + "." + // Class Name (Class Name (클래스명))
System.Reflection.MethodBase.GetCurrentMethod().Name + "()", // Function Name (Function Name (함수명))
ex.Message);
}
}
/// <summary>
/// ProgressBar 진행 상태 갱신
/// </summary>
/// <param name="iStep">증가값</param>
public void ProgressProgressBar(int iStep)
{
try
{
if (InvokeRequired)
{
StepUpProgressBarDelegate pbDelegate = new StepUpProgressBarDelegate(ProgressProgressBar);
this.Invoke(pbDelegate, new object[] { iStep });
}
else
{
progressBar1.Value += iStep;
lblPercent.Text = GetProgressPercentage();
progressBar1.Refresh();
lblPercent.Refresh();
}
}
catch (Exception ex)
{
UserLog.WriteLogFile(UserCom.LOG_ERROR,
System.Reflection.Assembly.GetExecutingAssembly().ManifestModule.Name, // Project Name (프로젝트명)
System.Reflection.MethodBase.GetCurrentMethod().DeclaringType.Name + "." + // Class Name (Class Name (클래스명))
System.Reflection.MethodBase.GetCurrentMethod().Name + "()", // Function Name (Function Name (함수명))
ex.Message);
}
}
/// <summary>
/// ProgressBar 진행율을 가져 옴
/// </summary>
/// <returns></returns>
private string GetProgressPercentage()
{
string sPercent = string.Empty;
try
{
int percent = (int)(((double)progressBar1.Value / (double)progressBar1.Maximum) * 100);
sPercent = percent.ToString() + "%";
}
catch (Exception ex)
{
UserLog.WriteLogFile(UserCom.LOG_ERROR,
System.Reflection.Assembly.GetExecutingAssembly().ManifestModule.Name, // Project Name (프로젝트명)
System.Reflection.MethodBase.GetCurrentMethod().DeclaringType.Name + "." + // Class Name (Class Name (클래스명))
System.Reflection.MethodBase.GetCurrentMethod().Name + "()", // Function Name (Function Name (함수명))
ex.Message);
}
return sPercent;
}
#endregion
private void SaleOpenProcess()
{
bool bIsUrgent = false;
string sReturn = UserCom.RST_ERR;
//string sReqDateTime = string.Empty;
//Hashtable htMasterList = new Hashtable();
//Hashtable htComplexStoreMstList = new Hashtable();
Hashtable htMasterList = null;
Hashtable htComplexStoreMstList = null;
DataTable dtData = null;
try
{
// 주변장치 표시 창을 비활성화.
SetPanelShowFlag(false);
string sToBeMstDownTime = DateTime.Now.ToString("yyyyMMddHHmmss");
//테이블 변경사항에 대한 적용(추후 없어질 수도 있음)
// 일반 마스터 정보 Down
int iSeq = 0;
dtData = m_cMstDownSrv.SelectEmergencyMasterList();
if(MstDownOp == PosConst.MASTER_DOWN_OP.ALL_CAMPAIGN)
{
ShowUrgentLabel(false);
// 캠페인 관련 마스터만 받는다.
htMasterList = MasterListManager.GetCampaignMaster();
}
else if (MstDownOp == PosConst.MASTER_DOWN_OP.ALL || (dtData == null || dtData.Rows.Count == 0))
{
ShowUrgentLabel(false);
if (m_cPosStatus.Base.PosType == PosConst.POS_TYPE.DEFERRED_PAYMENT && m_cPosStatus.Base.PosCommunicationType == PosConst.MAIN_POS_DIV.SUB_POS)
{
// 후불SUB POS 의 경우에 SUB POS 전용 마스터만 받는다.
htMasterList = MasterListManager.GetSubPosMaster();
}
else
{
// 그 이외라면 일반 마스터를 받는다.
htMasterList = MasterListManager.GetNormalMaster();
}
}
else
{
bIsUrgent = true;
ShowUrgentLabel(true);
foreach(DataRow dr in dtData.Rows)
{
htMasterList.Add(iSeq++, dr["MST_TBL_ID"].ToString());
}
m_cMstDownSrv.UpdateEmergencyMasterList();
}
sReturn = m_cMstDownSrv.Execute(new object[] { htMasterList, ReqDateTime, BGReqDateTime });
if(sReturn != UserCom.RST_OK)
{
UserLog.WriteLogFile(UserCom.LOG_ERROR,
System.Reflection.Assembly.GetExecutingAssembly().ManifestModule.Name, // Project Name (프로젝트명)
System.Reflection.MethodBase.GetCurrentMethod().DeclaringType.Name + "." + // Class Name (Class Name (클래스명))
System.Reflection.MethodBase.GetCurrentMethod().Name + "()", // Function Name (Function Name (함수명))
"Failed specified master download and insert.");
return;
}
// 선불 이거나 후불 MAIN POS 의 경우에만 복합매장 정보를 추가로 다운로드
if (m_cPosStatus.Base.PosType != PosConst.POS_TYPE.DEFERRED_PAYMENT ||
(m_cPosStatus.Base.PosType == PosConst.POS_TYPE.DEFERRED_PAYMENT && m_cPosStatus.Base.PosCommunicationType == PosConst.MAIN_POS_DIV.MAIN_POS))
{
// 복합매장점포일 경우 복합매장 정보를 추가로 Down
iSeq = 0;
dtData = (DataTable)m_cMstDownSrv.GetData(new string[] { m_cPosStatus.Base.CmpCd, m_cPosStatus.Base.StoreNo });
if (dtData != null && dtData.Rows.Count > 0)
{
htComplexStoreMstList = MasterListManager.GetComplexStorMaster();
foreach (DataRow dr in dtData.Rows)
{
sReturn = m_cMstDownSrv.Execute(new object[] { htComplexStoreMstList, ReqDateTime, BGReqDateTime, CmUtil.GetDataRowStr(dr, "SUB_BRAND_CD"), CmUtil.GetDataRowStr(dr, "SUB_STOR_CD") });
if (sReturn != UserCom.RST_OK)
{
UserLog.WriteLogFile(UserCom.LOG_ERROR,
System.Reflection.Assembly.GetExecutingAssembly().ManifestModule.Name, // Project Name (프로젝트명)
System.Reflection.MethodBase.GetCurrentMethod().DeclaringType.Name + "." + // Class Name (Class Name (클래스명))
System.Reflection.MethodBase.GetCurrentMethod().Name + "()", // Function Name (Function Name (함수명))
"Failed Complex store specified master download and insert.");
return;
}
}
}
}
// 마스터 다운 일자 갱신
if (bIsUrgent == false && MstDownOp != PosConst.MASTER_DOWN_OP.ALL_CAMPAIGN)
{
m_cPosStatus.Base.MstDownDate = sToBeMstDownTime;
m_cPosStatus.Base.MstBatchDownDate = sToBeMstDownTime;
// PosSaleInfo.ini 저장
IServiceUs cSaveConfigInfo = (IServiceUs)sManager.InitServiceInstance(ServiceLists.BSV_OPEN_CLOSE.DLL, ServiceLists.BSV_OPEN_CLOSE.SAVE_CONFIGINFO);
string sRet = cSaveConfigInfo.Execute(new string[] { PosConst.INI_FILE_NAME.PosSaleInfo });
}
}
catch (Exception ex)
{
WinManager.ExceptionMessage(System.Reflection.Assembly.GetExecutingAssembly().ManifestModule.Name,
System.Reflection.MethodBase.GetCurrentMethod().DeclaringType.Name + "." + System.Reflection.MethodBase.GetCurrentMethod().Name + "()", ex.Message);
return;
}
finally
{
m_bIsOver = true;
}
return;
}
// Device Check
private bool DeviceCheck()
{
string sRet = UserCom.RST_ERR;
// 프로그래스바 초기화
//progressBar1.Value = 0;
InitProgressbar();
// 주변장치 표시 창 활성화 한다.
//pnlDeviceCheck.Visible = true;
SetPanelShowFlag(true);
try
{
// 주변장비 체크 서비스 인스턴스 활성화
IServiceUs cDeviceSrv = (IServiceUs)sManager.InitServiceInstance(ServiceLists.BSV_OPEN_CLOSE.DLL, ServiceLists.BSV_OPEN_CLOSE.DEVICE_SERVICE);
// 주변장치 목록 체크
CmMessage msgSend = CmMessage.MakeMessageFromFile(BaseCom.NxIniPath + PosConst.INI_FILE_NAME.PosDevice);
for (int i = 0; i < aDeviceList.Length; i++)
{
//string sDeviceName = msgSend.MessageKeyList[i].ToString();
string sDeviceName = aDeviceList[i].ToString();
if (msgSend.GetMessage(sDeviceName).GetMessageValue("UseFlag") != PosConst.DEVICE_USE_FLAG.YES_USE)
{
DisplayDeviceStatus(sDeviceName, UserCom.RST_IGNORE);
SaleOpenProgress(sDeviceName, (100 / aDeviceList.Length));
}
else
{
sRet = cDeviceSrv.Execute(new string[] { sDeviceName });
DisplayDeviceStatus(sDeviceName, sRet);
SaleOpenProgress(sDeviceName, (100 / aDeviceList.Length));
}
}
// Network
sRet = SetServerSysDateTime();
DisplayDeviceStatus("NETWORK", sRet);
}
catch (Exception ex)
{
WinManager.ExceptionMessage(System.Reflection.Assembly.GetExecutingAssembly().ManifestModule.Name,
System.Reflection.MethodBase.GetCurrentMethod().DeclaringType.Name + "." + System.Reflection.MethodBase.GetCurrentMethod().Name + "()", ex.Message);
return false;
}
return true;
}
#region -
/// <summary>
/// 서버 시간 동기화
/// </summary>
public string SetServerSysDateTime()
{
string sRet = UserCom.RST_ERR;
try
{
// 서버 시간 동기화
ISvr2Tran m_cSvr2Tran = (ISvr2Tran)sManager.InitServiceInstance(ServiceLists.BSV_SALE.DLL, ServiceLists.BSV_SALE.SVR2TRAN);
sRet = m_cSvr2Tran.ServerSysDateTime();
}
catch (Exception ex)
{
}
return sRet;
}
#endregion
public void DisplayDeviceStatus(string pDeviceName, string pStatus)
{
try
{
switch (pDeviceName)
{
case "POSPRINTER":
SetImage(this.lblPrinterStatus, pStatus);
m_cPosStatus.Base.OlePosPrinterStatus = pStatus;
//lblPrinterStatus.Text = "OK";
break;
//case "SCANNER":
// SetImage(this.pnlScanner, lblScannerStatus, pStatus);
// m_cPosStatus.Base.OlePosScannerStatus = pStatus;
// break;
case "ICREADER":
SetImage(this.lblCardReaderStatus, pStatus);
m_cPosStatus.Base.OlePosICReaderStatus = pStatus;
break;
case "CATTERMINAL":
SetImage(this.lblCatTerminalStatus, pStatus);
m_cPosStatus.Base.OlePosCATStatus = pStatus;
break;
case "CASHDRAWER":
SetImage(this.lblCashDrawerStatus, pStatus);
m_cPosStatus.Base.OlePosCashDrawerStatus = pStatus;
break;
case "SCALE":
SetImage(this.lblScaleStatus, pStatus);
m_cPosStatus.Base.OlePosScaleStatus = pStatus;
break;
case "SIGNPAD":
SetImage(this.lblSignPadStatus, pStatus);
m_cPosStatus.Base.OlePosSignPadStatus = pStatus;
break;
case "LABELPRINTER":
SetImage(this.lblLabelPrinterStatus, pStatus);
m_cPosStatus.Base.OlePosLabelPrinterStatus = pStatus;
break;
case "SCALEPOLEDISP":
SetImage(this.lblScalePoleDispStatus, pStatus);
m_cPosStatus.Base.OlePosScalePoleDispStatus = pStatus;
break;
//case "MSR":
// SetImage(this.pnlMSR, lblMSRStatus, pStatus);
// m_cPosStatus.Base.OlePosMsrStatus = pStatus;
// break;
case "NETWORK":
m_cPosStatus.Base.OlePosNetworkStatus = pStatus;
break;
case "":
break;
}
}
catch (Exception ex)
{
WinManager.ExceptionMessage(System.Reflection.Assembly.GetExecutingAssembly().ManifestModule.Name,
System.Reflection.MethodBase.GetCurrentMethod().DeclaringType.Name + "." + System.Reflection.MethodBase.GetCurrentMethod().Name + "()", ex.Message);
}
}
private void SetImage(Label lStatus, string sStatus)
{
Image imgBack = null;
string sTextStatus = UserCom.RST_ERR;
if (sStatus == UserCom.RST_OK)//OK
{
imgBack = ImageManager.GetImage(BaseCom.NxImgPath, ImageManager.DEVICE_OK);
sTextStatus = "OK";
}
else if (sStatus == UserCom.RST_ERR)//NG
{
imgBack = ImageManager.GetImage(BaseCom.NxImgPath, ImageManager.DEVICE_NG);
sTextStatus = "NG";
}
else if (sStatus == UserCom.RST_IGNORE) //PASS (미사용)
{
imgBack = ImageManager.GetImage(BaseCom.NxImgPath, ImageManager.DEVICE_PASS);
sTextStatus = "PASS";
}
lStatus.Image = imgBack;
lStatus.Text = sTextStatus;
}
private void tmrCheckStatus_Tick(object sender, EventArgs e)
{
try
{
tmrCheckStatus.Enabled = false;
if (m_bIsOver == true)
{
#region ### ###
if (PeripheralChk == PosConst.POS_PERIPHERAL_CHECK.CHECK)
{
DeviceCheck();
}
#endregion
this.Close();
return;
}
tmrCheckStatus.Enabled = true;
}
catch (Exception ex)
{
WinManager.ExceptionMessage(System.Reflection.Assembly.GetExecutingAssembly().ManifestModule.Name,
System.Reflection.MethodBase.GetCurrentMethod().DeclaringType.Name + "." + System.Reflection.MethodBase.GetCurrentMethod().Name + "()", ex.Message);
}
}
#region
/// <summary>
/// 상태 진행바
/// </summary>
/// <param name="iMaxPercent"></param>
private void SetProgreeBar(int iMaxPercent, string sMsgCD)
{
try
{
progressBar1.Increment(1);
double nPercent = ((double)progressBar1.Value / (double)iMaxPercent) * 100;
lblStatusMsg.Visible = true;
lblStatusMsg.Text = string.Format(sMsgCD + "{0}%", Math.Round(nPercent, 0, MidpointRounding.AwayFromZero).ToString());
lblStatusMsg.Refresh();
Application.DoEvents();
}
catch (Exception ex)
{
WinManager.ExceptionMessage(System.Reflection.Assembly.GetExecutingAssembly().ManifestModule.Name,
System.Reflection.MethodBase.GetCurrentMethod().DeclaringType.Name + "." + System.Reflection.MethodBase.GetCurrentMethod().Name + "()", ex.Message);
}
}
#endregion
private void btnCancel_Click(object sender, EventArgs e)
{
try
{
m_cMstDownSrv.IsAborted = true;
}
catch(Exception ex)
{
WinManager.ExceptionMessage(System.Reflection.Assembly.GetExecutingAssembly().ManifestModule.Name,
System.Reflection.MethodBase.GetCurrentMethod().DeclaringType.Name + "." + System.Reflection.MethodBase.GetCurrentMethod().Name + "()", ex.Message);
}
}
}
}