FRAME_IncidentRegistF.cpp 28 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691
  1. //---------------------------------------------------------------------------
  2. #include <vcl.h>
  3. #include "ITSSkinF.h"
  4. #include "ITSUtilF.h"
  5. #include "AppGlobalF.h"
  6. #pragma hdrstop
  7. #include "FRAME_IncidentRegistF.h"
  8. //---------------------------------------------------------------------------
  9. #pragma package(smart_init)
  10. #pragma link "cxContainer"
  11. #pragma link "cxControls"
  12. #pragma link "cxEdit"
  13. #pragma link "cxGraphics"
  14. #pragma link "cxGroupBox"
  15. #pragma link "cxLookAndFeelPainters"
  16. #pragma link "cxLookAndFeels"
  17. #pragma link "dxSkinBlack"
  18. #pragma link "dxSkinBlue"
  19. #pragma link "dxSkinCaramel"
  20. #pragma link "dxSkinCoffee"
  21. #pragma link "dxSkinDarkRoom"
  22. #pragma link "dxSkinDarkSide"
  23. #pragma link "dxSkinFoggy"
  24. #pragma link "dxSkinGlassOceans"
  25. #pragma link "dxSkiniMaginary"
  26. #pragma link "dxSkinLilian"
  27. #pragma link "dxSkinLiquidSky"
  28. #pragma link "dxSkinLondonLiquidSky"
  29. #pragma link "dxSkinMcSkin"
  30. #pragma link "dxSkinMoneyTwins"
  31. #pragma link "dxSkinOffice2007Black"
  32. #pragma link "dxSkinOffice2007Blue"
  33. #pragma link "dxSkinOffice2007Green"
  34. #pragma link "dxSkinOffice2007Pink"
  35. #pragma link "dxSkinOffice2007Silver"
  36. #pragma link "dxSkinOffice2010Black"
  37. #pragma link "dxSkinOffice2010Blue"
  38. #pragma link "dxSkinOffice2010Silver"
  39. #pragma link "dxSkinsCore"
  40. #pragma link "dxSkinSeven"
  41. #pragma link "dxSkinSharp"
  42. #pragma link "dxSkinSilver"
  43. #pragma link "dxSkinStardust"
  44. #pragma link "cxSplitter"
  45. #pragma link "cxClasses"
  46. #pragma link "cxCustomData"
  47. #pragma link "cxData"
  48. #pragma link "cxDataStorage"
  49. #pragma link "cxFilter"
  50. #pragma link "cxGrid"
  51. #pragma link "cxGridCustomTableView"
  52. #pragma link "cxGridCustomView"
  53. #pragma link "cxGridLevel"
  54. #pragma link "cxGridTableView"
  55. #pragma link "cxLabel"
  56. #pragma link "cxStyles"
  57. #pragma link "dxSkinscxPCPainter"
  58. #pragma link "cxButtons"
  59. #pragma link "cxTextEdit"
  60. #pragma link "cxDropDownEdit"
  61. #pragma link "cxMaskEdit"
  62. #pragma link "cxCalc"
  63. #pragma link "cxCalendar"
  64. #pragma resource "*.dfm"
  65. TFRAMEIncidentRegist *FRAMEIncidentRegist;
  66. //---------------------------------------------------------------------------
  67. __fastcall TFRAMEIncidentRegist::TFRAMEIncidentRegist(TComponent* Owner)
  68. : TFrame(Owner)
  69. {
  70. ITSSkin_Load((TForm*)this);
  71. FTitle = "신규 돌발 등록";
  72. m_pGDC = TvList->DataController;
  73. TvList->OptionsView->NoDataToDisplayInfoText = "<현재 등록된 돌발정보가 없습니다>";
  74. FCodeIST = ItsCodeManager->FLists.Find("IST"); //돌발상황 원본 코드 : IST
  75. FCodeLTCU = ItsCodeManager->FLists.Find("LTCU"); //소통 등급 코드 : LTCU
  76. FCodeICM = ItsCodeManager->FLists.Find("ICM"); //돌발상황 확인 방법 코드 : ICM
  77. FCodeIDTU = ItsCodeManager->FLists.Find("IDTU"); //돌발상황 유형 분류 코드 : IDTU
  78. FCodeACTU = ItsCodeManager->FLists.Find("ACTU"); //돌발상황 유형 코드 : ACTU, CRTU, EVTU, WETU 중 하나
  79. FCodeCRTU = ItsCodeManager->FLists.Find("CRTU"); //돌발상황 유형 코드 : ACTU, CRTU, EVTU, WETU 중 하나
  80. FCodeEVTU = ItsCodeManager->FLists.Find("EVTU"); //돌발상황 유형 코드 : ACTU, CRTU, EVTU, WETU 중 하나
  81. FCodeWETU = ItsCodeManager->FLists.Find("WETU"); //돌발상황 유형 코드 : ACTU, CRTU, EVTU, WETU 중 하나
  82. FCodeSRLU = ItsCodeManager->FLists.Find("SRLU"); //돌발상황 심각도 코드 : SRLU
  83. FCodePRTU = ItsCodeManager->FLists.Find("PRTU"); //통행 제한 유형 코드 : PRTU
  84. FCodeRSL = ItsCodeManager->FLists.Find("RSL"); //대응 수준 코드 : RSL
  85. FCodeISS = ItsCodeManager->FLists.Find("ISS"); //돌발상황 진행 단계 코드 : ISS
  86. FCodeICM = ItsCodeManager->FLists.Find("ICM"); //돌발상황 종료 확인 방법 코드 : ICM
  87. FCodeDFW = ItsCodeManager->FLists.Find("DFW"); //기상 코드 : DFW
  88. FCodeVIT = ItsCodeManager->FLists.Find("VIT"); //VMS 돌발 유형 코드 : VIT
  89. FCodeIDT = ItsCodeManager->FLists.Find("IDT"); //VMS 돌발 유형 세부 코드 : IDT
  90. FCodeEDT = ItsCodeManager->FLists.Find("EDT"); //VMS 돌발 유형 세부 코드 : EDT
  91. InitForm();
  92. }
  93. //---------------------------------------------------------------------------
  94. void __fastcall TFRAMEIncidentRegist::InitForm()
  95. {
  96. DtINCD_CNFM_DT->Date = Now();
  97. DtINCD_STRT_DT->Date = Now();
  98. DtINCD_END_PRAR_DT->Date = Now() + ( 1 / 24 );
  99. CbINCD_ORGN_CD->Properties->Items->Clear();
  100. if (FCodeIST)
  101. {
  102. FOR_STL(TItsSubCode *, pSubCode, FCodeIST->FSubLists)
  103. {
  104. if (pSubCode->USE_YN == "N") continue;
  105. CbINCD_ORGN_CD->Properties->Items->Add(" [" + pSubCode->CMMN_CD + "] " + pSubCode->CMMN_CD_KOR_NM);
  106. }
  107. }
  108. CbINCD_ORGN_CD->ItemIndex = 0;
  109. CbCMTR_GRAD_CD->Properties->Items->Clear();
  110. if (FCodeLTCU)
  111. {
  112. FOR_STL(TItsSubCode *, pSubCode, FCodeLTCU->FSubLists)
  113. {
  114. if (pSubCode->USE_YN == "N") continue;
  115. CbCMTR_GRAD_CD->Properties->Items->Add(" [" + pSubCode->CMMN_CD + "] " + pSubCode->CMMN_CD_KOR_NM);
  116. }
  117. }
  118. CbCMTR_GRAD_CD->ItemIndex = 0;
  119. CbINCD_CNFM_MTHD_CD->Properties->Items->Clear();
  120. if (FCodeICM)
  121. {
  122. FOR_STL(TItsSubCode *, pSubCode, FCodeICM->FSubLists)
  123. {
  124. if (pSubCode->USE_YN == "N") continue;
  125. CbINCD_CNFM_MTHD_CD->Properties->Items->Add(" [" + pSubCode->CMMN_CD + "] " + pSubCode->CMMN_CD_KOR_NM);
  126. }
  127. }
  128. CbINCD_CNFM_MTHD_CD->ItemIndex = 0;
  129. CbINCD_SERN_CD->Properties->Items->Clear();
  130. if (FCodeSRLU)
  131. {
  132. FOR_STL(TItsSubCode *, pSubCode, FCodeSRLU->FSubLists)
  133. {
  134. if (pSubCode->USE_YN == "N") continue;
  135. CbINCD_SERN_CD->Properties->Items->Add(" [" + pSubCode->CMMN_CD + "] " + pSubCode->CMMN_CD_KOR_NM);
  136. }
  137. }
  138. CbINCD_SERN_CD->ItemIndex = 0;
  139. CbINCD_TYPE_CLSF_CD->Properties->Items->Clear();
  140. if (FCodeIDTU)
  141. {
  142. FOR_STL(TItsSubCode *, pSubCode, FCodeIDTU->FSubLists)
  143. {
  144. if (pSubCode->USE_YN == "N") continue;
  145. CbINCD_TYPE_CLSF_CD->Properties->Items->Add(" [" + pSubCode->CMMN_CD + "] " + pSubCode->CMMN_CD_KOR_NM);
  146. }
  147. }
  148. CbINCD_TYPE_CLSF_CD->ItemIndex = 0;
  149. CbINCD_TYPE_CLSF_CDClick((TObject *)CbINCD_TYPE_CLSF_CD);
  150. }
  151. //---------------------------------------------------------------------------
  152. void __fastcall TFRAMEIncidentRegist::UpdateList()
  153. {
  154. TItsSubCode *pSubCode;
  155. CMM_ClearGridTableView(TvList);
  156. int nRow = 0;
  157. try
  158. {
  159. TvList->BeginUpdate();
  160. try
  161. {
  162. ItsIncidentManager->FLists.Lock();
  163. FOR_STL(TItsIncident *, pObj, ItsIncidentManager->FLists)
  164. {
  165. if (pObj->INCD_PRGR_STEP_CD != "ISS1") continue;
  166. nRow = m_pGDC->AppendRecord();
  167. String sIST = "";
  168. if (pObj->INCD_ORGN_CD != "") sIST = " [" + pObj->INCD_ORGN_CD + "] ";
  169. String sLTCU= "";
  170. if (pObj->CMTR_GRAD_CD != "") sLTCU = " [" + pObj->CMTR_GRAD_CD + "] ";
  171. String sICM = "";
  172. if (pObj->INCD_CNFM_MTHD_CD != "") sICM = " [" + pObj->INCD_CNFM_MTHD_CD + "] ";
  173. String sSRLU= "";
  174. if (pObj->INCD_SERN_CD != "") sSRLU = " [" + pObj->INCD_SERN_CD + "] ";
  175. String sIDTU = "";
  176. if (pObj->INCD_TYPE_CLSF_CD != "") sIDTU = " [" + pObj->INCD_TYPE_CLSF_CD + "] ";
  177. String sACTU = "";
  178. if (pObj->INCD_TYPE_CD != "") sACTU = " [" + pObj->INCD_TYPE_CD + "] ";
  179. String sISS = "";
  180. if (pObj->INCD_PRGR_STEP_CD != "") sISS = " [" + pObj->INCD_PRGR_STEP_CD + "] ";
  181. String sDFW = "";
  182. if (pObj->WTHR_CD != "") sDFW = " [" + pObj->WTHR_CD + "] ";
  183. String sRSL = "";
  184. if (pObj->RESP_LVL_CD != "") sRSL = " [" + pObj->RESP_LVL_CD + "] ";
  185. String sPRTU = "";
  186. if (pObj->TRVL_LMNT_TYPE_CD != "") sPRTU = " [" + pObj->TRVL_LMNT_TYPE_CD + "] ";
  187. if (FCodeIST)
  188. {
  189. pSubCode = FCodeIST->FSubLists.Find(pObj->INCD_ORGN_CD);
  190. if (pSubCode) sIST = sIST + pSubCode->CMMN_CD_KOR_NM;
  191. }
  192. if (FCodeLTCU)
  193. {
  194. pSubCode = FCodeLTCU->FSubLists.Find(pObj->CMTR_GRAD_CD);
  195. if (pSubCode) sLTCU = sLTCU + pSubCode->CMMN_CD_KOR_NM;
  196. }
  197. if (FCodeICM)
  198. {
  199. pSubCode = FCodeICM->FSubLists.Find(pObj->INCD_CNFM_MTHD_CD);
  200. if (pSubCode) sICM = sICM + pSubCode->CMMN_CD_KOR_NM;
  201. }
  202. if (FCodeSRLU)
  203. {
  204. pSubCode = FCodeSRLU->FSubLists.Find(pObj->INCD_SERN_CD);
  205. if (pSubCode) sSRLU = sSRLU + pSubCode->CMMN_CD_KOR_NM;
  206. }
  207. if (FCodeIDTU)
  208. {
  209. pSubCode = FCodeIDTU->FSubLists.Find(pObj->INCD_TYPE_CLSF_CD);
  210. if (pSubCode) sIDTU = sIDTU + pSubCode->CMMN_CD_KOR_NM;
  211. }
  212. if (!pObj->INCD_TYPE_CLSF_CD.IsEmpty() && !pObj->INCD_TYPE_CD.IsEmpty())
  213. {
  214. if (pObj->INCD_TYPE_CLSF_CD == "1")
  215. {
  216. if (FCodeACTU)
  217. {
  218. pSubCode = FCodeACTU->FSubLists.Find(pObj->INCD_TYPE_CD);
  219. if (pSubCode) sACTU = sACTU + pSubCode->CMMN_CD_KOR_NM;
  220. }
  221. }
  222. else if (pObj->INCD_TYPE_CLSF_CD == "2")
  223. {
  224. if (FCodeCRTU)
  225. {
  226. pSubCode = FCodeCRTU->FSubLists.Find(pObj->INCD_TYPE_CD);
  227. if (pSubCode) sACTU = sACTU + pSubCode->CMMN_CD_KOR_NM;
  228. }
  229. }
  230. else if (pObj->INCD_TYPE_CLSF_CD == "3")
  231. {
  232. if (FCodeEVTU)
  233. {
  234. pSubCode = FCodeEVTU->FSubLists.Find(pObj->INCD_TYPE_CD);
  235. if (pSubCode) sACTU = sACTU + pSubCode->CMMN_CD_KOR_NM;
  236. }
  237. }
  238. else if (pObj->INCD_TYPE_CLSF_CD == "4")
  239. {
  240. if (FCodeWETU)
  241. {
  242. pSubCode = FCodeWETU->FSubLists.Find(pObj->INCD_TYPE_CD);
  243. if (pSubCode) sACTU = sACTU + pSubCode->CMMN_CD_KOR_NM;
  244. }
  245. }
  246. }
  247. if (FCodeISS)
  248. {
  249. pSubCode = FCodeISS->FSubLists.Find(pObj->INCD_PRGR_STEP_CD);
  250. if (pSubCode) sISS = sISS + pSubCode->CMMN_CD_KOR_NM;
  251. }
  252. if (FCodeDFW)
  253. {
  254. pSubCode = FCodeISS->FSubLists.Find(pObj->WTHR_CD);
  255. if (pSubCode) sDFW = sDFW + pSubCode->CMMN_CD_KOR_NM;
  256. }
  257. if (FCodeRSL)
  258. {
  259. pSubCode = FCodeRSL->FSubLists.Find(pObj->RESP_LVL_CD);
  260. if (pSubCode) sRSL = sRSL + pSubCode->CMMN_CD_KOR_NM;
  261. }
  262. if (FCodePRTU)
  263. {
  264. pSubCode = FCodePRTU->FSubLists.Find(pObj->TRVL_LMNT_TYPE_CD);
  265. if (pSubCode) sPRTU = sPRTU + pSubCode->CMMN_CD_KOR_NM;
  266. }
  267. m_pGDC->Values[nRow][Column01->Index] = pObj->INCD_OCRR_ID; //돌발상황 발생 ID
  268. m_pGDC->Values[nRow][Column02->Index] = ITSUtil_StrToDateTime(pObj->RGST_DT); //등록 일시
  269. m_pGDC->Values[nRow][Column03->Index] = sISS;//pObj->INCD_PRGR_STEP_CD; //돌발상황 진행 단계 코드 : ISS
  270. m_pGDC->Values[nRow][Column04->Index] = sIST;//pObj->INCD_ORGN_CD; //돌발상황 원본 코드 : IST
  271. m_pGDC->Values[nRow][Column05->Index] = pObj->OCRR_LCTN_NM; //발생 위치 명
  272. m_pGDC->Values[nRow][Column06->Index] = pObj->LINK_ID; //돌발발생 LINK ID
  273. m_pGDC->Values[nRow][Column07->Index] = pObj->X_CRDN; //X 좌표
  274. m_pGDC->Values[nRow][Column08->Index] = pObj->Y_CRDN; //Y 좌표
  275. m_pGDC->Values[nRow][Column09->Index] = pObj->INCD_EXPL; //돌발상황 설명
  276. m_pGDC->Values[nRow][Column10->Index] = sLTCU;//pObj->CMTR_GRAD_CD; //소통 등급 코드 : LTCU
  277. m_pGDC->Values[nRow][Column11->Index] = pObj->IFMR_NM; //제보자 명
  278. m_pGDC->Values[nRow][Column12->Index] = sICM;//pObj->INCD_CNFM_MTHD_CD; //돌발상황 확인 방법 코드 : ICM
  279. m_pGDC->Values[nRow][Column13->Index] = sSRLU;//pObj->INCD_SERN_CD; //돌발상황 심각도 코드 : SRLU
  280. m_pGDC->Values[nRow][Column14->Index] = pObj->INCD_TITL; //돌발상황 제목
  281. m_pGDC->Values[nRow][Column15->Index] = sIDTU;//pObj->INCD_TYPE_CLSF_CD; //돌발상황 유형 분류 코드 : IDTU
  282. m_pGDC->Values[nRow][Column16->Index] = sACTU;//pObj->INCD_TYPE_CD; //돌발상황 유형 코드 : ACTU, CRTU, EVTU, WETU 중 하나
  283. m_pGDC->Values[nRow][Column17->Index] = ITSUtil_StrToDateTime(pObj->FINCD_STRT_DT); //돌발상황 시작 일시
  284. m_pGDC->Values[nRow][Column18->Index] = ITSUtil_StrToDateTime(pObj->INCD_END_PRAR_DT); //돌발상황 종료 예정 일시
  285. m_pGDC->Values[nRow][Column19->Index] = pObj->INCD_OCRR_LANE; //돌발상황 발생 차로
  286. m_pGDC->Values[nRow][Column20->Index] = pObj->INCD_CLSR_LANE; //돌발상황 차단 차로
  287. m_pGDC->Values[nRow][Column21->Index] = pObj->DELY_LNGT; //지체 길이
  288. m_pGDC->Values[nRow][Column22->Index] = pObj->INCD_LNGT; //돌발상황 길이
  289. m_pGDC->Values[nRow][Column23->Index] = pObj->SMLT_VHCL_UNUM; //소형 차량 대수
  290. m_pGDC->Values[nRow][Column24->Index] = pObj->MDLT_VHCL_UNUM; //중대형 차량 대수
  291. m_pGDC->Values[nRow][Column25->Index] = pObj->INJR_PNUM; //부상자 인원수
  292. m_pGDC->Values[nRow][Column26->Index] = pObj->FTLT_PNUM; //사망자 인원수
  293. m_pGDC->Values[nRow][Column27->Index] = sDFW;//pObj->WTHR_CD; //기상 코드 : DFW
  294. m_pGDC->Values[nRow][Column28->Index] = sRSL;//pObj->RESP_LVL_CD; //대응 수준 코드 : RSL
  295. m_pGDC->Values[nRow][Column29->Index] = pObj->UTIS_CNCT_YN; //UTIS 연계 여부
  296. m_pGDC->Values[nRow][Column30->Index] = pObj->TRUB_VHCL_YN; //고장 차량 여부
  297. m_pGDC->Values[nRow][Column31->Index] = pObj->FALT_YN; //낙하물 여부
  298. m_pGDC->Values[nRow][Column32->Index] = pObj->FRWT_YN; //화재위험물 여부
  299. m_pGDC->Values[nRow][Column33->Index] = sPRTU;//pObj->TRVL_LMNT_TYPE_CD; //통행 제한 유형 코드 : PRTU
  300. m_pGDC->Values[nRow][Column34->Index] = pObj->VMS_DSPL_YN; //VMS 표출 여부
  301. m_pGDC->Values[nRow][Column35->Index] = ITSUtil_StrToDateTime(pObj->INCD_CNFM_DT); //VMS 표출 여부
  302. m_pGDC->Values[nRow][Column99->Index] = (int)pObj;
  303. }
  304. }
  305. __finally
  306. {
  307. ItsIncidentManager->FLists.UnLock();
  308. }
  309. }
  310. __finally
  311. {
  312. LblRecords->Caption = "("+FormatFloat("##,##0", m_pGDC->FilteredRecordCount) +"/"+FormatFloat("##,##0", m_pGDC->RecordCount) + ")";
  313. TvList->EndUpdate();
  314. TvList->DataController->GotoFirst();
  315. TvList->DataController->FocusedRecordIndex = 0;
  316. }
  317. }
  318. //---------------------------------------------------------------------------
  319. void __fastcall TFRAMEIncidentRegist::TvListDataControllerFilterChanged(TObject *Sender)
  320. {
  321. LblRecords->Caption = "("+FormatFloat("##,##0", m_pGDC->FilteredRecordCount) +"/"+FormatFloat("##,##0", m_pGDC->RecordCount) + ")";
  322. }
  323. //---------------------------------------------------------------------------
  324. void __fastcall TFRAMEIncidentRegist::BtnExlSaveClick(TObject *Sender)
  325. {
  326. TcxGrid *pGrid = CxList;
  327. TcxGridTableView *pView = TvList;
  328. String sTitle= "등록된 돌발정보";
  329. CMM_ExportToExcelFile(sTitle, pGrid, pView, (TForm*)this);
  330. }
  331. //---------------------------------------------------------------------------
  332. void __fastcall TFRAMEIncidentRegist::CbINCD_TYPE_CLSF_CDClick(TObject *Sender)
  333. {
  334. if (CbINCD_TYPE_CLSF_CD->ItemIndex < 0) return;
  335. CbINCD_TYPE_CD->Properties->Items->Clear();
  336. String sCode = ITSUtil_GetCode(CbINCD_TYPE_CLSF_CD->Text);
  337. if (sCode == "1")
  338. {
  339. if (FCodeACTU)
  340. {
  341. FOR_STL(TItsSubCode *, pSubCode, FCodeACTU->FSubLists)
  342. {
  343. if (pSubCode->USE_YN == "N") continue;
  344. CbINCD_TYPE_CD->Properties->Items->Add(" [" + pSubCode->CMMN_CD + "] " + pSubCode->CMMN_CD_KOR_NM);
  345. }
  346. }
  347. }
  348. else
  349. if (sCode == "2")
  350. {
  351. if (FCodeCRTU)
  352. {
  353. FOR_STL(TItsSubCode *, pSubCode, FCodeCRTU->FSubLists)
  354. {
  355. if (pSubCode->USE_YN == "N") continue;
  356. CbINCD_TYPE_CD->Properties->Items->Add(" [" + pSubCode->CMMN_CD + "] " + pSubCode->CMMN_CD_KOR_NM);
  357. }
  358. }
  359. }
  360. else
  361. if (sCode == "3")
  362. {
  363. if (FCodeEVTU)
  364. {
  365. FOR_STL(TItsSubCode *, pSubCode, FCodeEVTU->FSubLists)
  366. {
  367. if (pSubCode->USE_YN == "N") continue;
  368. CbINCD_TYPE_CD->Properties->Items->Add(" [" + pSubCode->CMMN_CD + "] " + pSubCode->CMMN_CD_KOR_NM);
  369. }
  370. }
  371. }
  372. else
  373. if (sCode == "4")
  374. {
  375. if (FCodeWETU)
  376. {
  377. FOR_STL(TItsSubCode *, pSubCode, FCodeWETU->FSubLists)
  378. {
  379. if (pSubCode->USE_YN == "N") continue;
  380. CbINCD_TYPE_CD->Properties->Items->Add(" [" + pSubCode->CMMN_CD + "] " + pSubCode->CMMN_CD_KOR_NM);
  381. }
  382. }
  383. }
  384. CbINCD_TYPE_CD->ItemIndex = 0;
  385. }
  386. //---------------------------------------------------------------------------
  387. void __fastcall TFRAMEIncidentRegist::TvListCellDblClick(TcxCustomGridTableView *Sender, TcxGridTableDataCellViewInfo *ACellViewInfo,
  388. TMouseButton AButton, TShiftState AShift, bool &AHandled)
  389. {
  390. int nRow = m_pGDC->FocusedRecordIndex;
  391. if( nRow <= -1 )
  392. return;
  393. TItsSubCode *pSubCode;
  394. int nMemPtr = m_pGDC->Values[nRow][Column99->Index];
  395. TItsIncident *pObj = (TItsIncident *)nMemPtr;
  396. String sIST = "";
  397. if (pObj->INCD_ORGN_CD != "") sIST = " [" + pObj->INCD_ORGN_CD + "] ";
  398. String sLTCU= "";
  399. if (pObj->CMTR_GRAD_CD != "") sLTCU = " [" + pObj->CMTR_GRAD_CD + "] ";
  400. String sICM = "";
  401. if (pObj->INCD_CNFM_MTHD_CD != "") sICM = " [" + pObj->INCD_CNFM_MTHD_CD + "] ";
  402. String sSRLU= "";
  403. if (pObj->INCD_SERN_CD != "") sSRLU = " [" + pObj->INCD_SERN_CD + "] ";
  404. String sIDTU = "";
  405. if (pObj->INCD_TYPE_CLSF_CD != "") sIDTU = " [" + pObj->INCD_TYPE_CLSF_CD + "] ";
  406. String sACTU = "";
  407. if (pObj->INCD_TYPE_CD != "") sACTU = " [" + pObj->INCD_TYPE_CD + "] ";
  408. String sISS = "";
  409. if (pObj->INCD_PRGR_STEP_CD != "") sISS = " [" + pObj->INCD_PRGR_STEP_CD + "] ";
  410. String sDFW = "";
  411. if (pObj->WTHR_CD != "") sDFW = " [" + pObj->WTHR_CD + "] ";
  412. String sRSL = "";
  413. if (pObj->RESP_LVL_CD != "") sRSL = " [" + pObj->RESP_LVL_CD + "] ";
  414. String sPRTU = "";
  415. if (pObj->TRVL_LMNT_TYPE_CD != "") sPRTU = " [" + pObj->TRVL_LMNT_TYPE_CD + "] ";
  416. if (FCodeIST)
  417. {
  418. pSubCode = FCodeIST->FSubLists.Find(pObj->INCD_ORGN_CD);
  419. if (pSubCode) sIST = sIST + pSubCode->CMMN_CD_KOR_NM;
  420. }
  421. if (FCodeLTCU)
  422. {
  423. pSubCode = FCodeLTCU->FSubLists.Find(pObj->CMTR_GRAD_CD);
  424. if (pSubCode) sLTCU = sLTCU + pSubCode->CMMN_CD_KOR_NM;
  425. }
  426. if (FCodeICM)
  427. {
  428. pSubCode = FCodeICM->FSubLists.Find(pObj->INCD_CNFM_MTHD_CD);
  429. if (pSubCode) sICM = sICM + pSubCode->CMMN_CD_KOR_NM;
  430. }
  431. if (FCodeSRLU)
  432. {
  433. pSubCode = FCodeSRLU->FSubLists.Find(pObj->INCD_SERN_CD);
  434. if (pSubCode) sSRLU = sSRLU + pSubCode->CMMN_CD_KOR_NM;
  435. }
  436. if (FCodeIDTU)
  437. {
  438. pSubCode = FCodeIDTU->FSubLists.Find(pObj->INCD_TYPE_CLSF_CD);
  439. if (pSubCode) sIDTU = sIDTU + pSubCode->CMMN_CD_KOR_NM;
  440. }
  441. if (!pObj->INCD_TYPE_CLSF_CD.IsEmpty() && !pObj->INCD_TYPE_CD.IsEmpty())
  442. {
  443. if (pObj->INCD_TYPE_CLSF_CD == "1")
  444. {
  445. if (FCodeACTU)
  446. {
  447. pSubCode = FCodeACTU->FSubLists.Find(pObj->INCD_TYPE_CD);
  448. if (pSubCode) sACTU = sACTU + pSubCode->CMMN_CD_KOR_NM;
  449. }
  450. }
  451. else if (pObj->INCD_TYPE_CLSF_CD == "2")
  452. {
  453. if (FCodeCRTU)
  454. {
  455. pSubCode = FCodeCRTU->FSubLists.Find(pObj->INCD_TYPE_CD);
  456. if (pSubCode) sACTU = sACTU + pSubCode->CMMN_CD_KOR_NM;
  457. }
  458. }
  459. else if (pObj->INCD_TYPE_CLSF_CD == "3")
  460. {
  461. if (FCodeEVTU)
  462. {
  463. pSubCode = FCodeEVTU->FSubLists.Find(pObj->INCD_TYPE_CD);
  464. if (pSubCode) sACTU = sACTU + pSubCode->CMMN_CD_KOR_NM;
  465. }
  466. }
  467. else if (pObj->INCD_TYPE_CLSF_CD == "4")
  468. {
  469. if (FCodeWETU)
  470. {
  471. pSubCode = FCodeWETU->FSubLists.Find(pObj->INCD_TYPE_CD);
  472. if (pSubCode) sACTU = sACTU + pSubCode->CMMN_CD_KOR_NM;
  473. }
  474. }
  475. }
  476. if (FCodeISS)
  477. {
  478. pSubCode = FCodeISS->FSubLists.Find(pObj->INCD_PRGR_STEP_CD);
  479. if (pSubCode) sISS = sISS + pSubCode->CMMN_CD_KOR_NM;
  480. }
  481. if (FCodeDFW)
  482. {
  483. pSubCode = FCodeISS->FSubLists.Find(pObj->WTHR_CD);
  484. if (pSubCode) sDFW = sDFW + pSubCode->CMMN_CD_KOR_NM;
  485. }
  486. if (FCodeRSL)
  487. {
  488. pSubCode = FCodeRSL->FSubLists.Find(pObj->RESP_LVL_CD);
  489. if (pSubCode) sRSL = sRSL + pSubCode->CMMN_CD_KOR_NM;
  490. }
  491. if (FCodePRTU)
  492. {
  493. pSubCode = FCodePRTU->FSubLists.Find(pObj->TRVL_LMNT_TYPE_CD);
  494. if (pSubCode) sPRTU = sPRTU + pSubCode->CMMN_CD_KOR_NM;
  495. }
  496. EdINCD_OCRR_ID->Text = pObj->INCD_OCRR_ID;
  497. EdRGST_DT->Text = ITSUtil_StrToDateTime(pObj->RGST_DT);
  498. CbINCD_ORGN_CD->Text = sIST;
  499. EdOCRR_LCTN_NM->Text = pObj->OCRR_LCTN_NM;
  500. EdINCD_EXPL->Text = pObj->INCD_EXPL;
  501. CbCMTR_GRAD_CD->Text = sLTCU;
  502. EdIFMR_NM->Text = pObj->IFMR_NM;
  503. CbINCD_CNFM_MTHD_CD->Text = sICM;
  504. CbINCD_SERN_CD->Text = sSRLU;
  505. CbINCD_TYPE_CLSF_CD->Text = sIDTU;
  506. CbINCD_TYPE_CLSF_CDClick((TObject *)CbINCD_TYPE_CLSF_CD);
  507. CbINCD_TYPE_CD->Text = sACTU;
  508. DtINCD_CNFM_DT->Date = ITSUtil_StrToDateTime(pObj->INCD_CNFM_DT);
  509. DtINCD_STRT_DT->Date = ITSUtil_StrToDateTime(pObj->FINCD_STRT_DT);
  510. DtINCD_END_PRAR_DT->Date = ITSUtil_StrToDateTime(pObj->INCD_END_PRAR_DT);
  511. }
  512. //---------------------------------------------------------------------------
  513. void __fastcall TFRAMEIncidentRegist::BtnSaveClick(TObject *Sender)
  514. {
  515. //입력
  516. if (EdOCRR_LCTN_NM->Text.IsEmpty() || EdINCD_EXPL->Text.IsEmpty() || DtINCD_CNFM_DT->EditValue.IsEmpty())
  517. {
  518. Application->MessageBox(L"★항목은 필수 입력 항목입니다.\r\n모두 입력후 진행해 주세요.",
  519. FTitle.c_str(), MB_OK|MB_ICONERROR|MB_APPLMODAL);
  520. return;
  521. }
  522. if (Application->MessageBox(L"신규 돌발 정보를 저장 하시겠습니까?",
  523. FTitle.c_str(), MB_YESNO|MB_ICONQUESTION|MB_APPLMODAL) != IDYES) return;
  524. String sIncidentId = "";
  525. if (!ItsIncidentManager->GetNextIncidentId(CenterId, sIncidentId))
  526. {
  527. Application->MessageBox(L"신규 돌발 ID를 조회하지 못하였습니다.\r\n데이터베이스 관리자에게 확인 후에 작업하세요.",
  528. FTitle.c_str(), MB_OK|MB_ICONERROR|MB_APPLMODAL);
  529. return;
  530. }
  531. bool bResult = InsertToDb(sIncidentId,
  532. ITSUtil_GetCode(CbINCD_ORGN_CD->Text),
  533. EdOCRR_LCTN_NM->Text.Trim(),
  534. EdINCD_EXPL->Text.Trim(),
  535. ITSUtil_GetCode(CbCMTR_GRAD_CD->Text),
  536. EdIFMR_NM->Text.Trim(),
  537. ITSUtil_GetCode(CbINCD_CNFM_MTHD_CD->Text),
  538. ITSUtil_GetCode(CbINCD_SERN_CD->Text),
  539. ITSUtil_GetCode(CbINCD_TYPE_CLSF_CD->Text),
  540. ITSUtil_GetCode(CbINCD_TYPE_CD->Text),
  541. DtINCD_CNFM_DT->Date.FormatString("YYYYMMDDHHNNSS"),
  542. DtINCD_STRT_DT->Date.FormatString("YYYYMMDDHHNNSS"),
  543. DtINCD_END_PRAR_DT->Date.FormatString("YYYYMMDDHHNNSS"));
  544. if (bResult)
  545. {
  546. ItsIncidentManager->LoadFromDb();
  547. UpdateList();
  548. CMM_SetGridFocusRow(CxList, TvList, sIncidentId, Column01->Index);
  549. }
  550. }
  551. //---------------------------------------------------------------------------
  552. bool __fastcall TFRAMEIncidentRegist::InsertToDb(String AINCD_OCRR_ID, //돌발ID
  553. String AINCD_ORGN_CD, //돌발상황 원본 코드 : IST
  554. String AOCRR_LCTN_NM, //발생 위치 명
  555. String AINCD_EXPL, //돌발상황 설명
  556. String ACMTR_GRAD_CD, //소통 등급 코드 : LTCU
  557. String AIFMR_NM, //제보자 명
  558. String AINCD_CNFM_MTHD_CD, //돌발상황 확인 방법 코드 : ICM
  559. String AINCD_SERN_CD, //돌발상황 심각도 코드 : SRLU
  560. String AINCD_TYPE_CLSF_CD, //돌발상황 유형 분류 코드 : IDTU
  561. String AINCD_TYPE_CD, //돌발상황 유형 코드 : ACTU, CRTU, EVTU, WETU 중 하나
  562. String AINCD_CNFM_DT, //돌발상황 확인 일시
  563. String AINCD_STRT_DT, //돌발상황 시작 일시
  564. String AINCD_END_PRAR_DT) //돌발상황 종료 예정 일시
  565. {
  566. String sQry;
  567. TADOQuery *pADO = NULL;
  568. try
  569. {
  570. try
  571. {
  572. pADO = new TADOQuery(NULL);
  573. pADO->Close();
  574. pADO->Connection = ITSDb_GetConnection();
  575. ITSDb_GetConnection()->BeginTrans();
  576. sQry = "INSERT INTO TB_INCD_OCRR(INCD_OCRR_ID, RGST_DT, INCD_ORGN_CD, OCRR_LCTN_NM, \r\n"
  577. " INCD_EXPL, CMTR_GRAD_CD, IFMR_NM, INCD_CNFM_MTHD_CD, \r\n"
  578. " INCD_CNFM_DT, INCD_STRT_DT, INCD_END_PRAR_DT, INCD_TYPE_CLSF_CD, \r\n"
  579. " INCD_TYPE_CD, INCD_SERN_CD, INCD_PRGR_STEP_CD ) \r\n"
  580. " VALUES(:p01, :p02, :p03, :p04, \r\n"
  581. " :p05, :p06, :p07, :p08, \r\n"
  582. " :p09, :p10, :p11, :p12, \r\n"
  583. " :p13, :p14, 'ISS1' ) \r\n";
  584. ITSDb_SQLText(pADO, sQry);
  585. ITSDb_SQLBind(pADO, "p01", AINCD_OCRR_ID);
  586. ITSDb_SQLBind(pADO, "p02", Now().FormatString("YYYYMMDDHHNNSS"));
  587. ITSDb_SQLBind(pADO, "p03", AINCD_ORGN_CD);
  588. ITSDb_SQLBind(pADO, "p04", AOCRR_LCTN_NM);
  589. ITSDb_SQLBind(pADO, "p05", AINCD_EXPL);
  590. ITSDb_SQLBind(pADO, "p06", ACMTR_GRAD_CD);
  591. ITSDb_SQLBind(pADO, "p07", AIFMR_NM);
  592. ITSDb_SQLBind(pADO, "p08", AINCD_CNFM_MTHD_CD);
  593. ITSDb_SQLBind(pADO, "p09", AINCD_CNFM_DT);
  594. ITSDb_SQLBind(pADO, "p10", AINCD_STRT_DT);
  595. ITSDb_SQLBind(pADO, "p11", AINCD_END_PRAR_DT);
  596. ITSDb_SQLBind(pADO, "p12", AINCD_TYPE_CLSF_CD);
  597. ITSDb_SQLBind(pADO, "p13", AINCD_TYPE_CD);
  598. ITSDb_SQLBind(pADO, "p14", AINCD_SERN_CD);
  599. ITSDb_SQLExec(pADO);
  600. ITSDb_GetConnection()->CommitTrans();
  601. Application->MessageBox(L"신규 돌발 정보를 저장 하였습니다.", FTitle.c_str(), MB_OK|MB_ICONINFORMATION|MB_APPLMODAL);
  602. }
  603. catch(EDatabaseError &E)
  604. {
  605. ITSDb_GetConnection()->RollbackTrans();
  606. ShowMessage(String(E.ClassName()) + E.Message);
  607. }
  608. catch(Exception &exception)
  609. {
  610. ITSDb_GetConnection()->RollbackTrans();
  611. ShowMessage(String(exception.ClassName()) + exception.Message);
  612. }
  613. catch(...)
  614. {
  615. ITSDb_GetConnection()->RollbackTrans();
  616. ShowMessage("데이터 작업 중에 알수없는 DB 오류가 발생하였습니다.");
  617. }
  618. }
  619. __finally
  620. {
  621. if (pADO)
  622. {
  623. pADO->Close();
  624. delete pADO;
  625. }
  626. }
  627. return true;
  628. }
  629. //---------------------------------------------------------------------------