VMSVIEWMF.cpp 26 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922
  1. /****************************************************************************
  2. * @source :
  3. * @description :
  4. ****************************************************************************
  5. * DATE AUTHOR DESCRIPTION
  6. * --------------------------------------------------------------------------
  7. * 2016/07/10 shjung 최초작성
  8. *
  9. ****************************************************************************/
  10. //---------------------------------------------------------------------------
  11. #include <vcl.h>
  12. #include "ITSSkinF.h"
  13. #include "ITSUtilF.h"
  14. #include "AppGlobalF.h"
  15. #pragma hdrstop
  16. #include "VMSVIEWMF.h"
  17. //---------------------------------------------------------------------------
  18. #pragma package(smart_init)
  19. #pragma link "cxButtons"
  20. #pragma link "cxCalendar"
  21. #pragma link "cxContainer"
  22. #pragma link "cxControls"
  23. #pragma link "cxDropDownEdit"
  24. #pragma link "cxEdit"
  25. #pragma link "cxGraphics"
  26. #pragma link "cxGroupBox"
  27. #pragma link "cxLabel"
  28. #pragma link "cxLookAndFeelPainters"
  29. #pragma link "cxLookAndFeels"
  30. #pragma link "cxMaskEdit"
  31. #pragma link "cxPC"
  32. #pragma link "cxPCdxBarPopupMenu"
  33. #pragma link "cxSpinEdit"
  34. #pragma link "cxSplitter"
  35. #pragma link "cxTextEdit"
  36. #pragma link "cxTimeEdit"
  37. #pragma link "dxSkinBlack"
  38. #pragma link "dxSkinBlue"
  39. #pragma link "dxSkinCaramel"
  40. #pragma link "dxSkinCoffee"
  41. #pragma link "dxSkinDarkRoom"
  42. #pragma link "dxSkinDarkSide"
  43. #pragma link "dxSkinFoggy"
  44. #pragma link "dxSkinGlassOceans"
  45. #pragma link "dxSkiniMaginary"
  46. #pragma link "dxSkinLilian"
  47. #pragma link "dxSkinLiquidSky"
  48. #pragma link "dxSkinLondonLiquidSky"
  49. #pragma link "dxSkinMcSkin"
  50. #pragma link "dxSkinMoneyTwins"
  51. #pragma link "dxSkinOffice2007Black"
  52. #pragma link "dxSkinOffice2007Blue"
  53. #pragma link "dxSkinOffice2007Green"
  54. #pragma link "dxSkinOffice2007Pink"
  55. #pragma link "dxSkinOffice2007Silver"
  56. #pragma link "dxSkinOffice2010Black"
  57. #pragma link "dxSkinOffice2010Blue"
  58. #pragma link "dxSkinOffice2010Silver"
  59. #pragma link "dxSkinsCore"
  60. #pragma link "dxSkinscxPCPainter"
  61. #pragma link "dxSkinSeven"
  62. #pragma link "dxSkinSharp"
  63. #pragma link "dxSkinSilver"
  64. #pragma link "dxSkinStardust"
  65. #pragma link "cxRadioGroup"
  66. #pragma link "cxClasses"
  67. #pragma link "cxCustomData"
  68. #pragma link "cxData"
  69. #pragma link "cxDataStorage"
  70. #pragma link "cxDBData"
  71. #pragma link "cxFilter"
  72. #pragma link "cxGrid"
  73. #pragma link "cxGridCustomTableView"
  74. #pragma link "cxGridCustomView"
  75. #pragma link "cxGridDBTableView"
  76. #pragma link "cxGridLevel"
  77. #pragma link "cxGridTableView"
  78. #pragma link "cxStyles"
  79. #pragma link "cxCheckBox"
  80. #pragma link "cxImage"
  81. #pragma link "cxButtonEdit"
  82. #pragma link "cxBlobEdit"
  83. #pragma link "cxColorComboBox"
  84. #pragma link "cxCalc"
  85. #pragma link "FRAME_VmsListF"
  86. #pragma resource "*.dfm"
  87. //TVMSVIEWM *VMSVIEWM = NULL;
  88. //---------------------------------------------------------------------------
  89. __fastcall TVMSVIEWM::TVMSVIEWM(TComponent* Owner)
  90. : TForm(Owner)
  91. {
  92. ITSSkin_Load(this);
  93. //CMM_LoadForm(g_sFormsDir, this);
  94. FUpdate= false;
  95. FTitle = Caption; //"VMS 모니터링 화면 관리";
  96. EditMode = false;
  97. FRAMEVmsList1->PnlTop->Visible = false;
  98. FRAMEVmsList1->PnlBottom->Visible = false;
  99. FRAMEVmsList1->ColumnSel->Visible = false;
  100. FRAMEVmsList1->Column04->Visible = true;
  101. FRAMEVmsList1->TvList->OptionsView->ColumnAutoWidth = true;
  102. FRAMEVmsList1->TvList->OptionsSelection->MultiSelect = true;
  103. FRAMEVmsList1->TvList->OptionsSelection->CellSelect = false;
  104. }
  105. //---------------------------------------------------------------------------
  106. void __fastcall TVMSVIEWM::CommClose()
  107. {
  108. try
  109. {
  110. //CMM_SaveForm(g_sFormsDir, this);
  111. }
  112. catch(...)
  113. {
  114. }
  115. }
  116. //---------------------------------------------------------------------------
  117. void __fastcall TVMSVIEWM::FormShow(TObject *Sender)
  118. {
  119. Refresh();
  120. FormInit();
  121. ChangeEditMode(1);
  122. TmrShow->Enabled = true;
  123. }
  124. //---------------------------------------------------------------------------
  125. void __fastcall TVMSVIEWM::FormInit()
  126. {
  127. //TvList->OptionsView->NoDataToDisplayInfoText = "<등록되어 있는 정보가 없습니다>";
  128. //TvVms->OptionsView->NoDataToDisplayInfoText = "<등록되어 있는 정보가 없습니다>";
  129. FRAMEVmsList1->UpdateList();
  130. FNewDb = false;
  131. }
  132. //---------------------------------------------------------------------------
  133. void __fastcall TVMSVIEWM::TmrShowTimer(TObject *Sender)
  134. {
  135. TmrShow->Enabled = false;
  136. BtnSearchClick(NULL);
  137. }
  138. //---------------------------------------------------------------------------
  139. /*
  140. * Close 버튼 클릭 이벤트 핸들러
  141. * arguments
  142. * Sender : event handler 객체
  143. * return
  144. * void
  145. */
  146. void __fastcall TVMSVIEWM::BtnCloseClick(TObject *Sender)
  147. {
  148. Close();
  149. }
  150. //---------------------------------------------------------------------------
  151. void __fastcall TVMSVIEWM::FormClose(TObject *Sender, TCloseAction &Action)
  152. {
  153. CommClose();
  154. //VMSVIEWM = NULL;
  155. Action = caFree;
  156. }
  157. //---------------------------------------------------------------------------
  158. void __fastcall TVMSVIEWM::BtnEditClick(TObject *Sender)
  159. {
  160. if (BtnEdit->Caption == MSG903)
  161. {
  162. ChangeEditMode(0);
  163. FNewDb = false;
  164. }
  165. else
  166. {
  167. String sName = EdName->Text;
  168. ChangeEditMode(1);
  169. if (CMM_FindGridData(TvList->DataController, sName, Col02->Index) >= 0)
  170. {
  171. CMM_SetGridRow(CxList, TvList, sName, Col02->Index);
  172. DisplayInfo();
  173. }
  174. }
  175. }
  176. //---------------------------------------------------------------------------
  177. void __fastcall TVMSVIEWM::ChangeEditMode(int AEdit)
  178. {
  179. bool bEnabled = false;
  180. switch(AEdit)
  181. {
  182. case 0: //편집버튼클릭
  183. {
  184. BtnEdit->Enabled = true;
  185. BtnInsert->Enabled = false;
  186. BtnDelete->Enabled = false;
  187. BtnSave->Enabled = true;
  188. BtnEdit->Caption = MSG901;
  189. BtnEdit->Hint = MSG902;
  190. EditMode = true;
  191. }
  192. break;
  193. case 1: //편집[취소]버튼클릭
  194. {
  195. FormClear(); //화면을 모두 지운다.
  196. BtnEdit->Enabled = false;
  197. BtnInsert->Enabled = true;
  198. BtnDelete->Enabled = false;
  199. BtnSave->Enabled = false;
  200. BtnEdit->Caption = MSG903;
  201. BtnEdit->Hint = MSG904;
  202. //bEnabled = true;
  203. EditMode = false;
  204. }
  205. break;
  206. case 2: //추가
  207. {
  208. BtnEdit->Enabled = true;
  209. BtnInsert->Enabled = false;
  210. BtnDelete->Enabled = false;
  211. BtnSave->Enabled = true;
  212. BtnEdit->Caption = MSG901;
  213. BtnEdit->Hint = MSG902;
  214. EditMode = true;
  215. }
  216. break;
  217. case 3: //수정모드
  218. {
  219. BtnEdit->Enabled = true;
  220. BtnInsert->Enabled = true;
  221. BtnDelete->Enabled = true;
  222. BtnSave->Enabled = false;
  223. BtnEdit->Caption = MSG903;
  224. BtnEdit->Hint = MSG904;
  225. bEnabled = true;
  226. EditMode = false;
  227. }
  228. break;
  229. }
  230. if (AEdit == 0 || AEdit == 2)
  231. {
  232. PnlCmd->Enabled = true;
  233. }
  234. else
  235. {
  236. PnlCmd->Enabled = false;
  237. }
  238. }
  239. //---------------------------------------------------------------------------
  240. int __fastcall TVMSVIEWM::CheckDupFormName(String ANewName, String AOldName)
  241. {
  242. int nDupCnt = 0;
  243. try
  244. {
  245. TvList->BeginUpdate();
  246. TcxGridDataController *pGDC = TvList->DataController;
  247. int nRows = pGDC->RecordCount;
  248. for (int ii = 0; ii < nRows; ii++)
  249. {
  250. String sFormName = VarToStr(pGDC->Values[ii][Col02->Index]);
  251. if (sFormName == AOldName)
  252. {
  253. continue;
  254. }
  255. if (sFormName == ANewName)
  256. {
  257. nDupCnt++;
  258. }
  259. }
  260. }
  261. __finally
  262. {
  263. TvList->EndUpdate();
  264. }
  265. return nDupCnt;
  266. }
  267. //---------------------------------------------------------------------------
  268. void __fastcall TVMSVIEWM::BtnSaveClick(TObject *Sender)
  269. {
  270. if (EdName->Text.Trim().IsEmpty())
  271. {
  272. Application->MessageBox(MSG100, FTitle.c_str(), MB_OK|MB_ICONERROR|MB_APPLMODAL);
  273. return;
  274. }
  275. if (!FNewDb)
  276. {
  277. if (EdOrgName->Text.Trim().IsEmpty())
  278. {
  279. Application->MessageBox(MSG101, FTitle.c_str(), MB_OK|MB_ICONERROR|MB_APPLMODAL);
  280. return;
  281. }
  282. }
  283. if (TvVms->DataController->RecordCount == 0)
  284. {
  285. Application->MessageBox(MSG102, FTitle.c_str(), MB_OK|MB_ICONERROR|MB_APPLMODAL);
  286. return;
  287. }
  288. String sOldName = EdOrgName->Text;
  289. String sNewName = EdName->Text.Trim();
  290. int nDupCnt;
  291. bool bResult = false;
  292. if (FNewDb)
  293. {
  294. nDupCnt = CheckDupFormName(sNewName, "");
  295. }
  296. else
  297. {
  298. nDupCnt = CheckDupFormName(sNewName, sOldName);
  299. }
  300. if (nDupCnt >= 1)
  301. {
  302. Application->MessageBox(MSG103, FTitle.c_str(), MB_OK|MB_ICONERROR|MB_APPLMODAL);
  303. return;
  304. }
  305. bResult = DelVmsMonitoring(sOldName);
  306. if (!bResult)
  307. {
  308. return;
  309. }
  310. String sQry;
  311. TADOQuery *pADO = NULL;
  312. try
  313. {
  314. try
  315. {
  316. pADO = new TADOQuery(NULL);
  317. pADO->Close();
  318. pADO->Connection = ITSDb_GetConnection();
  319. sQry = "INSERT INTO TB_VMS_MONITORING ( \r\n"
  320. " MONITORING_TYPE, \r\n"
  321. " MONITORING_NM, \r\n"
  322. " MONITORING_SEQ, \r\n"
  323. " VMS_CTLR_NMBR \r\n"
  324. " ) \r\n"
  325. " VALUES ( \r\n"
  326. " :p01, \r\n"
  327. " :p02, \r\n"
  328. " :p03, \r\n"
  329. " :p04 \r\n"
  330. " ) \r\n";
  331. ITSDb_SQLText(pADO, sQry);
  332. ITSDb_GetConnection()->BeginTrans();
  333. TcxGridDataController *pGDC = TvVms->DataController;
  334. int nRows = pGDC->RecordCount;
  335. for (int ii = 0; ii < nRows; ii++)
  336. {
  337. String sVmsNmbr = VarToStr(pGDC->Values[ii][ColVms2->Index]);
  338. ITSDb_SQLBind(pADO, "p01", String(FMonitoringType));
  339. ITSDb_SQLBind(pADO, "p02", sNewName);
  340. ITSDb_SQLBind(pADO, "p03", String(ii+1));
  341. ITSDb_SQLBind(pADO, "p04", sVmsNmbr);
  342. ITSDb_SQLExec(pADO);
  343. }
  344. ITSDb_GetConnection()->CommitTrans();
  345. bResult = true;
  346. }
  347. catch(EDatabaseError &E)
  348. {
  349. ITSDb_GetConnection()->RollbackTrans();
  350. DBERRORMSG("VMS Monitoring Save", String(E.ClassName()), E.Message, sQry);
  351. throw Exception(String(E.ClassName()) + E.Message);
  352. }
  353. catch(Exception &e)
  354. {
  355. ITSDb_GetConnection()->RollbackTrans();
  356. DBERRORMSG("VMS Monitoring Save", String(e.ClassName()), e.Message, sQry);
  357. throw Exception(String(e.ClassName()) + e.Message);
  358. }
  359. }
  360. __finally
  361. {
  362. if (pADO)
  363. {
  364. pADO->Close();
  365. delete pADO;
  366. }
  367. }
  368. if (bResult)
  369. {
  370. Application->MessageBox(MSG104, FTitle.c_str(), MB_OK|MB_ICONINFORMATION|MB_APPLMODAL);
  371. FUpdate = true;
  372. LoadVmsMonitoring();
  373. CMM_SetGridRow(CxList, TvList, sNewName, Col02->Index);
  374. DisplayInfo();
  375. }
  376. }
  377. //---------------------------------------------------------------------------
  378. void __fastcall TVMSVIEWM::BtnInsertClick(TObject *Sender)
  379. {
  380. FormClear();
  381. EdName->Text = "";
  382. EdOrgName->Text = "";
  383. ChangeEditMode(2);
  384. FNewDb = true;
  385. }
  386. //---------------------------------------------------------------------------
  387. void __fastcall TVMSVIEWM::BtnDeleteClick(TObject *Sender)
  388. {
  389. int nIdx = TvList->DataController->FocusedRecordIndex;
  390. if (nIdx < 0) return;
  391. String sFormName = EdOrgName->Text;
  392. if (sFormName.IsEmpty())
  393. {
  394. Application->MessageBox(MSG105, FTitle.c_str(), MB_OK|MB_ICONERROR|MB_APPLMODAL);
  395. return;
  396. }
  397. String sMsg;
  398. sMsg = MSG106 + sFormName;
  399. sMsg+= MSG107;
  400. if (Application->MessageBox(sMsg.c_str(), FTitle.c_str(), MB_YESNO|MB_ICONQUESTION|MB_APPLMODAL) != IDYES) return;
  401. if (DelVmsMonitoring(sFormName))
  402. {
  403. FUpdate = true;
  404. Application->MessageBox(MSG108, FTitle.c_str(), MB_OK|MB_ICONINFORMATION|MB_APPLMODAL);
  405. FormClear();
  406. ChangeEditMode(1);
  407. LoadVmsMonitoring();
  408. }
  409. }
  410. //---------------------------------------------------------------------------
  411. bool __fastcall TVMSVIEWM::DelVmsMonitoring(String AFormName)
  412. {
  413. String sQry;
  414. TADOQuery *pADO = NULL;
  415. sQry = "DELETE TB_VMS_MONITORING \r\n"
  416. " WHERE MONITORING_TYPE = :p01 \r\n"
  417. " AND MONITORING_NM = :p02 \r\n";
  418. try
  419. {
  420. try
  421. {
  422. pADO = new TADOQuery(NULL);
  423. pADO->Close();
  424. pADO->Connection = ITSDb_GetConnection();
  425. ITSDb_SQLText(pADO, sQry);
  426. ITSDb_SQLBind(pADO, "p01", String(FMonitoringType));
  427. ITSDb_SQLBind(pADO, "p02", AFormName);
  428. pADO->ExecSQL();
  429. return true;
  430. }
  431. catch(EDatabaseError &E)
  432. {
  433. DBERRORMSG("VMS Monitoring Delete", String(E.ClassName()), E.Message, sQry);
  434. throw Exception(String(E.ClassName()) + E.Message);
  435. }
  436. catch(Exception &e)
  437. {
  438. DBERRORMSG("VMS Monitoring Delete", String(e.ClassName()), e.Message, sQry);
  439. throw Exception(String(e.ClassName()) + e.Message);
  440. }
  441. }
  442. __finally
  443. {
  444. if (pADO)
  445. {
  446. pADO->Close();
  447. delete pADO;
  448. }
  449. }
  450. return true;
  451. }
  452. //---------------------------------------------------------------------------
  453. void __fastcall TVMSVIEWM::TvListCellDblClick(TcxCustomGridTableView *Sender, TcxGridTableDataCellViewInfo *ACellViewInfo,
  454. TMouseButton AButton, TShiftState AShift,
  455. bool &AHandled)
  456. {
  457. if (!ACellViewInfo) return;
  458. DisplayInfo();
  459. }
  460. //---------------------------------------------------------------------------
  461. void __fastcall TVMSVIEWM::TvListFocusedRecordChanged(TcxCustomGridTableView *Sender,
  462. TcxCustomGridRecord *APrevFocusedRecord, TcxCustomGridRecord *AFocusedRecord,
  463. bool ANewItemRecordFocusingChanged)
  464. {
  465. if (!AFocusedRecord) return;
  466. DisplayInfo();
  467. }
  468. //---------------------------------------------------------------------------
  469. void __fastcall TVMSVIEWM::BtnSearchClick(TObject *Sender)
  470. {
  471. RefreshData();
  472. EdFocus->SetFocus();
  473. ChangeEditMode(1);
  474. }
  475. //---------------------------------------------------------------------------
  476. void __fastcall TVMSVIEWM::RefreshData()
  477. {
  478. // 검색조건에 의한 링크 데이터 조회
  479. FormClear();
  480. LoadVmsMonitoring();
  481. }
  482. //---------------------------------------------------------------------------
  483. void __fastcall TVMSVIEWM::LoadVmsMonitoring()
  484. {
  485. String sQry;
  486. TADOQuery *pADO = NULL;
  487. CMM_ClearGridTableView(TvList);
  488. sQry = "SELECT MONITORING_NM, COUNT(1) AS CNT \r\n"
  489. " FROM TB_VMS_MONITORING \r\n"
  490. " WHERE MONITORING_TYPE = :p01 \r\n"
  491. " GROUP BY MONITORING_NM \r\n"
  492. " ORDER BY MONITORING_NM DESC \r\n";
  493. String sFirstFormId = "";
  494. try
  495. {
  496. int nRow;
  497. TcxDataController *pGDC = TvList->DataController;
  498. TvList->BeginUpdate();
  499. try
  500. {
  501. pADO = new TADOQuery(NULL);
  502. pADO->Close();
  503. pADO->Connection = ITSDb_GetConnection();
  504. ITSDb_SQLText(pADO, sQry);
  505. ITSDb_SQLBind(pADO, "p01", String(FMonitoringType));
  506. ITSDb_SQLOpen(pADO);
  507. for( ; !pADO->Eof; pADO->Next())
  508. {
  509. nRow = pGDC->AppendRecord();
  510. pGDC->Values[nRow][Col01->Index] = "";
  511. pGDC->Values[nRow][Col02->Index] = pADO->FieldByName("MONITORING_NM")->AsString;
  512. pGDC->Values[nRow][Col03->Index] = pADO->FieldByName("CNT")->AsString;
  513. }
  514. }
  515. catch(EDatabaseError &E)
  516. {
  517. DBERRORMSG("VMS Monitoring Query", String(E.ClassName()), E.Message, sQry);
  518. throw Exception(String(E.ClassName()) + E.Message);
  519. }
  520. catch(Exception &e)
  521. {
  522. DBERRORMSG("VMS Monitoring Query", String(e.ClassName()), e.Message, sQry);
  523. throw Exception(String(e.ClassName()) + e.Message);
  524. }
  525. }
  526. __finally
  527. {
  528. if (pADO)
  529. {
  530. pADO->Close();
  531. delete pADO;
  532. }
  533. TvList->EndUpdate();
  534. }
  535. }
  536. //---------------------------------------------------------------------------
  537. void __fastcall TVMSVIEWM::FormClear()
  538. {
  539. CMM_ClearGridTableView(TvVms);
  540. EdOrgName->Clear();
  541. EdName->Clear();
  542. FNewDb = false;
  543. }
  544. //---------------------------------------------------------------------------
  545. void __fastcall TVMSVIEWM::DisplayInfo()
  546. {
  547. FormClear();
  548. int nSelIdx = TvList->DataController->FocusedRecordIndex;
  549. if( nSelIdx <= -1 )
  550. return;
  551. DisplayFormInfo(nSelIdx);
  552. ChangeEditMode(3);
  553. }
  554. //---------------------------------------------------------------------------
  555. void __fastcall TVMSVIEWM::DisplayFormInfo(int AIdx)
  556. {
  557. TcxGridDataController *pDc = TvList->DataController;
  558. String sScrName = VarToStr(pDc->Values[AIdx][Col02->Index]);
  559. EdName->Text = sScrName;
  560. EdOrgName->Text = sScrName;
  561. CMM_ClearGridTableView(TvVms);
  562. String sQry;
  563. TADOQuery *pADO = NULL;
  564. sQry = "SELECT A.MONITORING_NM, A.MONITORING_SEQ, \r\n"
  565. " A.VMS_CTLR_NMBR, B.VMS_CTLR_ID, B.VMS_NM \r\n"
  566. " FROM TB_VMS_MONITORING A, \r\n"
  567. " TB_VMS_CTLR B \r\n"
  568. " WHERE A.MONITORING_TYPE = :p01 \r\n"
  569. " AND A.MONITORING_NM = :p02 \r\n"
  570. " AND A.VMS_CTLR_NMBR = B.VMS_CTLR_NMBR(+) \r\n"
  571. " ORDER BY A.MONITORING_NM, A.MONITORING_SEQ \r\n";
  572. String sFirstFormId = "";
  573. try
  574. {
  575. int nRow;
  576. TcxDataController *pGDC = TvVms->DataController;
  577. TvVms->BeginUpdate();
  578. try
  579. {
  580. pADO = new TADOQuery(NULL);
  581. pADO->Close();
  582. pADO->Connection = ITSDb_GetConnection();
  583. ITSDb_SQLText(pADO, sQry);
  584. ITSDb_SQLBind(pADO, "p01", String(FMonitoringType));
  585. ITSDb_SQLBind(pADO, "p02", sScrName);
  586. ITSDb_SQLOpen(pADO);
  587. for( ; !pADO->Eof; pADO->Next())
  588. {
  589. nRow = pGDC->AppendRecord();
  590. pGDC->Values[nRow][ColVms1->Index] = pADO->FieldByName("MONITORING_SEQ")->AsString;
  591. pGDC->Values[nRow][ColVms2->Index] = pADO->FieldByName("VMS_CTLR_NMBR")->AsString;
  592. pGDC->Values[nRow][ColVms3->Index] = pADO->FieldByName("VMS_NM")->AsString;
  593. }
  594. }
  595. catch(EDatabaseError &E)
  596. {
  597. DBERRORMSG("VMS Monitoring Query", String(E.ClassName()), E.Message, sQry);
  598. throw Exception(String(E.ClassName()) + E.Message);
  599. }
  600. catch(Exception &e)
  601. {
  602. DBERRORMSG("VMS Monitoring Query", String(e.ClassName()), e.Message, sQry);
  603. throw Exception(String(e.ClassName()) + e.Message);
  604. }
  605. }
  606. __finally
  607. {
  608. if (pADO)
  609. {
  610. pADO->Close();
  611. delete pADO;
  612. }
  613. TvVms->EndUpdate();
  614. }
  615. }
  616. //---------------------------------------------------------------------------
  617. bool __fastcall TVMSVIEWM::FindVmsInfo(String AVmsNmbr)
  618. {
  619. try {
  620. TvVms->BeginUpdate();
  621. for (int ii = 0; ii < TvVms->DataController->RecordCount; ii++)
  622. {
  623. String sVmsNmbr = VarToStr(TvVms->DataController->Values[ii][ColVms2->Index]);
  624. if (sVmsNmbr == AVmsNmbr) return true;
  625. }
  626. }
  627. __finally
  628. {
  629. TvVms->EndUpdate();
  630. }
  631. return false;
  632. }
  633. //---------------------------------------------------------------------------
  634. void __fastcall TVMSVIEWM::UpdateVmsSeq()
  635. {
  636. try {
  637. TvVms->BeginUpdate();
  638. for (int ii = 0; ii < TvVms->DataController->RecordCount; ii++)
  639. {
  640. TvVms->DataController->Values[ii][ColVms1->Index] = String(ii+1);
  641. }
  642. }
  643. __finally
  644. {
  645. TvVms->EndUpdate();
  646. }
  647. }
  648. //---------------------------------------------------------------------------
  649. void __fastcall TVMSVIEWM::BtnListAddClick(TObject *Sender)
  650. {
  651. TcxGridTableView *pSrcList = FRAMEVmsList1->TvList;
  652. TcxGridTableView *pDstList = TvVms;
  653. int nSelRows = pSrcList->Controller->SelectedRowCount;
  654. if (nSelRows <= 0)
  655. {
  656. return;
  657. }
  658. try
  659. {
  660. TcxGridDataController *pGDC = pDstList->DataController;
  661. try
  662. {
  663. for (int ii = 0; ii < nSelRows; ii++)
  664. {
  665. int nSelIdx = pSrcList->Controller->SelectedRows[ii]->RecordIndex;
  666. String sVmsNmbr = VarToStr(pSrcList->DataController->Values[nSelIdx][FRAMEVmsList1->Column01->Index]);
  667. String sVmsName = VarToStr(pSrcList->DataController->Values[nSelIdx][FRAMEVmsList1->Column03->Index]);
  668. if (FindVmsInfo(sVmsNmbr)) continue;
  669. int nRow = pGDC->AppendRecord();
  670. pGDC->Values[nRow][ColVms2->Index] = sVmsNmbr;
  671. pGDC->Values[nRow][ColVms3->Index] = sVmsName;
  672. }
  673. }
  674. catch(...)
  675. {
  676. }
  677. }
  678. __finally
  679. {
  680. UpdateVmsSeq();
  681. }
  682. }
  683. //---------------------------------------------------------------------------
  684. void __fastcall TVMSVIEWM::BtnListDeleteClick(TObject *Sender)
  685. {
  686. TcxGridTableView *pSrcList = TvVms;
  687. int nFocused = pSrcList->Controller->FocusedRecordIndex;
  688. int nSelRows = pSrcList->Controller->SelectedRowCount;
  689. if (nSelRows <= 0)
  690. {
  691. return;
  692. }
  693. try
  694. {
  695. TcxGridDataController *pGDC = pSrcList->DataController;
  696. pSrcList->BeginUpdate();
  697. try
  698. {
  699. pSrcList->Controller->DeleteSelection();
  700. int nDataCnt = pSrcList->DataController->RecordCount;
  701. if (nDataCnt <= nFocused)
  702. nFocused = nDataCnt - 1;
  703. pSrcList->Controller->ClearSelection();
  704. if (nFocused >= 0)
  705. {
  706. pSrcList->Controller->FocusedRowIndex = nFocused;
  707. pSrcList->ViewData->Records[nFocused]->Focused = true;
  708. pSrcList->ViewData->Records[nFocused]->Selected = true;
  709. }
  710. //CxLink->SetFocus();
  711. }
  712. catch(...)
  713. {
  714. }
  715. }
  716. __finally
  717. {
  718. pSrcList->EndUpdate();
  719. UpdateVmsSeq();
  720. }
  721. }
  722. //---------------------------------------------------------------------------
  723. void __fastcall TVMSVIEWM::BtnUpClick(TObject *Sender)
  724. {
  725. try
  726. {
  727. TvVms->BeginUpdate();
  728. int nCurIdx = TvVms->DataController->FocusedRowIndex;//FocusedRecordIndex;
  729. if (nCurIdx <= 0)
  730. {
  731. return;
  732. }
  733. int nUpIdx = nCurIdx-1;
  734. try
  735. {
  736. String sVal1 = VarToStr(TvVms->DataController->Values[nCurIdx][ColVms1->Index]);
  737. String sVal2 = VarToStr(TvVms->DataController->Values[nCurIdx][ColVms2->Index]);
  738. String sVal3 = VarToStr(TvVms->DataController->Values[nCurIdx][ColVms3->Index]);
  739. TvVms->DataController->Values[nCurIdx][ColVms1->Index] = TvVms->DataController->Values[nUpIdx][ColVms1->Index];
  740. TvVms->DataController->Values[nCurIdx][ColVms2->Index] = TvVms->DataController->Values[nUpIdx][ColVms2->Index];
  741. TvVms->DataController->Values[nCurIdx][ColVms3->Index] = TvVms->DataController->Values[nUpIdx][ColVms3->Index];
  742. TvVms->DataController->Values[nUpIdx][ColVms1->Index] = sVal1;
  743. TvVms->DataController->Values[nUpIdx][ColVms2->Index] = sVal2;
  744. TvVms->DataController->Values[nUpIdx][ColVms3->Index] = sVal3;
  745. TvVms->Controller->ClearSelection();
  746. TvVms->Controller->FocusedRowIndex = nUpIdx;
  747. TvVms->ViewData->Records[nUpIdx]->Focused = true;
  748. TvVms->ViewData->Records[nUpIdx]->Selected = true;
  749. CxVms->SetFocus();
  750. }
  751. catch(...)
  752. {
  753. }
  754. }
  755. __finally
  756. {
  757. TvVms->EndUpdate();
  758. UpdateVmsSeq();
  759. }
  760. }
  761. //---------------------------------------------------------------------------
  762. void __fastcall TVMSVIEWM::BtnDownClick(TObject *Sender)
  763. {
  764. try
  765. {
  766. TvVms->BeginUpdate();
  767. int nCurIdx = TvVms->DataController->FocusedRowIndex;//FocusedRecordIndex;
  768. if (nCurIdx < 0)
  769. {
  770. return;
  771. }
  772. if (nCurIdx == TvVms->DataController->RecordCount-1)
  773. {
  774. return;
  775. }
  776. int nDnIdx = nCurIdx+1;
  777. try
  778. {
  779. String sVal1 = VarToStr(TvVms->DataController->Values[nCurIdx][ColVms1->Index]);
  780. String sVal2 = VarToStr(TvVms->DataController->Values[nCurIdx][ColVms2->Index]);
  781. String sVal3 = VarToStr(TvVms->DataController->Values[nCurIdx][ColVms3->Index]);
  782. TvVms->DataController->Values[nCurIdx][ColVms1->Index] = TvVms->DataController->Values[nDnIdx][ColVms1->Index];
  783. TvVms->DataController->Values[nCurIdx][ColVms2->Index] = TvVms->DataController->Values[nDnIdx][ColVms2->Index];
  784. TvVms->DataController->Values[nCurIdx][ColVms3->Index] = TvVms->DataController->Values[nDnIdx][ColVms3->Index];
  785. TvVms->DataController->Values[nDnIdx][ColVms1->Index] = sVal1;
  786. TvVms->DataController->Values[nDnIdx][ColVms2->Index] = sVal2;
  787. TvVms->DataController->Values[nDnIdx][ColVms3->Index] = sVal3;
  788. TvVms->Controller->ClearSelection();
  789. TvVms->Controller->FocusedRowIndex = nDnIdx;
  790. TvVms->ViewData->Records[nDnIdx]->Focused = true;
  791. TvVms->ViewData->Records[nDnIdx]->Selected = true;
  792. CxVms->SetFocus();
  793. }
  794. catch(...)
  795. {
  796. }
  797. }
  798. __finally
  799. {
  800. TvVms->EndUpdate();
  801. UpdateVmsSeq();
  802. }
  803. }
  804. //---------------------------------------------------------------------------