VMSVIEWMF.cpp 27 KB

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