VDSM000MF.cpp 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417
  1. /****************************************************************************
  2. * @source :
  3. * @description :
  4. ****************************************************************************
  5. * DATE AUTHOR DESCRIPTION
  6. * --------------------------------------------------------------------------
  7. * 2011/12/24 정승호 최초작성
  8. *
  9. ****************************************************************************/
  10. //---------------------------------------------------------------------------
  11. #include <vcl.h>
  12. #include "ITSSkinF.h"
  13. #include "ITSUtilF.h"
  14. #include "ITSDbF.h"
  15. #include "AppGlobalF.h"
  16. #include "WindowMsgF.h"
  17. #include "CDSFacilityF.h"
  18. #include "CommFlashF.h"
  19. #pragma hdrstop
  20. #include "VDSM000MF.h"
  21. #include "FrmMainF.h"
  22. //---------------------------------------------------------------------------
  23. #pragma package(smart_init)
  24. #pragma link "cxButtons"
  25. #pragma link "cxCalc"
  26. #pragma link "cxCheckBox"
  27. #pragma link "cxClasses"
  28. #pragma link "cxContainer"
  29. #pragma link "cxControls"
  30. #pragma link "cxCustomData"
  31. #pragma link "cxData"
  32. #pragma link "cxDataStorage"
  33. #pragma link "cxDropDownEdit"
  34. #pragma link "cxEdit"
  35. #pragma link "cxFilter"
  36. #pragma link "cxGraphics"
  37. #pragma link "cxGrid"
  38. #pragma link "cxGridCustomTableView"
  39. #pragma link "cxGridCustomView"
  40. #pragma link "cxGridLevel"
  41. #pragma link "cxGridTableView"
  42. #pragma link "cxLabel"
  43. #pragma link "cxLookAndFeelPainters"
  44. #pragma link "cxLookAndFeels"
  45. #pragma link "cxStyles"
  46. #pragma link "cxTextEdit"
  47. #pragma link "dxSkinBlack"
  48. #pragma link "dxSkinBlue"
  49. #pragma link "dxSkinCaramel"
  50. #pragma link "dxSkinCoffee"
  51. #pragma link "dxSkinDarkRoom"
  52. #pragma link "dxSkinDarkSide"
  53. #pragma link "dxSkinFoggy"
  54. #pragma link "dxSkinGlassOceans"
  55. #pragma link "dxSkiniMaginary"
  56. #pragma link "dxSkinLilian"
  57. #pragma link "dxSkinLiquidSky"
  58. #pragma link "dxSkinLondonLiquidSky"
  59. #pragma link "dxSkinMcSkin"
  60. #pragma link "dxSkinMoneyTwins"
  61. #pragma link "dxSkinOffice2007Black"
  62. #pragma link "dxSkinOffice2007Blue"
  63. #pragma link "dxSkinOffice2007Green"
  64. #pragma link "dxSkinOffice2007Pink"
  65. #pragma link "dxSkinOffice2007Silver"
  66. #pragma link "dxSkinOffice2010Black"
  67. #pragma link "dxSkinOffice2010Blue"
  68. #pragma link "dxSkinOffice2010Silver"
  69. #pragma link "dxSkinsCore"
  70. #pragma link "dxSkinscxPCPainter"
  71. #pragma link "dxSkinSeven"
  72. #pragma link "dxSkinSharp"
  73. #pragma link "dxSkinSilver"
  74. #pragma link "dxSkinStardust"
  75. #pragma link "cxGroupBox"
  76. #pragma link "cxGridBandedTableView"
  77. #pragma resource "*.dfm"
  78. TVDSM000M *VDSM000M = NULL;
  79. //---------------------------------------------------------------------------
  80. __fastcall TVDSM000M::TVDSM000M(TComponent* Owner)
  81. : TForm(Owner)
  82. {
  83. ITSSkin_Load(this);
  84. CMM_LoadForm(g_sFormsDir, this);
  85. FTitle = "VDS-검지기 상태현황";
  86. FFacilityType = "";
  87. }
  88. //---------------------------------------------------------------------------
  89. /*
  90. * 닫기버튼 이나 x버튼 클릭시 공통으로 처리하는 로직이들어간다..
  91. * Form과 DataModule class를 delete시킨다.
  92. * arguments
  93. *
  94. * return
  95. * void
  96. */
  97. void __fastcall TVDSM000M::CommClose()
  98. {
  99. try
  100. {
  101. CMM_SaveForm(g_sFormsDir, this);
  102. }
  103. catch(...)
  104. {
  105. }
  106. }
  107. //---------------------------------------------------------------------------
  108. /*
  109. * Form을 보여줄때 호출되는 event 메서드이다.
  110. * arguments
  111. * Sender : event handler 객체
  112. * return
  113. * void
  114. */
  115. void __fastcall TVDSM000M::FormShow(TObject *Sender)
  116. {
  117. Refresh();
  118. FormInit();
  119. TmrShow->Enabled = true;
  120. }
  121. //---------------------------------------------------------------------------
  122. /*
  123. * form 초기화
  124. *
  125. * arguments
  126. *
  127. * return
  128. * void
  129. */
  130. void __fastcall TVDSM000M::FormInit()
  131. {
  132. TvList->OptionsView->NoDataToDisplayInfoText = "<VDS-검지기 상태현황>";
  133. }
  134. //---------------------------------------------------------------------------
  135. /*
  136. * Form이 Show되고 난 후 최초 1회 수행되는 타이머 이벤트
  137. * arguments
  138. * Sender : event handler 객체
  139. * return
  140. * void
  141. */
  142. void __fastcall TVDSM000M::TmrShowTimer(TObject *Sender)
  143. {
  144. TmrShow->Enabled = false;
  145. RefreshData();
  146. }
  147. //---------------------------------------------------------------------------
  148. /*
  149. * Search 버튼 클릭 이벤트 핸들러
  150. * arguments
  151. * Sender : event handler 객체
  152. * return
  153. * void
  154. */
  155. void __fastcall TVDSM000M::BtnSearchClick(TObject *Sender)
  156. {
  157. BtnSearch->Enabled = false;
  158. TmrShow->Enabled = true;
  159. }
  160. //---------------------------------------------------------------------------
  161. /*
  162. * Refresh Data Event Function
  163. * arguments
  164. *
  165. * return
  166. * void
  167. */
  168. void __fastcall TVDSM000M::RefreshData()
  169. {
  170. BtnSearch->Enabled = false;
  171. UpdateFacility();
  172. BtnSearch->Enabled = true;
  173. }
  174. //---------------------------------------------------------------------------
  175. /*
  176. * Close 버튼 클릭 이벤트 핸들러
  177. * arguments
  178. * Sender : event handler 객체
  179. * return
  180. * void
  181. */
  182. void __fastcall TVDSM000M::BtnCloseClick(TObject *Sender)
  183. {
  184. Close();
  185. }
  186. //---------------------------------------------------------------------------
  187. void __fastcall TVDSM000M::FormClose(TObject *Sender, TCloseAction &Action)
  188. {
  189. CommClose();
  190. VDSM000M = NULL;
  191. Action = caFree;
  192. }
  193. //---------------------------------------------------------------------------
  194. void __fastcall TVDSM000M::UpdateFacility()
  195. {
  196. String sQry;
  197. TADOQuery *pADO = NULL;
  198. sQry =
  199. #if 0
  200. "SELECT A.CTLR_MNGM_NMBR, A.VDS_CTLR_ID, A.LCTN, \r\n"
  201. " B.DTCT_NMBR, B.VDS_DTCT_NM, B.ISTL_LANE, \r\n"
  202. " C.UPDT_DT, C.DTCT_FAIL_STTS, \r\n"
  203. " (SELECT CMMN_CD_KOR_NM \r\n"
  204. " FROM TB_CMMN_CD \r\n"
  205. " WHERE CMMN_CLSF_CD = 'ACD' \r\n"
  206. " AND CMMN_CD = B.DTCT_TYPE_CD) AS DTCT_TYPE_CD_NM, \r\n"
  207. " DECODE(TRIM(C.DTCT_FAIL_STTS), '0', '정상', \r\n"
  208. " '1', '점유오류', \r\n"
  209. " '2', '단선오류', \r\n"
  210. " '3', '발진오류', \r\n"
  211. " '4', '통신장애', '알수없음') AS STTS_NM \r\n"
  212. " \r\n"
  213. " FROM TB_VDS_CTLR A, \r\n"
  214. " TB_VDS_DTCT_MSTR B, \r\n"
  215. " (SELECT * \r\n"
  216. " FROM TB_VDS_DTCT_STTS_PNST \r\n"
  217. " WHERE UPDT_DT >= TO_CHAR(SYSDATE-5/1440, 'YYYYMMDDHH24MISS') \r\n"
  218. " ) C \r\n"
  219. " WHERE A.DEL_YN = 'N' \r\n"
  220. " AND B.DEL_YN = 'N' \r\n"
  221. " AND A.CTLR_MNGM_NMBR = B.CTLR_MNGM_NMBR \r\n"
  222. " AND B.DTCT_NMBR = C.DTCT_NMBR(+) \r\n"
  223. " ORDER BY A.CTLR_MNGM_NMBR, B.DTCT_NMBR, B.ISTL_LANE \r\n";
  224. #else
  225. "SELECT A.*, \r\n"
  226. " B.DTCT_NMBR, B.VDS_DTCT_NM, B.ISTL_LANE, \r\n"
  227. " C.UPDT_DT, C.DTCT_FAIL_STTS, \r\n"
  228. " (SELECT CMMN_CD_KOR_NM \r\n"
  229. " FROM TB_CMMN_CD \r\n"
  230. " WHERE CMMN_CLSF_CD = 'ACD' \r\n"
  231. " AND CMMN_CD = B.DTCT_TYPE_CD) AS DTCT_TYPE_CD_NM, \r\n"
  232. " DECODE(TRIM(C.DTCT_FAIL_STTS), '0', '정상', \r\n"
  233. " '1', '점유오류', \r\n"
  234. " '2', '단선오류', \r\n"
  235. " '3', '발진오류', \r\n"
  236. " '4', '통신장애', '알수없음') AS STTS_NM \r\n"
  237. " FROM (SELECT B.CTLR_MNGM_NMBR, B.VDS_CTLR_ID, B.LCTN, \r\n"
  238. " CMNC_STTS_CD AS STTS_CD, CBOX_DOOR_STTS_CD AS DOOR_STTS_CD, \r\n"
  239. " DECODE(CMNC_STTS_CD, 'CMS0', '0', 'CMS1', '1', '2') AS COMM, \r\n"
  240. " DECODE(CBOX_DOOR_STTS_CD, 'CDS0', '0', 'CDS1', '1', '0') AS DOOR, \r\n"
  241. " NVL(A.CBOX_TMPR, 0) AS CBOX_TMPR, \r\n"
  242. " A.UPDT_DT AS STS00, \r\n"
  243. " '0' AS STS01, '0' AS STS02, '0' AS STS03, '0' AS STS04, '0' AS STS05, \r\n"
  244. " '0' AS STS06, '0' AS STS07, '0' AS STS08, '0' AS STS09, '0' AS STS10 \r\n"
  245. " FROM (SELECT * \r\n"
  246. " FROM TB_VDS_CTLR_STTS \r\n"
  247. " WHERE UPDT_DT >= TO_CHAR(SYSDATE-5/1440, 'YYYYMMDDHH24MISS') \r\n"
  248. " ) A, \r\n"
  249. " TB_VDS_CTLR B \r\n"
  250. " WHERE B.DEL_YN = 'N' \r\n"
  251. " AND A.CTLR_MNGM_NMBR(+) = B.CTLR_MNGM_NMBR \r\n"
  252. " ) A, \r\n"
  253. " TB_VDS_DTCT_MSTR B, \r\n"
  254. " (SELECT * \r\n"
  255. " FROM TB_VDS_DTCT_STTS_PNST \r\n"
  256. " WHERE UPDT_DT >= TO_CHAR(SYSDATE-5/1440, 'YYYYMMDDHH24MISS') \r\n"
  257. " ) C \r\n"
  258. " WHERE B.DEL_YN = 'N' \r\n"
  259. " AND A.CTLR_MNGM_NMBR = B.CTLR_MNGM_NMBR \r\n"
  260. " AND B.DTCT_NMBR = C.DTCT_NMBR(+) \r\n"
  261. " ORDER BY A.CTLR_MNGM_NMBR, B.DTCT_NMBR, B.ISTL_LANE \r\n";
  262. #endif
  263. try
  264. {
  265. int nRow = 0;
  266. int nDataCnt = 0;
  267. TcxDataController *pGDC = TvList->DataController;
  268. try
  269. {
  270. pADO = new TADOQuery(NULL);
  271. pADO->Close();
  272. pADO->Connection = ITSDb_GetConnection();
  273. pADO->SQL->Clear();
  274. pADO->SQL->Text = sQry;
  275. pADO->Open();
  276. CMM_ClearGridTableView(TvList);
  277. TvList->BeginUpdate();
  278. nDataCnt = pADO->RecordCount;
  279. pGDC->RecordCount = nDataCnt;
  280. for( ; !pADO->Eof; pADO->Next(), nRow++)
  281. {
  282. pGDC->Values[nRow][Col00->Index] = pADO->FieldByName("CTLR_MNGM_NMBR")->AsString;
  283. pGDC->Values[nRow][Col01->Index] = pADO->FieldByName("LCTN")->AsString;
  284. pGDC->Values[nRow][Col02->Index] = pADO->FieldByName("ISTL_LANE")->AsString;
  285. pGDC->Values[nRow][Col03->Index] = pADO->FieldByName("DTCT_TYPE_CD_NM")->AsString;
  286. pGDC->Values[nRow][Col04->Index] = pADO->FieldByName("DTCT_NMBR")->AsString;
  287. pGDC->Values[nRow][Col05->Index] = pADO->FieldByName("VDS_DTCT_NM")->AsString;
  288. pGDC->Values[nRow][Col06->Index] = pADO->FieldByName("UPDT_DT")->AsString;
  289. String sComm = pADO->FieldByName("COMM")->AsString;
  290. if (sComm == "0")
  291. {
  292. pGDC->Values[nRow][Col07->Index] = pADO->FieldByName("STTS_NM")->AsString;
  293. pGDC->Values[nRow][Col09->Index] = "정상";
  294. }
  295. else
  296. {
  297. pGDC->Values[nRow][Col07->Index] = "알수없음";
  298. pGDC->Values[nRow][Col09->Index] = "이상";
  299. }
  300. }
  301. }
  302. catch(EDatabaseError &E)
  303. {
  304. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  305. DBERRORMSG("VDS-검지기상태정보조회", String(E.ClassName()), E.Message, sQry);
  306. throw Exception(String(E.ClassName()) + E.Message);
  307. }
  308. catch(Exception &exception)
  309. {
  310. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  311. DBERRORMSG("VDS-검지기상태정보조회", String(exception.ClassName()), exception.Message, sQry);
  312. throw Exception(String(exception.ClassName()) + exception.Message);
  313. }
  314. }
  315. __finally
  316. {
  317. if (pADO)
  318. {
  319. pADO->Close();
  320. delete pADO;
  321. }
  322. TvList->EndUpdate();
  323. }
  324. CMM_ExpandCollapseChk(TvList, ChkExpand->Checked);
  325. }
  326. //---------------------------------------------------------------------------
  327. void __fastcall TVDSM000M::BtnExlSaveClick(TObject *Sender)
  328. {
  329. TcxGrid *pGrid = CxList;
  330. TcxGridTableView *pView = TvList;
  331. String sTitle= "VDS-검지기 상태현황";
  332. CMM_ExportToExcelFile(sTitle, pGrid, pView, (TForm*)this);
  333. }
  334. //---------------------------------------------------------------------------
  335. void __fastcall TVDSM000M::ChkExpandClick(TObject *Sender)
  336. {
  337. CMM_ExpandCollapseChk(TvList, ChkExpand->Checked);
  338. }
  339. //---------------------------------------------------------------------------
  340. void __fastcall TVDSM000M::TvListDataControllerFilterChanged(TObject *Sender)
  341. {
  342. CMM_SetFilterLike(TvList);
  343. }
  344. //---------------------------------------------------------------------------
  345. void __fastcall TVDSM000M::Col07CustomDrawCell(TcxCustomGridTableView *Sender, TcxCanvas *ACanvas,
  346. TcxGridTableDataCellViewInfo *AViewInfo, bool &ADone)
  347. {
  348. if( AViewInfo )
  349. {
  350. if(AViewInfo->Text == "정상")
  351. {
  352. ACanvas->Canvas->Font->Color = clTeal;
  353. }
  354. else if(AViewInfo->Text == "통신장애")
  355. {
  356. ACanvas->Canvas->Font->Color = clRed;
  357. }
  358. else if(AViewInfo->Text == "알수없음")
  359. {
  360. ACanvas->Canvas->Font->Color = clGray;
  361. }
  362. else
  363. {
  364. ACanvas->Canvas->Font->Color = clFuchsia;
  365. }
  366. }
  367. }
  368. //---------------------------------------------------------------------------
  369. void __fastcall TVDSM000M::Col09CustomDrawCell(TcxCustomGridTableView *Sender, TcxCanvas *ACanvas,
  370. TcxGridTableDataCellViewInfo *AViewInfo, bool &ADone)
  371. {
  372. if( AViewInfo )
  373. {
  374. if(AViewInfo->Text == "정상")
  375. {
  376. ACanvas->Canvas->Font->Color = clTeal;
  377. }
  378. else
  379. {
  380. ACanvas->Canvas->Font->Color = clRed;
  381. }
  382. }
  383. }
  384. //---------------------------------------------------------------------------