FrmParkMsgF.cpp 7.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195
  1. //---------------------------------------------------------------------------
  2. #include <vcl.h>
  3. #include "ITSDbF.h"
  4. #include "ITSUtilF.h"
  5. #include "AppGlobalF.h"
  6. #include "ITSSkinF.h"
  7. #include "ITSLangTransF.h"
  8. #pragma hdrstop
  9. #include "FrmParkMsgF.h"
  10. #include "ITS_OPLibF.h"
  11. //---------------------------------------------------------------------------
  12. #pragma package(smart_init)
  13. #pragma link "cxClasses"
  14. #pragma link "cxControls"
  15. #pragma link "cxCustomData"
  16. #pragma link "cxData"
  17. #pragma link "cxDataStorage"
  18. #pragma link "cxEdit"
  19. #pragma link "cxFilter"
  20. #pragma link "cxGraphics"
  21. #pragma link "cxGrid"
  22. #pragma link "cxGridCustomTableView"
  23. #pragma link "cxGridCustomView"
  24. #pragma link "cxGridLevel"
  25. #pragma link "cxGridTableView"
  26. #pragma link "cxLabel"
  27. #pragma link "cxLookAndFeelPainters"
  28. #pragma link "cxLookAndFeels"
  29. #pragma link "cxStyles"
  30. #pragma link "dxSkinBlack"
  31. #pragma link "dxSkinBlue"
  32. #pragma link "dxSkinsCore"
  33. #pragma link "dxSkinscxPCPainter"
  34. #pragma link "cxContainer"
  35. #pragma link "cxPC"
  36. #pragma link "cxPCdxBarPopupMenu"
  37. #pragma link "dxSkinMcSkin"
  38. #pragma resource "*.dfm"
  39. TFrmParkMsg *FrmParkMsg = NULL;
  40. //---------------------------------------------------------------------------
  41. __fastcall TFrmParkMsg::TFrmParkMsg(TComponent* Owner, TPrltCtlr *AObj)
  42. : TForm(Owner)
  43. {
  44. LangTrans->Translate(this, ITSDb_GetConnection());
  45. FObj = AObj;
  46. pADO->Connection = ITSDb_GetConnection();
  47. TvList->OptionsView->NoDataToDisplayInfoText = "<주차정보>";
  48. }
  49. //---------------------------------------------------------------------------
  50. void __fastcall TFrmParkMsg::FormClose(TObject *Sender, TCloseAction &Action)
  51. {
  52. Action = caFree;
  53. }
  54. //---------------------------------------------------------------------------
  55. void __fastcall TFrmParkMsg::FormShow(TObject *Sender)
  56. {
  57. if (FObj)
  58. {
  59. Caption = FObj->PRLT_CTLR_ID + ": " + FObj->PRLT_NM;
  60. //PnlMenu->Visible = FObj->REAL_DATA_YN == "Y" ? true : false;
  61. }
  62. TmrShow->Enabled = true;
  63. //EdNm->SetFocus();
  64. }
  65. //---------------------------------------------------------------------------
  66. void __fastcall TFrmParkMsg::TmrShowTimer(TObject *Sender)
  67. {
  68. TmrShow->Enabled = false;
  69. if (FObj)
  70. {
  71. //EdNmbr->Text = FObj->PRLT_CTLR_NMBR;
  72. //EdId->Text = FObj->PRLT_CTLR_ID;
  73. EdNm->Text = FObj->PRLT_NM;
  74. EdTel->Text = FObj->PRLT_TEL;
  75. EdAddr->Text = FObj->ISTL_LCTN_ADDR;
  76. //PnlMenu->Visible = FObj->REAL_DATA_YN == "Y" ? true : false;
  77. }
  78. TmrQry->Interval = 100;
  79. TmrQry->Enabled = true;
  80. }
  81. //---------------------------------------------------------------------------
  82. void __fastcall TFrmParkMsg::TmrQryTimer(TObject *Sender)
  83. {
  84. TmrQry->Enabled = false;
  85. if (!FObj) return;
  86. //if (FObj->REAL_DATA_YN == "Y")
  87. {
  88. SelectParkMsg();
  89. }
  90. TmrQry->Interval = 60 * 1000;
  91. TmrQry->Enabled = true;
  92. }
  93. //---------------------------------------------------------------------------
  94. void __fastcall TFrmParkMsg::SelectParkMsg()
  95. {
  96. String sQry;
  97. if (!FObj)
  98. {
  99. return;
  100. }
  101. CMM_ClearGridTableView(TvList);
  102. sQry = "SELECT 0 as data_seq, A.prk_plce_nmbr, A.prk_plce_manage_no, A.prk_plce_nm, A.prk_plce_adres, \r\n"
  103. " B.cmnc_stts_cd, DECODE(C.stts_cd, '0', '정상', '이상') AS cmnc_stts_desc, \r\n"
  104. " C.data_colct_time, \r\n"
  105. " DECODE(sign(to_date(C.data_colct_time, 'YYYYMMDDHH24MISS') - SYSDATE-10/1440), -1, 1, 0) as colct_stts, \r\n"
  106. " fnParkingCgsSttus(C.prk_cmprt_co, c.prk_parking_co) AS parking_cgs_sttus, \r\n"
  107. " DECODE(fnParkingCgsSttus(C.prk_cmprt_co, C.prk_parking_co), 0, '여유', \r\n"
  108. " 1, '보통', \r\n"
  109. " 2, '혼잡', \r\n"
  110. " 3, '만차', \r\n"
  111. " '알수없음') AS parking_cgs_desc, \r\n"
  112. " C.prk_cmprt_co AS prk_cmprt_co, \r\n"
  113. " C.remndr_prk_cmprt_co AS remndr_prk_cmprt_co, \r\n"
  114. " C.prk_parking_co AS prk_parking_co \r\n"
  115. " FROM TB_PRK_PLCE A, TB_PRK_PLCE_STTS B, \r\n"
  116. " TB_PRK_PLCE_RT C \r\n"
  117. " WHERE A.prk_plce_nmbr = :p01 \r\n"
  118. " AND A.prk_plce_nmbr = B.prk_plce_nmbr \r\n"
  119. " AND A.prk_plce_nmbr = C.prk_plce_nmbr \r\n"
  120. " AND A.pis_type != 'N' \r\n"
  121. " AND A.del_yn = 'N' \r\n";
  122. try
  123. {
  124. int nRow;
  125. TvList->BeginUpdate();
  126. try
  127. {
  128. pADO->Connection = ITSDb_GetConnection();
  129. ITSDb_SQLText(pADO, sQry);
  130. ITSDb_SQLBind(pADO, "p01", FObj->CTLR_NMBR);
  131. ITSDb_SQLOpen(pADO);
  132. for( ; !pADO->Eof; pADO->Next())
  133. {
  134. String colctStts = "";
  135. int COLCT_STTS = pADO->FieldByName("colct_stts")->AsInteger;
  136. if (COLCT_STTS == 1) colctStts = " [수집 이상]";
  137. nRow = TvList->DataController->AppendRecord();
  138. EdNm->Text = pADO->FieldByName("prk_plce_nm")->AsString;
  139. EdAddr->Text = pADO->FieldByName("prk_plce_adres")->AsString;
  140. EdClctDt->Text = ITSUtil_StrToDateTime(pADO->FieldByName("data_colct_time")->AsString).FormatString(STR_DATETIME) + colctStts;
  141. TvList->DataController->Values[nRow][Col03->Index] = pADO->FieldByName("cmnc_stts_desc")->AsString;
  142. TvList->DataController->Values[nRow][Col04->Index] = pADO->FieldByName("prk_cmprt_co")->AsString;
  143. TvList->DataController->Values[nRow][Col05->Index] = pADO->FieldByName("remndr_prk_cmprt_co")->AsString;
  144. TvList->DataController->Values[nRow][Col06->Index] = pADO->FieldByName("prk_parking_co")->AsString;
  145. TvList->DataController->Values[nRow][Col07->Index] = pADO->FieldByName("parking_cgs_desc")->AsString;
  146. }
  147. ITSDb_SQLClose(pADO);
  148. }
  149. catch(EDatabaseError &E)
  150. {
  151. throw Exception(String(E.ClassName()) + E.Message);
  152. }
  153. catch(...)
  154. {
  155. throw Exception("알수없는 오류가 발생하였습니다.");
  156. }
  157. }
  158. __finally
  159. {
  160. TvList->EndUpdate();
  161. }
  162. }
  163. //---------------------------------------------------------------------------
  164. void __fastcall TFrmParkMsg::FormDestroy(TObject *Sender)
  165. {
  166. TmrQry->Enabled = false;
  167. try {
  168. if (FObj) FObj->FData1 = NULL;
  169. } catch(...) {}
  170. }
  171. //---------------------------------------------------------------------------