FrmVmsLogSttsF.cpp 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369
  1. //---------------------------------------------------------------------------
  2. #include <vcl.h>
  3. #include "ITSSkinF.h"
  4. #include "ITSUtilF.h"
  5. #include "ITSLangTransF.h"
  6. #pragma hdrstop
  7. #include "FrmVmsLogSttsF.h"
  8. //---------------------------------------------------------------------------
  9. //---------------------------------------------------------------------------
  10. #pragma package(smart_init)
  11. #pragma link "cxClasses"
  12. #pragma link "cxContainer"
  13. #pragma link "cxControls"
  14. #pragma link "cxEdit"
  15. #pragma link "cxGraphics"
  16. #pragma link "cxHint"
  17. #pragma link "cxLabel"
  18. #pragma link "cxLookAndFeelPainters"
  19. #pragma link "cxLookAndFeels"
  20. #pragma link "cxMaskEdit"
  21. #pragma link "cxPC"
  22. #pragma link "cxPCdxBarPopupMenu"
  23. #pragma link "cxSpinEdit"
  24. #pragma link "cxTextEdit"
  25. #pragma link "dxBar"
  26. #pragma link "dxCustomHint"
  27. #pragma link "dxRibbon"
  28. #pragma link "dxRibbonGallery"
  29. #pragma link "dxRibbonSkins"
  30. #pragma link "dxRibbonStatusBar"
  31. #pragma link "dxScreenTip"
  32. #pragma link "dxSkinBlack"
  33. #pragma link "dxSkinBlue"
  34. #pragma link "dxSkinCaramel"
  35. #pragma link "dxSkinChooserGallery"
  36. #pragma link "dxSkinCoffee"
  37. #pragma link "dxSkinDarkRoom"
  38. #pragma link "dxSkinDarkSide"
  39. #pragma link "dxSkinFoggy"
  40. #pragma link "dxSkinGlassOceans"
  41. #pragma link "dxSkiniMaginary"
  42. #pragma link "dxSkinLilian"
  43. #pragma link "dxSkinLiquidSky"
  44. #pragma link "dxSkinLondonLiquidSky"
  45. #pragma link "dxSkinMcSkin"
  46. #pragma link "dxSkinMoneyTwins"
  47. #pragma link "dxSkinOffice2007Black"
  48. #pragma link "dxSkinOffice2007Blue"
  49. #pragma link "dxSkinOffice2007Green"
  50. #pragma link "dxSkinOffice2007Pink"
  51. #pragma link "dxSkinOffice2007Silver"
  52. #pragma link "dxSkinOffice2010Black"
  53. #pragma link "dxSkinOffice2010Blue"
  54. #pragma link "dxSkinOffice2010Silver"
  55. #pragma link "dxSkinsCore"
  56. #pragma link "dxSkinscxPCPainter"
  57. #pragma link "dxSkinsdxBarPainter"
  58. #pragma link "dxSkinsdxRibbonPainter"
  59. #pragma link "dxSkinSeven"
  60. #pragma link "dxSkinsForm"
  61. #pragma link "dxSkinSharp"
  62. #pragma link "dxSkinSilver"
  63. #pragma link "dxSkinStardust"
  64. #pragma link "dxStatusBar"
  65. #pragma link "dxTabbedMDI"
  66. #pragma link "cxButtons"
  67. #pragma link "cxCalendar"
  68. #pragma link "cxDropDownEdit"
  69. #pragma link "cxGroupBox"
  70. #pragma link "cxSplitter"
  71. #pragma link "cxTimeEdit"
  72. #pragma link "cxCalc"
  73. #pragma link "cxCheckBox"
  74. #pragma link "cxCustomData"
  75. #pragma link "cxData"
  76. #pragma link "cxDataStorage"
  77. #pragma link "cxFilter"
  78. #pragma link "cxGrid"
  79. #pragma link "cxGridCustomTableView"
  80. #pragma link "cxGridCustomView"
  81. #pragma link "cxGridLevel"
  82. #pragma link "cxGridTableView"
  83. #pragma link "cxStyles"
  84. #pragma resource "*.dfm"
  85. TFrmVmsLogStts *FrmVmsLogStts = NULL;
  86. //---------------------------------------------------------------------------
  87. __fastcall TFrmVmsLogStts::TFrmVmsLogStts(TComponent* Owner)
  88. : TForm(Owner)//TdxCustomRibbonForm(Owner)//TForm(Owner)
  89. {
  90. DoubleBuffered = true;
  91. g_AppCfg.lMainWinHandle = (long)Handle;
  92. LangTrans->Translate(this, ITSDb_GetConnection());
  93. CMM_SetFormPosition(g_AppCfg.bSaveForm);
  94. ITSSkin_Initialize(Application);
  95. ITSSkin_Load(this);
  96. CMM_LoadForm(g_sFormsDir, this);
  97. #if 0
  98. String sCaption = "";
  99. ReadConfigInfo(g_AppCfg.sConfigFile, "APPLICATION", "CAPTION", sCaption);
  100. ITSSkin_Caption(sCaption == "1" ? true : false);
  101. #endif
  102. SetColorScheme(g_AppCfg.sSkinName);
  103. FFormList = new TList();
  104. TsList01->TabVisible = false;
  105. }
  106. //---------------------------------------------------------------------------
  107. void __fastcall TFrmVmsLogStts::FormCreate(TObject *Sender)
  108. {
  109. Application->ShowMainForm = false;
  110. try {
  111. Application->Icon->LoadFromResourceName(((unsigned int)HInstance), "MAINICON");
  112. } catch(...) { ShowMessage("LoadFromResourceName failed"); }
  113. Application->ShowMainForm = true;
  114. }
  115. //---------------------------------------------------------------------------
  116. void __fastcall TFrmVmsLogStts::FormShow(TObject *Sender)
  117. {
  118. Application->ProcessMessages();
  119. FormInit();
  120. }
  121. //---------------------------------------------------------------------------
  122. void __fastcall TFrmVmsLogStts::FormClose(TObject *Sender, TCloseAction &Action)
  123. {
  124. CommClose();
  125. Action = caFree;
  126. }
  127. //---------------------------------------------------------------------------
  128. void __fastcall TFrmVmsLogStts::CommClose()
  129. {
  130. try
  131. {
  132. for (int idx = FFormList->Count-1; idx >= 0; idx--)
  133. {
  134. TFrmVmsLogSttsSub *pLogForm = (TFrmVmsLogSttsSub*)FFormList->Items[idx];
  135. delete pLogForm;
  136. FFormList->Delete(idx);
  137. }
  138. delete FFormList;
  139. ITSSkin_Term();
  140. CMM_SaveForm(g_sFormsDir, this);
  141. }
  142. catch(Exception &e)
  143. {
  144. }
  145. }
  146. //---------------------------------------------------------------------------
  147. void __fastcall TFrmVmsLogStts::SetColorScheme(String ASkinName)
  148. {
  149. dxSkinController1->SkinName = ASkinName;
  150. dxSkinController1->Refresh();
  151. }
  152. //---------------------------------------------------------------------------
  153. void __fastcall TFrmVmsLogStts::BtnCloseClick(TObject *Sender)
  154. {
  155. Close();
  156. }
  157. //---------------------------------------------------------------------------
  158. void __fastcall TFrmVmsLogStts::FormInit()
  159. {
  160. DtStrDate->Date = Now();
  161. DtStrTime->DateTime = StrToDateTime("00:00");//Now(); //오늘 00시00분부터
  162. //DtStrTime->DateTime = Now();
  163. DtEndDate->Date = Now();
  164. DtEndTime->DateTime = Now();
  165. FillVmsList();
  166. }
  167. //---------------------------------------------------------------------------
  168. void __fastcall TFrmVmsLogStts::FillVmsList()
  169. {
  170. String sQry;
  171. TADOQuery *pADO = NULL;
  172. CMM_ClearGridTableView(TvList);
  173. sQry = "SELECT A.*, \r\n"
  174. " B.VMS_TYPE_NM, \r\n"
  175. " B.VMS_WDTH, B.VMS_HGHT, \r\n"
  176. " B.ROW_NUM, B.COL_NUM, \r\n"
  177. " B.MODL_ROW_NUM, B.MODL_COL_NUM, \r\n"
  178. " B.POWR_ROW_NUM, B.POWR_COL_NUM \r\n"
  179. " FROM TB_VMS_CTLR A, \r\n"
  180. " TB_VMS_TYPE B \r\n"
  181. " WHERE A.VMS_TYPE_CD = B.VMS_TYPE_CD \r\n"
  182. " AND A.DEL_YN = 'N' \r\n"
  183. " ORDER BY A.VMS_CTLR_NMBR \r\n";
  184. int nRow = 0;
  185. TcxDataController *pGDC = TvList->DataController;
  186. try
  187. {
  188. TvList->BeginUpdate(lsimImmediate);
  189. try
  190. {
  191. pADO = new TADOQuery(NULL);
  192. pADO->Close();
  193. pADO->Connection = ITSDb_GetConnection();
  194. pADO->SQL->Clear();
  195. pADO->SQL->Text = sQry;
  196. pADO->Open();
  197. for( ; !pADO->Eof; pADO->Next())
  198. {
  199. String DEL_YN = pADO->FieldByName("DEL_YN")->AsString;
  200. if (DEL_YN == "Y") continue;
  201. String VMS_CTLR_NMBR = pADO->FieldByName("VMS_CTLR_NMBR")->AsString;
  202. String VMS_CTLR_ID = pADO->FieldByName("VMS_CTLR_ID")->AsString;
  203. String VMS_NM = pADO->FieldByName("VMS_NM")->AsString;
  204. String VMS_TYPE_CD = pADO->FieldByName("VMS_TYPE_NM")->AsString;
  205. nRow = pGDC->AppendRecord();
  206. pGDC->Values[nRow][ColumnSel->Index] = false;
  207. pGDC->Values[nRow][Column00->Index] = "-";
  208. pGDC->Values[nRow][Column01->Index] = VMS_CTLR_NMBR;
  209. pGDC->Values[nRow][Column02->Index] = VMS_CTLR_ID;
  210. pGDC->Values[nRow][Column03->Index] = VMS_NM;
  211. pGDC->Values[nRow][Column11->Index] = VMS_CTLR_NMBR;
  212. pGDC->Values[nRow][Column12->Index] = VMS_CTLR_ID;
  213. }
  214. }
  215. catch(EDatabaseError &E)
  216. {
  217. DBERRORMSG("VMS Information Query", String(E.ClassName()), E.Message, sQry);
  218. throw Exception(String(E.ClassName()) + E.Message);
  219. }
  220. catch(Exception &e)
  221. {
  222. DBERRORMSG("VMS Information Query", String(e.ClassName()), e.Message, sQry);
  223. throw Exception(String(e.ClassName()) + e.Message);
  224. }
  225. }
  226. __finally
  227. {
  228. if (pADO)
  229. {
  230. pADO->Close();
  231. delete pADO;
  232. }
  233. TvList->EndUpdate();
  234. }
  235. }
  236. //---------------------------------------------------------------------------
  237. void __fastcall TFrmVmsLogStts::OnSubFormClose(TMessage Msg)
  238. {
  239. int nActiveIdx = PgTab->ActivePageIndex;
  240. if (nActiveIdx <= 0) return;
  241. LockWindowUpdate(Handle);
  242. TcxTabSheet *pSheet = PgTab->ActivePage;
  243. if (pSheet)
  244. {
  245. delete pSheet;
  246. }
  247. nActiveIdx--; // 첫번째 탭은 화면에 숨겨져 있다.
  248. FFormList->Delete(nActiveIdx);
  249. LockWindowUpdate(0);
  250. }
  251. //---------------------------------------------------------------------------
  252. void __fastcall TFrmVmsLogStts::PgTabDblClick(TObject *Sender)
  253. {
  254. TPoint APoint;
  255. APoint = PgTab->MouseDownPos;
  256. if (PgTab->IndexOfTabAt(APoint.x, APoint.y) != -1)
  257. POST_MSG(Handle, WM_SUBFORM_CLOSE, 0, 0);
  258. }
  259. //---------------------------------------------------------------------------
  260. void __fastcall TFrmVmsLogStts::BtnAllSelectClick(TObject *Sender)
  261. {
  262. TcxButton *pBtn = (TcxButton*)Sender;
  263. CMM_CheckAllListItem(TvList, ColumnSel->Index, pBtn->Tag);
  264. }
  265. //---------------------------------------------------------------------------
  266. void __fastcall TFrmVmsLogStts::BtnSearchClick(TObject *Sender)
  267. {
  268. String sStrDate = DtStrDate->Date.FormatString("yyyymmdd");
  269. String sStrTime = DtStrTime->DateTime.FormatString("HHnn");
  270. String sEndDate = DtEndDate->Date.FormatString("yyyymmdd");
  271. String sEndTime = DtEndTime->DateTime.FormatString("HHnn");
  272. FStrTime = sStrDate + sStrTime;
  273. FEndTime = sEndDate + sEndTime;
  274. if (FStrTime > FEndTime)
  275. {
  276. Application->MessageBox(lblText3->Caption.c_str(),//L"검색 시작시각이 검색 종료시각 보다 큽니다.",
  277. Caption.c_str(), MB_OK|MB_ICONWARNING|MB_APPLMODAL);
  278. ActiveControl = DtStrDate;
  279. return;
  280. }
  281. FStrTime = FStrTime + "00";
  282. FEndTime = FEndTime + "59";
  283. FIdList = "";
  284. int nSelects = CMM_GetSelectCount(TvList, ColumnSel->Index, Column01->Index, FIdList);
  285. if (0 == nSelects)
  286. {
  287. Application->MessageBox(lblText4->Caption.c_str(),//L"VMS가 선택되지 않았습니다.\r\nVMS 목록에서 VMS를 선택하십시요.",
  288. Caption.c_str(), MB_OK|MB_ICONWARNING|MB_APPLMODAL);
  289. CxList->SetFocus();
  290. return;
  291. }
  292. String sTitle = "[" + FStrTime.SubString(1,10) + "-" + FEndTime.SubString(1,10) + "]";
  293. try
  294. {
  295. Application->ProcessMessages();
  296. LockWindowUpdate(Handle);
  297. TcxTabSheet *pSheet = CMM_AddTabSheet(PgTab, sTitle);
  298. if (!pSheet) return;
  299. TFrmVmsLogSttsSub *pLogForm = new TFrmVmsLogSttsSub(this, Handle, FStrTime, FEndTime, FIdList);
  300. pLogForm->Caption= Caption;
  301. pLogForm->Parent = pSheet;
  302. pLogForm->Show();
  303. PgTab->ActivePage = pSheet;
  304. pSheet = PgTab->ActivePage;
  305. FFormList->Add(pLogForm);
  306. }
  307. __finally
  308. {
  309. LockWindowUpdate(0);
  310. }
  311. }
  312. //---------------------------------------------------------------------------
  313. void __fastcall TFrmVmsLogStts::PgTabCanCloseEx(TObject *Sender, int ATabIndex, bool &ACanClose)
  314. {
  315. int nActiveIdx = ATabIndex;
  316. if (nActiveIdx <= 0) return;
  317. nActiveIdx--; // 첫번째 탭은 화면에 숨겨져 있다.
  318. FFormList->Delete(nActiveIdx);
  319. }
  320. //---------------------------------------------------------------------------