CDSCodeF.cpp 9.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263
  1. //---------------------------------------------------------------------------
  2. #pragma hdrstop
  3. #include "CDSCodeF.h"
  4. #include "VmsCommonLibF.h"
  5. //---------------------------------------------------------------------------
  6. #pragma package(smart_init)
  7. TSysCode::TSysCode()
  8. {
  9. }
  10. //---------------------------------------------------------------------------
  11. TSysCode::TSysCode(String ACLSS_CD, String ACODE_NO, String ACD_NM)
  12. {
  13. TSysCode(ACLSS_CD, ACODE_NO, ACD_NM, "");
  14. CLSS_CD = ACLSS_CD;
  15. CODE_NO = ACODE_NO;
  16. CD_NM = ACD_NM;
  17. CD_VAL_1 = "";
  18. USE_YN = "Y";
  19. }
  20. //---------------------------------------------------------------------------
  21. TSysCode::TSysCode(String ACLSS_CD, String ACODE_NO, String ACD_NM, String ACD_VAL_1)
  22. {
  23. CLSS_CD = ACLSS_CD;
  24. CODE_NO = ACODE_NO;
  25. CD_NM = ACD_NM;
  26. CD_VAL_1 = ACD_VAL_1;
  27. USE_YN = "Y";
  28. }
  29. //---------------------------------------------------------------------------
  30. void TSysCode::Clear()
  31. {
  32. }
  33. //---------------------------------------------------------------------------
  34. TSysCode::~TSysCode()
  35. {
  36. }
  37. //---------------------------------------------------------------------------
  38. //---------------------------------------------------------------------------
  39. TSysClssCode::TSysClssCode()
  40. {
  41. }
  42. //---------------------------------------------------------------------------
  43. TSysClssCode::TSysClssCode(String ACLSS_CD, String ACLSS_CD_NM)
  44. {
  45. CLSS_CD = ACLSS_CD;
  46. CLSS_CD_NM = ACLSS_CD_NM;
  47. }
  48. //---------------------------------------------------------------------------
  49. void TSysClssCode::Clear()
  50. {
  51. }
  52. //---------------------------------------------------------------------------
  53. TSysClssCode::~TSysClssCode()
  54. {
  55. FLists.RemoveAll();
  56. }
  57. //---------------------------------------------------------------------------
  58. //---------------------------------------------------------------------------
  59. TSysCodeManager *SysCodeManager = NULL;
  60. //---------------------------------------------------------------------------
  61. /*
  62. * Link Manager
  63. */
  64. TSysCodeManager::TSysCodeManager()
  65. {
  66. }
  67. //---------------------------------------------------------------------------
  68. TSysCodeManager::~TSysCodeManager()
  69. {
  70. }
  71. //---------------------------------------------------------------------------
  72. bool TSysCodeManager::LoadFromDb(TADOConnection *ADbConn/*=NULL*/)
  73. {
  74. FLists.RemoveAll();
  75. return (LoadSysClssCode(ADbConn) && LoadSysCode(ADbConn));
  76. }
  77. //---------------------------------------------------------------------------
  78. bool TSysCodeManager::LoadSysClssCode(TADOConnection *ADbConn/*=NULL*/)
  79. {
  80. String sQry;
  81. TADOQuery *pADO = NULL;
  82. sQry = "SELECT * \r\n"
  83. " FROM TB_SYS_CLSS_CD \r\n";
  84. FLists.Lock();
  85. try
  86. {
  87. FLists.RemoveAll();
  88. try
  89. {
  90. pADO = new TADOQuery(NULL);
  91. pADO->Close();
  92. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  93. pADO->SQL->Clear();
  94. pADO->SQL->Text = sQry;
  95. pADO->Prepared = true;
  96. pADO->Open();
  97. for( ; !pADO->Eof; pADO->Next())
  98. {
  99. TSysClssCode *pCode = new TSysClssCode();
  100. pCode->CLSS_CD = pADO->FieldByName("CLSS_CD")->AsString;
  101. pCode->CLSS_CD_NM = pADO->FieldByName("CLSS_CD_NM")->AsString;
  102. FLists.Push(pCode->CLSS_CD, pCode);
  103. }
  104. }
  105. catch(EDatabaseError &E)
  106. {
  107. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  108. DBERRORMSG("TSysCodeManager::LoadSysClssCode", String(E.ClassName()), E.Message, sQry);
  109. throw Exception(String(E.ClassName()) + E.Message);
  110. }
  111. catch(Exception &exception)
  112. {
  113. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  114. DBERRORMSG("TSysCodeManager::LoadSysClssCode", String(exception.ClassName()), exception.Message, sQry);
  115. throw Exception(String(exception.ClassName()) + exception.Message);
  116. }
  117. }
  118. __finally
  119. {
  120. if (pADO)
  121. {
  122. pADO->Close();
  123. delete pADO;
  124. }
  125. FLists.UnLock();
  126. }
  127. return true;
  128. }
  129. //---------------------------------------------------------------------------
  130. bool TSysCodeManager::LoadSysCode(TADOConnection *ADbConn/*=NULL*/)
  131. {
  132. String sQry;
  133. TADOQuery *pADO = NULL;
  134. sQry = "SELECT * \r\n"
  135. " FROM TB_SYS_CD \r\n"
  136. " WHERE USE_YN = 'Y' \r\n";
  137. FLists.Lock();
  138. try
  139. {
  140. TSysClssCode *pClssCd = NULL;
  141. try
  142. {
  143. pADO = new TADOQuery(NULL);
  144. pADO->Close();
  145. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  146. pADO->SQL->Clear();
  147. pADO->SQL->Text = sQry;
  148. pADO->Prepared = true;
  149. pADO->Open();
  150. for( ; !pADO->Eof; pADO->Next())
  151. {
  152. String CLSS_CD = pADO->FieldByName("CLSS_CD")->AsString;
  153. pClssCd = SysCodeManager->FLists.Find(CLSS_CD);
  154. if (!pClssCd) continue;
  155. TSysCode *pSysCode = new TSysCode();
  156. pSysCode->CLSS_CD = pADO->FieldByName("CLSS_CD")->AsString; // N VARCHAR2(32) N 분류코드
  157. pSysCode->CODE_NO = pADO->FieldByName("CODE_NO")->AsString; // N VARCHAR2(5) N 코드
  158. pSysCode->CD_NM = pADO->FieldByName("CD_NM")->AsString; // N VARCHAR2(50) N 코드명
  159. pSysCode->CD_VAL_1 = pADO->FieldByName("CD_VAL_1")->AsString; // N VARCHAR2(32) Y 코드값1
  160. pSysCode->CD_VAL_2 = pADO->FieldByName("CD_VAL_2")->AsString; // N VARCHAR2(32) Y 코드값2
  161. pSysCode->CD_VAL_3 = pADO->FieldByName("CD_VAL_3")->AsString; // N VARCHAR2(32) Y 코드값3
  162. pSysCode->CD_VAL_4 = pADO->FieldByName("CD_VAL_4")->AsString; // N VARCHAR2(32) Y 코드값4
  163. pSysCode->CD_VAL_5 = pADO->FieldByName("CD_VAL_5")->AsString; // N VARCHAR2(32) Y 코드값5
  164. pSysCode->CD_VAL_6 = pADO->FieldByName("CD_VAL_6")->AsString; // N VARCHAR2(32) Y 코드값6
  165. pSysCode->CD_VAL_7 = pADO->FieldByName("CD_VAL_7")->AsString; // N VARCHAR2(32) Y 코드값7
  166. pSysCode->CD_VAL_8 = pADO->FieldByName("CD_VAL_8")->AsString; // N VARCHAR2(32) Y 코드값8
  167. pSysCode->CD_VAL_9 = pADO->FieldByName("CD_VAL_9")->AsString; // N VARCHAR2(32) Y 코드값9
  168. pSysCode->USE_YN = pADO->FieldByName("USE_YN")->AsString; // N CHAR(1) N 사용여부
  169. pClssCd->FLists.Push(pSysCode->CODE_NO, pSysCode);
  170. }
  171. }
  172. catch(EDatabaseError &E)
  173. {
  174. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  175. DBERRORMSG("TSysCodeManager::LoadSysCode", String(E.ClassName()), E.Message, sQry);
  176. throw Exception(String(E.ClassName()) + E.Message);
  177. }
  178. catch(Exception &exception)
  179. {
  180. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  181. DBERRORMSG("TSysCodeManager::LoadSysCode", String(exception.ClassName()), exception.Message, sQry);
  182. throw Exception(String(exception.ClassName()) + exception.Message);
  183. }
  184. }
  185. __finally
  186. {
  187. if (pADO)
  188. {
  189. pADO->Close();
  190. delete pADO;
  191. }
  192. FLists.UnLock();
  193. }
  194. return true;
  195. }
  196. //---------------------------------------------------------------------------
  197. bool TSysCodeManager::LoadFromDbOffline(TSysCodeManager *ASysCodeManager)
  198. {
  199. TSysClssCode *pCode;
  200. TSysCode *pSysCode;
  201. //폼유형 "VMS_FORM_TYPE_CD");
  202. //표출방법"VMS_FORM_DSPL_EFF_CD");
  203. pCode = new TSysClssCode("VMS_FORM_DSPL_EFF_CD", "표출방법");
  204. pCode->FLists.Push("00", new TSysCode("FONT_KIND_CD", "00", "Shift-Up"));
  205. pCode->FLists.Push("01", new TSysCode("FONT_KIND_CD", "01", "Shift-Down"));
  206. pCode->FLists.Push("02", new TSysCode("FONT_KIND_CD", "02", "Shift-Left"));
  207. pCode->FLists.Push("03", new TSysCode("FONT_KIND_CD", "03", "Shift-Right"));
  208. pCode->FLists.Push("10", new TSysCode("FONT_KIND_CD", "10", "Scroll-Up"));
  209. pCode->FLists.Push("11", new TSysCode("FONT_KIND_CD", "11", "Scroll-Down"));
  210. pCode->FLists.Push("12", new TSysCode("FONT_KIND_CD", "12", "Scroll-Left"));
  211. pCode->FLists.Push("13", new TSysCode("FONT_KIND_CD", "13", "Scroll-Right"));
  212. pCode->FLists.Push("20", new TSysCode("FONT_KIND_CD", "20", "Wipe-Up"));
  213. pCode->FLists.Push("21", new TSysCode("FONT_KIND_CD", "21", "Wipe-Down"));
  214. pCode->FLists.Push("22", new TSysCode("FONT_KIND_CD", "22", "Wipe-Left"));
  215. pCode->FLists.Push("23", new TSysCode("FONT_KIND_CD", "23", "Wipe-Right"));
  216. pCode->FLists.Push("30", new TSysCode("FONT_KIND_CD", "30", "Curtain-Up"));
  217. pCode->FLists.Push("31", new TSysCode("FONT_KIND_CD", "31", "Curtain-Down"));
  218. pCode->FLists.Push("32", new TSysCode("FONT_KIND_CD", "32", "Curtain-Left"));
  219. pCode->FLists.Push("33", new TSysCode("FONT_KIND_CD", "33", "Curtain-Right"));
  220. pCode->FLists.Push("40", new TSysCode("FONT_KIND_CD", "40", "Trace-Up"));
  221. pCode->FLists.Push("41", new TSysCode("FONT_KIND_CD", "41", "Trace-Down"));
  222. pCode->FLists.Push("42", new TSysCode("FONT_KIND_CD", "42", "Trace-Left"));
  223. pCode->FLists.Push("43", new TSysCode("FONT_KIND_CD", "43", "Trace-Right"));
  224. pCode->FLists.Push("50", new TSysCode("FONT_KIND_CD", "50", "Blind-Up"));
  225. pCode->FLists.Push("51", new TSysCode("FONT_KIND_CD", "51", "Blind-Down"));
  226. pCode->FLists.Push("52", new TSysCode("FONT_KIND_CD", "52", "Blind-Left"));
  227. pCode->FLists.Push("53", new TSysCode("FONT_KIND_CD", "53", "Blind-Right"));
  228. pCode->FLists.Push("60", new TSysCode("FONT_KIND_CD", "60", "Flashing"));
  229. pCode->FLists.Push("70", new TSysCode("FONT_KIND_CD", "70", "Stationary"));
  230. ASysCodeManager->FLists.Push(pCode->CLSS_CD, pCode);
  231. //폼객체종류 "VMS_FORM_OBJ_KIND_CD");
  232. return true;
  233. }
  234. //---------------------------------------------------------------------------