VMSM570MF.cpp 8.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296
  1. //---------------------------------------------------------------------------
  2. #include <vcl.h>
  3. #include "ITSSkinF.h"
  4. #include "ITSUtilF.h"
  5. #include "AppGlobalF.h"
  6. #pragma hdrstop
  7. #include "VMSM570MF.h"
  8. //---------------------------------------------------------------------------
  9. #pragma package(smart_init)
  10. #pragma link "cxButtons"
  11. #pragma link "cxCalendar"
  12. #pragma link "cxContainer"
  13. #pragma link "cxControls"
  14. #pragma link "cxDropDownEdit"
  15. #pragma link "cxEdit"
  16. #pragma link "cxGraphics"
  17. #pragma link "cxGroupBox"
  18. #pragma link "cxLabel"
  19. #pragma link "cxLookAndFeelPainters"
  20. #pragma link "cxLookAndFeels"
  21. #pragma link "cxMaskEdit"
  22. #pragma link "cxPC"
  23. #pragma link "cxPCdxBarPopupMenu"
  24. #pragma link "cxSpinEdit"
  25. #pragma link "cxSplitter"
  26. #pragma link "cxTextEdit"
  27. #pragma link "cxTimeEdit"
  28. #pragma link "dxSkinBlack"
  29. #pragma link "dxSkinBlue"
  30. #pragma link "dxSkinCaramel"
  31. #pragma link "dxSkinCoffee"
  32. #pragma link "dxSkinDarkRoom"
  33. #pragma link "dxSkinDarkSide"
  34. #pragma link "dxSkinFoggy"
  35. #pragma link "dxSkinGlassOceans"
  36. #pragma link "dxSkiniMaginary"
  37. #pragma link "dxSkinLilian"
  38. #pragma link "dxSkinLiquidSky"
  39. #pragma link "dxSkinLondonLiquidSky"
  40. #pragma link "dxSkinMcSkin"
  41. #pragma link "dxSkinMoneyTwins"
  42. #pragma link "dxSkinOffice2007Black"
  43. #pragma link "dxSkinOffice2007Blue"
  44. #pragma link "dxSkinOffice2007Green"
  45. #pragma link "dxSkinOffice2007Pink"
  46. #pragma link "dxSkinOffice2007Silver"
  47. #pragma link "dxSkinOffice2010Black"
  48. #pragma link "dxSkinOffice2010Blue"
  49. #pragma link "dxSkinOffice2010Silver"
  50. #pragma link "dxSkinsCore"
  51. #pragma link "dxSkinscxPCPainter"
  52. #pragma link "dxSkinSeven"
  53. #pragma link "dxSkinSharp"
  54. #pragma link "dxSkinSilver"
  55. #pragma link "dxSkinStardust"
  56. #pragma link "cxRadioGroup"
  57. #pragma link "cxClasses"
  58. #pragma link "cxCustomData"
  59. #pragma link "cxData"
  60. #pragma link "cxDataStorage"
  61. #pragma link "cxDBData"
  62. #pragma link "cxFilter"
  63. #pragma link "cxGrid"
  64. #pragma link "cxGridCustomTableView"
  65. #pragma link "cxGridCustomView"
  66. #pragma link "cxGridDBTableView"
  67. #pragma link "cxGridLevel"
  68. #pragma link "cxGridTableView"
  69. #pragma link "cxStyles"
  70. #pragma link "cxCheckBox"
  71. #pragma link "cxImage"
  72. #pragma link "cxButtonEdit"
  73. #pragma link "cxBlobEdit"
  74. #pragma resource "*.dfm"
  75. TVMSM570M *VMSM570M = NULL;
  76. //---------------------------------------------------------------------------
  77. __fastcall TVMSM570M::TVMSM570M(TComponent* Owner)
  78. : TForm(Owner)
  79. {
  80. ITSSkin_Load(this);
  81. //CMM_LoadForm(g_sFormsDir, this);
  82. FUpdate= false;
  83. FTitle = Caption;//"VMS 제공구간 선택";
  84. EditMode = false;
  85. m_bSelected = false;
  86. }
  87. //---------------------------------------------------------------------------
  88. void __fastcall TVMSM570M::CommClose()
  89. {
  90. try
  91. {
  92. //CMM_SaveForm(g_sFormsDir, this);
  93. }
  94. catch(...)
  95. {
  96. }
  97. }
  98. //---------------------------------------------------------------------------
  99. void __fastcall TVMSM570M::FormShow(TObject *Sender)
  100. {
  101. Refresh();
  102. FormInit();
  103. InitCctvInfo();
  104. TmrShow->Enabled = true;
  105. }
  106. //---------------------------------------------------------------------------
  107. void __fastcall TVMSM570M::FormInit()
  108. {
  109. FNewDb = false;
  110. EdFormObjId->Clear();
  111. EdCctvNm->Clear();
  112. EdCctvId->Clear();
  113. }
  114. //---------------------------------------------------------------------------
  115. bool __fastcall TVMSM570M::InitCctvInfo()
  116. {
  117. String sQry;
  118. TADOQuery *pADO = NULL;
  119. try {
  120. try {
  121. pADO = new TADOQuery(NULL);
  122. pADO->Close();
  123. pADO->Connection = ITSDb_GetConnection();
  124. sQry = "INSERT INTO TB_VMS_FORM_OBJ_CCTV(VMS_FORM_OBJ_ID, CCTV_ID, RGSTR_ID, REG_DT) \r\n"
  125. "SELECT T.CCTV_ID AS VMS_FORM_OBJ_ID, T.CCTV_ID AS CCTV_ID, :p01, SYSDATE \r\n"
  126. " FROM TB_CCTV T \r\n"
  127. " WHERE 1=1 \r\n"
  128. " AND T.USE_YN = 'Y' \r\n"
  129. " AND T.CCTV_ID NOT IN (SELECT CCTV_ID \r\n"
  130. " FROM TB_VMS_FORM_OBJ_CCTV) \r\n";
  131. ITSDb_SQLText(pADO, sQry);
  132. ITSDb_SQLBind(pADO, "p01", g_AppCfg.OPER_ID);
  133. pADO->ExecSQL();
  134. return true;
  135. }
  136. catch(EDatabaseError &E) {
  137. DBERRORMSG("TVMSM570M::InitCctvInfo", String(E.ClassName()), E.Message, sQry);
  138. return false;
  139. }
  140. catch(Exception &e) {
  141. DBERRORMSG("TVMSM570M::InitCctvInfo", String(e.ClassName()), e.Message, sQry);
  142. return false;
  143. }
  144. }
  145. __finally {
  146. if (pADO) {
  147. pADO->Close();
  148. delete pADO;
  149. }
  150. }
  151. return true;
  152. }
  153. //---------------------------------------------------------------------------
  154. void __fastcall TVMSM570M::TmrShowTimer(TObject *Sender)
  155. {
  156. TmrShow->Enabled = false;
  157. LoadCctvInfo();
  158. CMM_ExpandCollapseChk(TvList, true);
  159. }
  160. //---------------------------------------------------------------------------
  161. void __fastcall TVMSM570M::BtnCloseClick(TObject *Sender)
  162. {
  163. Close();
  164. }
  165. //---------------------------------------------------------------------------
  166. void __fastcall TVMSM570M::FormClose(TObject *Sender, TCloseAction &Action)
  167. {
  168. CommClose();
  169. VMSM570M = NULL;
  170. Action = caFree;
  171. }
  172. //---------------------------------------------------------------------------
  173. void __fastcall TVMSM570M::DisplayInfo()
  174. {
  175. FormInit();
  176. int nRow = TvList->DataController->FocusedRecordIndex;
  177. if( nRow <= -1 )
  178. return;
  179. TcxGridDataController *pDc = TvList->DataController;
  180. EdFormObjId->Text = VarToStr(pDc->Values[nRow][Col01->Index]);
  181. EdCctvId->Text = VarToStr(pDc->Values[nRow][Col02->Index]);
  182. EdCctvNm->Text = VarToStr(pDc->Values[nRow][Col03->Index]);
  183. }
  184. //---------------------------------------------------------------------------
  185. bool __fastcall TVMSM570M::LoadCctvInfo()
  186. {
  187. CMM_ClearGridTableView(TvList);
  188. String sQry;
  189. TADOQuery *pADO = NULL;
  190. sQry = "SELECT A.VMS_FORM_OBJ_ID, A.CCTV_ID, B.CCTV_NM \r\n"
  191. " FROM TB_VMS_FORM_OBJ_CCTV A, \r\n"
  192. " TB_CCTV B \r\n"
  193. " WHERE 1=1 \r\n"
  194. " AND B.USE_YN = 'Y' \r\n"
  195. " AND A.CCTV_ID = B.CCTV_ID \r\n";
  196. try
  197. {
  198. int nRow;
  199. TcxDataController *pGDC = TvList->DataController;
  200. TvList->BeginUpdate();
  201. try
  202. {
  203. pADO = new TADOQuery(NULL);
  204. pADO->Close();
  205. pADO->Connection = ITSDb_GetConnection();
  206. ITSDb_SQLText(pADO, sQry);
  207. ITSDb_SQLOpen(pADO);
  208. for( ; !pADO->Eof; pADO->Next()) {
  209. nRow = pGDC->AppendRecord();
  210. pGDC->Values[nRow][Col01->Index] = pADO->FieldByName("VMS_FORM_OBJ_ID")->AsString;
  211. pGDC->Values[nRow][Col02->Index] = pADO->FieldByName("CCTV_ID")->AsString;
  212. pGDC->Values[nRow][Col03->Index] = pADO->FieldByName("CCTV_NM")->AsString;
  213. }
  214. }
  215. catch(EDatabaseError &E) {
  216. DBERRORMSG("TVMSM570M::LoadCctvInfo", String(E.ClassName()), E.Message, sQry);
  217. return false;
  218. }
  219. catch(Exception &e)
  220. {
  221. DBERRORMSG("TVMSM570M::LoadCctvInfo", String(e.ClassName()), e.Message, sQry);
  222. return false;
  223. }
  224. }
  225. __finally {
  226. if (pADO) {
  227. pADO->Close();
  228. delete pADO;
  229. }
  230. TvList->EndUpdate();
  231. }
  232. return true;
  233. }
  234. //---------------------------------------------------------------------------
  235. void __fastcall TVMSM570M::TvListCellDblClick(TcxCustomGridTableView *Sender, TcxGridTableDataCellViewInfo *ACellViewInfo,
  236. TMouseButton AButton, TShiftState AShift,
  237. bool &AHandled)
  238. {
  239. if (!ACellViewInfo) return;
  240. DisplayInfo();
  241. Sleep(200);
  242. BtnSelImageClick((TObject*)BtnSelImage);
  243. }
  244. //---------------------------------------------------------------------------
  245. void __fastcall TVMSM570M::BtnSelImageClick(TObject *Sender)
  246. {
  247. if (EdFormObjId->Text == "")
  248. {
  249. Application->MessageBox(L"CCTV 선택\r\nCCTV 목록에서 CCTV를 선택하세요.",
  250. FTitle.c_str(),
  251. MB_OK|MB_ICONERROR|MB_APPLMODAL);
  252. return;
  253. }
  254. m_bSelected = true;
  255. Close();
  256. }
  257. //---------------------------------------------------------------------------
  258. void __fastcall TVMSM570M::TvListFocusedRecordChanged(TcxCustomGridTableView *Sender, TcxCustomGridRecord *APrevFocusedRecord,
  259. TcxCustomGridRecord *AFocusedRecord, bool ANewItemRecordFocusingChanged)
  260. {
  261. if (!AFocusedRecord) return;
  262. DisplayInfo();
  263. }
  264. //---------------------------------------------------------------------------