VMSVIEWMF.cpp 27 KB

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